/* ============================================================
   FlixLink — shared design system
   Brand: red #D33A34 · cyan #08BAFF · charcoal #2F2E2D (from logo)
   ============================================================ */
:root{
  --red:#D33A34; --red-press:#B42E29; --red-soft:#fdeceb;
  --cyan:#0FB5F2; --cyan-deep:#0A86B8; --cyan-soft:#e7f7fe;
  --ink:#181C22; --ink-2:#262b33; --ink-3:#39414d;
  --text:#23262c; --muted:#5c6470;
  --paper:#ffffff; --paper-2:#f5f7fa; --paper-3:#eef1f5;
  --line:#e6e9ee; --line-dark:#333b46;
  --shadow-sm:0 2px 10px -4px rgba(24,28,34,.18);
  --shadow:0 16px 44px -22px rgba(24,28,34,.42);
  --radius:16px; --radius-lg:22px;
  --display:"Sora",system-ui,sans-serif;
  --body:"Hanken Grotesk",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--text);background:var(--paper);line-height:1.55;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,.display{font-family:var(--display);color:var(--ink);letter-spacing:-.02em;line-height:1.08}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
.narrow{max-width:980px}
.accent-red{color:var(--red)} .accent-cyan{color:var(--cyan-deep)}

/* ---------- Buttons ---------- */
.btn{font-family:var(--body);font-weight:700;font-size:15px;border:none;cursor:pointer;border-radius:11px;padding:12px 22px;display:inline-flex;align-items:center;gap:8px;transition:transform .12s ease, background .15s, box-shadow .15s, color .15s;white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--red);color:#fff}
.btn-primary:hover{background:var(--red-press);box-shadow:0 10px 22px -10px rgba(211,58,52,.7)}
.btn-cyan{background:var(--cyan);color:#fff}
.btn-cyan:hover{background:var(--cyan-deep)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:var(--ink-2)}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line-dark)}
.btn-ghost:hover{background:var(--ink);color:#fff}
.btn-light{background:#fff;color:var(--ink);border:1.5px solid var(--line)}
.btn-light:hover{border-color:var(--ink);}

/* ---------- Header ---------- */
header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.88);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.logo{display:flex;align-items:center;gap:10px}
.logo .mark{width:34px;height:34px;border-radius:50%;background:var(--red);color:var(--cyan);font-family:var(--display);font-weight:800;font-size:19px;font-style:italic;display:grid;place-items:center;flex-shrink:0}
.logo .wordmark{font-family:var(--display);font-weight:800;font-size:22px;letter-spacing:-.025em}
.logo .flix{color:var(--cyan-deep)} .logo .link{color:var(--red)}
footer .logo .flix{color:var(--cyan)} footer .logo .link{color:#ff6a5f}
.navlinks{display:flex;gap:28px;align-items:center;font-weight:600;font-size:15px}
.navlinks a{color:var(--ink-2);transition:color .15s;padding:6px 0;position:relative}
.navlinks a:hover{color:var(--red)}
.navlinks a.active{color:var(--red)}
.navlinks a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--red);border-radius:2px}
.navactions{display:flex;align-items:center;gap:18px}
.phone{font-weight:700;font-size:15px;color:var(--ink);display:flex;align-items:center;gap:7px}
.phone svg{color:var(--red)}
@media(max-width:900px){.navlinks,.phone{display:none}}

/* ---------- Generic section ---------- */
section.block{padding:74px 0}
.kicker{font-weight:700;font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--red);margin-bottom:11px}
.h2{font-size:clamp(28px,4vw,42px);font-weight:800;margin-bottom:14px;max-width:20ch}
.lead{color:var(--muted);font-size:18px;max-width:54ch}
.section-head{margin-bottom:42px}
.center{text-align:center;margin-left:auto;margin-right:auto}
.center .lead{margin-left:auto;margin-right:auto}
.alt{background:var(--paper-2)}

/* ---------- Page hero (subpages) ---------- */
.page-hero{background:var(--ink);color:#fff;padding:66px 0 70px;position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(680px 360px at 88% -12%, rgba(211,58,52,.32), transparent 60%),
  radial-gradient(560px 380px at 4% 120%, rgba(15,181,242,.22), transparent 60%)}
