/* =====================================================================
   Symphony by New Medley — shared marketing stylesheet
   Native CSS only (Grid, Flexbox, clamp, custom properties, @media).
   No framework. Matches Continuo's --nm-*/vanilla-CSS approach.

   Per-page accent is set by a class on <body>:
     .theme-main      cosmic cyan→gold (home)
     .theme-business  cool teal / structured / credible
     .theme-builder   electric cyan / frontier
     .theme-dreamer   warm gold / aspirational
   Each theme overrides --accent / --accent-2 / --accent-soft.
   ===================================================================== */

:root{
  /* Deep ocean-night base (shared across all pages) */
  --bg:#07171c;
  --bg-2:#0a1f26;
  --bg-3:#0e2730;
  --ink:#eaf4f3;
  --ink-soft:#a9c2c1;
  --ink-faint:#6f8c8b;
  --line:rgba(180,220,218,.12);
  --line-soft:rgba(180,220,218,.07);
  --panel:linear-gradient(160deg,rgba(14,39,48,.7),rgba(10,31,38,.5));
  --panel-solid:rgba(14,39,48,.92);

  /* Accent palette — default (main theme): cyan + gold */
  --accent:#36d6c4;
  --accent-bright:#5cf2e2;
  --accent-deep:#1aa89a;
  --accent-2:#f0b53f;
  --accent-2-bright:#ffcf6b;
  --accent-soft:rgba(54,214,196,.14);

  --radius:16px;
  --radius-sm:10px;
  --maxw:1200px;

  --font-display:"Sora",system-ui,sans-serif;
  --font-body:"Spectral",Georgia,serif;
  --font-mono:"IBM Plex Mono",monospace;
}

/* ---------- PER-PAGE THEMES ---------- */
body.theme-business{
  --accent:#0fb6a6;--accent-bright:#3ad8c8;--accent-deep:#0a8c80;
  --accent-2:#7fb2d4;--accent-2-bright:#a6cce6;--accent-soft:rgba(15,182,166,.12);
}
body.theme-builder{
  --accent:#36d6c4;--accent-bright:#5cf2e2;--accent-deep:#1aa89a;
  --accent-2:#5ad1ff;--accent-2-bright:#8fe2ff;--accent-soft:rgba(54,214,196,.16);
}
body.theme-dreamer{
  --accent:#f0b53f;--accent-bright:#ffcf6b;--accent-deep:#cc922a;
  --accent-2:#ff9d5c;--accent-2-bright:#ffb784;--accent-soft:rgba(240,181,63,.16);
}

