/*
 * uprise.css — Shared design system for plugins.uprisemedia.co
 * Inherits tokens, patterns, and components from uprisemedia.co/index.html
 * Loaded by: index.html, account.html, terms.html, privacy.html, refunds.html
 */

/* ---- Google Fonts (imported here so pages only need this one CSS) ---- */
@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&family=Dancing+Script:wght@600;700&display=swap");

/* ---- Design tokens ---- */
:root {
  --bg: #0A0A0A;
  --surface: #161616;
  --surface-2: #1c1c1c;
  --hairline: rgba(255,255,255,0.08);
  --hairline-strong: rgba(255,255,255,0.14);
  --text: #F5F5F7;
  --text-dim: #A1A1A6;
  --accent: #FF4F18;
  --accent-soft: rgba(255,79,24,0.14);
  --accent-glow: rgba(255,79,24,0.28);
  --ease: cubic-bezier(0.16,1,0.3,1);
  --maxw: 1100px;
  --sans: "Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --script: "Dancing Script",cursive;
}

/* ---- Reset ---- */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--sans);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
::selection{background:var(--accent);color:#fff}
a{color:inherit;text-decoration:none}

/* ---- Grain overlay (subtle noise) ---- */
body::after{
  content:"";
  position:fixed;inset:0;
  pointer-events:none;
  z-index:9999;
  opacity:0.025;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---- Layout ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ---- Wordmark ---- */
.wordmark{
  position:relative;
  display:inline-block;
  font-weight:800;
  letter-spacing:-0.03em;
  line-height:1;
  color:var(--text);
  white-space:nowrap;
}
.wordmark .media{
  position:absolute;
  top:-0.52em;right:-0.06em;
  font-family:var(--script);
  font-weight:700;
  letter-spacing:0;
  color:var(--accent);
  line-height:1;
}

/* ---- Sticky header / nav ---- */
header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background:rgba(10,10,10,0.55);
  backdrop-filter:saturate(180%) blur(20px);
  -webkit-backdrop-filter:saturate(180%) blur(20px);
  border-bottom:1px solid transparent;
  transition:border-color .4s var(--ease),background .4s var(--ease);
}
header.scrolled{border-bottom-color:var(--hairline);background:rgba(10,10,10,0.78)}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  height:64px;max-width:var(--maxw);margin:0 auto;padding:0 24px;
}
.nav .brand{font-size:22px}
.nav .brand .media{font-size:15px}
.nav-links{display:flex;align-items:center;gap:34px}
.nav-links a{
  font-size:14px;font-weight:500;color:var(--text-dim);
  transition:color .25s var(--ease);position:relative;
}
.nav-links a:hover{color:var(--text)}
.nav-links a:focus-visible{outline:2px solid var(--accent);outline-offset:4px;border-radius:3px}

/* ---- Pill CTA ---- */
.pill{
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--accent);color:#fff;font-weight:600;font-size:14px;
  padding:9px 18px;border-radius:980px;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),filter .25s var(--ease);
  box-shadow:0 4px 18px var(--accent-glow);
}
.pill:hover{filter:brightness(1.07);transform:translateY(-1px);box-shadow:0 8px 26px rgba(255,79,24,0.4)}
.pill:focus-visible{outline:2px solid #fff;outline-offset:3px}

/* ---- Mobile hamburger ---- */
.menu-btn{
  display:none;background:none;border:0;cursor:pointer;
  width:40px;height:40px;border-radius:10px;position:relative;
}
.menu-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.menu-btn span{
  position:absolute;left:9px;right:9px;height:1.5px;background:var(--text);
  transition:transform .3s var(--ease),opacity .3s var(--ease);
}
.menu-btn span:nth-child(1){top:14px}
.menu-btn span:nth-child(2){top:20px}
.menu-btn span:nth-child(3){top:26px}
body.menu-open .menu-btn span:nth-child(1){transform:translateY(6px) rotate(45deg)}
body.menu-open .menu-btn span:nth-child(2){opacity:0}
body.menu-open .menu-btn span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

.mobile-menu{
  position:fixed;inset:64px 0 auto 0;z-index:999;
  background:rgba(10,10,10,0.96);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--hairline);
  display:flex;flex-direction:column;padding:18px 24px 28px;gap:6px;
  transform:translateY(-12px);opacity:0;pointer-events:none;
  transition:transform .35s var(--ease),opacity .35s var(--ease);
}
body.menu-open .mobile-menu{transform:translateY(0);opacity:1;pointer-events:auto}
.mobile-menu a{padding:13px 4px;font-size:17px;font-weight:500;border-bottom:1px solid var(--hairline)}
.mobile-menu a:last-of-type{border-bottom:0}
.mobile-menu .pill{margin-top:14px;align-self:flex-start;padding:12px 22px;font-size:15px}

