/* ============ Artistflow marketing — dark main-stage (Identity Guide v1.0) ============ */
:root{
  --bg:#0A0A0A; --bg-2:#141414; --bg-3:#1C1C1C; --bg-4:#242424;
  --tx:#FAFAFA; --tx-2:#A3A3A3; --tx-3:#6E6E6E;
  --bd:rgba(255,255,255,0.10); --bd-2:rgba(255,255,255,0.18);
  --moss:#7AAB00; --on-moss:#1A2400;
  --ok:#22C55E; --warn:#F59E0B; --bad:#EF4444; --info:#60A5FA;
  --sans:"Geist",system-ui,sans-serif; --mono:"Geist Mono",ui-monospace,monospace; --serif:"DM Serif Display",Georgia,serif;
  --max:1120px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--tx);font-family:var(--sans);font-weight:400;font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden}
::selection{background:var(--moss);color:var(--on-moss)}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
.serif{font-family:var(--serif);font-style:italic;font-weight:400}
.mono{font-family:var(--mono)}
.kick{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--tx-3)}
.kick.moss{color:var(--moss)}
.muted{color:var(--tx-2)} .muted-3{color:var(--tx-3)}
.wrap{max-width:var(--max);margin:0 auto;padding:0 28px}

/* nav */
header.nav{position:sticky;top:0;z-index:50;backdrop-filter:blur(10px);background:rgba(10,10,10,.72);border-bottom:.5px solid var(--bd)}
.nav-in{max-width:var(--max);margin:0 auto;padding:14px 28px;display:flex;align-items:center;gap:26px}
.logo{display:flex;align-items:center;gap:10px;font-weight:500;letter-spacing:-.02em;font-size:24px;line-height:1}
.mark{width:26px;height:26px;border-radius:7px;background:var(--moss);color:#FAFAFA;display:grid;place-items:center;font-weight:500;font-size:16px;flex:none}
.nav-links{display:flex;gap:24px;margin-left:14px}
.nav-links a{color:var(--tx-2);font-size:14.5px}
.nav-links a:hover,.nav-links a.on{color:var(--tx)}
.nav-cta{margin-left:auto;display:flex;align-items:center;gap:12px}
.btn{display:inline-flex;align-items:center;gap:8px;border-radius:10px;padding:10px 17px;font-size:14.5px;font-weight:500;border:.5px solid var(--bd);background:transparent;color:var(--tx)}
.btn:hover{border-color:var(--bd-2)}
.btn-moss{background:var(--moss);color:var(--on-moss);border-color:transparent}
.btn-moss:hover{filter:brightness(1.06)}
.btn-lg{padding:14px 24px;font-size:16px;border-radius:12px}
.btn-ghost{border-color:transparent;color:var(--tx-2)}
.btn[disabled]{opacity:.55;cursor:not-allowed}

/* sections */
section{padding:84px 0}
.eyebrow{margin-bottom:18px}
h1,h2,h3{font-weight:500;letter-spacing:-.02em;margin:0}
.h-hero{font-size:clamp(40px,6.4vw,76px);line-height:1.02}
.h-sec{font-size:clamp(28px,3.6vw,44px);line-height:1.08}
.lead{font-size:clamp(17px,1.7vw,21px);color:var(--tx-2);max-width:620px}
.center{text-align:center} .mx{margin-left:auto;margin-right:auto}

/* hero */
.hero{position:relative;padding:74px 0 60px;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(90% 70% at 70% -10%,rgba(122,171,0,.16),transparent 60%);pointer-events:none}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:44px;align-items:center;position:relative}
.pill{display:inline-flex;align-items:center;gap:8px;border:.5px solid var(--bd);border-radius:999px;padding:6px 13px;font-size:12.5px;color:var(--tx-2);margin-bottom:24px}
.pill .d{width:7px;height:7px;border-radius:50%;background:var(--moss)}

/* cards / grid */
.cards{display:grid;gap:18px}
.card{background:var(--bg-2);border:.5px solid var(--bd);border-radius:16px;padding:24px}
.card.soft{background:var(--bg-2)}
.feat-ico{width:38px;height:38px;border-radius:10px;background:var(--bg-3);display:grid;place-items:center;color:var(--moss);margin-bottom:14px}