/* ---------- RESET ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--ink);
  line-height:1.62;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  position:relative;
}
h1,h2,h3,h4,h5{font-family:var(--font-display);font-weight:600;line-height:1.1;letter-spacing:-.02em}
.serif{font-family:var(--font-body)}
.mono{font-family:var(--font-mono)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ---------- ATMOSPHERE ---------- */
.atmos{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.atmos .glow{position:absolute;border-radius:50%;filter:blur(80px);opacity:.5}
.atmos .g1{top:-200px;left:-100px;width:640px;height:640px;
  background:radial-gradient(circle,var(--accent-soft),transparent 65%);animation:drift1 22s ease-in-out infinite}
.atmos .g2{top:200px;right:-180px;width:560px;height:560px;
  background:radial-gradient(circle,rgba(240,181,63,.16),transparent 65%);animation:drift2 27s ease-in-out infinite}
.atmos .g3{bottom:-220px;left:30%;width:720px;height:720px;
  background:radial-gradient(circle,var(--accent-soft),transparent 65%);animation:drift1 30s ease-in-out infinite reverse}
@keyframes drift1{0%,100%{transform:translate(0,0)}50%{transform:translate(60px,40px)}}
@keyframes drift2{0%,100%{transform:translate(0,0)}50%{transform:translate(-50px,30px)}}
body::after{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.4;
  background-image:radial-gradient(1px 1px at 20% 30%,rgba(234,244,243,.5),transparent),radial-gradient(1px 1px at 70% 60%,rgba(234,244,243,.4),transparent),radial-gradient(1px 1px at 45% 80%,rgba(234,244,243,.35),transparent),radial-gradient(1px 1px at 85% 20%,rgba(234,244,243,.4),transparent),radial-gradient(1px 1px at 12% 70%,rgba(234,244,243,.3),transparent);}

/* ---------- LAYOUT ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 30px;position:relative;z-index:2}
.sec-pad{padding:90px 0;position:relative;z-index:2}
section{position:relative;z-index:2}

/* ---------- NAV ---------- */
header.nav{position:sticky;top:0;z-index:50;backdrop-filter:blur(14px);background:rgba(7,23,28,.7);border-bottom:1px solid var(--line-soft)}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:16px 30px;display:flex;align-items:center;gap:34px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--font-display);font-weight:600;font-size:1.2rem}
.brand .mark{width:30px;height:30px;flex:none}
.brand small{display:block;font-family:var(--font-mono);font-weight:400;font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-faint);margin-top:2px}
.nav-links{display:flex;gap:30px;margin-left:auto;align-items:center}
.nav-links a:not(.btn){font-family:var(--font-mono);font-size:.78rem;letter-spacing:.03em;color:var(--ink-soft);transition:color .2s}
.nav-links a:not(.btn):hover{color:var(--accent-bright)}
.nav-links a.active{color:var(--accent-bright)}
@media(max-width:880px){.nav-links a:not(.btn){display:none}}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-display);font-weight:500;font-size:.84rem;padding:11px 20px;border-radius:var(--radius-sm);border:1px solid transparent;cursor:pointer;transition:all .22s;white-space:nowrap}
.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-deep));color:#04181a;font-weight:600;box-shadow:0 0 0 1px var(--accent-soft),0 8px 30px var(--accent-soft)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 0 1px var(--accent),0 14px 40px var(--accent-soft)}
.btn-ghost{border-color:var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent-bright)}
.btn-gold{background:linear-gradient(135deg,var(--accent-2-bright),var(--accent-2));color:#1f1403;font-weight:600;box-shadow:0 8px 30px rgba(240,181,63,.22)}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 14px 40px rgba(240,181,63,.34)}
.btn-lg{padding:15px 30px;font-size:.92rem}

/* ---------- TYPOGRAPHY HELPERS ---------- */
.kicker{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:18px;display:flex;align-items:center;gap:12px}
.kicker.center{justify-content:center}
.kicker.center::before,.kicker.center::after{content:"";width:24px;height:1px;background:var(--accent);opacity:.5}
.kicker:not(.center)::before{content:"";width:24px;height:1px;background:var(--accent);opacity:.5}
.grad{background:linear-gradient(120deg,var(--accent-bright),var(--accent-2-bright));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:32px;padding:8px 16px;border:1px solid var(--line);border-radius:40px;background:var(--accent-soft)}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent)}

.sec-head{text-align:center;max-width:38em;margin:0 auto 54px}
.sec-head.left{text-align:left;margin-left:0}
.sec-head h2{font-size:clamp(2rem,4vw,3rem)}
.sec-head p{font-size:1.18rem;color:var(--ink-soft);margin-top:18px;font-family:var(--font-body)}

/* ---------- HERO ---------- */
.hero{padding:118px 0 96px;text-align:center;position:relative}
.hero.left{text-align:left}
.hero h1{font-size:clamp(2.7rem,6.2vw,5.2rem);font-weight:700;max-width:15em;margin:0 auto;letter-spacing:-.03em}
.hero.left h1{margin:0}
.hero .lede{font-family:var(--font-body);font-size:clamp(1.18rem,2.1vw,1.48rem);color:var(--ink-soft);margin:32px auto 0;max-width:34em;font-weight:400}
.hero.left .lede{margin-left:0}
.hero-cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:44px}
.hero.left .hero-cta{justify-content:flex-start}
.hero-note{font-family:var(--font-mono);font-size:.74rem;color:var(--ink-faint);margin-top:24px}