.page-hero .wrap{position:relative;z-index:2}
.page-hero .kicker{color:var(--cyan)}
.page-hero h1{font-size:clamp(34px,5.4vw,54px);font-weight:800;margin-bottom:14px;max-width:18ch}
.page-hero p{color:rgba(255,255,255,.74);font-size:18px;max-width:56ch}
.crumb{font-size:13px;color:rgba(255,255,255,.55);margin-bottom:20px}
.crumb a{color:rgba(255,255,255,.75)} .crumb a:hover{color:#fff}

/* ---------- Home hero ---------- */
.hero{position:relative;background:var(--ink);color:#fff;overflow:hidden;padding:72px 0 88px}
.hero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(900px 520px at 80% -8%, rgba(211,58,52,.34), transparent 60%),
  radial-gradient(720px 520px at 6% 115%, rgba(15,181,242,.24), transparent 60%)}
.hero .wrap{position:relative;z-index:2}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:13px;letter-spacing:.03em;color:#fff;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);padding:7px 14px;border-radius:100px;margin-bottom:22px}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--cyan);box-shadow:0 0 0 3px rgba(15,181,242,.3)}
.hero h1{font-size:clamp(38px,6vw,66px);font-weight:800;max-width:15ch;margin-bottom:18px}
.hero p.sub{font-size:clamp(17px,2vw,20px);color:rgba(255,255,255,.74);max-width:48ch;margin-bottom:30px}

/* ---------- Address checker ---------- */
.checker{background:#fff;color:var(--text);border-radius:var(--radius-lg);padding:26px;box-shadow:var(--shadow);max-width:660px}
.checker .checker-label{font-weight:700;font-size:15px;margin-bottom:6px;display:flex;align-items:center;gap:9px;color:var(--ink)}
.checker .checker-label .pin{color:var(--red)}
.checker .hint{color:var(--muted);font-size:13.5px;margin-bottom:14px}
.addrbox{position:relative}
.addr-input-row{display:flex;gap:10px}
.addrfield{flex:1;position:relative}
.addrfield input{width:100%;font-family:var(--body);font-size:16px;padding:16px 16px 16px 46px;border:1.5px solid var(--line);border-radius:12px;background:var(--paper-2);transition:border .15s, box-shadow .15s, background .15s}
.addrfield input:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 4px rgba(15,181,242,.14);background:#fff}
.addrfield .ico{position:absolute;left:15px;top:50%;transform:translateY(-50%);color:var(--muted)}
.predict{position:absolute;left:0;right:0;top:calc(100% + 8px);background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);overflow:hidden;z-index:20;display:none}
.predict.show{display:block}
.predict button{display:flex;align-items:center;gap:11px;width:100%;text-align:left;padding:13px 16px;background:none;border:none;border-bottom:1px solid var(--line);cursor:pointer;font-family:var(--body);font-size:15px;color:var(--text)}
.predict button:last-child{border-bottom:none}
.predict button:hover{background:var(--paper-2)}
.predict .pico{color:var(--red);flex-shrink:0}
.predict .sub{color:var(--muted);font-size:12.5px}
.result{margin-top:18px;display:none}
.result.show{display:block;animation:rise .4s ease}
@keyframes rise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.checking{display:none;align-items:center;gap:13px;margin-top:18px;color:var(--ink-2);font-weight:600}
.checking.show{display:flex}
.spinner{width:22px;height:22px;border:3px solid var(--line);border-top-color:var(--red);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.res-head{display:flex;align-items:flex-start;gap:14px;padding:16px;border-radius:13px;background:var(--cyan-soft);border:1px solid #bfeafd}
.res-head.nores{background:var(--red-soft);border-color:#f8cfcd}
.res-tick{width:42px;height:42px;border-radius:11px;background:var(--cyan);color:#fff;display:grid;place-items:center;flex-shrink:0}
.res-head.nores .res-tick{background:var(--red)}
.res-head h3{font-size:19px;margin-bottom:3px}
.res-addr{color:var(--muted);font-size:14px}
.techbadge{display:inline-flex;align-items:center;gap:7px;margin-top:9px;font-weight:700;font-size:13px;background:#fff;border:1px solid var(--cyan);color:var(--cyan-deep);padding:5px 11px;border-radius:100px}
.techbadge .d{width:7px;height:7px;border-radius:50%;background:var(--cyan)}

/* ---------- Plans ---------- */
.plan-toggle{display:inline-flex;background:#fff;border:1px solid var(--line);border-radius:13px;padding:5px;gap:4px;margin-bottom:32px}
.seg{font-family:var(--body);font-weight:700;font-size:14.5px;border:none;background:none;color:var(--muted);padding:9px 22px;border-radius:9px;cursor:pointer;transition:all .15s}
.seg.on{background:var(--ink);color:#fff}
.group-h{font-family:var(--display);font-weight:800;font-size:23px;margin:0 0 18px;display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;color:var(--ink)}
.group-h span{font-family:var(--body);font-weight:600;font-size:14px;color:var(--muted)}
.group-h:not(:first-child){margin-top:42px}
.addon{font-size:13px;color:var(--muted);margin-top:14px}
.plangrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(244px,1fr));gap:20px}
.plan{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px 24px;display:flex;flex-direction:column;position:relative;transition:transform .18s ease, box-shadow .18s ease, border-color .18s}
.plan:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:#d3d8e0}
.plan.feature{border-color:var(--red);box-shadow:var(--shadow)}
.plan .tag{position:absolute;top:-12px;left:24px;background:var(--red);color:#fff;font-weight:700;font-size:12px;padding:5px 12px;border-radius:100px}
.plan .pname{font-family:var(--display);font-weight:800;font-size:21px;margin-bottom:3px;color:var(--ink)}
.plan .ptier{color:var(--muted);font-size:13.5px;margin-bottom:18px}
.plan .speed{display:flex;align-items:baseline;gap:6px;margin-bottom:4px}
.plan .speed b{font-family:var(--display);font-size:34px;font-weight:800;color:var(--ink)}
.plan .speed span{color:var(--muted);font-size:14px;font-weight:600}
.plan .evening{font-size:13px;color:var(--cyan-deep);font-weight:600;margin-bottom:16px;display:flex;align-items:center;gap:6px}
.plan ul{list-style:none;margin:6px 0 0;font-size:13.5px;color:var(--ink-2)}
.plan ul li{display:flex;gap:8px;padding:3px 0}
.plan ul li svg{color:var(--cyan);flex-shrink:0;margin-top:2px}
.plan .price{margin-top:auto;padding-top:18px;border-top:1px solid var(--line)}
.plan .price b{font-family:var(--display);font-size:30px;font-weight:800;color:var(--ink)}
.plan .price span{color:var(--muted);font-size:14px}
.plan .price small{display:block;color:var(--muted);font-size:12px;margin-top:2px}
.plan .btn{width:100%;justify-content:center;margin-top:16px}

/* ---------- Feature cards ---------- */
.feats{display:grid;grid-template-columns:repeat(auto-fit,minmax(232px,1fr));gap:22px}
.feat{padding:26px;border-radius:var(--radius);background:#fff;border:1px solid var(--line);transition:transform .18s, box-shadow .18s}
.feat:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.feat .fi{width:46px;height:46px;border-radius:12px;background:var(--ink);color:var(--cyan);display:grid;place-items:center;margin-bottom:16px}
.feat h3{font-size:18px;margin-bottom:7px}
.feat p{color:var(--muted);font-size:14.5px}

/* ---------- Split / voice / panels ---------- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:42px;align-items:center}
@media(max-width:820px){.split{grid-template-columns:1fr;gap:30px}}
.vlist{list-style:none;margin:18px 0 0}
.vlist li{display:flex;gap:13px;padding:14px 0;border-bottom:1px solid var(--line)}
.vlist li:last-child{border-bottom:none}
.vlist .vi{width:40px;height:40px;border-radius:11px;background:var(--ink);color:var(--cyan);display:grid;place-items:center;flex-shrink:0}
.vlist h4{font-size:15.5px;margin-bottom:2px;font-family:var(--body);font-weight:700;color:var(--ink)}
.vlist p{font-size:13.5px;color:var(--muted)}
.panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px}
.pill{display:inline-flex;align-items:center;gap:7px;background:#fff;border:1px solid var(--line);border-radius:100px;padding:8px 14px;font-size:13px;font-weight:600;margin:4px 6px 4px 0;color:var(--ink-2)}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
.stats .stat b{font-family:var(--display);font-size:clamp(30px,4vw,40px);font-weight:800;display:block;color:var(--ink);line-height:1}
.stats .stat span{color:var(--muted);font-size:14px}
@media(max-width:680px){.stats{grid-template-columns:repeat(2,1fr);gap:26px}}

/* ---------- CTA band ---------- */
.band{background:var(--ink);color:#fff;border-radius:var(--radius-lg);padding:52px;display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;position:relative;overflow:hidden}
.band::before{content:"";position:absolute;inset:0;background:radial-gradient(620px 320px at 92% -20%,rgba(211,58,52,.32),transparent 60%),radial-gradient(420px 300px at 0% 120%,rgba(15,181,242,.2),transparent 60%)}
.band>*{position:relative;z-index:2}
.band h2{font-size:clamp(26px,3.6vw,38px);max-width:18ch;color:#fff}
.band p{color:rgba(255,255,255,.72);margin-top:10px;max-width:46ch}
@media(max-width:760px){.band{padding:34px}}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start}
@media(max-width:760px){.contact-grid{grid-template-columns:1fr}}
.cinfo .ci-row{display:flex;gap:14px;align-items:flex-start;padding:16px 0;border-bottom:1px solid var(--line)}
.cinfo .ci-row:last-child{border-bottom:none}
.cinfo .ci-ic{width:42px;height:42px;border-radius:11px;background:var(--red-soft);color:var(--red);display:grid;place-items:center;flex-shrink:0}
.cinfo h4{font-size:15px;margin-bottom:2px;font-family:var(--body);color:var(--ink)}
.cinfo a,.cinfo p{color:var(--muted);font-size:15px}
.field{margin-bottom:15px}
.field label{display:block;font-weight:600;font-size:13.5px;margin-bottom:6px;color:var(--ink)}
.field input,.field select,.field textarea{width:100%;font-family:var(--body);font-size:15px;padding:12px 14px;border:1.5px solid var(--line);border-radius:11px;background:#fff;transition:border .15s,box-shadow .15s}
.field textarea{min-height:120px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 4px rgba(15,181,242,.12)}
.field.row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.field.row>div{margin:0}

/* ---------- Footer ---------- */
footer{background:var(--ink);color:rgba(255,255,255,.62);padding:58px 0 30px}
.fcols{display:grid;grid-template-columns:1.7fr 1fr 1fr 1.2fr;gap:30px}
footer .fbrand p{font-size:14px;max-width:34ch;margin-top:14px}
footer .abn{font-size:13px;color:rgba(255,255,255,.45);margin-top:12px}
footer h4{color:#fff;font-family:var(--display);font-size:15px;margin-bottom:14px;letter-spacing:0}
footer a{display:block;color:rgba(255,255,255,.62);font-size:14px;padding:5px 0;transition:color .12s}
footer a:hover{color:var(--cyan)}
.fbottom{border-top:1px solid var(--line-dark);margin-top:36px;padding-top:22px;font-size:13px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}
@media(max-width:760px){.fcols{grid-template-columns:1fr 1fr}}

/* ---------- Order modal ---------- */
.modal-bg{position:fixed;inset:0;background:rgba(24,28,34,.6);backdrop-filter:blur(4px);z-index:100;display:none;align-items:flex-start;justify-content:center;padding:40px 16px;overflow-y:auto}
.modal-bg.show{display:flex}
.modal{background:var(--paper);border-radius:20px;max-width:560px;width:100%;box-shadow:var(--shadow);overflow:hidden;animation:rise .35s ease}
.modal-top{background:var(--ink);color:#fff;padding:22px 26px;display:flex;justify-content:space-between;align-items:center}
.modal-top h3{font-size:20px;color:#fff}
.modal-top .x{background:rgba(255,255,255,.1);border:none;color:#fff;width:34px;height:34px;border-radius:9px;cursor:pointer;font-size:18px;line-height:1}
.steps{display:flex;gap:6px;padding:18px 26px 0}
.step-pip{flex:1;height:5px;border-radius:100px;background:var(--line)}
.step-pip.on{background:var(--red)}
.modal-body{padding:22px 26px 28px}
.order-summary{background:#fff;border:1px solid var(--line);border-radius:13px;padding:16px;display:flex;justify-content:space-between;align-items:center;margin-bottom:22px}
.order-summary .os-name{font-family:var(--display);font-weight:800;font-size:18px;color:var(--ink)}
.order-summary .os-sub{color:var(--muted);font-size:13px}
.order-summary .os-price b{font-family:var(--display);font-size:22px;color:var(--ink)}
.order-summary .os-price span{color:var(--muted);font-size:13px}
.check-line{display:flex;gap:10px;align-items:flex-start;font-size:13.5px;color:var(--ink-2);margin:6px 0 18px}
.check-line input{margin-top:3px;width:17px;height:17px;accent-color:var(--red)}
.check-line a{color:var(--red);font-weight:600}
.modal-actions{display:flex;gap:12px;justify-content:space-between;align-items:center}
.note-box{background:var(--cyan-soft);border:1px solid #bfeafd;border-radius:12px;padding:13px 15px;font-size:13px;color:var(--cyan-deep);margin-bottom:18px}
.done{text-align:center;padding:14px 0}
.done .big{width:64px;height:64px;border-radius:50%;background:var(--cyan);color:#fff;display:grid;place-items:center;margin:0 auto 18px}
.done h3{font-size:24px;margin-bottom:8px}
.done p{color:var(--muted);max-width:40ch;margin:0 auto 6px}
.legal{font-size:12px;color:var(--muted);margin-top:22px}
.hidden{display:none!important}

/* ============================================================
   Scroll motion — content fades & slides up as it enters view.
   Pure CSS (scroll-driven animations). Where unsupported
   (older Safari/Firefox) everything simply shows normally.
   ============================================================ */
@keyframes flxReveal{ from{opacity:0; transform:translateY(30px)} to{opacity:1; transform:none} }

@supports (animation-timeline: view()){
  @media (prefers-reduced-motion: no-preference){
    .block .section-head .kicker,
    .block .section-head .h2,
    .block .section-head .lead,
    .block .split > *,
    .feat,
    .plan,
    .panel,
    .stats .stat,
    .tcards .tcard,
    .keys li,
    .cinfo .ci-row,
    .band{
      animation: flxReveal linear both;
      animation-timeline: view();
      animation-range: entry 0% cover 24%;
    }
  }
}
