/* ============================================================
   Appzoola — Business in a Box
   Apple-grade single page
   ============================================================ */
:root{
  --black:#06070d;
  --ink:#1d1d1f;
  --paper:#f5f5f7;
  --line:rgba(255,255,255,.12);
  --blue:#2b8fff;          /* Appzoola blue */
  --blue-2:#5aa8ff;
  --red:#e8442b;           /* Appzoola red accent */
  --maxw:1320px;
  --ease:cubic-bezier(.16,.84,.44,1);
  -webkit-font-smoothing:antialiased;font-synthesis:none;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:15px}   /* base scaled down a notch — everything in rem follows */
body{font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif;
  background:var(--black);color:#fff;line-height:1.5;overflow-x:hidden;
  min-height:100vh;display:flex;flex-direction:column}
a{color:inherit;text-decoration:none}

/* ---------- type ---------- */
.eyebrow{text-transform:uppercase;letter-spacing:.22em;font-size:.72rem;font-weight:600;
  color:rgba(255,255,255,.55);margin-bottom:1.1rem}
.eyebrow--accent{color:var(--blue-2)}
.panel--light .eyebrow--accent{color:#1668c9}
.display{font-size:clamp(2.4rem,6vw,5rem);line-height:1.02;letter-spacing:-.03em;font-weight:700;margin-bottom:1.4rem}
.lead{font-size:clamp(1.05rem,1.8vw,1.5rem);line-height:1.5;color:rgba(255,255,255,.8);max-width:36ch}
.panel--light .lead{color:#3a3a3f}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;padding:.85rem 1.7rem;border-radius:980px;
  font-size:1rem;font-weight:600;line-height:1;font-family:inherit;background:transparent;border:0;cursor:pointer;
  transition:transform .25s var(--ease),background .25s,opacity .25s;white-space:nowrap}
.btn:hover{transform:translateY(-2px)}
.btn--primary{background:var(--blue);color:#fff}
.btn--primary:hover{background:var(--blue-2)}
.btn--ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.4)}
.btn--ghost:hover{background:rgba(255,255,255,.08)}
.panel--light .btn--ghost{color:var(--ink);border-color:rgba(0,0,0,.3)}
.btn--lg{padding:1.05rem 2.3rem;font-size:1.1rem}

/* ---------- the cube mark ---------- */
.nav__cube,.foot__brand .nav__cube{width:22px;height:22px;border-radius:6px;
  background:linear-gradient(145deg,var(--blue-2),var(--blue) 55%,#1668c9);
  box-shadow:inset 0 1px 2px rgba(255,255,255,.5),0 4px 12px rgba(43,143,255,.5);
  display:inline-block;transform:rotate(0deg)}

/* ============================================================
   NAV
   ============================================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;backdrop-filter:saturate(160%) blur(18px);
  -webkit-backdrop-filter:saturate(160%) blur(18px);background:rgba(10,11,18,.6);border-bottom:1px solid var(--line);
  transition:transform .4s var(--ease)}
.nav.hide{transform:translateY(-100%)}
.nav__inner{max-width:none;margin:0;height:56px;padding:0 clamp(24px,3.5vw,56px);display:flex;align-items:center;gap:2rem}
.nav__brand{display:flex;align-items:center;gap:.6rem;font-weight:700;font-size:1.15rem;letter-spacing:-.02em}
.nav__logo{height:46px;width:auto;display:block}
.foot__logo{height:60px;width:auto}
.nav__links{display:flex;gap:1.7rem;margin-left:auto;font-size:.86rem;color:rgba(255,255,255,.72)}
.nav__links a:hover{color:#fff}
.nav__signin{font-size:.86rem;font-weight:500;color:rgba(255,255,255,.82);transition:color .2s}
.nav__signin:hover{color:#fff}
.nav__cta{background:var(--blue);color:#fff;padding:.45rem 1.1rem;border-radius:980px;font-size:.84rem;font-weight:600;transition:background .2s}
.nav__cta:hover{background:var(--blue-2)}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;height:100vh;min-height:680px;overflow:hidden;text-align:center;
  background:#0b111a}
/* ---- full-bleed cinematic video hero (custom-software) ---- */
.hero--video{text-align:left}
.hero__bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;
  opacity:0;animation:fadeIn 1.2s var(--ease) .1s forwards}
.hero--video .hero__copy{position:absolute;left:clamp(22px,6vw,90px);right:auto;top:50%;bottom:auto;
  transform:translateY(-50%);z-index:3;text-align:left;max-width:640px;padding:0;background:none}
/* no panel/overlay over the video — just a soft shadow on the type for legibility */
.hero--video .hero__title{text-align:left;text-shadow:0 2px 30px rgba(0,0,0,.55),0 1px 4px rgba(0,0,0,.5)}
.hero--video .hero__tagline{margin-left:0;margin-right:0;text-align:left;text-shadow:0 1px 14px rgba(0,0,0,.6)}
.hero--video .hero__actions{justify-content:flex-start}
.hero>.hero__glow{display:none}            /* no glow band in the contain letterbox — keep it seamless */
.hero__product{position:absolute;inset:0;z-index:2}
/* cover = the video fills the whole stage edge-to-edge — no letterbox box around it */
.hero__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;
  opacity:0;animation:fadeIn 1s var(--ease) .15s forwards}
@keyframes fadeIn{to{opacity:1}}
.hero__glow{position:absolute;left:50%;top:38%;width:min(1500px,108vw);height:70vh;
  transform:translate(-50%,-50%) scale(.6);z-index:0;pointer-events:none;
  background:radial-gradient(closest-side,rgba(43,143,255,.16),transparent 66%);filter:blur(40px);
  opacity:0;animation:glowIn 1.8s var(--ease) .15s forwards}
@keyframes glowIn{to{opacity:1;transform:translate(-50%,-50%) scale(1)}}

.hero__product{position:absolute;inset:0;z-index:2;display:flex;align-items:center;justify-content:center;
  padding:10vh 14px 0;gap:0}
/* copy lifted up so it sits over the laptop screen (not anchored to the bottom) */
.hero__copy{position:absolute;left:0;right:0;top:47%;bottom:auto;transform:translateY(-50%);z-index:3;padding:0 16px;
  pointer-events:none;background:none}
.hero__copy>*{pointer-events:auto}
.hero__copy>*{pointer-events:auto}
.hero__title{font-size:clamp(2.4rem,6.2vw,5rem);font-weight:700;letter-spacing:-.03em;line-height:1.02;color:#fff;
  text-shadow:0 2px 40px rgba(0,0,0,.5);overflow:hidden;padding-bottom:.1em}
.hero__title span{display:inline-block;animation:titleUp 1s cubic-bezier(.2,.85,.3,1) .4s both}
@keyframes titleUp{from{transform:translateY(106%)}to{transform:translateY(0)}}
.hero__tagline{margin:1rem auto 0;max-width:52ch;font-size:clamp(1.05rem,2vw,1.45rem);color:rgba(255,255,255,.82);
  text-shadow:0 1px 20px rgba(0,0,0,.5);animation:upFade .8s var(--ease) .8s both}