/* ---------- ENTRANCE ANIMATION ---------- */
.reveal{opacity:0;transform:translateY(20px);animation:rise 1s cubic-bezier(.2,.7,.2,1) forwards}
@keyframes rise{to{opacity:1;transform:none}}
.d1{animation-delay:.05s}.d2{animation-delay:.18s}.d3{animation-delay:.32s}.d4{animation-delay:.46s}.d5{animation-delay:.6s}

/* ---------- CARDS / GRIDS ---------- */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:28px;transition:transform .26s,border-color .26s,box-shadow .26s}
.card:hover{transform:translateY(-4px);border-color:var(--accent)}
.card svg.ic{width:34px;height:34px;margin-bottom:16px}
.card h4{font-size:1.08rem;margin-bottom:9px;font-weight:600}
.card p{font-size:.94rem;color:var(--ink-soft);font-family:var(--font-body)}

/* ---------- BANDS ---------- */
.band{background:linear-gradient(180deg,rgba(10,31,38,.5),rgba(7,23,28,0));border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}

/* ---------- FEATURE LIST (numbered steps) ---------- */
.steps{display:flex;flex-direction:column}
.step{display:grid;grid-template-columns:auto 1fr;gap:18px;padding:18px 0;border-bottom:1px solid var(--line-soft)}
.step:last-child{border-bottom:none}
.step .n{font-family:var(--font-body);font-style:italic;font-size:1.5rem;color:var(--accent);line-height:1}
.step h4{font-size:1.08rem;margin-bottom:5px}
.step p{font-size:.96rem;color:var(--ink-soft);font-family:var(--font-body)}

/* ---------- CTA ---------- */
.cta{text-align:center;padding:106px 0}
.cta h2{font-size:clamp(2.2rem,4.6vw,3.6rem);max-width:15em;margin:0 auto}
.cta p{font-family:var(--font-body);font-size:1.2rem;color:var(--ink-soft);margin:24px auto 38px;max-width:32em}
.cta-row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ---------- PRICING ---------- */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:stretch}
.tier{background:var(--panel);border:1px solid var(--line);border-radius:20px;padding:34px 30px;display:flex;flex-direction:column;position:relative;transition:transform .28s,border-color .28s}
.tier:hover{transform:translateY(-5px);border-color:var(--accent)}
.tier.featured{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-soft),0 24px 60px var(--accent-soft)}
.tier .badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);font-family:var(--font-mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;background:linear-gradient(135deg,var(--accent),var(--accent-deep));color:#04181a;padding:5px 14px;border-radius:30px;font-weight:600}
.tier h3{font-size:1.4rem;margin-bottom:6px}
.tier .tagline{font-family:var(--font-body);font-size:.96rem;color:var(--ink-soft);margin-bottom:22px;min-height:2.8em}
.tier .price{font-family:var(--font-display);font-size:2.6rem;font-weight:700;letter-spacing:-.02em}
.tier .price .per{font-size:.9rem;font-weight:400;color:var(--ink-faint);font-family:var(--font-mono)}
.tier .price-note{font-family:var(--font-mono);font-size:.68rem;color:var(--ink-faint);margin-top:6px;margin-bottom:24px}
.tier ul{list-style:none;margin:0 0 28px;flex:1}
.tier li{display:flex;gap:11px;align-items:flex-start;padding:8px 0;font-family:var(--font-body);font-size:.96rem;color:var(--ink-soft);border-bottom:1px solid var(--line-soft)}
.tier li:last-child{border-bottom:none}
.tier li svg{width:17px;height:17px;flex:none;margin-top:4px}
.tier .btn{width:100%;justify-content:center}

/* ---------- SIMPLE / STUB PAGES ---------- */
.stub{min-height:60vh;display:flex;align-items:center;padding:90px 0}
.stub-inner{max-width:42em}
.stub h1{font-size:clamp(2.2rem,4.6vw,3.4rem);margin-bottom:20px}
.stub p{font-family:var(--font-body);font-size:1.18rem;color:var(--ink-soft);margin-bottom:16px}
.stub .badge-soon{display:inline-block;font-family:var(--font-mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);border:1px solid var(--line);padding:6px 14px;border-radius:30px;margin-bottom:28px}

/* news list */
.news-list{display:flex;flex-direction:column;gap:2px;max-width:48em}
.news-item{display:grid;grid-template-columns:auto 1fr;gap:24px;padding:26px 0;border-bottom:1px solid var(--line-soft);transition:padding-left .2s}
.news-item:hover{padding-left:8px}
.news-item .date{font-family:var(--font-mono);font-size:.72rem;color:var(--ink-faint);white-space:nowrap;padding-top:5px}
.news-item h3{font-size:1.3rem;margin-bottom:6px}
.news-item p{font-family:var(--font-body);color:var(--ink-soft);font-size:1rem}

/* downloads */
.dl-row{display:flex;align-items:center;gap:20px;padding:22px 24px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);margin-bottom:14px}
.dl-row .dl-ic{width:42px;height:42px;flex:none}
.dl-row h4{font-size:1.12rem}
.dl-row .meta{font-family:var(--font-mono);font-size:.7rem;color:var(--ink-faint);margin-top:3px}
.dl-row .btn{margin-left:auto}

