/* ============================================================
   RepCraft — "Iron & Ember"
   Warm iron-charcoal base · ONE ember-orange signal accent
   Display: Big Shoulders Display · Body: Schibsted Grotesk
   One system. Every page derives from these tokens.
   ============================================================ */

:root{
  --ink:#15110d; --surface:#1e1812; --surface-2:#271f17;
  --cream:#f3ebdf; --muted:#b3a796;
  --line:rgba(243,235,223,.10); --line-2:rgba(243,235,223,.17);
  --accent:#ff5d28;            /* ember — the signal */
  --a2:#f2a83c;                /* gold — effort/intensity */
  --a3:#6f97b8;                /* steel-blue — recovery/structure */
  --a4:#c9744f;                /* clay — warm bridge */
  --display:"Big Shoulders Display", "Arial Narrow", sans-serif;
  --body:"Schibsted Grotesk", system-ui, sans-serif;
  --maxw:1200px; --r-sm:10px; --r-md:18px; --r-lg:28px;
  --ease:cubic-bezier(.22,1,.36,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; position:relative; min-height:100%;
  background:var(--ink); color:var(--cream);
  font-family:var(--body); font-size:17px; line-height:1.6;
  font-weight:400; letter-spacing:.005em;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

/* ---- Atmosphere: layered ember/steel glows + film grain ---- */
body::before{
  content:""; position:fixed; inset:0; z-index:-2; pointer-events:none;
  background:
    radial-gradient(58% 48% at 80% -6%, color-mix(in oklch, var(--accent) 16%, transparent), transparent 60%),
    radial-gradient(46% 42% at 6% 10%, color-mix(in oklch, var(--a2) 10%, transparent), transparent 56%),
    radial-gradient(70% 60% at 50% 114%, color-mix(in oklch, var(--a3) 11%, transparent), transparent 60%);
}
body::after{
  content:""; position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E");
}

/* ---- Type scale ---- */
h1,h2,h3,h4{font-family:var(--display); font-weight:700; line-height:.98; margin:0;
  letter-spacing:.01em; text-transform:none;}
h1{font-size:clamp(3.1rem,8vw,6rem); font-weight:800;}
h2{font-size:clamp(2.3rem,5vw,3.7rem);}
h3{font-size:clamp(1.5rem,2.4vw,2rem);}
p{margin:0}
a{color:inherit; text-decoration:none}
img{max-width:100%; display:block}
.accent{color:var(--accent)}
.serif-i{font-style:italic}

.wrap{max-width:var(--maxw); margin-inline:auto; padding-inline:28px}
section{padding-block:clamp(60px,9vw,108px); position:relative}
.eyebrow{font-family:var(--display); font-weight:600; text-transform:uppercase;
  letter-spacing:.18em; font-size:.92rem; color:var(--accent);
  display:inline-flex; align-items:center; gap:.6em;}
.eyebrow::before{content:""; width:26px; height:2px; background:var(--accent); opacity:.7}
.lede{color:var(--muted); font-size:clamp(1.05rem,1.5vw,1.22rem); max-width:56ch; line-height:1.55}
.section-head{max-width:60ch; margin-bottom:clamp(34px,5vw,56px)}
.section-head h2{margin:14px 0 16px}

/* ---- Buttons ---- */
.btn{display:inline-flex; align-items:center; gap:.55em; cursor:pointer;
  font-family:var(--body); font-weight:600; font-size:1rem; letter-spacing:.01em;
  padding:14px 24px; border-radius:999px; border:1px solid transparent;
  transition:transform .25s var(--ease), box-shadow .3s var(--ease), background .25s, border-color .25s;}
.btn svg{width:18px; height:18px}
.btn-primary{color:#1a0f08; background:linear-gradient(180deg,#ff7a4d,var(--accent));
  box-shadow:0 1px 0 rgba(255,255,255,.28) inset,
    0 14px 40px -14px color-mix(in oklch, var(--accent) 65%, transparent);}
.btn-primary:hover{transform:translateY(-2px);
  box-shadow:0 1px 0 rgba(255,255,255,.3) inset,
    0 22px 54px -16px color-mix(in oklch, var(--accent) 75%, transparent);}
.btn-ghost{color:var(--cream); background:rgba(243,235,223,.03); border-color:var(--line-2)}
.btn-ghost:hover{border-color:var(--cream); transform:translateY(-2px);
  background:rgba(243,235,223,.06)}
.btn-lg{padding:16px 30px; font-size:1.08rem}
.btn-block{width:100%; justify-content:center}

/* ---- Nav ---- */
.nav{position:sticky; top:0; z-index:60;
  backdrop-filter:saturate(140%) blur(14px);
  background:color-mix(in oklch, var(--ink) 78%, transparent);
  border-bottom:1px solid var(--line)}
.nav-in{max-width:var(--maxw); margin-inline:auto; padding:14px 28px;
  display:flex; align-items:center; gap:26px}
.brand{display:flex; align-items:center; gap:11px; font-family:var(--display);
  font-weight:800; font-size:1.5rem; letter-spacing:.02em; color:var(--cream)}
.brand svg{width:34px; height:34px; flex:none}
.nav-links{display:flex; align-items:center; gap:7px; margin-left:auto}
.nav-links a{padding:9px 13px; border-radius:999px; color:var(--muted);
  font-size:.97rem; font-weight:500; transition:color .2s, background .2s}
.nav-links a:hover,.nav-links a[aria-current="page"]{color:var(--cream); background:rgba(243,235,223,.05)}
.nav-cta{margin-left:6px}
.nav-toggle{display:none; margin-left:auto; width:46px; height:46px; border-radius:12px;
  background:rgba(243,235,223,.05); border:1px solid var(--line-2); cursor:pointer;
  color:var(--cream); align-items:center; justify-content:center}
.nav-toggle svg{width:22px; height:22px}

/* Full-screen overlay menu */
.nav-menu{position:fixed; inset:0; z-index:80; display:none;
  flex-direction:column; padding:26px 28px;
  background:color-mix(in oklch, var(--ink) 97%, #000);
  background-image:
    radial-gradient(60% 40% at 80% 0%, color-mix(in oklch, var(--accent) 14%, transparent), transparent 60%);}
.nav-menu.open{display:flex}
body.menu-open{overflow:hidden}
.nav-menu-top{display:flex; align-items:center}
.nav-menu-close{margin-left:auto; width:46px; height:46px; border-radius:12px;
  background:rgba(243,235,223,.05); border:1px solid var(--line-2); color:var(--cream); cursor:pointer}
.nav-menu-links{display:flex; flex-direction:column; gap:6px; margin-top:8vh}
.nav-menu-links a{font-family:var(--display); font-weight:700; font-size:clamp(2rem,9vw,3rem);
  color:var(--cream); padding:8px 0; border-bottom:1px solid var(--line)}
.nav-menu-links a:hover{color:var(--accent)}
.nav-menu .btn{margin-top:auto}

/* ---- Hero ---- */
.hero{padding-top:clamp(40px,6vw,68px)}
.hero-grid{display:grid; grid-template-columns:1.04fr .96fr; gap:56px; align-items:center}
.hero h1{margin:18px 0 0}
.hero-sub{color:var(--muted); font-size:clamp(1.08rem,1.6vw,1.28rem); margin-top:22px; max-width:50ch}
.hero-cta{display:flex; flex-wrap:wrap; gap:14px; margin-top:30px}
.hero-meta{display:flex; flex-wrap:wrap; gap:22px; margin-top:30px; color:var(--muted); font-size:.95rem}
.hero-meta span{display:inline-flex; align-items:center; gap:8px}
.hero-meta svg{width:17px; height:17px; color:var(--a3)}

/* ---- Raised surface (panels / mocks / cards) ---- */
.surface{background:linear-gradient(165deg,var(--surface-2),var(--surface));
  border:1px solid var(--line-2); border-radius:var(--r-lg);
  box-shadow:0 40px 90px -42px rgba(0,0,0,.85), 0 0 0 1px rgba(0,0,0,.25)}

/* ---- Hero product mock: a weekly program draft ---- */
.mock{position:relative}
.mock-panel{padding:18px}
.mock-bar{display:flex; align-items:center; gap:10px; padding:6px 6px 16px;
  border-bottom:1px solid var(--line)}
.mock-bar .tt{font-family:var(--display); font-weight:700; font-size:1.15rem; letter-spacing:.01em}
.mock-bar .dot{width:9px; height:9px; border-radius:50%; background:var(--line-2)}
.mock-bar .spacer{margin-left:auto}
.mock-regen{display:inline-flex; align-items:center; gap:7px; font-size:.82rem; color:var(--accent);
  border:1px solid color-mix(in oklch,var(--accent) 40%, transparent); padding:6px 11px; border-radius:999px}
.mock-regen svg{width:14px; height:14px}
.mock-meta{display:flex; flex-wrap:wrap; gap:8px; padding:15px 4px 4px}
.tag{display:inline-flex; align-items:center; gap:7px; font-size:.82rem; color:var(--muted);
  background:rgba(243,235,223,.04); border:1px solid var(--line); padding:6px 11px; border-radius:8px}
.tag svg{width:14px; height:14px}
.tag.hot{color:var(--accent); border-color:color-mix(in oklch,var(--accent) 35%,transparent)}
.tag.cool{color:var(--a3); border-color:color-mix(in oklch,var(--a3) 38%,transparent)}
.mock-days{display:flex; gap:7px; padding:14px 4px; }
.mock-days button{flex:1; text-align:center; font-family:var(--display); font-weight:600;
  font-size:.95rem; letter-spacing:.04em; padding:8px 0; border-radius:9px; color:var(--muted);
  border:1px solid var(--line); background:none; cursor:pointer; transition:color .2s, border-color .2s, background .2s}
.mock-days button:hover{color:var(--cream); border-color:var(--line-2)}
.mock-days button.on{color:#1a0f08; background:linear-gradient(180deg,#ff7a4d,var(--accent)); border-color:transparent}
.mock-days button.on:hover{color:#1a0f08}
.mock-rows{display:flex; flex-direction:column; gap:9px; padding:6px 2px 2px}
.mock-rows{transition:opacity .18s var(--ease)}
.mock-rows.swap{opacity:0}
.mock-row{display:grid; grid-template-columns:1fr auto 78px; align-items:center; gap:14px;
  padding:12px 14px; border-radius:12px; background:rgba(243,235,223,.025); border:1px solid var(--line)}
.mock-row .ex{font-weight:600; color:var(--cream); font-size:.97rem}
.mock-row .sr{font-family:var(--display); font-weight:600; color:var(--muted); font-size:1.02rem; letter-spacing:.03em}
.mock-load{height:7px; border-radius:99px; background:rgba(243,235,223,.08); overflow:hidden; position:relative}
.mock-load i{position:absolute; inset:0 auto 0 0; border-radius:99px;
  background:linear-gradient(90deg,var(--a2),var(--accent))}
.mock-foot{display:flex; align-items:center; gap:10px; padding:16px 6px 4px; color:var(--muted); font-size:.9rem}
.mock-foot .ok{display:inline-flex; align-items:center; gap:7px; color:var(--a3)}
.mock-foot .ok svg{width:16px; height:16px}

/* float chips overflowing the mock */
.floatchip{position:absolute; display:inline-flex; align-items:center; gap:9px;
  padding:11px 14px; border-radius:13px; font-size:.86rem; color:var(--cream);
  background:linear-gradient(165deg,var(--surface-2),var(--surface));
  border:1px solid var(--line-2); box-shadow:0 22px 50px -22px rgba(0,0,0,.9);
  animation:float 6s ease-in-out infinite}
.floatchip svg{width:16px; height:16px}
.floatchip.one{top:-22px; left:-26px} .floatchip.one svg{color:var(--a3)}
.floatchip.two{bottom:34px; right:-30px; animation-delay:-3s} .floatchip.two svg{color:var(--a2)}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}

/* ---- Trust / platform strip ---- */
.strip{border-block:1px solid var(--line); background:rgba(243,235,223,.015)}
.strip-in{display:flex; flex-wrap:wrap; align-items:center; gap:18px 34px; padding-block:26px}
.strip .label{color:var(--muted); font-size:.86rem; text-transform:uppercase; letter-spacing:.14em}
.strip .items{display:flex; flex-wrap:wrap; gap:14px 26px; margin-left:auto}
.strip .items span{display:inline-flex; align-items:center; gap:9px; color:var(--cream); font-weight:500; font-size:.98rem}
.strip .items svg{width:18px; height:18px; color:var(--accent)}

/* ---- Bento feature grid ---- */
.bento{display:grid; grid-template-columns:repeat(12,1fr); gap:18px}
.feature{grid-column:span 3; padding:26px; border-radius:var(--r-md);
  background:linear-gradient(165deg,var(--surface-2),var(--surface)); border:1px solid var(--line);
  position:relative; overflow:hidden; transition:transform .3s var(--ease), border-color .3s}
.feature::after{content:""; position:absolute; inset:0; pointer-events:none; opacity:0;
  background:radial-gradient(70% 60% at 80% 0%, var(--glow,transparent), transparent 70%); transition:opacity .35s}
.feature:hover{transform:translateY(-5px); border-color:var(--line-2)}
.feature:hover::after{opacity:1}
.feature.lg{grid-column:span 6}
.ico{width:46px; height:46px; border-radius:12px; display:flex; align-items:center; justify-content:center;
  background:color-mix(in oklch, var(--ico,var(--accent)) 14%, transparent);
  border:1px solid color-mix(in oklch, var(--ico,var(--accent)) 30%, transparent); margin-bottom:18px}
.ico svg{width:23px; height:23px; color:var(--ico,var(--accent))}
.feature h3{font-size:1.32rem; margin-bottom:9px}
.feature p{color:var(--muted); font-size:.99rem}
.feature .shot{margin:-26px -26px 20px; border-bottom:1px solid var(--line); aspect-ratio:4/3; object-fit:cover; width:calc(100% + 52px)}

/* ---- Banner band (uses generated image, ken-burns) ---- */
.band{position:relative; overflow:hidden; border-block:1px solid var(--line-2)}
.band-img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  transform:scale(1.06); animation:kenburns 24s ease-in-out infinite alternate; opacity:.34}
@keyframes kenburns{from{transform:scale(1.04) translateY(0)}to{transform:scale(1.14) translateY(-3%)}}
.band::after{content:""; position:absolute; inset:0;
  background:linear-gradient(90deg, var(--ink) 6%, color-mix(in oklch,var(--ink) 62%,transparent) 60%, var(--ink) 100%)}
.band-in{position:relative; z-index:2}
/* About hero — studio photo as a muted background banner, copy on top */
.about-hero{padding-block:clamp(72px,12vw,156px)}
.about-hero-img{opacity:.24; filter:grayscale(.78) contrast(.92) brightness(.92)}
.about-hero::after{background:linear-gradient(90deg, var(--ink) 32%, color-mix(in oklch,var(--ink) 48%,transparent) 72%, color-mix(in oklch,var(--ink) 18%,transparent) 100%)}
.about-hero-copy{max-width:640px}
.about-hero-copy h1{margin-top:16px}
.about-hero-copy .lede{margin-top:28px}

/* ---- How it works ---- */
.steps{display:grid; grid-template-columns:repeat(3,1fr); gap:18px; counter-reset:s}
.step{padding:28px; border-radius:var(--r-md); background:linear-gradient(165deg,var(--surface-2),var(--surface));
  border:1px solid var(--line); position:relative}
.step::before{counter-increment:s; content:"0" counter(s); font-family:var(--display); font-weight:800;
  font-size:2.6rem; color:var(--accent); opacity:.9; line-height:1; display:block; margin-bottom:14px}
.step h3{font-size:1.3rem; margin-bottom:8px}
.step p{color:var(--muted); font-size:.98rem}

/* ---- FAQ (centered contained column) ---- */
.faq{max-width:760px; margin-inline:auto; display:flex; flex-direction:column; gap:12px}
.qa{border:1px solid var(--line); border-radius:var(--r-md); overflow:hidden;
  background:linear-gradient(165deg,var(--surface-2),var(--surface)); transition:border-color .3s}
.qa:hover{border-color:var(--line-2)}
.qa[open]{border-color:var(--line-2)}
.qa summary{list-style:none; display:flex; align-items:center; gap:18px; cursor:pointer;
  color:var(--cream); font-family:var(--body); font-weight:600; font-size:1.12rem; padding:20px 24px}
.qa summary::-webkit-details-marker{display:none}
.qa summary:hover .q{color:var(--accent)}
.qa .q{flex:1; transition:color .25s}
.qa .pm{flex:none; width:24px; height:24px; position:relative; transition:transform .3s var(--ease)}
.qa[open] .pm{transform:rotate(180deg)}
.qa .pm::before,.qa .pm::after{content:""; position:absolute; background:var(--accent); border-radius:2px}
.qa .pm::before{inset:11px 3px auto; height:2px}
.qa .pm::after{inset:3px auto 3px 11px; width:2px; transition:opacity .3s}
.qa[open] .pm::after{opacity:0}
.qa .a{color:var(--muted); padding:0 24px 22px; max-width:64ch; font-size:1.02rem; margin:0}

/* ---- CTA band ---- */
.ctaband .surface{padding:clamp(34px,5vw,60px); text-align:center;
  background:
    radial-gradient(70% 120% at 50% -10%, color-mix(in oklch,var(--accent) 20%, transparent), transparent 60%),
    linear-gradient(165deg,var(--surface-2),var(--surface))}
.ctaband h2{margin-bottom:16px}
.ctaband p{color:var(--muted); max-width:52ch; margin:0 auto 28px}
.ctaband .hero-cta{justify-content:center}

/* ---- Footer ---- */
.footer{border-top:1px solid var(--line); padding-block:54px 38px; margin-top:20px}
.footer-grid{display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:34px}
.footer .brand{margin-bottom:14px}
.footer p{color:var(--muted); font-size:.96rem; max-width:34ch}
.footer h4{font-family:var(--body); font-weight:600; font-size:.82rem; text-transform:uppercase;
  letter-spacing:.14em; color:var(--muted); margin-bottom:14px}
.footer ul{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:10px}
.footer ul a{color:var(--cream); opacity:.82; font-size:.97rem}
.footer ul a:hover{opacity:1; color:var(--accent)}
.footer-base{display:flex; flex-wrap:wrap; gap:12px; align-items:center; justify-content:space-between;
  margin-top:40px; padding-top:24px; border-top:1px solid var(--line); color:var(--muted); font-size:.9rem}

/* ---- Generic content blocks (inner pages) ---- */
.grid-2{display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px,4.5vw,64px)}
.grid-3{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.panel{padding:28px; border-radius:var(--r-md); background:linear-gradient(165deg,var(--surface-2),var(--surface));
  border:1px solid var(--line)}
.panel h3{font-size:1.3rem; margin-bottom:10px}
.panel p{color:var(--muted); font-size:.99rem}
.panel .ico{margin-bottom:16px}
.prose{max-width:70ch}
.prose p{color:var(--muted); margin-bottom:18px}
.prose h2{margin:14px 0 16px}
.prose h3{margin:26px 0 10px}
.lead-row{display:flex; flex-wrap:wrap; gap:14px; margin-top:26px}

/* page hero (inner) */
.phero{padding-top:clamp(50px,7vw,84px); padding-bottom:clamp(30px,4vw,40px)}
.phero h1{font-size:clamp(2.6rem,6.4vw,4.8rem); margin:16px 0 0}
.phero .lede{margin-top:20px}

/* pricing */
.price-grid{display:grid; grid-template-columns:1fr 1fr; gap:18px; max-width:860px; margin-inline:auto}
.price{padding:32px; border-radius:var(--r-lg); background:linear-gradient(165deg,var(--surface-2),var(--surface));
  border:1px solid var(--line); position:relative}
.price.feat{border-color:color-mix(in oklch,var(--accent) 45%,transparent);
  box-shadow:0 40px 90px -50px color-mix(in oklch,var(--accent) 60%,transparent)}
.price .pname{font-family:var(--display); font-weight:700; font-size:1.5rem}
.price .pcost{font-family:var(--display); font-weight:800; font-size:2.6rem; margin:14px 0 4px; line-height:1}
.price .psub{color:var(--muted); font-size:.94rem; margin-bottom:20px}
.plist{list-style:none; margin:0 0 26px; padding:0; display:flex; flex-direction:column; gap:12px}
.plist li{display:flex; gap:11px; color:var(--cream); font-size:.98rem; align-items:flex-start}
.plist svg{width:19px; height:19px; color:var(--accent); flex:none; margin-top:2px}

/* comparison table */
.ctable{width:100%; border-collapse:collapse; margin-top:8px}
.ctable th,.ctable td{text-align:left; padding:15px 16px; border-bottom:1px solid var(--line); font-size:.97rem}
.ctable th{font-family:var(--display); font-weight:600; letter-spacing:.03em; color:var(--cream)}
.ctable td{color:var(--muted)}
.ctable td svg{width:18px; height:18px; color:var(--accent)}
.ctable .ct-no{display:inline-block; color:var(--muted); opacity:.45; font-size:1.1rem; line-height:1}
.ctable tr:hover td{background:rgba(243,235,223,.02)}

/* contact details */
.cdetail{display:flex; align-items:center; gap:14px; padding:18px 20px; border-radius:var(--r-md);
  background:linear-gradient(165deg,var(--surface-2),var(--surface)); border:1px solid var(--line)}
.cdetail .ico{margin:0; width:42px; height:42px}
.cdetail b{display:block; font-weight:600}
.cdetail span{color:var(--muted); font-size:.94rem}

/* ============================================================
   FORM CONTROLS — themed BY ELEMENT (no native white boxes,
   even if a builder forgets the class)
   ============================================================ */
.form{display:grid; gap:16px}
.field{display:flex; flex-direction:column; gap:8px}
.field label{font-weight:600; font-size:.92rem; color:var(--cream)}
.field .hint{color:var(--muted); font-size:.84rem}
.row-2{display:grid; grid-template-columns:1fr 1fr; gap:16px}

input, textarea, select{
  font-family:var(--body); font-size:1rem; color:var(--cream);
  background:rgba(243,235,223,.035); border:1px solid var(--line-2);
  border-radius:12px; padding:13px 15px; width:100%;
  -webkit-appearance:none; appearance:none; outline:none;
  transition:border-color .2s, box-shadow .2s, background .2s;
}
input::placeholder, textarea::placeholder{color:color-mix(in oklch,var(--muted) 80%,transparent)}
input:focus, textarea:focus, select:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 4px color-mix(in oklch,var(--accent) 18%, transparent);
  background:rgba(243,235,223,.05);
}
textarea{min-height:130px; resize:vertical; line-height:1.55}
select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23b3a796' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 14px center; padding-right:42px;
}
select option{background:var(--surface); color:var(--cream)}
input[type=checkbox]{width:20px; height:20px; border-radius:6px; flex:none; cursor:pointer; position:relative}
input[type=checkbox]:checked{background:var(--accent); border-color:var(--accent)}
input[type=checkbox]:checked::after{content:""; position:absolute; inset:0;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%231a0f08' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/14px no-repeat}
.check-row{display:flex; align-items:flex-start; gap:11px; color:var(--muted); font-size:.92rem; line-height:1.45}
.form-note{color:var(--muted); font-size:.86rem}
.form-success{display:none; align-items:center; gap:13px; padding:18px 20px; border-radius:var(--r-md);
  background:color-mix(in oklch,var(--a3) 12%, transparent);
  border:1px solid color-mix(in oklch,var(--a3) 40%, transparent); color:var(--cream)}
.form-success.show{display:flex}
.form-success svg{width:24px; height:24px; color:var(--a3); flex:none}

/* ---- reveal animation hooks ---- */
.reveal{opacity:0; transform:translateY(22px); transition:opacity .7s var(--ease), transform .7s var(--ease)}
.reveal.in{opacity:1; transform:none}
.d1{transition-delay:.05s}.d2{transition-delay:.13s}.d3{transition-delay:.21s}
.d4{transition-delay:.29s}.d5{transition-delay:.37s}

/* ============================================================
   Micro-interactions — site-wide hover + press polish
   ============================================================ */
/* tactile press + ripple host on every button */
.btn{position:relative; overflow:hidden}
.btn:active{transform:translateY(0) scale(.97); transition-duration:.07s}
/* light sheen sweeps across the primary button on hover */
.btn-primary::before{content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none;
  background:linear-gradient(110deg, transparent 32%, rgba(255,255,255,.34) 50%, transparent 68%);
  transform:translateX(-130%); transition:transform .6s var(--ease)}
.btn-primary:hover::before{transform:translateX(130%)}
/* click ripple (element injected by app.js) */
.ripple{position:absolute; border-radius:50%; transform:scale(0); pointer-events:none;
  background:rgba(255,255,255,.4); animation:ripple .6s var(--ease) forwards}
@keyframes ripple{to{transform:scale(2.4); opacity:0}}

/* cards: one consistent hover lift + border warm-up across pages */
.panel,.price,.step,.cdetail,.integration-card{
  transition:transform .3s var(--ease), border-color .3s var(--ease), box-shadow .3s var(--ease)}
.panel:hover,.step:hover,.integration-card:hover{transform:translateY(-4px); border-color:var(--line-2)}
.cdetail:hover{transform:translateY(-3px); border-color:var(--line-2)}
.price:hover{transform:translateY(-5px); border-color:color-mix(in oklch,var(--accent) 35%,transparent);
  box-shadow:0 36px 80px -50px color-mix(in oklch,var(--accent) 50%,transparent)}
.price.feat:hover{transform:translateY(-5px)}

/* icon "pop" when its card is hovered */
.panel .ico,.cdetail .ico,.feature .ico{transition:transform .3s var(--ease)}
.panel:hover .ico,.cdetail:hover .ico,.feature:hover .ico{transform:translateY(-2px) scale(1.08) rotate(-3deg)}

/* nav + brand life */
.nav-links a:active{transform:scale(.93)}
.brand{transition:transform .3s var(--ease)}
.brand svg{transition:transform .55s var(--ease)}
.brand:hover svg{transform:rotate(-12deg) scale(1.06)}

/* link nudges */
.footer ul a{display:inline-block; transition:color .2s, opacity .2s, transform .2s var(--ease)}
.footer ul a:hover{transform:translateX(3px)}
.cdetail span,.cdetail b{transition:color .2s}
.cdetail:hover b{color:var(--accent)}

/* chips/tags */
.tag{transition:border-color .2s, color .2s, transform .2s var(--ease)}

/* keyboard focus ring (accessibility) */
a:focus-visible, button:focus-visible, .btn:focus-visible, summary:focus-visible,
input:focus-visible, select:focus-visible, textarea:focus-visible{
  outline:2px solid color-mix(in oklch,var(--accent) 75%, transparent); outline-offset:3px; border-radius:8px}

/* arrow / icon slides forward on button hover */
.btn svg{transition:transform .25s var(--ease)}
.btn:hover svg{transform:translateX(3px)}

/* bento image gently zooms when its card is hovered */
.feature .shot{transition:transform .55s var(--ease)}
.feature:hover .shot{transform:scale(1.06)}

/* soft accent glow blooms on content cards */
.panel,.price{position:relative}
.panel::after,.price::after{content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none;
  opacity:0; transition:opacity .4s var(--ease);
  background:radial-gradient(65% 60% at 82% 0%, color-mix(in oklch,var(--accent) 13%,transparent), transparent 70%)}
.panel:hover::after,.price:hover::after{opacity:1}
.panel > *,.price > *{position:relative; z-index:1}

/* tags / chips */
.tag:hover{border-color:var(--line-2); color:var(--cream); transform:translateY(-1px)}

/* trust-strip items */
.strip .items span{transition:transform .25s var(--ease), color .2s}
.strip .items span:hover{transform:translateY(-2px)}
.strip .items svg{transition:transform .25s var(--ease)}
.strip .items span:hover svg{transform:scale(1.15) rotate(-4deg)}

/* sticky nav lifts once you scroll past the top */
.nav{transition:box-shadow .3s var(--ease), background .3s}
.nav.scrolled{background:color-mix(in oklch,var(--ink) 90%,transparent);
  box-shadow:0 14px 36px -22px rgba(0,0,0,.92)}

/* top scroll-progress bar (element injected by app.js) */
.scroll-prog{position:fixed; top:0; left:0; height:3px; width:0; z-index:100; pointer-events:none;
  background:linear-gradient(90deg,var(--a2),var(--accent));
  box-shadow:0 0 12px color-mix(in oklch,var(--accent) 60%,transparent); transition:width .12s linear}

@media (prefers-reduced-motion:reduce){
  .btn:active{transform:none}
  .btn-primary::before{display:none}
  .ripple{display:none}
  .panel:hover,.price:hover,.step:hover,.cdetail:hover,.integration-card:hover,.feature:hover{transform:none}
  .panel:hover .ico,.cdetail:hover .ico,.feature:hover .ico,.brand:hover svg{transform:none}
  .footer ul a:hover{transform:none}
  .btn:hover svg{transform:none}
  .feature:hover .shot{transform:none}
  .strip .items span:hover,.strip .items span:hover svg,.tag:hover{transform:none}
  .scroll-prog{display:none}
}

/* hero accent word — slow ember shimmer */
.hero h1 .accent{
  background:linear-gradient(100deg, var(--accent) 30%, #ffb583 50%, var(--accent) 70%);
  background-size:220% 100%; -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent; color:transparent;
  animation:accentShimmer 5.5s linear infinite}
@keyframes accentShimmer{to{background-position:-220% 0}}

/* hero product mock — cursor-following 3D tilt (transform set inline by app.js) */
.mock{will-change:transform}
.mock-load i{transition:right .7s var(--ease)}

@media (prefers-reduced-motion:reduce){
  .hero h1 .accent{animation:none}
}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:1000px){
  .hero-grid{grid-template-columns:1fr; gap:40px}
  .hero-mock-col{order:2}
  .bento{grid-template-columns:repeat(4,1fr)}
  .feature.lg,.feature{grid-column:span 2}
  .steps{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr; gap:28px}
  .footer .brand-col{grid-column:1 / -1}
}
@media (max-width:720px){
  body{font-size:16px}
  .nav-links,.nav-cta{display:none}
  .nav-toggle{display:inline-flex}
  .bento{grid-template-columns:1fr; gap:14px}
  .feature,.feature.lg{grid-column:auto}
  .grid-2,.grid-3,.price-grid,.row-2{grid-template-columns:1fr}
  .strip-in{flex-direction:column; align-items:flex-start; gap:14px}
  .strip .items{margin-left:0}
  .footer-grid{grid-template-columns:1fr 1fr}
  .floatchip.one{left:-6px; top:-16px}
  .floatchip.two{right:-6px}
  .mock-row{grid-template-columns:1fr auto 56px; gap:10px}
}
@media (max-width:430px){
  .wrap{padding-inline:20px}
  .floatchip{display:none}
  .footer-grid{grid-template-columns:1fr}
}

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