.hero__tagline em{font-style:normal;color:#fff;font-weight:600}
.hero__actions{margin-top:1.8rem;display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;animation:upFade .8s var(--ease) .95s both}
.hero__fine{margin-top:1.1rem;font-size:.85rem;color:rgba(255,255,255,.5);animation:upFade .8s var(--ease) 1.1s both}
/* Home hero: copy + buttons bottom-left (video is too busy for centred overlay) */
.hero--bl{text-align:left}
.hero--bl::after{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(105deg,rgba(0,0,0,.62) 0%,rgba(0,0,0,.38) 32%,rgba(0,0,0,0) 62%),
             linear-gradient(to top,rgba(0,0,0,.5) 0%,rgba(0,0,0,0) 42%)}
.hero--bl .hero__copy{left:clamp(22px,6vw,84px);right:auto;top:auto;bottom:clamp(54px,11vh,120px);
  transform:none;max-width:640px;padding:0;text-align:left}
.hero--bl .eyebrow{text-align:left}
.hero--bl .hero__title{text-align:left;text-shadow:0 2px 30px rgba(0,0,0,.6),0 1px 4px rgba(0,0,0,.55)}
.hero--bl .hero__tagline{margin-left:0;margin-right:0;max-width:46ch;text-align:left;text-shadow:0 1px 16px rgba(0,0,0,.65)}
.hero--bl .hero__actions{justify-content:flex-start}
.hero--bl .hero__fine{text-align:left}
@keyframes upFade{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}

/* hero: real product screenshot, large & fully visible, rises in on load */
.hero__shot{max-height:84vh;max-width:95vw;width:auto;height:auto;object-fit:contain;
  filter:drop-shadow(0 60px 70px rgba(0,0,0,.7));
  animation:bedRise 1.8s cubic-bezier(.16,.86,.26,1.06) .2s both}
@keyframes bedRise{0%{opacity:0;transform:translateY(24vh) scale(.78)}55%{opacity:1}100%{opacity:1;transform:translateY(0) scale(1)}}

/* hero: dramatic "Business in a Box" concept */
.hero__box{width:min(760px,86vw);height:auto;max-height:80vh;
  filter:drop-shadow(0 40px 70px rgba(43,143,255,.35));
  animation:bedRise 1.7s cubic-bezier(.16,.86,.26,1.06) .2s both}
.box-card{animation:cardFloat 6s ease-in-out infinite}
.box-card--2{animation-delay:.8s}
.box-card--3{animation-delay:1.5s}
.box-beam{animation:beamPulse 4s ease-in-out infinite}
@keyframes cardFloat{50%{transform:translateY(-16px)}}
@keyframes beamPulse{50%{opacity:.32}}
/* hero product entrance (device mockups, still used on sub-pages) */
.hero__product .laptop{animation:bedRise 1.7s cubic-bezier(.16,.86,.26,1.06) .2s both}
.hero__product .phone{animation:phoneRise 1.6s cubic-bezier(.16,.86,.26,1.06) .55s both}
@keyframes phoneRise{0%{opacity:0;transform:translateY(26vh) scale(.8)}60%{opacity:1}100%{opacity:1;transform:translateY(0) scale(1)}}

.hero__scroll{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);z-index:4;width:24px;height:38px;
  border:2px solid rgba(255,255,255,.35);border-radius:14px}
.hero__scroll span{position:absolute;top:7px;left:50%;width:3px;height:7px;border-radius:2px;background:#fff;
  transform:translateX(-50%);animation:scroll 1.8s ease-in-out infinite}
@keyframes scroll{0%{opacity:0;transform:translate(-50%,0)}30%{opacity:1}60%{opacity:1;transform:translate(-50%,12px)}100%{opacity:0;transform:translate(-50%,14px)}}

/* ============================================================
   DEVICE MOCKUPS (CSS)
   ============================================================ */
.laptop{position:relative;width:min(54vw,620px);flex:0 0 auto}
.laptop__screen{background:#0b0e18;border:10px solid #16181f;border-radius:18px 18px 4px 4px;
  box-shadow:0 40px 80px rgba(0,0,0,.6),inset 0 0 0 1px rgba(255,255,255,.06);aspect-ratio:16/10;overflow:hidden}