/* auth (login) */
.auth{min-height:80vh;display:flex;align-items:center;justify-content:center;padding:60px 0}
.auth-card{width:100%;max-width:400px;background:var(--panel);border:1px solid var(--line);border-radius:20px;padding:40px}
.auth-card h1{font-size:1.8rem;margin-bottom:8px;text-align:center}
.auth-card .sub{font-family:var(--font-body);color:var(--ink-soft);text-align:center;margin-bottom:30px;font-size:.98rem}
.field{margin-bottom:18px}
.field label{display:block;font-family:var(--font-mono);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:8px}
.field input{width:100%;padding:13px 15px;background:rgba(7,23,28,.6);border:1px solid var(--line);border-radius:var(--radius-sm);color:var(--ink);font-family:var(--font-body);font-size:1rem;transition:border-color .2s}
.field input:focus{outline:none;border-color:var(--accent)}
.auth-card .btn{width:100%;justify-content:center;margin-top:6px}
.auth-alt{text-align:center;margin-top:22px;font-family:var(--font-body);font-size:.92rem;color:var(--ink-faint)}
.auth-alt a{color:var(--accent-bright)}

/* ---------- FOOTER ---------- */
footer{border-top:1px solid var(--line-soft);padding:56px 0 36px;position:relative;z-index:2;background:rgba(5,17,21,.6)}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px;margin-bottom:40px}
.foot-brand p{font-family:var(--font-body);font-size:.96rem;color:var(--ink-faint);margin-top:16px;max-width:24em}
.foot-col h5{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:16px}
.foot-col a{display:block;font-size:.92rem;color:var(--ink-soft);padding:5px 0;transition:color .2s;font-family:var(--font-body)}
.foot-col a:hover{color:var(--accent-bright)}
.foot-bot{border-top:1px solid var(--line-soft);padding-top:24px;display:flex;justify-content:space-between;align-items:center;font-family:var(--font-mono);font-size:.7rem;color:var(--ink-faint);flex-wrap:wrap;gap:10px}

/* ---------- RESPONSIVE ---------- */
@media(max-width:980px){
  .grid-4{grid-template-columns:1fr 1fr}
  .tiers{grid-template-columns:1fr;max-width:460px;margin:0 auto}
}
@media(max-width:880px){
  .grid-2,.grid-3{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .hero{padding:90px 0 70px}
  .sec-pad{padding:64px 0}
}
@media(max-width:560px){
  .grid-4{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .wrap{padding:0 20px}
  .news-item{grid-template-columns:1fr;gap:6px}
}