/* AI marker */
.ai{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--moss)}
.ai .d{width:6px;height:6px;border-radius:50%;background:var(--moss);animation:pulse 1.8s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.dot.ok{background:var(--ok)}.dot.warn{background:var(--warn)}.dot.moss{background:var(--moss)}.dot.neu{background:var(--tx-3)}.dot.info{background:var(--info)}

/* demo panel */
.demo{background:var(--bg-2);border:.5px solid var(--bd);border-radius:18px;overflow:hidden}
.demo-bar{display:flex;align-items:center;gap:8px;padding:11px 16px;background:var(--bg-3);border-bottom:.5px solid var(--bd)}
.demo-bar .d{width:9px;height:9px;border-radius:50%;background:#333}
.demo-bar .u{margin-left:8px;font-family:var(--mono);font-size:11px;color:var(--moss)}
.demo-body{padding:22px}
.field{border:.5px solid var(--bd);border-radius:10px;background:var(--bg);padding:11px 13px;font-size:14px;color:var(--tx);width:100%}
.field::placeholder{color:var(--tx-3)}
.lab{font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--tx-3);margin-bottom:6px;display:block}
.flash{animation:flash .8s ease}
@keyframes flash{0%{background:rgba(122,171,0,.22)}100%{background:var(--bg)}}
.chip{display:inline-flex;align-items:center;gap:7px;border:.5px solid var(--bd);border-radius:999px;padding:7px 13px;font-size:13.5px;color:var(--tx-2);background:transparent}
.chip:hover{border-color:var(--bd-2);color:var(--tx)}
.chip.on{border-color:var(--moss);color:var(--tx);background:rgba(122,171,0,.12)}
.opt{display:flex;align-items:center;justify-content:space-between;border:.5px solid var(--bd);border-radius:10px;padding:11px 13px;cursor:pointer}
.opt:hover{border-color:var(--bd-2)}
.opt.on{border-color:var(--moss);background:rgba(122,171,0,.08)}

/* phone */
.phone{width:300px;border-radius:36px;border:.5px solid var(--bd);background:#000;padding:9px}
.phone-s{border-radius:28px;background:#0A0A0A;overflow:hidden;height:600px;overflow-y:auto}

/* iPhone mockup */
.iphone{position:relative;width:372px;max-width:100%;padding:15px;border-radius:64px;
  background:linear-gradient(150deg,#46474b,#17181b 46%,#0b0b0d);
  box-shadow:0 0 0 1.5px #000, 0 50px 90px -34px rgba(0,0,0,.95);}
.iphone::after{content:"";position:absolute;inset:7px;border-radius:57px;border:1px solid rgba(255,255,255,.07);pointer-events:none}
.iphone .screen{position:relative;border-radius:50px;overflow:hidden;background:#0A0A0A;height:760px;overflow-y:auto;
  scrollbar-width:none;-ms-overflow-style:none}
.iphone .screen::-webkit-scrollbar{width:0;height:0;display:none}
.iphone .island{position:absolute;top:13px;left:50%;transform:translateX(-50%);width:100px;height:31px;background:#000;border-radius:16px;z-index:30}
.iphone .island::after{content:"";position:absolute;right:11px;top:50%;transform:translateY(-50%);width:9px;height:9px;border-radius:50%;background:#06060a;box-shadow:inset 0 0 3px rgba(90,90,140,.7)}
.iphone .side{position:absolute;background:#0a0a0c;border-radius:2px}
.iphone .pwr{right:-3px;top:172px;width:3.5px;height:74px}
.iphone .v1{left:-3px;top:138px;width:3.5px;height:34px}
.iphone .v2{left:-3px;top:182px;width:3.5px;height:60px}
.iphone .sil{left:-3px;top:108px;width:3.5px;height:22px}
.iphone .statusbar{position:sticky;top:0;z-index:25;display:flex;justify-content:space-between;align-items:center;padding:14px 26px 8px;background:#0A0A0A;color:#FAFAFA;font-size:14px;font-weight:600;font-family:var(--sans)}
.iphone .sb-r{display:flex;align-items:center;gap:6px}
.iphone .bars{display:inline-block;width:17px;height:11px;background:linear-gradient(90deg,#FAFAFA 0 75%,#555 75%);-webkit-mask:repeating-linear-gradient(90deg,#000 0 3px,transparent 3px 4px);mask:repeating-linear-gradient(90deg,#000 0 3px,transparent 3px 4px)}
.iphone .batt{display:inline-block;width:23px;height:12px;border:1px solid rgba(255,255,255,.55);border-radius:3px;position:relative;padding:1.5px}
.iphone .batt::before{content:"";display:block;width:70%;height:100%;background:#FAFAFA;border-radius:1px}
.iphone .batt::after{content:"";position:absolute;right:-3px;top:3.5px;width:2px;height:4px;background:rgba(255,255,255,.55);border-radius:0 1px 1px 0}

/* pricing toggle */
.seg{display:inline-flex;gap:4px;background:var(--bg-2);border:.5px solid var(--bd);border-radius:999px;padding:4px}
.segbtn{border:0;background:transparent;color:var(--tx-2);padding:10px 20px;border-radius:999px;font-size:14px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:8px}
.segbtn.on{background:var(--moss);color:var(--on-moss)}
.save{font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;border:.5px solid currentColor;border-radius:999px;padding:2px 7px;opacity:.85}

/* pricing */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.price{background:var(--bg-2);border:.5px solid var(--bd);border-radius:18px;padding:26px;display:flex;flex-direction:column}
.price.hot{border-color:var(--moss);box-shadow:0 0 0 1px rgba(122,171,0,.35) inset}
.price .amt{font-size:40px;font-weight:500;letter-spacing:-.02em;margin:6px 0 2px}
.price ul{list-style:none;padding:0;margin:18px 0;display:flex;flex-direction:column;gap:10px}
.price li{display:flex;gap:9px;font-size:14px;color:var(--tx-2)}
.price li::before{content:"✓";color:var(--moss)}

/* logos / proof */
.scene{display:flex;gap:30px;flex-wrap:wrap;align-items:center;justify-content:center;opacity:.6;font-family:var(--mono);font-size:13px;letter-spacing:.1em;text-transform:uppercase}

/* "the problem" — handled pain tags */
.paintag{display:inline-flex;align-items:center;gap:8px;border:.5px solid var(--bd);border-radius:999px;padding:8px 14px;font-size:13.5px;color:var(--tx-3);background:var(--bg-2)}
.paintag s{text-decoration-color:rgba(255,255,255,.28)}
.pt-ck{color:var(--moss);font-size:12px;line-height:1}

/* beta band */
.band{background:radial-gradient(80% 120% at 50% 0%,rgba(122,171,0,.16),transparent 60%);border:.5px solid var(--bd);border-radius:22px;padding:54px 30px;text-align:center}

/* footer */
footer{border-top:.5px solid var(--bd);padding:48px 0 40px}
.foot-grid{display:flex;justify-content:space-between;flex-wrap:wrap;gap:24px}
.foot-links{display:flex;gap:40px;flex-wrap:wrap}
.foot-col h4{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--tx-3);margin:0 0 12px;font-weight:500}
.foot-col a{display:block;color:var(--tx-2);font-size:14px;padding:4px 0}
.foot-col a:hover{color:var(--tx)}
.flowfam{display:flex;gap:8px;align-items:center;font-size:13px;color:var(--tx-3)}
.fmark{width:18px;height:18px;border-radius:5px;display:grid;place-items:center;font-size:10px;color:#fff;font-weight:500}

/* modal */
#ov{position:fixed;inset:0;background:rgba(0,0,0,.62);backdrop-filter:blur(4px);z-index:100;display:none;align-items:flex-start;justify-content:center;padding:6vh 16px}
#ov.open{display:flex}
.modal{width:min(560px,96vw);background:var(--bg-2);border:.5px solid var(--bd-2);border-radius:18px;overflow:hidden;animation:pop .18s ease}
@keyframes pop{from{transform:translateY(8px);opacity:.5}to{transform:none;opacity:1}}
.modal-h{padding:22px 24px 0;display:flex;justify-content:space-between;align-items:flex-start}
.modal-b{padding:18px 24px 24px}
.x{color:var(--tx-3);font-size:22px;line-height:1;cursor:pointer}
.x:hover{color:var(--tx)}
.fld{margin-bottom:14px}
.err{color:var(--bad);font-size:12.5px;margin-top:8px;display:none}
.err.show{display:block}
#toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:#fff;color:#0A0A0A;padding:11px 18px;border-radius:999px;font-size:13.5px;opacity:0;transition:.25s;z-index:200}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

@media(max-width:880px){
  .hero-grid{grid-template-columns:1fr;gap:30px} .price-grid{grid-template-columns:1fr}
  .nav-links{display:none} section{padding:60px 0}
  .two{grid-template-columns:1fr!important}
}
.two{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.order-2{order:2}
@media(max-width:880px){.order-2{order:0}}
.legal-grid{display:grid;grid-template-columns:220px 1fr;gap:46px;align-items:start}
.legal-nav a{display:block;padding:9px 12px;border-radius:9px;color:var(--tx-2);font-size:14px;cursor:pointer}
.legal-nav a:hover{background:var(--bg-2);color:var(--tx)}
.legal-nav a.on{background:var(--bg-2);color:var(--tx);font-weight:500}
.legal-body h3{font-size:24px;margin:0 0 14px}
.legal-body h4{font-size:15px;margin:22px 0 6px;color:var(--tx)}
.legal-body p,.legal-body li{color:var(--tx-2);font-size:14.5px;line-height:1.65}
.legal-body ul{padding-left:18px;margin:8px 0}
.turnstile{margin:14px 0;min-height:65px}
.turnstile-fallback{display:flex;align-items:center;gap:10px;border:.5px solid var(--bd);border-radius:8px;background:var(--bg);padding:10px 12px}
.turnstile-fallback .cbx{width:20px;height:20px;border-radius:5px;border:1.5px solid var(--moss);display:grid;place-items:center;color:var(--moss);font-size:13px}
.turnstile-fallback .tlabel{font-size:13px;color:var(--tx-2)}
.turnstile-fallback .tlogo{margin-left:auto;font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--tx-3)}
@media(max-width:880px){.legal-grid{grid-template-columns:1fr;gap:24px}}
.divider{height:.5px;background:var(--bd);border:0;margin:0}

/* ============ motion (subtle; disabled for prefers-reduced-motion) ============ */
@media (prefers-reduced-motion: no-preference){
  /* scroll reveal */
  .reveal{opacity:0;transform:translateY(16px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1);will-change:opacity,transform}
  .reveal.in{opacity:1;transform:none}

  /* hero entrance on load */
  .hero .pill,.hero h1,.hero .lead,.hero [style*="margin-top:30px"],.hero .muted-3,.hero-grid>div:last-child{
    opacity:0;transform:translateY(18px);animation:heroIn .8s cubic-bezier(.2,.7,.2,1) forwards}
  .hero h1{animation-delay:.06s}
  .hero .lead{animation-delay:.14s}
  .hero [style*="margin-top:30px"]{animation-delay:.22s}
  .hero .muted-3{animation-delay:.3s}
  .hero-grid>div:last-child{animation-delay:.18s}
  @keyframes heroIn{to{opacity:1;transform:none}}

  /* slow drifting hero glow */
  .hero::before{animation:glowDrift 16s ease-in-out infinite alternate}
  @keyframes glowDrift{
    0%{background:radial-gradient(90% 70% at 70% -10%,rgba(122,171,0,.16),transparent 60%)}
    100%{background:radial-gradient(95% 75% at 58% -6%,rgba(122,171,0,.20),transparent 62%)}
  }

  /* hover micro-interactions */
  .card{transition:transform .26s cubic-bezier(.2,.7,.2,1),border-color .26s ease,background .26s ease}
  .card:hover{transform:translateY(-3px);border-color:var(--bd-2)}
  .feat-ico{transition:transform .26s cubic-bezier(.2,.7,.2,1)}
  .card:hover .feat-ico{transform:translateY(-2px) scale(1.06)}
  .price{transition:transform .26s cubic-bezier(.2,.7,.2,1),border-color .26s ease,box-shadow .26s ease}
  .price:hover{transform:translateY(-4px)}
  .btn{transition:transform .15s ease,border-color .2s ease,background .2s ease,filter .2s ease}
  .btn:hover{transform:translateY(-1px)}
  .btn:active{transform:translateY(0) scale(.985)}
  .chip,.opt{transition:transform .18s ease,border-color .2s ease,color .2s ease,background .2s ease}
  .chip:hover{transform:translateY(-1px)}
  .scene{transition:opacity .4s ease}
  .paintag{transition:transform .2s ease,border-color .2s ease,color .2s ease}
  .paintag:hover{transform:translateY(-2px);border-color:var(--bd-2);color:var(--tx-2)}
  .logo .mark{transition:transform .3s cubic-bezier(.2,.7,.2,1)}
  .logo:hover .mark{transform:rotate(-6deg) scale(1.05)}

  /* nav shadow once scrolled */
  header.nav{transition:box-shadow .3s ease,background .3s ease}
  header.nav.scrolled{box-shadow:0 8px 30px -18px rgba(0,0,0,.8)}
}
.reveal.stagger>*{opacity:0;transform:translateY(14px)}
@media (prefers-reduced-motion: no-preference){
  .reveal.in.stagger>*{animation:heroIn .6s cubic-bezier(.2,.7,.2,1) forwards}
}
@media (prefers-reduced-motion: reduce){
  .reveal,.reveal.stagger>*{opacity:1!important;transform:none!important}
}
/* search skeleton + card swap */
.skel{background:var(--bg-2);border:.5px solid var(--bd)}
@media (prefers-reduced-motion: no-preference){
  .skel{background:linear-gradient(90deg,var(--bg-2) 0%,var(--bg-3) 50%,var(--bg-2) 100%);background-size:200% 100%;animation:shine 1.1s linear infinite}
  @keyframes shine{to{background-position:-200% 0}}
  #shape-card.swap{animation:swapIn .35s ease}
  @keyframes swapIn{from{opacity:.35;transform:translateY(4px)}to{opacity:1;transform:none}}
}