.laptop__base{height:14px;margin:0 -7%;border-radius:0 0 14px 14px;
  background:linear-gradient(180deg,#2a2d36,#0e1016);box-shadow:0 18px 30px rgba(0,0,0,.5)}
.laptop__base::after{content:"";display:block;width:18%;height:5px;margin:0 auto;border-radius:0 0 8px 8px;background:#0a0b11}
.laptop--sm{width:min(60vw,460px)}

.phone{position:relative;width:min(20vw,210px);flex:0 0 auto;
  background:#16181f;border-radius:34px;padding:10px;box-shadow:0 40px 70px rgba(0,0,0,.6),inset 0 0 0 1px rgba(255,255,255,.07)}
.phone__notch{position:absolute;top:14px;left:50%;transform:translateX(-50%);width:42%;height:18px;border-radius:0 0 14px 14px;background:#0b0d14;z-index:3}
.phone .ui{border-radius:26px;overflow:hidden;aspect-ratio:9/19;background:#0b0e18}
.phone--sm{width:min(26vw,180px)}
.phone--lg{width:min(74vw,300px)}

/* hero overlap of laptop + phone */
.hero__product .phone{margin-left:-7%;margin-top:14%;z-index:3}

/* the UI inside */
.ui{position:relative;background:#0d1018;height:100%;display:flex;flex-direction:column;text-align:left}
.ui--web{padding:0}
.ui__bar{display:flex;align-items:center;gap:8px;padding:11px 14px;background:#11141f;border-bottom:1px solid rgba(255,255,255,.06)}
.ui__appbar{display:flex;align-items:center;gap:7px;padding:12px 12px 8px}
.ui__dot{width:16px;height:16px;border-radius:5px;background:linear-gradient(145deg,var(--blue-2),var(--blue));flex:0 0 auto;box-shadow:0 2px 6px rgba(43,143,255,.5)}
.ui__pill{height:8px;width:64px;border-radius:5px;background:rgba(255,255,255,.22)}
.ui__pill--sm{width:34px}
.ui__title{font-size:11px;font-weight:600;color:#fff}
.ui__cta{margin-left:auto;font-size:9px;font-weight:600;color:#fff;background:var(--blue);padding:5px 10px;border-radius:980px}
.ui__hero{height:34%;margin:12px;border-radius:12px;
  background:linear-gradient(135deg,var(--blue) 0%,#1668c9 60%,#0c3f86 100%);position:relative;overflow:hidden}
.ui__hero::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 90% at 80% 10%,rgba(255,255,255,.35),transparent 55%)}
.ui__hero--app{height:30%;margin:10px}
.ui__grid{display:flex;gap:8px;padding:0 12px}
.ui__grid span{flex:1;height:42px;border-radius:9px;background:rgba(255,255,255,.08)}
.ui__cards{display:flex;gap:8px;padding:0 10px}
.ui__cards span{flex:1;height:44px;border-radius:10px;background:rgba(255,255,255,.08)}
.ui__rows{display:flex;flex-direction:column;gap:7px;padding:12px}
.ui__rows span{height:13px;border-radius:5px;background:rgba(255,255,255,.07)}
.ui__rows span:nth-child(2){width:70%}
.ui__tabs{margin-top:auto;display:flex;gap:18px;justify-content:center;padding:10px 0 12px;border-top:1px solid rgba(255,255,255,.06)}
.ui__tabs span{width:18px;height:6px;border-radius:4px;background:rgba(255,255,255,.18)}
.ui__tabs span.is-on{background:var(--blue);width:22px}

/* ============================================================
   HIGHLIGHTS — SCROLLER
   ============================================================ */
.reel{background:var(--black);padding:10rem 0 7rem}
.reel__head{max-width:var(--maxw);margin:0 auto 2.2rem;padding:0 clamp(22px,6vw,90px);display:flex;align-items:flex-end;justify-content:space-between;gap:1rem}
.reel__title{font-size:clamp(1.8rem,4vw,3rem);font-weight:700;letter-spacing:-.03em}
.reel__nav{display:flex;gap:.6rem}
.reel__btn{width:46px;height:46px;border-radius:50%;border:1px solid var(--line);background:rgba(255,255,255,.06);color:#fff;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .15s}
.reel__btn:hover{background:rgba(255,255,255,.16)}
.reel__btn:active{transform:scale(.92)}
.reel__btn:disabled{opacity:.3;cursor:default}
.reel__track{display:flex;gap:clamp(16px,2vw,28px);overflow-x:auto;scroll-snap-type:x mandatory;padding:0 clamp(22px,6vw,90px) 1rem;scrollbar-width:none;scroll-behavior:smooth}
.reel__track::-webkit-scrollbar{display:none}
/* frameless cards — no box, no border, no background; image floats on the page */
.card{position:relative;flex:0 0 clamp(320px,72vw,1080px);aspect-ratio:16/10;
  display:flex;flex-direction:column;
  scroll-snap-align:center;opacity:.5;transform:scale(.95);
  transition:opacity .6s var(--ease),transform .6s var(--ease);background:none}
.card.is-focus{opacity:1;transform:scale(1)}
.card__art{position:relative;order:1;flex:1 1 auto;min-height:0;background:none}
.card__art img,.card__art svg{position:relative;z-index:1;width:100%;height:100%;object-fit:contain;display:block;mix-blend-mode:screen}
.card__art--web{background:linear-gradient(135deg,#0c1020,#10224a)}
.card__art--grid{background:
  repeating-linear-gradient(0deg,transparent 0 38px,rgba(255,255,255,.05) 38px 39px),
  repeating-linear-gradient(90deg,transparent 0 38px,rgba(255,255,255,.05) 38px 39px),#0c1020}
.card__art--code{background:linear-gradient(135deg,#0c1020,#12183a)}
.card__art--chart{background:linear-gradient(135deg,#0c1020,#0a2a5c)}
.card__art--rocket{background:linear-gradient(135deg,#0c1020,#1a1340)}
.card__cap{position:relative;order:0;z-index:3;flex:0 0 auto;text-align:left;background:none;
  padding:clamp(1.4rem,2.6vw,2.4rem) clamp(1.8rem,3vw,3rem) .9rem}
.card__cap span{display:block;font-size:clamp(1.7rem,2.8vw,2.6rem);font-weight:700;letter-spacing:-.025em;
  line-height:1.05;margin-bottom:.55rem;color:#fff;text-shadow:0 2px 24px rgba(0,0,0,.65)}
.card__cap p{color:#fff;opacity:.92;font-size:clamp(1.02rem,1.4vw,1.25rem);line-height:1.45;max-width:30ch;
  text-shadow:0 1px 16px rgba(0,0,0,.65)}
.reel__dots{display:flex;gap:.5rem;justify-content:center;margin-top:1.8rem}
.reel__dots button{width:8px;height:8px;border-radius:50%;border:0;background:rgba(255,255,255,.25);cursor:pointer;padding:0;transition:background .25s,width .25s}
.reel__dots button.is-active{background:var(--blue);width:22px;border-radius:6px}

/* ============================================================
   FEATURE PANELS
   ============================================================ */
.panel{position:relative;min-height:100svh;display:grid;grid-template-columns:1fr 1fr;align-items:center;
  gap:clamp(2rem,5vw,5rem);padding:9rem clamp(22px,6vw,90px);overflow:hidden}
.panel__text{max-width:520px}
.panel--dark{background:radial-gradient(120% 100% at 80% 20%,#10224a,#06070d 70%)}
.panel--light{background:var(--paper);color:var(--ink)}
.panel--light .display{color:var(--ink)}
.panel__media{display:flex;align-items:center;justify-content:center;min-height:340px}

/* steps */
.steps{display:flex;flex-direction:column;gap:1rem;width:100%;max-width:460px}
.step{position:relative;border:1px solid var(--line);border-radius:18px;padding:1.5rem 1.7rem;background:rgba(255,255,255,.03)}
.step b{font-size:.9rem;color:var(--blue-2);letter-spacing:.1em}
.step span{display:block;font-size:1.35rem;font-weight:600;letter-spacing:-.02em;margin:.3rem 0 .4rem}
.step p{color:rgba(255,255,255,.62);font-size:.98rem}

/* duo (light panel device pair) */
.duo{display:flex;align-items:flex-end;justify-content:center;width:100%}
.duo .phone{margin-left:-8%;margin-bottom:6%;z-index:3}

/* ============================================================
   INTERACTIVE — FIND YOUR BUSINESS
   ============================================================ */
.closer{background:#0a0b13;padding:7rem clamp(22px,6vw,90px) 8rem;border-top:1px solid var(--line);text-align:center}
.closer__title{font-size:clamp(1.8rem,4vw,3rem);font-weight:700;letter-spacing:-.03em;margin:0 auto .6rem;max-width:var(--maxw)}
.closer__sub{color:rgba(255,255,255,.6);font-size:1.1rem;margin-bottom:3rem}
.closer__stage{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;text-align:left}
.closer__chips{display:flex;flex-direction:column;gap:.7rem}
.chip{display:flex;align-items:center;gap:.7rem;text-align:left;padding:1rem 1.25rem;border-radius:14px;border:1px solid var(--line);
  background:rgba(255,255,255,.03);color:rgba(255,255,255,.72);font:inherit;font-size:1.05rem;font-weight:500;cursor:pointer;
  transition:background .25s,color .25s,border-color .25s}
.chip::before{content:"";width:10px;height:10px;border-radius:3px;background:var(--chip-accent,var(--blue));flex:0 0 auto;transition:transform .25s}
.chip:hover{background:rgba(255,255,255,.07);color:#fff}
.chip.is-active{background:rgba(43,143,255,.14);border-color:rgba(43,143,255,.5);color:#fff}
.chip.is-active::before{transform:scale(1.4)}

.closer__view{position:relative;display:flex;flex-direction:column;align-items:center;gap:1.6rem;margin:0}
.closer__phone{display:flex;justify-content:center;filter:drop-shadow(0 40px 60px rgba(0,0,0,.6))}
.closer__cap{text-align:center;max-width:42ch}
.closer__tag{display:inline-block;font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:var(--blue-2);border:1px solid rgba(90,168,255,.4);border-radius:980px;padding:.25rem .8rem;margin-bottom:1rem}
.closer__cap h3{font-size:1.7rem;font-weight:600;letter-spacing:-.02em;margin-bottom:.5rem}
.closer__cap p{color:rgba(255,255,255,.74);font-size:1.05rem}
.closer__view .ui__hero{transition:background .5s var(--ease)}
.closer__view .ui__dot{transition:background .5s var(--ease)}

/* real screenshot inside a feature panel */
/* black-bg product screenshots: screen-blend so the black vanishes — laptop floats seamlessly, no panel */
.shot-img{width:100%;max-width:820px;height:auto;mix-blend-mode:screen;
  transition:transform 1.2s var(--ease)}
.panel__media:hover .shot-img{transform:scale(1.02)}
.lead--center{margin-left:auto;margin-right:auto;text-align:center}

/* ============================================================
   SOLUTIONS — real model-tile marquee
   ============================================================ */
.solutions{background:#06070d;padding:7rem 0 8rem;text-align:center;overflow:hidden}
.solutions__head{max-width:var(--maxw);margin:0 auto 3rem;padding:0 22px}
.marquee{display:flex;flex-direction:column;gap:34px;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee__row{display:flex;gap:40px;width:max-content}
.marquee__row a{flex:0 0 auto;display:block;transition:transform .25s var(--ease)}
.marquee__row a:hover{transform:translateY(-6px)}
.marquee__row img{width:clamp(340px,38vw,540px);aspect-ratio:1/.97;object-fit:cover;border-radius:24px;
  box-shadow:0 30px 70px rgba(0,0,0,.5);flex:0 0 auto;display:block}
.marquee__row--a{animation:marqA 56s linear infinite}
.marquee__row--b{animation:marqB 64s linear infinite}
@keyframes marqA{to{transform:translateX(-50%)}}
@keyframes marqB{from{transform:translateX(-50%)}to{transform:translateX(0)}}
.marquee:hover .marquee__row{animation-play-state:paused}
.solutions__cta{margin-top:3rem}
/* Clickable lineup of the REAL boxes — each card deep-links to its product page on the store. */
.bnb-lineup{max-width:var(--maxw);margin:0 auto;padding:0 22px;display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:20px}
.bnb-card{display:flex;flex-direction:column;text-decoration:none;border-radius:22px;overflow:hidden;background:#0e1019;border:1px solid rgba(255,255,255,.08);transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.bnb-card:hover{transform:translateY(-6px);box-shadow:0 26px 54px rgba(0,0,0,.55)}
.bnb-card__img{display:block;aspect-ratio:1/.78;overflow:hidden}
.bnb-card__img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s var(--ease)}
.bnb-card:hover .bnb-card__img img{transform:scale(1.04)}
.bnb-card__name{padding:15px 18px;font-weight:600;font-size:1.05rem;color:#fff;text-align:left}
/* Built section: clickable showcase image + a Read more button under the caption. */
#builtShotLink{display:block;cursor:pointer}
.built__more{margin-top:1.3rem;display:inline-flex}
.buytime__dayseq{color:rgba(255,255,255,.5);font-weight:400;font-size:.62em;letter-spacing:0;margin-left:8px;white-space:nowrap}

/* ============================================================
   BUILT WITH APPZOOLA — product showcase
   ============================================================ */
.built{background:#06070d;padding:9rem clamp(22px,6vw,90px) 11rem;border-top:1px solid var(--line)}
.built__head{max-width:760px;margin:0 auto 5rem;text-align:center}
.built__title{text-align:center;margin-left:auto;margin-right:auto}
.built__feature{max-width:1080px;margin:0 auto;display:flex;justify-content:center}
.built__feature img{width:100%;height:auto;max-height:560px;object-fit:contain;transition:opacity .35s var(--ease),transform 1.2s var(--ease)}
.built__feature img.is-swapping{opacity:0}
.built__feature:hover img{transform:scale(1.015)}
.built__caption{max-width:680px;margin:1.8rem auto 0;text-align:center;transition:opacity .35s var(--ease)}
.built__caption.is-swapping{opacity:0}
.built__name{font-size:clamp(1.3rem,2.4vw,1.8rem);font-weight:600;color:#fff;margin:0 0 .55rem;letter-spacing:-.01em}
.built__desc{color:rgba(255,255,255,.72);font-size:1.02rem;line-height:1.6;margin:0}
.built__tags{max-width:940px;margin:2.6rem auto 0;display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}
.built__tag{border:1px solid var(--line);border-radius:980px;padding:.55rem 1.2rem;
  color:rgba(255,255,255,.78);font-size:.95rem;background:rgba(255,255,255,.03);
  font-family:inherit;cursor:pointer;transition:border-color .2s var(--ease),background .2s var(--ease),color .2s var(--ease),transform .2s var(--ease)}
.built__tag:hover{border-color:rgba(43,143,255,.45);color:#fff;transform:translateY(-1px)}
.built__tag:focus-visible{outline:2px solid rgba(43,143,255,.6);outline-offset:2px}
.built__tag--live{border-color:rgba(43,143,255,.5);background:rgba(43,143,255,.14);color:#fff}
.built__grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.4rem,3vw,2.4rem)}
.prod{}
.prod__frame{border-radius:16px;overflow:hidden;background:#0b0e18;border:1px solid rgba(90,168,255,.22);
  box-shadow:0 40px 90px rgba(0,0,0,.55);transition:transform .5s var(--ease)}
.prod:hover .prod__frame{transform:translateY(-6px)}
.prod__bar{display:flex;align-items:center;gap:7px;padding:11px 14px;background:#11141f;border-bottom:1px solid rgba(255,255,255,.05)}
.prod__bar i{width:9px;height:9px;border-radius:50%;background:#2a3040}
.prod__bar span{margin-left:10px;height:14px;flex:1;max-width:200px;border-radius:7px;background:rgba(255,255,255,.06)}
.prod__ui{aspect-ratio:16/10;background:#0c1020}
.prod__ui svg{width:100%;height:100%;display:block}
.prod__cap{padding:1.4rem .4rem 0}
.prod__cap h3{font-size:1.4rem;font-weight:600;letter-spacing:-.02em;margin-bottom:.35rem}
.prod__cap p{color:rgba(255,255,255,.66);font-size:1rem;max-width:42ch}

/* ============================================================
   STATEMENT
   ============================================================ */
.statement{padding:12rem 22px;text-align:center;background:linear-gradient(180deg,#06070d,#0c1730,#06070d)}
.statement p{font-size:clamp(2rem,5.5vw,4.4rem);font-weight:700;letter-spacing:-.03em;line-height:1.05;max-width:18ch;margin:0 auto}
.statement span{color:var(--blue-2)}

/* ============================================================
   PRICING
   ============================================================ */
.pricing{background:radial-gradient(120% 100% at 50% 0,#10224a,#06070d 62%);padding:8rem 22px 9rem;text-align:center}
.pricing__inner{max-width:640px;margin:0 auto}
.pricing__price{display:flex;align-items:baseline;justify-content:center;gap:.5rem;margin:.4rem 0 1.2rem}
.pricing__from{font-size:1.3rem;color:rgba(255,255,255,.6);align-self:center}
.pricing__amt{font-size:clamp(3.4rem,9vw,5.6rem);font-weight:700;letter-spacing:-.03em}
.pricing__per{font-size:1.3rem;color:rgba(255,255,255,.6)}
.pricing__lead{color:rgba(255,255,255,.78);font-size:1.15rem;margin-bottom:2rem}
.pricing__list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:.7rem 1.6rem;max-width:480px;margin:0 auto 2.4rem;text-align:left}
.pricing__list li{position:relative;padding-left:1.7rem;color:rgba(255,255,255,.82);font-size:.98rem}
.pricing__list li::before{content:"";position:absolute;left:0;top:.35em;width:14px;height:9px;border-left:2px solid var(--blue);border-bottom:2px solid var(--blue);transform:rotate(-45deg)}
.pricing__actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.pricing__fine{margin-top:1.6rem;font-size:.85rem;color:rgba(255,255,255,.45)}

/* ============================================================
   FOOTER
   ============================================================ */
.foot{background:#06070d;border-top:1px solid var(--line);padding:3rem 22px;margin-top:auto}
.foot__inner{max-width:var(--maxw);margin:0 auto;display:flex;flex-wrap:wrap;gap:1.4rem;align-items:center}
.foot__brand{font-weight:700;display:flex;align-items:center;gap:.5rem}
.foot nav{display:flex;gap:1.6rem;margin-left:auto;font-size:.9rem;color:rgba(255,255,255,.6)}
.foot nav a:hover{color:#fff}
.foot small{width:100%;color:rgba(255,255,255,.4);font-size:.8rem;border-top:1px solid var(--line);padding-top:1.2rem}

/* ============================================================
   SUB-PAGES
   ============================================================ */
.subhero{position:relative;min-height:78vh;overflow:hidden;
  display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:2rem;
  padding:18vh clamp(22px,6vw,90px) 8vh;
  background:radial-gradient(125% 100% at 50% 0,#10224a 0%,#0a0d1c 46%,#040507 100%)}
/* full-screen hero: the header fills the viewport so the model strip below sits BELOW the fold and
   only appears when you scroll down to it — never a cut-off peek */
.subhero--center{grid-template-columns:1fr;text-align:center;min-height:100svh;
  display:flex;flex-direction:column;align-items:center;justify-content:center;padding:12vh clamp(22px,6vw,90px)}
.subhero--center .subhero__title{font-size:clamp(2.4rem,5.5vw,4.4rem)}
.subhero__copy{position:relative;z-index:3;max-width:560px}
.subhero__title{font-size:clamp(2.6rem,7vw,5.4rem);font-weight:700;letter-spacing:-.03em;line-height:1;margin:1.1rem 0}
.subhero__tag{font-size:clamp(1.05rem,2vw,1.4rem);color:rgba(255,255,255,.8);max-width:46ch;line-height:1.5}
.subhero__art{position:relative;z-index:2;display:flex;justify-content:center}
/* big, bold, frameless — image sits directly on the page: screen blend drops the
   dark fill, and a soft edge mask feathers the rectangle boundary away entirely */
.panel__pic{width:100%;max-width:900px;height:auto;mix-blend-mode:screen;
  -webkit-mask-image:radial-gradient(72% 82% at 50% 48%,#000 32%,rgba(0,0,0,.35) 62%,transparent 82%);
          mask-image:radial-gradient(72% 82% at 50% 48%,#000 32%,rgba(0,0,0,.35) 62%,transparent 82%);
  transition:transform .9s cubic-bezier(.16,.86,.26,1.06)}
.panel__media:hover .panel__pic{transform:scale(1.03)}
/* alternate panel sides — image on the left, copy on the right */
.panel--rev .panel__text{order:2}
.panel--rev .panel__media{order:1}
.panel--rev .panel__text{margin-left:auto}
/* let the media cell breathe so images read big and bold, Apple-style */
.panel__media{min-height:420px}
.panel__media .panel__pic{max-width:min(52vw,900px)}
.subhero__car{width:min(46vw,560px);height:auto;filter:drop-shadow(0 50px 50px rgba(0,0,0,.6));
  animation:bedRise 1.6s cubic-bezier(.16,.86,.26,1.06) .15s both}
/* eyebrow label — NOT a button: no pill, no border, just uppercase accent text */
.badge{display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--blue-2);padding:0}

/* feature grid */
.featgrid{background:#06070d;padding:7rem clamp(22px,6vw,90px) 8rem;text-align:center}
.featgrid__title{font-size:clamp(1.8rem,4vw,3rem);font-weight:700;letter-spacing:-.03em;margin-bottom:3rem}
.featgrid__grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;text-align:left}
.featgrid__grid>div{border:1px solid var(--line);border-radius:18px;padding:1.9rem;background:rgba(255,255,255,.03)}
.featgrid__grid h4{font-size:1.2rem;font-weight:600;letter-spacing:-.02em;margin-bottom:.5rem}
.featgrid__grid p{color:rgba(255,255,255,.62);font-size:.98rem}

/* payment/partner logo chips */
.logos{background:#0a0b13;padding:5rem 22px;text-align:center;border-top:1px solid var(--line)}
.logos__label{text-transform:uppercase;letter-spacing:.18em;font-size:.74rem;color:rgba(255,255,255,.5);margin-bottom:2rem}
.logos__row{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;align-items:center;max-width:760px;margin:0 auto}
.logos__chip{background:#fff;border-radius:14px;padding:.9rem 1.3rem;display:flex;align-items:center;justify-content:center;height:64px;box-shadow:0 10px 30px rgba(0,0,0,.3)}
.logos__chip img{height:30px;width:auto;display:block}

/* catalogue */
.catalog{background:#06070d;padding:5rem clamp(22px,6vw,90px) 7rem}
.catalog__grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.4rem}
.cat{border:1px solid var(--line);border-radius:18px;padding:1.7rem 1.8rem;background:rgba(255,255,255,.02)}
.cat h3{font-size:1.25rem;font-weight:600;letter-spacing:-.02em;margin-bottom:1rem;color:#fff}
.cat ul{list-style:none}
.cat li{padding:.4rem 0;border-top:1px solid var(--line);color:rgba(255,255,255,.72);font-size:.96rem}
.cat li a{color:var(--blue-2)}
.cat li a:hover{text-decoration:underline}

/* included */
.included{background:radial-gradient(120% 100% at 50% 0,#10224a,#06070d 62%);padding:7rem 22px 8rem;text-align:center}
.included__title{font-size:clamp(1.8rem,4vw,3rem);font-weight:700;letter-spacing:-.03em;margin-bottom:2.6rem}
.included__list{list-style:none;max-width:760px;margin:0 auto 2.6rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.7rem 1.6rem;text-align:left}
.included__list li{position:relative;padding-left:1.7rem;color:rgba(255,255,255,.82);font-size:.98rem}
.included__list li::before{content:"";position:absolute;left:0;top:.35em;width:14px;height:9px;border-left:2px solid var(--blue);border-bottom:2px solid var(--blue);transform:rotate(-45deg)}

/* contact */
.contact{background:#06070d;padding:3rem clamp(22px,6vw,90px) 8rem;max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:1.4fr 1fr;gap:3rem;align-items:start}
.contact__form{display:flex;flex-direction:column;gap:1.1rem}
.contact__row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.contact label{display:flex;flex-direction:column;gap:.5rem;font-size:.9rem;color:rgba(255,255,255,.7)}
.contact input,.contact textarea{background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:10px;
  padding:.48rem .8rem;color:#fff;font:inherit;font-size:.95rem;transition:border-color .2s}
.contact input:focus,.contact textarea:focus{outline:none;border-color:var(--blue)}
.contact textarea{resize:vertical}
.contact__note{font-size:.82rem;color:rgba(255,255,255,.4)}
.contact__side{border:1px solid var(--line);border-radius:18px;padding:2rem;background:rgba(255,255,255,.03)}
.contact__side h3{font-size:1.4rem;font-weight:600;margin-bottom:.6rem}
.contact__side p{color:rgba(255,255,255,.7);margin-bottom:1.2rem}
.contact__meta{margin-top:1.6rem;border-top:1px solid var(--line);padding-top:1.4rem;display:flex;flex-direction:column;gap:1rem}
.contact__meta p{font-size:.92rem;color:rgba(255,255,255,.6);margin:0}
.contact__meta b{color:#fff}
/* Contact: intro + form side by side, filling the first viewport (no scroll) */
.contact--hero{max-width:none;width:100%;margin:0;display:flex;align-items:center;min-height:100svh;
  padding:clamp(84px,11vh,120px) 0 clamp(28px,5vh,60px);position:relative;overflow-x:clip;
  background:radial-gradient(135% 115% at 50% 0%, rgba(43,143,255,.20) 0%, rgba(43,143,255,.06) 34%, #06070d 64%)}
.contact--hero>.hero__glow{display:none}
.contact__inner{width:100%;max-width:1200px;margin:0 auto;padding:0 clamp(22px,6vw,90px);
  display:grid;grid-template-columns:1fr 1.05fr;gap:3rem;align-items:center}
.contact__intro{position:relative;z-index:1}
.contact__intro .subhero__title{text-align:left;margin-top:1rem}
.contact__intro .subhero__tag{text-align:left;margin:1.1rem 0 1.8rem;max-width:44ch}
.contact__introcta{display:flex;gap:1rem;flex-wrap:wrap}
.contact__social{display:flex;align-items:center;gap:13px;margin-top:1.9rem;color:rgba(255,255,255,.55);font-size:.92rem}
.contact__social span{color:#fff;font-weight:600;margin-right:2px}
.contact__social a{display:inline-flex;width:36px;height:36px;align-items:center;justify-content:center;border-radius:50%;
  border:1px solid var(--line);color:#cfe0ff;transition:background .2s,border-color .2s,color .2s,transform .2s}
.contact__social a:hover{background:var(--blue);border-color:var(--blue);color:#fff;transform:translateY(-2px)}
.contact__social svg{width:17px;height:17px;fill:currentColor}
.contact__form{position:relative;z-index:1;background:rgba(255,255,255,.025);border:1px solid var(--line);
  border-radius:20px;padding:clamp(1.4rem,2.6vw,2.1rem)}
.contact--hero .contact__form{gap:.85rem}
.hp{position:absolute!important;left:-9999px!important;top:auto;width:1px;height:1px;opacity:0;pointer-events:none}
.contact__captcha .cap-row{display:flex;align-items:center;gap:10px;margin-bottom:.6rem}
#capImg{border:1px solid var(--line);border-radius:9px;background:#0c1018;height:54px;width:170px;display:block}
.cap-reload{flex:0 0 auto;width:36px;height:36px;border-radius:9px;border:1px solid var(--line);
  background:rgba(255,255,255,.05);color:#cfe0ff;cursor:pointer;font-size:17px;line-height:1}
.cap-reload:hover{background:rgba(120,170,255,.18);color:#fff}
.contact__status{font-size:.9rem;min-height:1.2em;margin:.2rem 0 0}
.contact__status.ok{color:#5fe39a}
.contact__status.bad{color:#ff9b8e}

@media (max-width:880px){
  .subhero{grid-template-columns:1fr;text-align:center;min-height:auto;padding:16vh 22px 5vh}
  .subhero__copy{max-width:none;margin:0 auto}
  .subhero__tag{margin-left:auto;margin-right:auto}
  .subhero__car{width:min(74vw,420px)}
  .featgrid__grid{grid-template-columns:1fr}
  .contact{grid-template-columns:1fr;gap:2rem}
  .contact--hero{min-height:auto;text-align:center}
  .contact__inner{grid-template-columns:1fr}
  .contact__intro .subhero__title,.contact__intro .subhero__tag{text-align:center}
  .contact__intro .subhero__tag{margin-left:auto;margin-right:auto}
  .contact__introcta,.cap-row{justify-content:center}
}

/* ============================================================
   REVEAL
   ============================================================ */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:880px){
  .nav__links{display:none}
  .panel{grid-template-columns:1fr;text-align:center;min-height:auto;padding:5rem 22px}
  .panel__text{max-width:none}
  .panel__media{order:-1}
  .lead{margin-left:auto;margin-right:auto}
  .card{flex-basis:min(86vw,560px)}
  .closer__stage{grid-template-columns:1fr;gap:2rem}
  .closer__chips{flex-direction:row;flex-wrap:wrap;justify-content:center}
  .chip{flex:1 1 auto}
  .pricing__list{grid-template-columns:1fr;max-width:280px}
  .laptop{width:min(82vw,560px)}
  .hero__product .phone{width:min(34vw,170px)}
  .built__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}
  .hero__title span{transform:none}
}

/* ============================================================
   AUTH — sign in / sign up (full site section, not a bolted-on template)
   ============================================================ */
.authsec{position:relative;overflow:hidden;
  padding:clamp(7rem,11vw,9.5rem) clamp(22px,6vw,90px) clamp(5rem,8vw,7rem);
  background:radial-gradient(120% 110% at 22% 0,#12224c 0%,#0a0d1c 50%,#040507 100%);
  border-bottom:1px solid var(--line)}
.authsec__inner{max-width:var(--maxw);margin:0 auto;position:relative;z-index:2;
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2.5rem,6vw,6rem);align-items:center}
.authsec__copy{max-width:600px}
.authsec__title{font-size:clamp(2.8rem,6vw,5rem);font-weight:700;letter-spacing:-.03em;line-height:1;margin:1.1rem 0 1.4rem}
.authsec__lead{color:rgba(255,255,255,.8);font-size:clamp(1.05rem,1.6vw,1.35rem);line-height:1.5;margin-bottom:2rem;max-width:42ch}
.authsec__points{list-style:none;display:flex;flex-direction:column;gap:1rem;max-width:46ch}
.authsec__points li{display:flex;gap:.85rem;align-items:flex-start}
.authsec__points li span{color:rgba(255,255,255,.84);font-size:1.1rem;line-height:1.4}
.authsec__points li::before{content:"";flex:0 0 auto;width:22px;height:22px;border-radius:7px;margin-top:1px;
  background:linear-gradient(145deg,var(--blue-2),var(--blue));box-shadow:0 3px 10px rgba(43,143,255,.5);
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M5 12l4 4 10-11' fill='none' stroke='black' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'/></svg>") center/16px no-repeat;
  mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M5 12l4 4 10-11' fill='none' stroke='black' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'/></svg>") center/16px no-repeat}
.authsec__note{margin-top:1.9rem;color:rgba(255,255,255,.6);font-size:1rem}

.auth__card{width:100%;max-width:480px;justify-self:end;
  background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:24px;
  padding:clamp(1.8rem,3vw,2.7rem);backdrop-filter:blur(14px);
  box-shadow:0 40px 100px rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.06)}
.auth__card h2{font-size:clamp(1.7rem,2.6vw,2.2rem);font-weight:700;letter-spacing:-.02em;margin-bottom:.5rem}
.auth__sub{color:rgba(255,255,255,.6);margin-bottom:1.9rem}
.auth__form{display:flex;flex-direction:column;gap:1.05rem}
.auth__form label{display:flex;flex-direction:column;gap:.5rem;font-size:.9rem;color:rgba(255,255,255,.72)}
.auth__form input,.auth__form select{width:100%;box-sizing:border-box;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:10px;
  padding:.48rem .8rem;color:#fff;font:inherit;font-size:.95rem;transition:border-color .2s,background .2s}
.auth__form input::placeholder{color:rgba(255,255,255,.35)}
.auth__form input:focus,.auth__form select:focus{outline:none;border-color:var(--blue);background:rgba(43,143,255,.06)}
.auth__row{display:flex;align-items:center;justify-content:flex-end;font-size:.9rem;margin-top:-.3rem}
.auth__link{color:var(--blue-2)}
.auth__link:hover{text-decoration:underline}
.auth__submit{width:100%;margin-top:.6rem}
.auth__alt{margin-top:1.9rem;text-align:center;color:rgba(255,255,255,.62);font-size:.98rem;
  border-top:1px solid var(--line);padding-top:1.7rem}
.auth__note{margin-top:1.1rem;text-align:center;font-size:.8rem;color:rgba(255,255,255,.4)}
@media (max-width:860px){
  .authsec__inner{grid-template-columns:1fr;gap:2.6rem}
  .auth__card{justify-self:stretch;max-width:none}
}

/* ============================================================
   BRAND LOGO — session icon + Michroma wordmark (crisp at any size)
   ============================================================ */
.nav__brand{gap:.6rem}
.nav__icon{height:34px;width:auto;display:block;flex:0 0 auto}
.wordmark{font-family:'Michroma',sans-serif;font-weight:400;font-size:1.15rem;letter-spacing:.3px;line-height:1;white-space:nowrap}
.wm-app{color:#ee2b24}
.wm-rest{color:#fff}
.wordmark--lg{font-size:1.4rem}
.foot__icon{height:40px;width:auto;display:block;flex:0 0 auto}
.foot__brandmark{display:inline-flex;align-items:center;gap:.65rem}

/* ============================================================
   CUSTOM SOFTWARE DEVELOPMENT — beyond the box
   ============================================================ */
.custom{background:radial-gradient(120% 110% at 82% 0,#10224a 0%,#0a0d1c 48%,#06070d 100%);
  padding:clamp(6rem,10vw,9rem) clamp(22px,6vw,90px);border-top:1px solid var(--line)}
.custom__inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.05fr .95fr;
  gap:clamp(2rem,5vw,5rem);align-items:center}
.custom__copy{max-width:580px}
.custom__list{list-style:none;margin:1.8rem 0 2.3rem;display:flex;flex-direction:column;gap:.85rem}
.custom__list li{position:relative;padding-left:1.9rem;color:rgba(255,255,255,.84);font-size:1.08rem}
.custom__list li::before{content:"";position:absolute;left:0;top:.42em;width:14px;height:9px;
  border-left:2px solid var(--blue);border-bottom:2px solid var(--blue);transform:rotate(-45deg)}
.custom__actions{display:flex;gap:1rem;flex-wrap:wrap}
.custom__media{display:flex;justify-content:center}
.custom__media img{width:100%;max-width:560px;height:auto;border-radius:20px;
  box-shadow:0 50px 110px rgba(0,0,0,.55),0 0 0 1px rgba(90,168,255,.18)}
@media (max-width:880px){
  .custom__inner{grid-template-columns:1fr;text-align:center}
  .custom__copy{max-width:none}
  .custom__list{align-items:center}
  .custom__actions{justify-content:center}
  .custom__media{order:-1}
}

/* ===== Buy development time — commitment slider (Custom Software) ===== */
.buytime{background:radial-gradient(120% 100% at 50% 0,#10224a,#06070d 64%);padding:7rem clamp(22px,6vw,90px) 8rem;text-align:center}
.buytime__inner{max-width:940px;margin:0 auto}
.buytime__card{margin-top:2.4rem;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:24px;padding:clamp(1.6rem,3vw,2.6rem);text-align:left}
.buytime__row{margin-bottom:1.8rem}
.buytime__label{display:block;font-size:1rem;color:rgba(255,255,255,.82);margin-bottom:.85rem;font-weight:500}
.buytime__label b{color:#fff;font-size:1.35rem;margin-left:.4rem}
.buytime__slider{-webkit-appearance:none;appearance:none;width:100%;height:8px;border-radius:6px;background:linear-gradient(90deg,var(--blue),var(--blue-2));outline:none}
.buytime__slider::-webkit-slider-thumb{-webkit-appearance:none;width:30px;height:30px;border-radius:50%;background:#fff;border:3px solid var(--blue);cursor:pointer;box-shadow:0 6px 18px rgba(0,0,0,.5)}
.buytime__slider::-moz-range-thumb{width:30px;height:30px;border-radius:50%;background:#fff;border:3px solid var(--blue);cursor:pointer}
.buytime__scale{display:flex;justify-content:space-between;color:rgba(255,255,255,.45);font-size:.8rem;margin-top:.5rem}
.buytime__seg{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.2rem}
.buytime__seg button{flex:1 1 auto;min-width:108px;padding:.7rem 1rem;border-radius:12px;border:1px solid var(--line);background:rgba(255,255,255,.05);color:rgba(255,255,255,.85);font-size:.95rem;font-weight:500;cursor:pointer;transition:background .2s,border-color .2s,color .2s}
.buytime__seg button:hover{background:rgba(255,255,255,.12)}
.buytime__seg button.on{background:var(--blue);border-color:var(--blue);color:#fff}
.buytime__prepay{display:inline-flex;align-items:center;gap:.6rem;margin-top:1.1rem;color:rgba(255,255,255,.82);font-size:.95rem;cursor:pointer}
.buytime__prepay input{width:18px;height:18px;accent-color:var(--blue)}
.buytime__prepay input:disabled{opacity:.4;cursor:default}
.buytime__out{display:grid;grid-template-columns:1fr 1fr 1.5fr;gap:1rem;margin:1.8rem 0 1.4rem;padding-top:1.8rem;border-top:1px solid var(--line)}
.buytime__stat{display:flex;flex-direction:column;gap:.2rem}
.buytime__stat span{color:rgba(255,255,255,.55);font-size:.85rem}
.buytime__stat b{color:#fff;font-size:clamp(1.7rem,3vw,2.3rem);font-weight:700;letter-spacing:-.02em;line-height:1}
.buytime__stat small{color:rgba(255,255,255,.5);font-size:.8rem}
.buytime__stat--big b{color:var(--blue-2)}
.buytime__actions{display:flex;gap:1rem;flex-wrap:wrap;margin-top:.4rem}
.buytime__fine{margin-top:1.4rem;font-size:.82rem;color:rgba(255,255,255,.45);line-height:1.55}
@media (max-width:720px){.buytime__out{grid-template-columns:1fr 1fr}.buytime__stat--big{grid-column:1 / -1}}

/* ===== Auth pages ===== */
.auth__msg{margin-top:1rem;text-align:center;font-size:.95rem;min-height:1.2em;font-weight:500}

/* ===== Set-up / sign-up — service selection + plan summary ===== */
.signup{background:radial-gradient(120% 100% at 50% 0,#10224a,#06070d 64%);padding:7rem clamp(22px,6vw,90px) 8rem;position:relative}
/* Build it your way — left-aligned intro sitting above the purchase options, so the purchasing
   section is right there on landing (no full-screen splash). */
.signup__intro{margin-bottom:2.1rem;position:relative;z-index:3}
.signup__title{font-size:clamp(2.2rem,4.6vw,3.5rem);font-weight:700;letter-spacing:-.03em;line-height:1.02;margin:.85rem 0 .9rem;color:#fff}
.signup__tag{font-size:clamp(1rem,1.6vw,1.2rem);color:rgba(255,255,255,.8);line-height:1.5;max-width:54ch;margin:0}
.signup__grid{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:1.2fr .9fr;gap:clamp(1.5rem,3vw,3rem);align-items:start}
.svc{background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:20px;padding:clamp(1.3rem,2.4vw,2rem);margin-bottom:1.4rem}
.svc__h{font-size:1.25rem;font-weight:700;letter-spacing:-.02em;display:flex;align-items:center;gap:.7rem;flex-wrap:wrap;margin-bottom:.3rem}
.svc__tag{font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;font-weight:600;color:rgba(255,255,255,.55);border:1px solid var(--line);border-radius:999px;padding:2px 9px}
.svc__tag--blue{color:var(--blue-2);border-color:rgba(90,168,255,.4)}
.svc__sub{color:rgba(255,255,255,.6);font-size:.92rem;margin-bottom:1.1rem;line-height:1.5}
.svc__row{display:flex;align-items:center;gap:.9rem;padding:.7rem 0;border-top:1px solid rgba(255,255,255,.07);cursor:pointer}
.svc__row:first-of-type{border-top:0}
.svc__row input{width:18px;height:18px;accent-color:var(--blue);flex:0 0 auto}
.svc__name{flex:1 1 auto;color:rgba(255,255,255,.88)}
.svc__price{font-weight:700;color:#fff}
.svc__price small{color:rgba(255,255,255,.5);font-weight:400}
.svc__hours{margin-left:auto;color:rgba(255,255,255,.55);font-size:.9rem}
.signup__side{position:sticky;top:80px}
.sum{margin-top:.4rem}
.sum__row{display:flex;justify-content:space-between;align-items:baseline;padding:.55rem 0;color:rgba(255,255,255,.82);border-top:1px solid rgba(255,255,255,.07)}
.sum__row:first-child{border-top:0}
.sum__row b{color:#fff;font-weight:600}
.sum__row--disc b{color:var(--blue-2)}
.sum__row--total{margin-top:.3rem;padding-top:.9rem;border-top:1px solid var(--line)}
.sum__row--total span{font-size:1.05rem}
.sum__row--total b{font-size:1.7rem;font-weight:700;letter-spacing:-.02em;color:var(--blue-2)}
.sum__note{color:rgba(255,255,255,.55);font-size:.85rem;margin:.5rem 0 0;text-align:right}
.sum__fine{color:rgba(255,255,255,.45);font-size:.8rem;line-height:1.5;margin-top:1rem;border-top:1px solid rgba(255,255,255,.07);padding-top:.9rem}
@media (max-width:880px){.signup__grid{grid-template-columns:1fr}.signup__side{position:static}}

/* sign-up headline price — full amount large, per-month under (no misleading reversal) */
.sum__headline{margin-top:.5rem;padding-top:1rem;border-top:1px solid var(--line);display:flex;flex-direction:column}
.sum__was{color:rgba(255,255,255,.45);font-size:.85rem;text-decoration:line-through;min-height:1.1em}
.sum__big-label{color:rgba(255,255,255,.72);font-size:.95rem;margin-top:.15rem}
.sum__big{color:var(--blue-2);font-size:clamp(2rem,4vw,2.5rem);font-weight:700;letter-spacing:-.02em;line-height:1.05;margin:.05rem 0 .1rem}
.sum__secondary{color:rgba(255,255,255,.78);font-size:1rem}

/* reel heading must be CENTERED (title + nav stacked, centred) */
.reel__head{flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:1.1rem}
.reel__title{text-align:center}

/* ===== Customer dashboard (dashboard.html) ===== */
.nav__cta--ghost{background:transparent;border:1px solid rgba(255,255,255,.22);color:#fff}
.nav__cta--ghost:hover{border-color:#fff;background:rgba(255,255,255,.06)}
.nav__links a.is-current{color:#fff;opacity:1;text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:8px;text-decoration-color:var(--blue)}
.btn--sm{padding:.55rem 1.15rem;font-size:.92rem;font-weight:600}
.btn--block{display:flex;justify-content:center;width:100%}
.dash-hero{position:relative;z-index:0;text-align:left;max-width:var(--maxw);margin:0 auto;padding:7.5rem clamp(22px,6vw,90px) 5rem}
.dash-hero>.hero__glow{display:none}
/* full-section glow: spans the WHOLE section width (100vw), sits behind the content, and fades out —
   no confined box, Apple-style soft top glow */
.dash-hero::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:100vw;height:100%;z-index:-1;pointer-events:none;background:radial-gradient(1600px 560px at 50% -20%,rgba(43,143,255,.12),transparent 60%)}
.dash-hero__title{font-size:clamp(1.8rem,3.8vw,2.7rem);font-weight:700;letter-spacing:-.03em;line-height:1.04;margin:.7rem 0 .5rem;color:#fff}
.dash-hero__tag{font-size:clamp(.9rem,1.3vw,1.02rem);color:rgba(255,255,255,.75);max-width:56ch;margin:0}
.dash{padding:1rem clamp(22px,6vw,90px) 5rem}
.dash__grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.5fr .9fr;gap:clamp(1.4rem,3vw,2.6rem);align-items:start}
.dash__head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.1rem}
.dash__h{font-size:1.4rem;font-weight:700;letter-spacing:-.02em;color:#fff;margin:0}
.dash-app{display:flex;gap:1.3rem;background:#0d1018;border:1px solid var(--line);border-radius:20px;padding:1.1rem;align-items:center}
.dash-app__img{width:160px;height:115px;flex:0 0 auto;border-radius:14px;overflow:hidden;background:#000}
.dash-app__img img{width:100%;height:100%;object-fit:cover;display:block}
.dash-app__body{flex:1;min-width:0}
.dash-app__status{display:inline-flex;align-items:center;gap:.45rem;font-size:.72rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:#39d98a}
.dash-app__status--live::before{content:"";width:7px;height:7px;border-radius:50%;background:#39d98a;box-shadow:0 0 0 3px rgba(57,217,138,.18)}
.dash-app__name{font-size:1.4rem;font-weight:700;letter-spacing:-.02em;color:#fff;margin:.35rem 0 .1rem}
.dash-app__url{color:var(--blue);font-size:.9rem;margin:0 0 .35rem}
.dash-app__meta{color:rgba(255,255,255,.6);font-size:.85rem;margin:0 0 .9rem}
.dash-app__actions{display:flex;gap:.7rem;flex-wrap:wrap}
.dash-add{display:flex;align-items:center;gap:1rem;margin-top:1rem;padding:1.1rem 1.3rem;border:1px dashed rgba(255,255,255,.22);border-radius:20px;color:rgba(255,255,255,.8);transition:border-color .2s,background .2s}
.dash-add:hover{border-color:var(--blue);background:rgba(255,255,255,.03)}
.dash-add__plus{width:42px;height:42px;flex:0 0 auto;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;background:rgba(255,255,255,.08);color:#fff}
.dash-add small{color:rgba(255,255,255,.55)}
.dash-card{background:#0d1018;border:1px solid var(--line);border-radius:20px;padding:1.3rem;margin-bottom:1.2rem;opacity:1;transform:none;aspect-ratio:auto;flex:none}
.dash-card__h{font-size:1.05rem;font-weight:700;color:#fff;margin:0 0 .9rem}
.dash-card__p{color:rgba(255,255,255,.65);font-size:.9rem;margin:0 0 1rem}
.dash-plan{display:flex;align-items:baseline;gap:.6rem;margin-bottom:.9rem}
.dash-plan__price{font-size:2rem;font-weight:700;color:#fff}
.dash-plan__price small{font-size:1rem;font-weight:500;color:rgba(255,255,255,.55)}
.dash-plan__sub{color:rgba(255,255,255,.6);font-size:.85rem}
.dash-plan__list{list-style:none;padding:0;margin:0 0 1.1rem}
.dash-plan__list li{padding:.35rem 0 .35rem 1.4rem;position:relative;color:rgba(255,255,255,.8);font-size:.9rem;border-bottom:1px solid rgba(255,255,255,.06)}
.dash-plan__list li::before{content:"\2713";position:absolute;left:0;color:#39d98a}
.dash-acct{margin:0 0 1.1rem;display:grid;grid-template-columns:auto 1fr;gap:.45rem 1rem}
.dash-acct dt{color:rgba(255,255,255,.5);font-size:.85rem}
.dash-acct dd{color:#fff;font-size:.9rem;margin:0;text-align:right;overflow:hidden;text-overflow:ellipsis}
@media (max-width:880px){.dash__grid{grid-template-columns:1fr}.dash-app{flex-direction:column;align-items:flex-start}.dash-app__img{width:100%;height:180px}}
.dash-loading{color:rgba(255,255,255,.5);padding:1rem 0}
.dash-app--row{justify-content:space-between}
.dash-acct__btns{display:flex;gap:.6rem;margin:.2rem 0 .4rem}
/* keep the .auth__form label layout (label above input with a gap); just space the fields apart */
#acct-form label{margin-bottom:1rem}
#acct-form label:last-of-type{margin-bottom:.4rem}
/* ===== Manage subscription / add-on modules (manage.html) ===== */
.dash-back{display:flex;width:fit-content;align-items:center;gap:.4rem;color:#fff;font-size:.82rem;font-weight:600;text-decoration:none;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.28);border-radius:980px;padding:.45rem 1rem;margin-bottom:1.2rem;transition:background .2s,border-color .2s,transform .15s}
.dash-back:hover{background:rgba(255,255,255,.14);border-color:#fff;transform:translateX(-2px)}
.mod-row{display:flex;align-items:center;gap:1.2rem;justify-content:space-between;background:#0d1018;border:1px solid var(--line);border-radius:18px;padding:1.05rem 1.2rem;margin-bottom:.8rem;transition:border-color .2s}
.mod-row--on{border-color:rgba(57,217,138,.5)}
.mod-row__body{min-width:0}
.mod-row__name{font-size:1.05rem;font-weight:700;color:#fff;margin:0 0 .25rem}
.mod-row__tag{font-size:.62rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:#39d98a;border:1px solid rgba(57,217,138,.4);border-radius:999px;padding:.1rem .5rem;vertical-align:middle;margin-left:.4rem}
.mod-row__desc{color:rgba(255,255,255,.6);font-size:.88rem;margin:0;line-height:1.4}
.mod-row__right{display:flex;align-items:center;gap:1rem;flex:0 0 auto}
.mod-row__price{color:#fff;font-weight:600;font-size:1rem;white-space:nowrap}
.mod-row__price small{color:rgba(255,255,255,.5);font-weight:400;font-size:.75rem}
.mod-sum__row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;color:rgba(255,255,255,.75);font-size:.92rem;border-bottom:1px solid rgba(255,255,255,.06)}
.mod-sum__row b{color:#fff}
.mod-sum__total{display:flex;justify-content:space-between;align-items:baseline;padding:.9rem 0 .2rem;font-size:1rem;color:#fff}
.mod-sum__total b{font-size:1.6rem;font-weight:700}
@media (max-width:600px){.mod-row{flex-direction:column;align-items:flex-start}.mod-row__right{width:100%;justify-content:space-between}}
.dash-app__facts{display:flex;flex-wrap:wrap;gap:.4rem 2rem;margin:.75rem 0 0}
.dash-app__facts dt{color:rgba(255,255,255,.5);font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;margin:0}
.dash-app__facts dd{color:#fff;font-size:.92rem;margin:.12rem 0 0;font-weight:500}
.dash-app__status--warn{color:#f0a93a}
.dash-app__status--warn::before{content:"";width:7px;height:7px;border-radius:50%;background:#f0a93a;box-shadow:0 0 0 3px rgba(240,169,58,.18)}
.dash-app__status--bad{color:#ff6b6b}
.dash-app__status--bad::before{content:"";width:7px;height:7px;border-radius:50%;background:#ff6b6b;box-shadow:0 0 0 3px rgba(255,107,107,.18)}
.mod-group{font-size:.82rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:rgba(255,255,255,.5);margin:1.7rem 0 .8rem}
.mod-group:first-child{margin-top:0}
.mod-row--inc{border-color:rgba(57,217,138,.35)}
.mod-row__price--free{color:#39d98a;font-weight:600}
