  *{box-sizing:border-box;margin:0;padding:0}
  :root{
    --bg:#0b0b0d; --bg2:#121215; --card:#161619; --card2:#1c1c20;
    --line:rgba(255,255,255,.10); --line2:rgba(255,255,255,.17);
    --txt:#f4f2ed; --muted:#9d9ca2; --faint:#67666d;
    --accent:#e1232e; --accent-soft:rgba(225,35,46,.14);
    --shadow:0 28px 70px -28px rgba(0,0,0,.78);
    --ease:cubic-bezier(.22,.68,.18,1);
    --ease-out:cubic-bezier(.16,1,.3,1);
  }
  [data-theme="light"]{
    --bg:#efece6; --bg2:#f6f4ef; --card:#ffffff; --card2:#faf8f4;
    --line:rgba(20,16,14,.12); --line2:rgba(20,16,14,.2);
    --txt:#16131a; --muted:#6a686f; --faint:#9b968f;
    --accent:#c20e2a; --accent-soft:rgba(194,14,42,.10);
    --shadow:0 28px 70px -32px rgba(40,30,20,.34);
  }
  html{scroll-behavior:auto}
  body{
    background:var(--bg);color:var(--txt);
    font-family:Archivo,system-ui,-apple-system,sans-serif;
    -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
    min-height:100vh;display:flex;flex-direction:column;overflow-x:hidden;
    transition:background .5s var(--ease),color .5s var(--ease);
  }
  ::selection{background:var(--accent);color:#fff}
  ::-webkit-scrollbar{width:11px;height:11px}
  ::-webkit-scrollbar-thumb{background:var(--line2);border-radius:20px}
  ::-webkit-scrollbar-track{background:transparent}
  a{color:inherit}
  .kick{
    font-size:11.5px;font-weight:600;letter-spacing:.26em;text-transform:uppercase;
    color:var(--accent);
  }
  .mono{font-variant-numeric:tabular-nums;letter-spacing:.01em}

  /* ============ HEADER ============ */
  header{
    position:sticky;top:0;z-index:60;
    background:color-mix(in srgb,var(--bg) 78%,transparent);
    backdrop-filter:blur(18px) saturate(1.2);
    border-bottom:1px solid transparent;
    transition:border-color .45s var(--ease),background .5s var(--ease);
  }
  .header-inner{
    max-width:1320px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;
    gap:24px;padding:20px clamp(20px,4vw,56px);transition:padding .45s var(--ease);
  }
  header.scrolled{border-bottom-color:var(--line)}
  header.scrolled .header-inner{padding:12px clamp(20px,4vw,56px)}
  .brand{display:flex;align-items:center;gap:14px;cursor:pointer;user-select:none}
  .brand .mark{width:30px;height:36px;flex:none;transition:transform .5s var(--ease)}
  .brand:hover .mark{transform:translateY(-1px)}
  .brand .mark .leaf{transform-box:fill-box;transform-origin:left center;transition:transform .55s var(--ease)}
  .brand:hover .mark .leaf{transform:rotateY(34deg)}
  .brand .wm{display:flex;flex-direction:column;line-height:1}
  .brand .wm b{font-weight:800;font-size:21px;letter-spacing:.17em}
  .brand .wm span{font-size:9px;letter-spacing:.30em;color:var(--muted);margin-top:5px;font-weight:600}
  .hnav{display:flex;align-items:center;gap:14px;margin-left:auto}
  /* ============ MAIN NAV ============ */
  .mainnav{display:flex;align-items:center;gap:4px;margin-left:28px}
  .navlink{position:relative;background:none;border:none;font-family:inherit;font-size:13.5px;font-weight:600;
    letter-spacing:.005em;color:var(--muted);cursor:pointer;padding:9px 14px;border-radius:9px;
    display:inline-flex;align-items:center;gap:6px;transition:color .25s,background .25s}
  .navlink:hover{color:var(--txt);background:var(--card)}
  .navlink.active{color:var(--accent)}
  .navlink .chev{width:11px;height:11px;transition:transform .25s var(--ease)}
  .navitem{position:relative}
  .navitem:hover .chev,.navitem:focus-within .chev{transform:rotate(180deg)}
  .submenu{position:absolute;top:calc(100% + 10px);left:0;min-width:214px;background:var(--card);
    border:1px solid var(--line2);border-radius:15px;box-shadow:var(--shadow);padding:8px;
    opacity:0;visibility:hidden;transform:translateY(-10px) scale(.97);transform-origin:top left;
    transition:opacity .24s var(--ease),transform .24s var(--ease),visibility .24s}
  .navitem:hover .submenu,.navitem:focus-within .submenu{opacity:1;visibility:visible;transform:none}
  .submenu a{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:11px 14px;
    border-radius:11px;font-size:14px;font-weight:600;color:var(--txt);text-decoration:none;cursor:pointer;
    transition:background .2s,color .2s,padding .2s}
  .submenu a::after{content:"→";opacity:0;transform:translateX(-6px);transition:opacity .2s,transform .2s;font-weight:700}
  .submenu a:hover{background:var(--accent-soft);color:var(--accent);padding-left:17px}
  .submenu a:hover::after{opacity:1;transform:none}
  .submenu a.active{color:var(--accent)}

  /* ============ BURGER + DRAWER (mobile) ============ */
  .burger{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;
    width:44px;height:44px;border:1px solid var(--line2);border-radius:13px;background:var(--card);cursor:pointer;padding:0;
    box-shadow:0 3px 10px -6px rgba(0,0,0,.4);transition:border-color .3s,box-shadow .3s,background .3s}
  .burger:hover{border-color:var(--accent)}
  .burger span{width:19px;height:2px;background:var(--txt);border-radius:2px;
    transition:transform .3s var(--ease),opacity .2s,background .3s}
  .burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .burger.open span:nth-child(2){opacity:0}
  .burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .drawer{position:fixed;inset:0;z-index:150}
  .drawer[hidden]{display:none}
  .drawer-bg{position:absolute;inset:0;background:rgba(4,6,10,.5);backdrop-filter:blur(4px);animation:fade .3s ease}
  .drawer-panel{position:absolute;top:0;right:0;height:100%;width:min(86vw,360px);background:var(--bg);
    border-left:1px solid var(--line2);box-shadow:var(--shadow);padding:72px 26px 30px;overflow-y:auto;
    display:flex;flex-direction:column;gap:22px;animation:slideIn .4s var(--ease-out)}
  @keyframes slideIn{from{transform:translateX(100%)}to{transform:none}}
  .drawer .dclose{position:absolute;top:18px;right:20px;background:none;border:none;font-size:30px;
    color:var(--muted);cursor:pointer;line-height:1;transition:color .2s}
  .drawer .dclose:hover{color:var(--accent)}
  .dgroup{display:flex;flex-direction:column;gap:2px;padding-bottom:22px;border-bottom:1px solid var(--line)}
  .dgroup:last-child{border-bottom:none;padding-bottom:0}
  .dlabel{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--faint);font-weight:600;margin-bottom:10px}
  .drow{font-size:18px;font-weight:700;color:var(--txt);text-decoration:none;padding:9px 0;cursor:pointer;transition:color .2s}
  .drow:hover,.drow.active{color:var(--accent)}
  .dtoggle{align-self:flex-start}
  .dcontact a{display:block;font-size:15px;color:var(--muted);text-decoration:none;padding:5px 0;transition:color .2s}
  .dcontact a:hover{color:var(--accent)}

  @media (max-width:960px){
    .mainnav{display:none}
    .hnav .toggle{display:none}
    .burger{display:flex}
    .callbtn span{display:none}
    .callbtn{padding:11px}
    .hnav{gap:10px}
  }
  .toggle{display:flex;border:1px solid var(--line);border-radius:40px;padding:3px;background:var(--card)}
  .toggle button{
    border:none;background:transparent;color:var(--muted);padding:7px 15px;border-radius:30px;
    font-family:inherit;font-size:11px;letter-spacing:.08em;font-weight:600;cursor:pointer;
    transition:color .3s,background .3s;
  }
  .toggle button.on{background:var(--accent);color:#fff;font-weight:700}
  .callbtn{
    display:inline-flex;align-items:center;gap:9px;padding:11px 19px;border-radius:40px;
    background:var(--accent);color:#fff;text-decoration:none;font-size:12.5px;letter-spacing:.04em;font-weight:700;
    transition:transform .35s var(--ease),box-shadow .35s var(--ease);
    box-shadow:0 8px 22px -10px var(--accent);
  }
  .callbtn:hover{transform:translateY(-2px);box-shadow:0 14px 30px -10px var(--accent)}
  .callbtn svg{width:14px;height:14px}

  /* ============ CRUMBS ============ */
  .crumbs{border-bottom:1px solid var(--line)}
  .crumbs .inner{
    display:flex;align-items:center;gap:10px;max-width:1320px;margin:0 auto;
    padding:14px clamp(20px,4vw,56px);font-size:11.5px;letter-spacing:.11em;text-transform:uppercase;
    flex-wrap:wrap;font-weight:600;
  }
  .crumbs span[role=link]{color:var(--muted);cursor:pointer;transition:color .25s}
  .crumbs span[role=link]:hover{color:var(--accent)}
  .crumbs .cur{color:var(--txt)}
  .crumbs .sep{color:var(--faint)}

  main{flex:1;width:100%;max-width:1320px;margin:0 auto;padding:0 clamp(20px,4vw,56px)}
  #view{animation:viewIn .55s var(--ease-out) both}
  @keyframes viewIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

  /* reveal */
  [data-reveal]{opacity:0;transform:translateY(20px);
    transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
  [data-reveal].in{opacity:1;transform:none}

  /* ============ HOME ============ */
  .hero{padding:clamp(44px,7.5vh,92px) 0 64px;position:relative}
  .hero::before{content:"";position:absolute;top:-40px;left:-10%;width:60%;height:380px;
    background:radial-gradient(50% 50% at 50% 50%,var(--accent-soft),transparent 70%);
    filter:blur(20px);pointer-events:none;z-index:-1}
  .hero h1{font-size:clamp(38px,6.4vw,82px);font-weight:800;letter-spacing:-.025em;line-height:1.0;max-width:15ch}
  .hero h1 .em{color:var(--accent)}
  .hero p{margin-top:24px;max-width:58ch;font-size:clamp(16px,1.5vw,19px);line-height:1.62;color:var(--muted)}
  .pickgrid{display:flex;gap:20px;flex-wrap:wrap;margin-top:50px}
  .bigcard{
    position:relative;flex:1 1 420px;min-height:clamp(440px,58vh,620px);border-radius:8px;overflow:hidden;
    cursor:pointer;border:1px solid var(--line);box-shadow:var(--shadow);background:var(--card);isolation:isolate;
  }
  .bigcard .bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
    transition:transform 1.1s var(--ease);will-change:transform}
  .bigcard:hover .bg{transform:scale(1.07)}
  .bigcard .scrim{position:absolute;inset:0;
    background:linear-gradient(180deg,rgba(8,8,10,.04) 0%,rgba(8,8,10,.16) 40%,rgba(8,8,10,.88) 100%)}
  .bigcard .cap{position:absolute;left:0;right:0;bottom:0;padding:36px 34px;color:#fff}
  .bigcard .cap .k{font-size:11.5px;letter-spacing:.24em;font-weight:600;color:rgba(255,255,255,.72);text-transform:uppercase}
  .bigcard .cap .row{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-top:12px}
  .bigcard h2{font-size:clamp(28px,3.6vw,46px);font-weight:800;letter-spacing:-.015em;line-height:1}
  .bigcard .go{font-size:13px;letter-spacing:.06em;white-space:nowrap;border-bottom:2px solid var(--accent);
    padding-bottom:4px;font-weight:600;display:inline-flex;gap:7px;align-items:center}
  .bigcard .go .ar{transition:transform .4s var(--ease)}
  .bigcard:hover .go .ar{transform:translateX(6px)}

  /* ============ SUB ============ */
  .sub h1{font-size:clamp(30px,4.6vw,54px);font-weight:800;letter-spacing:-.02em;line-height:1.04}
  .sub p{margin-top:18px;max-width:58ch;font-size:17px;line-height:1.6;color:var(--muted)}
  .subgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(330px,1fr));gap:20px;margin-top:44px}
  .subcard{position:relative;min-height:clamp(380px,48vh,500px);border-radius:8px;overflow:hidden;cursor:pointer;
    border:1px solid var(--line);box-shadow:var(--shadow);background:var(--card);isolation:isolate}
  .subcard .bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease)}
  .subcard:hover .bg{transform:scale(1.07)}
  .subcard .scrim{position:absolute;inset:0;
    background:linear-gradient(180deg,rgba(8,8,10,.04),rgba(8,8,10,.2) 40%,rgba(8,8,10,.9))}
  .subcard .cap{position:absolute;left:0;right:0;bottom:0;padding:32px;color:#fff}
  .subcard .cap .k{font-size:11px;letter-spacing:.22em;font-weight:600;color:rgba(255,255,255,.72);text-transform:uppercase}
  .subcard h2{font-size:clamp(26px,3vw,38px);font-weight:800;margin-top:10px;letter-spacing:-.01em}
  .subcard .d{margin-top:10px;max-width:34ch;font-size:14.5px;line-height:1.55;color:rgba(255,255,255,.8)}

  /* ============ GRID ============ */
  .gridhead{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:38px}
  .gridhead h1{font-size:clamp(30px,4.4vw,52px);font-weight:800;letter-spacing:-.02em;line-height:1.02;margin-top:12px}
  .back{font-size:12.5px;letter-spacing:.04em;color:var(--muted);cursor:pointer;
    border-bottom:1px solid var(--line2);padding-bottom:3px;transition:color .25s,border-color .25s;font-weight:600}
  .back:hover{color:var(--accent);border-color:var(--accent)}
  .cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:26px}
  .card{position:relative;border:1px solid var(--line);border-radius:7px;overflow:hidden;cursor:pointer;
    background:var(--card);transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .5s}
  .card:hover{transform:translateY(-7px);box-shadow:var(--shadow);border-color:var(--line2)}
  .card .ph{position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--card2)}
  .card .ph .im{position:absolute;inset:0;background-size:cover;transition:transform 1.1s var(--ease)}
  .card:hover .ph .im{transform:scale(1.08)}
  .card .badge{position:absolute;top:14px;left:14px;font-size:10px;letter-spacing:.16em;font-weight:600;color:#fff;
    background:rgba(10,10,12,.55);backdrop-filter:blur(6px);padding:6px 10px;border-radius:4px;text-transform:uppercase}
  .card .body{padding:20px 20px 22px}
  .card .body .k{font-size:10.5px;letter-spacing:.15em;color:var(--muted);text-transform:uppercase;font-weight:600}
  .card .body .row{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;margin-top:11px}
  .card h3{font-size:23px;font-weight:700;letter-spacing:-.01em;line-height:1.05}
  .card .price{text-align:right;white-space:nowrap}
  .card .price .pl{font-size:9px;letter-spacing:.18em;color:var(--faint);font-weight:600}
  .card .price .pv{font-size:20px;font-weight:700;line-height:1.1;margin-top:2px}
  .card .more{display:flex;align-items:center;gap:8px;margin-top:16px;font-size:11.5px;letter-spacing:.06em;
    color:var(--accent);font-weight:600}
  .card .more .ar{transition:transform .35s var(--ease)}
  .card:hover .more .ar{transform:translateX(5px)}

  /* ============ DETAIL ============ */
  .detail{padding:clamp(28px,4vh,48px) 0 84px}
  .dwrap{display:flex;gap:clamp(28px,4vw,60px);flex-wrap:wrap;align-items:flex-start}
  .dmedia{flex:1 1 440px;min-width:320px}
  .dhero{position:relative;aspect-ratio:4/5;border-radius:8px;overflow:hidden;border:1px solid var(--line);
    background:var(--card2);box-shadow:var(--shadow)}
  .dhero .im{position:absolute;inset:0;background-size:cover;animation:kb 14s ease-in-out infinite alternate}
  @keyframes kb{from{transform:scale(1.0)}to{transform:scale(1.06)}}
  .thumbs{display:flex;gap:12px;margin-top:14px;flex-wrap:wrap}
  .thumb{width:74px;height:90px;border-radius:5px;overflow:hidden;cursor:pointer;border:2px solid var(--line);
    opacity:.7;transition:opacity .3s,border-color .3s,transform .3s}
  .thumb:hover{transform:translateY(-2px)}
  .thumb.on{border-color:var(--accent);opacity:1}
  .thumb .im{width:100%;height:100%;background-size:cover}
  .dinfo{flex:1 1 420px;min-width:320px}
  .dinfo h1{font-size:clamp(34px,4.4vw,56px);font-weight:800;letter-spacing:-.02em;line-height:1;margin-top:14px}
  .pricebox{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-top:22px}
  .pricebox .vp{display:flex;align-items:baseline;gap:12px;padding:14px 20px;border:1px solid var(--line);
    border-radius:6px;background:var(--card)}
  .pricebox .vp .l{font-size:10px;letter-spacing:.2em;color:var(--faint);font-weight:600}
  .pricebox .vp .v{font-size:32px;font-weight:800;color:var(--accent);letter-spacing:-.01em}
  .pricebox .upit{padding:14px 20px;border:1px solid var(--line);border-radius:6px;background:var(--card);
    font-size:12px;letter-spacing:.1em;color:var(--txt);font-weight:600}
  .dblurb{margin-top:24px;font-size:17px;line-height:1.65;color:var(--muted);max-width:52ch}
  .specs{margin-top:34px}
  .specs .h{font-size:11px;letter-spacing:.22em;color:var(--faint);padding-bottom:14px;
    border-bottom:1px solid var(--line2);font-weight:600;text-transform:uppercase}
  .specgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));column-gap:40px}
  .spec{display:flex;justify-content:space-between;gap:18px;padding:12px 0;border-bottom:1px solid var(--line)}
  .spec .k{font-size:11.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);white-space:nowrap;font-weight:600}
  .spec .v{font-size:14px;font-weight:500;text-align:right}
  .cta{display:flex;flex-wrap:wrap;gap:11px;margin-top:34px}
  .cta a,.cta button{display:inline-flex;align-items:center;gap:8px;padding:15px 23px;border-radius:6px;text-decoration:none;
    font-family:inherit;font-size:12.5px;letter-spacing:.04em;font-weight:600;cursor:pointer;border:none;background:none;
    transition:transform .3s var(--ease),background .3s,border-color .3s}
  .cta a:hover,.cta button:hover{transform:translateY(-2px)}
  .cta .primary{background:var(--accent);color:#fff;font-weight:700;box-shadow:0 10px 26px -12px var(--accent)}
  .cta .ghost{border:1px solid var(--line2);color:var(--txt)}
  .cta .ghost:hover{border-color:var(--accent);color:var(--accent)}
  .dnote{margin-top:18px;font-size:12.5px;line-height:1.6;color:var(--faint);max-width:52ch}

  /* ============ FOOTER ============ */
  footer{border-top:1px solid var(--line);background:var(--bg2);margin-top:auto}
  .fgrid{max-width:1320px;margin:0 auto;padding:54px clamp(20px,4vw,56px) 40px;
    display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:36px}
  .fgrid .ft{font-size:10.5px;letter-spacing:.2em;color:var(--faint);margin-bottom:14px;font-weight:600;text-transform:uppercase}
  .fgrid .fb b{font-weight:800;font-size:18px;letter-spacing:.16em}
  .fgrid .fb p{margin-top:16px;font-size:14px;line-height:1.6;color:var(--muted);max-width:30ch}
  .fcol a{display:block;color:var(--txt);text-decoration:none;font-size:14px;margin-bottom:8px;transition:color .25s}
  .fcol a:hover{color:var(--accent)}
  .fcol .mail{color:var(--muted);margin-top:4px}
  .fcol p{font-size:14px;line-height:1.65;color:var(--txt)}
  .fcol .hours{font-size:13px;line-height:1.6;color:var(--muted);margin-top:12px}
  .fcol .web{font-size:15px;color:var(--accent);font-weight:600;text-decoration:none}
  .copy{border-top:1px solid var(--line);padding:18px clamp(20px,4vw,56px);font-size:10.5px;letter-spacing:.12em;
    color:var(--faint);text-align:center;font-weight:600}

  /* ============ INTRO (door opening) ============ */
  #intro{position:fixed;inset:0;z-index:200;pointer-events:none;overflow:hidden}
  #intro .panel{position:absolute;top:0;height:100%;width:50.6%;
    transition:transform 1.05s cubic-bezier(.5,.05,.22,1)}
  #intro .panel.l{left:0;background:linear-gradient(100deg,#070708,#17171b)}
  #intro .panel.r{right:0;background:linear-gradient(260deg,#070708,#17171b)}
  #intro .intrologo{position:absolute;top:50%;left:50%;z-index:3;transform:translate(-50%,-50%)}
  /* Pure transitions (NOT keyframe animation): forwards-fill would snap opacity instead of fading. */
  #intro .il-inner{display:flex;flex-direction:column;align-items:center;gap:18px;
    opacity:0;transform:translateY(16px);
    transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
  #intro .il-inner.in{opacity:1;transform:translateY(0)}
  #intro .intrologo img{height:clamp(38px,6vw,54px);width:auto;display:block;
    filter:drop-shadow(0 8px 30px rgba(0,0,0,.5))}
  #intro .introtag{font-size:clamp(9.5px,1.4vw,12px);font-weight:600;letter-spacing:.26em;
    text-transform:uppercase;color:#e1232e;opacity:0;transition:opacity .6s ease .25s;text-align:center}
  #intro .il-inner.in .introtag{opacity:1}
  /* Exit: stays put until doors START, then fades AS they open (.12s delay). Must come last to win the specificity tie with .in */
  #intro.go .il-inner{opacity:0;transform:translateY(-12px);
    transition:opacity .28s ease,transform .5s cubic-bezier(.5,.05,.22,1)}
  #intro.go .panel.l{transform:translateX(-101%)}
  #intro.go .panel.r{transform:translateX(101%)}
  #intro.done{display:none}

  /* ============ LOGO IMG ============ */
  .brandimg{height:42px;width:auto;display:block;transition:height .4s var(--ease)}
  header.scrolled .brandimg{height:36px}
  .flogo{height:38px;width:auto;display:block;margin-bottom:16px}

  /* ============ VP BUTTON ============ */
  .vpbtn{display:inline-flex;align-items:center;gap:8px;padding:9px 17px;border-radius:40px;
    border:1px solid var(--line2);background:var(--card);color:var(--txt);font-family:inherit;font-size:12.5px;
    letter-spacing:.03em;font-weight:600;cursor:pointer;box-shadow:0 3px 10px -6px rgba(0,0,0,.4);
    transition:border-color .3s,color .3s,background .3s,transform .3s,box-shadow .3s}
  .vpbtn .lock{width:14px;height:14px;flex:none;color:var(--accent);transition:color .3s}
  .vpbtn:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 18px -8px rgba(0,0,0,.3)}
  .vpbtn.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 8px 20px -8px var(--accent)}
  .vpbtn.active .lock{color:#fff}

  /* ============ MODAL ============ */
  .modal{position:fixed;inset:0;z-index:140;display:flex;align-items:center;justify-content:center;padding:20px}
  .modal[hidden]{display:none}
  .modal .mbg{position:absolute;inset:0;background:rgba(4,6,10,.62);backdrop-filter:blur(7px);animation:fade .3s ease}
  .dialog{position:relative;width:100%;max-width:410px;background:var(--card);border:1px solid var(--line2);
    border-radius:14px;padding:36px 32px 28px;box-shadow:var(--shadow);animation:pop .42s var(--ease-out)}
  @keyframes fade{from{opacity:0}to{opacity:1}}
  @keyframes pop{from{opacity:0;transform:translateY(18px) scale(.96)}to{opacity:1;transform:none}}
  .dialog .x{position:absolute;top:12px;right:16px;background:none;border:none;color:var(--muted);font-size:26px;
    cursor:pointer;line-height:1;transition:color .25s}
  .dialog .x:hover{color:var(--accent)}
  .dialog h3{font-size:25px;font-weight:800;letter-spacing:-.01em;margin-top:10px}
  .dialog>p{margin-top:12px;font-size:14px;line-height:1.55;color:var(--muted)}
  .dialog form{display:flex;gap:10px;margin-top:22px}
  .dialog input{flex:1;padding:13px 16px;border-radius:9px;border:1px solid var(--line2);background:var(--bg);
    color:var(--txt);font-family:inherit;font-size:15px;outline:none;transition:border-color .25s}
  .dialog input:focus{border-color:var(--accent)}
  .dialog form button{padding:13px 22px;border-radius:9px;border:none;background:var(--accent);color:#fff;
    font-family:inherit;font-weight:700;font-size:14px;cursor:pointer;transition:transform .25s}
  .dialog form button:hover{transform:translateY(-1px)}
  .dialog .err{margin-top:14px;font-size:13px;color:var(--accent);font-weight:600}
  .dialog .hint{margin-top:18px;font-size:12px;color:var(--faint);line-height:1.5}
  .vphint{display:inline-flex;align-items:center;gap:7px;margin-top:14px;font-size:12.5px;font-weight:600;
    letter-spacing:.02em;color:var(--accent);cursor:pointer;border-bottom:1px solid transparent;transition:border-color .25s}
  .vphint:hover{border-color:var(--accent)}

  /* ============ NAVY FOOTER (light mode helper color #001020) ============ */
  [data-theme="light"] footer{
    --bg2:#001020; --txt:#eef2f6; --muted:#9fb0bf; --faint:#6f8190;
    --line:rgba(255,255,255,.13); --accent:#ff3b46;
  }

  @media (max-width:600px){
    .header-inner{padding:13px 15px;gap:10px}
    header.scrolled .header-inner{padding:13px 15px}
    .hnav{gap:8px}
    .brandimg,header.scrolled .brandimg{height:32px}
    .vpbtn{padding:10px 13px;font-size:11.5px;gap:7px}
    .callbtn{padding:10px}
    .burger{width:42px;height:42px}
    .hero{padding-top:clamp(28px,5vh,44px)}
    .pickgrid{gap:14px;margin-top:34px}
    .bigcard{flex:1 1 100%;min-height:clamp(340px,52vh,440px)}
    .bigcard .cap{padding:26px 24px}
    .cta a,.cta button{flex:1 1 auto;justify-content:center}
    .dwrap{gap:26px}
    .dmedia,.dinfo{min-width:0;flex-basis:100%}
    .subgrid,.cards,.specgrid{grid-template-columns:1fr}
    .fgrid{gap:28px;padding-top:44px}
  }
  @media (max-width:380px){
    .vpbtn .vptxt{font-size:11px}
    .brandimg,header.scrolled .brandimg{height:29px}
    .header-inner{gap:8px}
  }
  @media (max-width:345px){
    .vpbtn .vptxt{display:none}
    .vpbtn{padding:10px}
    .brandimg,header.scrolled .brandimg{height:27px}
    .hnav{gap:7px}
  }
  @media (prefers-reduced-motion:reduce){
    *{animation-duration:.001ms!important;transition-duration:.001ms!important}
    [data-reveal]{opacity:1;transform:none}
    .dhero .im{animation:none}
  }

  /* ---------- ZATRAŽI PONUDU (modal po modelu) ---------- */
  .inqdialog{max-width:460px;text-align:left}
  .inqdialog form{display:block;margin-top:18px}
  .iq-model{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:16px;
    padding:12px 14px;border:1px solid var(--line);border-radius:11px;background:var(--bg2)}
  .iq-kc{font-size:12px;color:var(--muted)}
  .iq-price{font-weight:700;color:var(--accent)}
  .iq-price.muted{color:var(--faint);font-weight:600}
  .inqdialog input,.inqdialog textarea{width:100%;padding:12px 13px;border:1px solid var(--line2);border-radius:10px;
    background:var(--bg2);color:var(--txt);font:inherit;font-size:14px;margin-top:10px;outline:none;
    transition:border-color .15s,box-shadow .15s,background .15s}
  .inqdialog input:focus,.inqdialog textarea:focus{border-color:var(--accent);background:var(--card);box-shadow:0 0 0 3px rgba(194,14,42,.13)}
  .inqdialog input::placeholder,.inqdialog textarea::placeholder{color:var(--faint)}
  .inqdialog textarea{resize:vertical;min-height:74px}
  .iq-two{display:flex;gap:10px}
  .iq-two input{margin-top:10px}
  .iq-hint{font-size:11.5px;color:var(--faint);margin-top:9px}
  .iq-send{width:100%;margin-top:14px;padding:13px;border:none;border-radius:11px;background:var(--accent);color:#fff;
    font:inherit;font-size:14.5px;font-weight:700;cursor:pointer;transition:.2s var(--ease)}
  .iq-send:hover{filter:brightness(1.06);transform:translateY(-1px)}
  .iq-send:disabled{opacity:.6;cursor:default;transform:none}
  .iq-done{text-align:center;padding:14px 0 4px}
  .iq-check{width:54px;height:54px;margin:0 auto 16px;border-radius:50%;background:rgba(34,160,90,.14);
    color:#1f9d57;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:800}
  .iq-done h4{font-size:20px;font-weight:800}
  .iq-done p{margin-top:8px;color:var(--muted);font-size:14px;line-height:1.55}
  @media (max-width:560px){.iq-two{flex-direction:column;gap:0}}