/* ---- Buttons ---- */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-weight:600;font-size:16px;padding:14px 28px;border-radius:980px;
  transition:transform .25s var(--ease),filter .25s var(--ease),box-shadow .25s var(--ease),background .25s var(--ease),border-color .25s var(--ease);
  cursor:pointer;border:1px solid transparent;
}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 6px 24px rgba(255,79,24,0.32)}
.btn-primary:hover{filter:brightness(1.07);transform:translateY(-2px);box-shadow:0 12px 34px rgba(255,79,24,0.44)}
.btn-ghost{background:transparent;color:var(--text);border-color:var(--hairline-strong)}
.btn-ghost:hover{border-color:var(--text-dim);background:rgba(255,255,255,0.04);transform:translateY(-2px)}
.btn:focus-visible{outline:2px solid #fff;outline-offset:3px}

/* ---- Card with pointer-tracked glow ---- */
.card{
  background:var(--surface);border:1px solid var(--hairline);
  border-radius:20px;padding:32px 28px 34px;position:relative;overflow:hidden;
  transition:transform .4s var(--ease),border-color .4s var(--ease),box-shadow .4s var(--ease),background .4s var(--ease);
}
.card::before{
  content:"";position:absolute;inset:0;border-radius:20px;pointer-events:none;
  background:radial-gradient(420px circle at var(--mx,50%) var(--my,0%), var(--accent-soft), transparent 60%);
  opacity:0;transition:opacity .4s var(--ease);
}
.card:hover{transform:translateY(-6px);border-color:rgba(255,79,24,0.4);background:var(--surface-2);box-shadow:0 20px 50px rgba(0,0,0,0.5)}
.card:hover::before{opacity:1}
.card .icon{
  width:50px;height:50px;border-radius:13px;
  display:flex;align-items:center;justify-content:center;
  background:var(--accent-soft);margin-bottom:22px;position:relative;z-index:1;
}
.card .icon svg{width:24px;height:24px;stroke:var(--accent);fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.card h3{font-size:20px;font-weight:700;letter-spacing:-0.02em;margin-bottom:9px;position:relative;z-index:1}
.card p{font-size:15px;color:var(--text-dim);position:relative;z-index:1;line-height:1.7}

/* ---- Section shell ---- */
section{padding-block:120px;position:relative}
.section-head{max-width:680px;margin-bottom:64px}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.tag{font-size:13px;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;color:var(--accent);margin-bottom:18px;display:block}
.section-head h2{font-size:clamp(34px,5.2vw,56px);font-weight:800;letter-spacing:-0.035em;line-height:1.04;margin-bottom:20px}
.section-head p{font-size:clamp(16px,2vw,19px);color:var(--text-dim);max-width:560px}
.section-head.center p{margin-inline:auto}
.eyebrow{display:inline-block;font-size:13px;font-weight:600;letter-spacing:0.28em;color:var(--accent);text-transform:uppercase;margin-bottom:26px}

/* ---- Reveal animation ---- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}
.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}
.reveal.d4{transition-delay:.32s}
.reveal.d5{transition-delay:.4s}

/* ---- Hero ---- */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:140px 24px 120px;overflow:hidden;
}
.hero-glow{
  position:absolute;top:38%;left:50%;
  width:min(900px,120vw);height:min(900px,120vw);
  transform:translate(-50%,-50%);
  background:radial-gradient(circle, rgba(255,79,24,0.22) 0%, rgba(255,79,24,0.08) 32%, transparent 62%);
  pointer-events:none;z-index:0;filter:blur(8px);
}
.hero .inner{position:relative;z-index:1;max-width:880px}
.hero h1{font-size:clamp(48px,9vw,96px);font-weight:800;letter-spacing:-0.04em;line-height:0.98;margin-bottom:26px}
.hero p.sub{font-size:clamp(17px,2.4vw,21px);color:var(--text-dim);max-width:560px;margin:0 auto 40px;font-weight:400}
.hero-ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ---- Rich Footer ---- */
footer{border-top:1px solid var(--hairline);padding-block:56px}
.foot{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap}
.foot .brand{font-size:26px;margin-bottom:14px;display:inline-block}
.foot .brand .media{font-size:17px}
.foot .tagline{color:var(--text-dim);font-size:14px;max-width:240px;margin-top:10px}
.foot-links{display:flex;gap:64px;flex-wrap:wrap}
.foot-col h4{font-size:13px;letter-spacing:0.14em;text-transform:uppercase;color:var(--text-dim);margin-bottom:16px;font-weight:600}
.foot-col a{display:block;font-size:15px;color:var(--text);margin-bottom:11px;transition:color .25s var(--ease)}
.foot-col a:hover{color:var(--accent)}
.socials{display:flex;gap:12px;margin-top:18px}
.socials a{
  width:40px;height:40px;border-radius:11px;border:1px solid var(--hairline);
  display:flex;align-items:center;justify-content:center;color:var(--text-dim);
  transition:color .25s var(--ease),border-color .25s var(--ease),transform .25s var(--ease);
}
.socials a:hover{color:var(--accent);border-color:rgba(255,79,24,0.4);transform:translateY(-2px)}
.socials svg{width:18px;height:18px;fill:currentColor}
.foot a:focus-visible,.foot-col a:focus-visible,.socials a:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}
.copyright{
  margin-top:48px;padding-top:26px;border-top:1px solid var(--hairline);
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  color:var(--text-dim);font-size:13.5px;
}

/* ---- Responsive ---- */
@media(max-width:680px){
  .nav-links{display:none}
  .nav .pill{display:none}
  .menu-btn{display:block}
  section{padding-block:84px}
  .foot-links{gap:36px}
}

@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}
