/* ============================================================
   ZAMON — Apple Premium Store · shared stylesheet (multi-page)
   Design system + global nav (gnav) + footer (gfooter) + pages
   ============================================================ */
:root{
  --bg:#fbfbfd; --bg-alt:#f5f5f7; --surface:#ffffff;
  --text:#1d1d1f; --text-2:#6e6e73; --text-3:#86868b;
  --border:rgba(0,0,0,.12); --border-2:rgba(0,0,0,.06);
  --accent:#0071e3; --accent-2:#0077ed; --ok:#1aa251; --new:#bf4800;
  --media:linear-gradient(180deg,#ffffff 0%,#f1f1f4 100%);
  --shadow-sm:0 2px 10px rgba(0,0,0,.05); --shadow:0 8px 34px rgba(0,0,0,.09); --shadow-lg:0 26px 70px rgba(0,0,0,.16);
  --nav-bg:rgba(251,251,253,.82);
  --hero-bg:radial-gradient(120% 120% at 50% 0%,#1d1d29 0%,#06060a 60%);
  --r:18px; --r-lg:28px; --maxw:1180px; --ease:cubic-bezier(.2,.7,.2,1);
}
html[data-theme="dark"]{
  --bg:#000; --bg-alt:#0b0b0d; --surface:#161617;
  --text:#f5f5f7; --text-2:#a1a1a6; --text-3:#7d7d82;
  --border:rgba(255,255,255,.16); --border-2:rgba(255,255,255,.08);
  --accent:#2997ff; --accent-2:#3aa0ff;
  --media:linear-gradient(180deg,#fff 0%,#eef0f3 100%);
  --nav-bg:rgba(22,22,23,.82); --hero-bg:radial-gradient(120% 120% at 50% 0%,#23232e 0%,#000 62%);
  --shadow-sm:0 2px 10px rgba(0,0,0,.4); --shadow:0 10px 40px rgba(0,0,0,.55); --shadow-lg:0 30px 80px rgba(0,0,0,.7);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,"SF Pro Display","Inter","Helvetica Neue",Arial,sans-serif;
  line-height:1.5;letter-spacing:-.011em;overflow-x:hidden;-webkit-font-smoothing:antialiased;transition:background .5s var(--ease),color .5s var(--ease)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:5px}
:focus:not(:focus-visible){outline:none}
.skip-link{position:fixed;top:-60px;left:14px;z-index:3000;background:var(--accent);color:#fff;padding:11px 20px;border-radius:0 0 12px 12px;font-weight:600;font-size:.9rem;transition:top .2s}
.skip-link:focus{top:0}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
section{position:relative}
h1,h2,h3{letter-spacing:-.025em;line-height:1.06;font-weight:700}
::selection{background:var(--accent);color:#fff}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:1rem;padding:13px 26px;border-radius:980px;border:none;cursor:pointer;transition:.3s var(--ease);white-space:nowrap}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-2);transform:translateY(-2px);box-shadow:0 12px 30px rgba(0,113,227,.42)}
.btn-ghost{background:transparent;color:var(--accent);padding-left:6px;padding-right:6px}
.btn-ghost:hover{color:var(--accent-2)}
.btn-soft{background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--accent)}
.btn-soft:hover{background:color-mix(in srgb,var(--accent) 20%,transparent)}
.btn-dark{background:var(--text);color:var(--bg)}
.btn-dark:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.btn.lg{padding:16px 34px;font-size:1.08rem}
.link-arrow{color:var(--accent);font-weight:500;display:inline-flex;align-items:center;gap:4px}
.link-arrow:hover{color:var(--accent-2)}
/* tactile press feedback (Apple-style compression) */
.btn:active,.add:active,.icon-btn:active,.cfg-color:active,.cfg-opt:active,.cfg-mat:active,.cfg-thumb:active,.psw:active,.chip:active,.pn-buy:active,.faq-q:active,.lang button:active{transform:scale(.95);transition:transform .08s var(--ease)}
@media (prefers-reduced-motion:reduce){.btn:active,.add:active,.icon-btn:active,.cfg-color:active,.cfg-opt:active,.cfg-mat:active,.cfg-thumb:active,.psw:active,.chip:active,.pn-buy:active,.faq-q:active,.lang button:active{transform:none}}

/* ===== TOP BAR ===== */
.topbar{background:var(--bg-alt);color:var(--text-2);font-size:.8rem;padding:8px 16px;border-bottom:1px solid var(--border-2);position:relative;z-index:60;display:flex;justify-content:center;align-items:center;gap:14px;flex-wrap:wrap}
.topbar b{color:var(--text);font-weight:600}
.region{display:inline-flex;align-items:center;gap:6px;color:var(--text);font-weight:600}
.region .chk{color:var(--ok)}

/* ===== GLOBAL NAV (Apple-style) ===== */
header.gnav{position:sticky;top:0;z-index:1000}
.gnav-bar{backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);background:var(--nav-bg);border-bottom:1px solid var(--border-2)}
.gnav-in{display:flex;align-items:center;height:48px;max-width:1024px;margin:0 auto;padding:0 22px;gap:2px}
.gnav-logo{display:flex;align-items:center;gap:8px;font-weight:700;font-size:1.08rem;letter-spacing:-.03em;margin-right:auto;padding-right:8px}
.gnav-logo .mark{width:24px;height:24px;border-radius:6px;background:linear-gradient(135deg,#0a84ff,#30d5c8);display:grid;place-items:center;box-shadow:0 3px 10px rgba(10,132,255,.45)}
.gnav-logo .mark svg{width:76%;height:76%;display:block}
.gnav-links{display:flex;align-items:center;height:100%;margin:0 auto}
.gnav-links a{font-size:.8rem;color:var(--text-2);font-weight:400;padding:0 11px;height:100%;display:flex;align-items:center;transition:.2s;position:relative;white-space:nowrap}
.gnav-links a:hover{color:var(--text)}
.gnav-links a.active{color:var(--text);font-weight:600}
.gnav-right{display:flex;align-items:center;gap:2px;margin-left:auto}
.icon-btn{width:36px;height:36px;border-radius:50%;background:transparent;border:none;cursor:pointer;display:grid;place-items:center;color:var(--text);transition:.2s;position:relative}
.icon-btn:hover{background:color-mix(in srgb,var(--text) 8%,transparent)}
.icon-btn svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.lang{display:flex;background:color-mix(in srgb,var(--text) 7%,transparent);border-radius:30px;padding:3px;margin:0 2px}
.lang button{background:none;border:none;color:var(--text-2);font-size:.7rem;font-weight:700;padding:4px 7px;border-radius:30px;cursor:pointer;transition:.2s}
.lang button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}
.cart-count{position:absolute;top:-1px;right:-1px;min-width:16px;height:16px;border-radius:8px;background:var(--accent);color:#fff;font-size:.6rem;font-weight:700;display:grid;place-items:center;padding:0 4px;transform:scale(0);transition:.3s var(--ease)}
.cart-count.show{transform:scale(1)}
.burger{display:none}
/* mega-menu flyout */
.megamenu{position:absolute;left:0;right:0;top:100%;background:var(--nav-bg);backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid var(--border-2);overflow:hidden;max-height:0;transition:max-height .4s var(--ease)}
.megamenu.open{max-height:520px}
.mega-in{max-width:1024px;margin:0 auto;padding:26px 22px 38px;display:flex;gap:48px}
.mega-left{display:flex;gap:40px;flex-shrink:0}
.mega-col h5{font-size:.72rem;color:var(--text-3);font-weight:500;margin-bottom:13px}
.mega-col a.big{font-size:1.4rem;font-weight:700;letter-spacing:-.02em;display:block;margin-bottom:11px;color:var(--text)}
.mega-col a{display:block;font-size:.9rem;color:var(--text-2);margin-bottom:9px;transition:.2s;font-weight:500}
.mega-col a:hover{color:var(--accent)}
.mega-cards{flex:1;display:grid;grid-template-columns:repeat(auto-fill,minmax(118px,1fr));gap:14px;align-content:start}
.mega-card{text-align:center;padding:10px 6px;border-radius:14px;transition:.2s}
.mega-card:hover{background:var(--bg-alt)}
.mc-img{position:relative;height:92px;display:grid;place-items:center;margin-bottom:8px}
.mc-img img{max-height:88px;max-width:100%;object-fit:contain}
.mc-new{position:absolute;top:0;left:50%;transform:translateX(-50%);font-size:.56rem;font-weight:700;letter-spacing:.04em;color:var(--new)}
.mc-name{font-size:.82rem;font-weight:600;color:var(--text);transition:.2s;line-height:1.2}
.mega-card:hover .mc-name{color:var(--accent)}
.mc-price{font-size:.74rem;color:var(--text-2);margin-top:3px}

/* ===== HERO (brand / page) ===== */
.hero{background:var(--hero-bg);color:#f5f5f7;text-align:center;padding:74px 24px 0;overflow:hidden;position:relative}
.hero .blob{position:absolute;border-radius:50%;filter:blur(120px);opacity:.5;pointer-events:none}
.hero .b1{width:520px;height:520px;background:#0a84ff;top:-160px;left:50%;transform:translateX(-60%)}
.hero .b2{width:420px;height:420px;background:#5e5ce6;bottom:-160px;right:8%;opacity:.35}
.hero .b3{width:360px;height:360px;background:#bf5af2;top:30%;left:6%;opacity:.25}
.hero-eyebrow{font-size:.95rem;font-weight:600;color:#5ac8fa;margin-bottom:8px}
.hero h1{font-size:clamp(2.8rem,8vw,5.6rem);font-weight:800;letter-spacing:-.04em;margin-bottom:14px}
.hero .sub{font-size:clamp(1.1rem,2.6vw,1.55rem);color:#c7c7cc;max-width:600px;margin:0 auto 14px;font-weight:500}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:26px}
.hero-cta .btn-ghost{color:#5ac8fa}
.hero-img-stage{position:relative;max-width:620px;margin:0 auto;min-height:320px}
.hero-img-stage .glow{position:absolute;inset:0;background:radial-gradient(circle at 50% 55%,rgba(10,132,255,.4),transparent 60%);filter:blur(40px)}
.hero-img-stage img{position:relative;width:auto;max-height:620px;margin:0 auto;filter:drop-shadow(0 40px 70px rgba(0,0,0,.6));will-change:transform}
.hero-stats{display:flex;justify-content:center;gap:54px;flex-wrap:wrap;padding:30px 0 64px}
.hero-stats .num{font-size:2.1rem;font-weight:700;letter-spacing:-.03em;background:linear-gradient(120deg,#5ac8fa,#0a84ff);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-stats .lbl{font-size:.82rem;color:#a1a1a6;margin-top:2px}
.hero-logo{width:80px;height:80px;border-radius:22px;margin:0 auto 20px;background:linear-gradient(135deg,#0a84ff,#30d5c8);display:grid;place-items:center;box-shadow:0 16px 44px rgba(10,132,255,.55)}
.hero-logo svg{width:74%;height:74%}
.hero-chips{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin:2px 0 26px}
.hero-chip{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);color:#e8e8ed;font-size:.86rem;font-weight:500;padding:8px 15px;border-radius:980px;backdrop-filter:blur(8px)}
.hero-chip .ck{color:#30d5c8;font-weight:800}
.hero h1.brand{font-size:clamp(3.4rem,9vw,6rem);letter-spacing:-.045em;background:linear-gradient(120deg,#fff,#a9d6ff);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ===== PRODUCT SUB-NAV ===== */
.psubnav{position:sticky;top:48px;z-index:90;background:var(--nav-bg);backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid var(--border-2)}
.psubnav-in{max-width:1024px;margin:0 auto;padding:0 22px;height:52px;display:flex;align-items:center;gap:22px}
.psubnav .pn-name{font-size:1.2rem;font-weight:700;letter-spacing:-.02em;margin-right:auto}
.psubnav a{font-size:.84rem;color:var(--text-2);font-weight:500;transition:color .2s,font-weight .2s}
.psubnav a:not(.pn-buy){position:relative}
.psubnav a:hover{color:var(--text)}
.psubnav a.spy-active{color:var(--text);font-weight:600}
.psubnav a.spy-active::after{content:"";position:absolute;left:0;right:0;bottom:-3px;height:2px;border-radius:2px;background:var(--accent);animation:spyU .3s var(--ease)}
@keyframes spyU{from{transform:scaleX(0);opacity:0}to{transform:scaleX(1);opacity:1}}
.psubnav .pn-buy{background:var(--accent);color:#fff;padding:7px 17px;border-radius:980px;font-weight:600;font-size:.82rem}
.psubnav .pn-buy:hover{background:var(--accent-2);color:#fff}
@media (max-width:680px){.psubnav a:not(.pn-buy){display:none}.psubnav .pn-name{font-size:1.05rem}}

/* ===== HIGHLIGHTS carousel ===== */
.hl-card{flex:0 0 auto;width:min(88vw,1000px);height:600px;border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;background:var(--bg-alt);color:var(--text)}
.hl-card.dark{background:#0a0a0f;color:#f5f5f7}
.hl-h{padding:40px 44px 14px;text-align:center;font-size:clamp(1.3rem,2.4vw,1.95rem);font-weight:600;line-height:1.25;flex-shrink:0}
.hl-h b{color:#0a84ff;font-weight:600}
.hl-card.dark .hl-h b{color:#30d5c8}
.hl-img{flex:1;width:100%;object-fit:contain;min-height:0;padding:0 20px 20px}
@media (max-width:560px){.hl-card{height:480px}}
.hl-controls{display:flex;align-items:center;gap:14px;justify-content:center;margin-top:18px}
.hl-play{width:42px;height:42px;border-radius:50%;background:var(--surface);border:1px solid var(--border-2);box-shadow:var(--shadow-sm);display:grid;place-items:center;cursor:pointer;color:var(--text);flex-shrink:0}
.hl-play svg{width:15px;height:15px;fill:currentColor}

/* ===== MODEL hero + floating Buy pill ===== */
.mhero{position:relative;background:#000;color:#fff;min-height:90vh;display:flex;flex-direction:column;align-items:center;text-align:center;padding:26px 24px 0;overflow:hidden}
.mhero .mh-eyebrow{font-size:1rem;font-weight:600;letter-spacing:.01em;margin-bottom:2px;display:flex;align-items:center;gap:7px;justify-content:center;text-transform:uppercase}
.mhero h1{font-size:clamp(3rem,8.5vw,5.6rem);font-weight:700;letter-spacing:-.045em;margin-bottom:10px}
.mhero.light{background:var(--bg-alt);color:var(--text)}
.mhero .mh-img{max-height:64vh;width:auto;object-fit:contain;margin-top:auto;filter:drop-shadow(0 30px 60px rgba(0,0,0,.6))}
.mhero.light .mh-img{filter:drop-shadow(0 24px 50px rgba(0,0,0,.18))}
.buypill{position:fixed;bottom:22px;right:22px;z-index:200;display:flex;align-items:center;gap:14px;background:rgba(70,70,75,.62);backdrop-filter:saturate(180%) blur(16px);-webkit-backdrop-filter:saturate(180%) blur(16px);border:1px solid rgba(255,255,255,.2);border-radius:980px;padding:7px 7px 7px 20px;color:#fff;box-shadow:var(--shadow-lg);opacity:0;transform:translateY(20px);transition:.4s var(--ease);pointer-events:none}
.buypill.show{opacity:1;transform:none;pointer-events:auto}
.buypill .bp-price{font-size:.88rem;color:#f0f0f2;white-space:nowrap}
.buypill .bp-buy{background:var(--accent);color:#fff;border:none;border-radius:980px;padding:9px 22px;font-weight:600;font-size:.9rem;cursor:pointer}
.buypill .bp-buy:hover{background:var(--accent-2)}
@media(max-width:560px){.buypill{left:14px;right:14px;justify-content:space-between;bottom:14px}}

/* ===== EXPLORER (Take a closer look) ===== */
.xplor-sec{background:#000;color:#f5f5f7}
.xplor-sec .sec-head h2{color:#f5f5f7}
.xplor-sec .sec-head{padding:0 24px}
/* immersive alternating feature blocks (model pages) */
.mfeats{display:flex;flex-direction:column;gap:84px;max-width:1080px;margin:24px auto 0;padding:0 24px}
.mfeat{display:grid;grid-template-columns:1fr 1.05fr;align-items:center;gap:46px}
.mfeat.rev{direction:rtl}
.mfeat.rev>*{direction:ltr}
.mf-text h3{font-size:clamp(1.7rem,3.2vw,2.6rem);letter-spacing:-.025em;line-height:1.1;margin-bottom:16px;color:#f5f5f7}
.mf-text p{font-size:1.08rem;line-height:1.6;color:#c7c7cc;max-width:38ch}
.mf-media{border-radius:22px;overflow:hidden;background:#0e0e10}
.mf-media img{width:100%;display:block;transition:transform .6s var(--ease)}
.mfeat:hover .mf-media img{transform:scale(1.03)}
.mf-sw{display:flex;gap:11px;margin-top:24px}
.mf-sw .sw{width:30px;height:30px;border:1px solid rgba(255,255,255,.28);border-radius:50%;cursor:pointer;transition:.2s}
.mf-sw .sw:hover{transform:scale(1.12)}
.mf-sw .sw.active{box-shadow:0 0 0 2px #000,0 0 0 4px #fff}
@media(max-width:760px){.mfeats{gap:56px}.mfeat,.mfeat.rev{grid-template-columns:1fr;direction:ltr}.mf-media{order:-1}}
.xplor-acc{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:10px}
.xi-img{display:block;width:100%;max-height:420px;object-fit:contain;margin-top:16px;border-radius:14px}
.xplor-item{background:#1c1c1e;border-radius:16px;overflow:hidden;transition:background .3s}
.xplor-item .xi-head{display:flex;align-items:center;gap:12px;padding:15px 18px;cursor:pointer;font-weight:600;font-size:1rem}
.xplor-item .xi-ic{width:24px;height:24px;border-radius:50%;border:1.5px solid #86868b;display:grid;place-items:center;font-size:1.05rem;line-height:1;color:#86868b;flex-shrink:0;transition:.3s}
.xplor-item.open{background:#2a2a2c}
.xplor-item.open .xi-ic{background:#fff;color:#000;border-color:#fff}
.xplor-item .xi-body{max-height:0;overflow:hidden;transition:max-height .38s var(--ease)}
.xplor-item.open .xi-body{max-height:640px}
.xplor-item .xi-desc{padding:0 18px 16px;color:#c7c7cc;font-size:.92rem;line-height:1.55}
.xplor-item .xi-sw{display:flex;gap:10px;padding:0 18px 16px}
.xplor-item .xi-sw .sw{width:26px;height:26px;border:1px solid rgba(255,255,255,.25)}
.xplor-item .xi-sw .sw.active{box-shadow:0 0 0 2px #000,0 0 0 3.5px #fff}
.xplor-media{display:grid;place-items:center;min-height:560px;position:relative}
.xplor-media img{max-height:540px;width:auto;object-fit:contain;transition:opacity .3s}
@media(max-width:860px){.xplor{grid-template-columns:1fr;min-height:0}.xplor-media{order:-1;min-height:320px}.xplor-media img{max-height:300px}}

/* ===== TECH SPECS ===== */
.specs-grid{max-width:980px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:18px}
.spec-group{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r);padding:26px 28px}
.spec-group h3{font-size:1.15rem;margin-bottom:14px;letter-spacing:-.01em}
.spec-group dl{margin:0}
.spec-row{display:flex;justify-content:space-between;gap:18px;padding:11px 0;border-top:1px solid var(--border)}
.spec-row:first-child{border-top:none}
.spec-row dt{color:var(--text-2);font-size:.9rem;flex-shrink:0}
.spec-row dd{margin:0;text-align:right;font-weight:500;font-size:.9rem;color:var(--text)}
@media(max-width:760px){.specs-grid{grid-template-columns:1fr}}

/* ===== WHY (advantages) ===== */
.why-adv{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.why-adv .wa{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r);padding:32px}
.why-adv .wa-ic{font-size:1.9rem;margin-bottom:14px}
.why-adv .wa h4{font-size:1.15rem;font-weight:600;margin-bottom:7px}
.why-adv .wa p{font-size:.93rem;color:var(--text-2);line-height:1.55}
@media (max-width:860px){.why-adv{grid-template-columns:1fr}}

/* ===== PRODUCT HIGHLIGHTS (3 key spec cards) ===== */
.prod-feats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:8px}
.prod-feats{perspective:1100px}
.pf-card{position:relative;background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-lg);padding:40px 28px;text-align:center;overflow:hidden;transform:rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) translateY(var(--ty,0)) scale(var(--sc,1));transform-style:preserve-3d;transition:transform .3s cubic-bezier(.2,.7,.2,1),box-shadow .35s,border-color .35s}
.pf-card.tilting{transition:box-shadow .35s,border-color .35s}
.pf-card::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at var(--mx,50%) var(--my,0%),color-mix(in srgb,var(--accent) 16%,transparent),transparent 55%);opacity:0;transition:opacity .35s}
.pf-card:hover{--ty:-4px;--sc:1.012;box-shadow:0 22px 46px -24px rgba(0,0,0,.45);border-color:color-mix(in srgb,var(--accent) 35%,var(--border-2))}
.pf-card:hover::after{opacity:1}
.pf-ic,.pf-big,.pf-lbl{transform:translateZ(28px)}
.pf-ic{font-size:2.3rem;margin-bottom:16px;line-height:1}
.pf-big{font-size:1.45rem;font-weight:700;letter-spacing:-.02em;line-height:1.2;margin-bottom:8px;color:var(--text)}
.pf-lbl{font-size:.74rem;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.08em}
@media(max-width:760px){.prod-feats{grid-template-columns:1fr}}
/* ===== IN THE BOX ===== */
.witb-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:840px;margin:0 auto}
.witb-item{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r);padding:30px 18px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px;transition:transform .3s var(--ease),box-shadow .3s,border-color .3s}
.witb-item:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:color-mix(in srgb,var(--accent) 25%,var(--border-2))}
.witb-ic{width:62px;height:62px;border-radius:50%;background:var(--bg-alt);display:grid;place-items:center;font-size:1.7rem}
.witb-n{font-size:.92rem;font-weight:600;color:var(--text);line-height:1.3}
@media(max-width:560px){.witb-grid{grid-template-columns:1fr}}

/* ===== FEATURES (alternating photo+text) ===== */
.fstrip{display:flex;flex-direction:column;gap:26px}
.fblock{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:0;background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-lg);overflow:hidden;min-height:380px}
.fblock:nth-child(even){direction:rtl}
.fblock:nth-child(even)>*{direction:ltr}
.fb-text{padding:46px 50px}
.fb-text .fb-e{font-size:2rem;margin-bottom:14px}
.fb-text h3{font-size:clamp(1.5rem,2.6vw,2.1rem);letter-spacing:-.02em;line-height:1.1;margin-bottom:14px}
.fb-text p{font-size:1.02rem;color:var(--text-2);line-height:1.6;margin-bottom:20px}
.fb-link{display:inline-flex;align-items:center;gap:5px;color:var(--accent);font-weight:600;font-size:.95rem;transition:.2s}
.fb-link:hover{gap:9px;color:var(--accent-2)}
.fb-media{align-self:stretch;display:grid;place-items:center;background:var(--bg-alt);overflow:hidden}
.fb-media.dark{background:#000}
.fb-media img{width:100%;height:100%;object-fit:cover}
@media (max-width:760px){.fblock{grid-template-columns:1fr;min-height:0}.fblock:nth-child(even){direction:ltr}.fb-media{order:-1;min-height:300px}.fb-media img{height:300px}.fb-text{padding:34px 28px}}

/* ===== PAGE HERO (product pages, Apple style) ===== */
.phero{text-align:center;padding:54px 24px 0;overflow:hidden;position:relative}
.phero.dark{background:#000;color:#f5f5f7}
.phero.light{background:var(--bg-alt)}
.phero .pe{font-size:1rem;font-weight:600;color:var(--new);margin-bottom:6px}
.phero h1{font-size:clamp(3rem,8vw,5.2rem);font-weight:700;letter-spacing:-.04em;margin-bottom:8px}
.phero .psub{font-size:clamp(1.2rem,2.6vw,1.7rem);color:var(--text-2);font-weight:500;margin-bottom:6px}
.phero.dark .psub{color:#c7c7cc}
.phero .pprice{font-size:1rem;color:var(--text-2);margin-bottom:18px}
.phero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:22px}
.phero-img{max-height:520px;width:auto;margin:0 auto;object-fit:contain}
.phero-video{max-width:min(900px,92%);max-height:560px;border-radius:24px;display:block;background:#000}
.mh-video{border-radius:24px;background:#000;object-fit:contain}

/* ===== section heading ===== */
.sec{padding:90px 0}
.sec.alt{background:var(--bg-alt)}
.sec-head{text-align:center;max-width:680px;margin:0 auto 48px}
.sec-tag{font-size:.82rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);display:block;margin-bottom:12px}
.sec-head h2{font-size:clamp(2rem,4.4vw,3.2rem);font-weight:700;margin-bottom:14px}
.sec-head p{color:var(--text-2);font-size:1.1rem}

/* ===== LINEUP / carousel ===== */
.lineup-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:26px;flex-wrap:wrap;gap:10px}
.lineup-head h2{font-size:clamp(1.8rem,4vw,2.6rem)}
.carousel{position:relative}
.car-viewport{overflow:hidden;padding:8px 2px 12px}
.car-track{display:flex;gap:18px;transition:transform .45s var(--ease);touch-action:pan-y}
.car-track.dragging{transition:none;cursor:grabbing}
.lcard{flex:0 0 auto;width:300px;min-width:300px;background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-lg);padding:0;overflow:hidden;cursor:pointer;transition:.35s var(--ease);display:flex;flex-direction:column}
.lcard:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.lcard .lc-media{height:360px;position:relative;overflow:hidden}
.lcard .lc-media img{width:100%;height:100%;object-fit:contain;object-position:center;padding:10px;transition:.6s var(--ease)}
.lcard:hover .lc-media img{transform:scale(1.04)}
.lcard .lc-badge{position:absolute;top:16px;left:0;right:0;text-align:center;font-size:.78rem;font-weight:600;color:var(--new);z-index:2}
.lcard .lc-body{padding:6px 24px 26px;text-align:center}
.lcard .lc-sw{display:flex;gap:7px;justify-content:center;margin-bottom:14px;min-height:14px}
.sw{width:13px;height:13px;border-radius:50%;border:1px solid rgba(0,0,0,.18);cursor:pointer;transition:.2s;position:relative}
.sw.active{box-shadow:0 0 0 2px var(--bg),0 0 0 3.5px var(--accent)}
.lcard h3{font-size:1.5rem;margin-bottom:8px}
.lcard .lc-desc{font-size:.95rem;color:var(--text-2);margin-bottom:12px;min-height:44px}
.lcard .lc-price{font-size:.9rem;color:var(--text);font-weight:500}
.lcard .lc-price b{font-weight:600}
.car-arrow{position:absolute;top:46%;transform:translateY(-50%);width:42px;height:42px;border-radius:50%;background:var(--surface);border:1px solid var(--border-2);box-shadow:var(--shadow);display:grid;place-items:center;cursor:pointer;z-index:5;transition:.2s;color:var(--text)}
.car-arrow:hover{transform:translateY(-50%) scale(1.08)}
.car-arrow.disabled{opacity:.3;pointer-events:none}
.car-arrow.prev{left:-8px}.car-arrow.next{right:-8px}
.car-arrow svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.car-dots{display:flex;gap:8px;justify-content:center;margin-top:18px}
.dot{width:8px;height:8px;border-radius:50%;background:var(--border);cursor:pointer;transition:.25s}
.dot.active{background:var(--text-2);width:22px;border-radius:5px}

/* ===== CATALOG carousels ===== */
.cat-block{margin-bottom:64px}
.cat-block:last-child{margin-bottom:0}
.cat-block .cb-head{text-align:center;margin-bottom:6px}
.cat-block .cb-head h3{font-size:clamp(1.6rem,3vw,2.1rem)}
.pcard{flex:0 0 auto;width:300px;min-width:300px;background:var(--bg-alt);border:1px solid transparent;border-radius:var(--r-lg);padding:22px;display:flex;flex-direction:column;transition:.35s var(--ease);position:relative;cursor:pointer}
html[data-theme="dark"] .pcard{background:var(--surface)}
.pcard:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.pcard .media{height:230px;border-radius:14px;display:grid;place-items:center;margin-bottom:8px;position:relative;overflow:hidden}
.pcard .media img{max-height:200px;width:auto;object-fit:contain;transition:.5s var(--ease)}
.pcard:hover .media img{transform:scale(1.05)}
.pcard .media.media-fb::after{content:attr(data-fb);font-size:4.4rem}
.badge-top{text-align:center;font-size:.76rem;font-weight:600;color:var(--new);margin-bottom:4px;min-height:18px}
.pcard .p-sw{display:flex;gap:7px;justify-content:center;margin-bottom:12px;min-height:13px}
.pcard h3{font-size:1.18rem;font-weight:600;text-align:center;margin-bottom:6px}
.pcard .ptag{font-size:.85rem;color:var(--text-2);text-align:center;margin-bottom:14px;min-height:38px}
.pcard .p-price{text-align:center;font-size:1.05rem;font-weight:600;margin-bottom:14px}
.pcard .p-price small{display:block;font-size:.78rem;color:var(--text-3);font-weight:400;margin-top:2px}
.pcard .p-price .old{text-decoration:line-through;color:var(--text-3);font-weight:400;margin-left:6px;font-size:.85rem}
.pcard .p-actions{margin-top:auto;display:flex;gap:8px;justify-content:center}
.pcard .add{background:var(--accent);color:#fff;border:none;border-radius:980px;padding:9px 20px;font-size:.9rem;font-weight:600;cursor:pointer;transition:.25s}
.pcard .add:hover{background:var(--accent-2)}
.pcard .more{background:transparent;border:none;color:var(--accent);font-size:.9rem;font-weight:500;cursor:pointer;padding:9px 6px}
.toolbar{display:flex;align-items:center;gap:16px;justify-content:center;flex-wrap:wrap;margin-bottom:44px}
.filters{display:flex;gap:8px;flex-wrap:wrap}
.chip{background:var(--surface);border:1px solid var(--border);color:var(--text-2);padding:9px 18px;border-radius:980px;font-size:.88rem;font-weight:500;cursor:pointer;transition:.25s}
.chip:hover{color:var(--text)}
.chip.active{background:var(--text);color:var(--bg);border-color:var(--text)}
.search{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:980px;padding:9px 16px;min-width:220px}
.search svg{width:17px;height:17px;stroke:var(--text-3);fill:none;stroke-width:1.8}
.search input{border:none;background:none;outline:none;color:var(--text);font-size:.9rem;width:100%}
.empty-grid{text-align:center;color:var(--text-2);padding:50px 0;font-size:1.05rem}

/* ===== FEATURE banners ===== */
.feature{border-radius:var(--r-lg);overflow:hidden;display:grid;grid-template-columns:1fr 1fr;align-items:center;min-height:480px;position:relative}
.feature.dark{background:#000;color:#f5f5f7}.feature.light{background:var(--bg-alt)}
.feature .fc{padding:60px}
.feature .fc h2{font-size:clamp(2rem,3.6vw,2.9rem);margin-bottom:14px}
.feature .fc p{color:var(--text-2);font-size:1.08rem;max-width:420px;margin-bottom:22px}
.feature.dark .fc p{color:#a1a1a6}
.feature .fimg{height:100%;min-height:420px;display:grid;place-items:center;padding:30px}
.feature .fimg img{max-height:430px;width:auto;object-fit:contain}
.feature.right .fc{order:2}

/* ===== SERVICES ===== */
.services{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.srv{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r);padding:30px;transition:.35s var(--ease)}
.srv:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.srv .si{width:48px;height:48px;border-radius:13px;background:color-mix(in srgb,var(--accent) 14%,transparent);display:grid;place-items:center;margin-bottom:16px;color:var(--accent)}
.srv .si svg{width:24px;height:24px;stroke:currentColor;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.srv h4{font-size:1.15rem;font-weight:600;margin-bottom:6px}
.srv p{font-size:.92rem;color:var(--text-2)}

/* ===== TESTIMONIALS ===== */
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.tq{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r);padding:30px}
.tq .qs{font-size:.86rem;color:#f5a623;margin-bottom:12px}
.tq p{font-size:1.02rem;margin-bottom:20px;line-height:1.55}
.tq .who{display:flex;align-items:center;gap:12px}
.tq .av{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#0071e3,#42c8ff);color:#fff;display:grid;place-items:center;font-weight:700}
.tq .who b{font-size:.95rem;font-weight:600;display:block}
.tq .who span{font-size:.82rem;color:var(--text-2)}

/* ===== NEWSLETTER ===== */
.nl{background:linear-gradient(135deg,#0071e3 0%,#5e5ce6 60%,#bf5af2 120%);color:#fff;border-radius:var(--r-lg);padding:64px 40px;text-align:center;overflow:hidden}
.nl h2{font-size:clamp(1.9rem,3.6vw,2.8rem);margin-bottom:12px}
.nl p{max-width:520px;margin:0 auto 26px;color:rgba(255,255,255,.9)}
.nl-form{display:flex;gap:10px;max-width:460px;margin:0 auto;flex-wrap:wrap;justify-content:center}
.nl-form input{flex:1;min-width:200px;border:none;border-radius:980px;padding:15px 22px;font-size:1rem;outline:none}
.nl .btn-dark{background:#000;color:#fff}

/* ===== promo showcase ===== */
.promo{position:relative;border-radius:var(--r-lg);overflow:hidden;text-align:center;padding:46px 28px 0;min-height:540px;display:flex;flex-direction:column;align-items:center;background:var(--bg-alt);transition:.4s var(--ease);cursor:pointer;color:#1d1d1f}
.promo.full{min-height:600px}
.promo.dark{color:#f5f5f7}
.promo h3{font-size:clamp(1.9rem,3.4vw,2.7rem);margin-bottom:6px}
.promo .pt{font-size:1.06rem;color:#5f6066;margin-bottom:4px;font-weight:500}
.promo.dark .pt{color:#c7c7cc}
.promo .pnew{color:var(--new);font-weight:600;font-size:.82rem;margin-bottom:6px}
.promo-btns{display:flex;gap:12px;justify-content:center;margin:14px 0 6px;flex-wrap:wrap}
.promo .pimg{margin-top:auto;max-height:330px;width:auto;object-fit:contain;transition:.5s var(--ease);transform:translateY(var(--py,0)) scale(var(--sc,1))}
.promo:hover .pimg{--sc:1.03}
.showcase-2 .promo:nth-child(2){transition-delay:.1s}
/* ===== iPhone lineup row (Apple chapternav style) ===== */
.sc-lineup{margin-bottom:24px}
.sc-lineup-head{text-align:center;margin-bottom:18px}
.lr-title{font-size:clamp(2rem,5vw,3.2rem);font-weight:700;letter-spacing:-.035em;margin-bottom:6px}
.lineup-wrap{position:relative}
.lr-arrow{position:absolute;top:128px;transform:translateY(-50%);z-index:6;width:44px;height:44px;border-radius:50%;border:1px solid var(--border-2);background:var(--surface);box-shadow:var(--shadow);color:var(--text);cursor:pointer;display:grid;place-items:center;transition:transform .2s var(--ease),background .2s,opacity .25s}
.lr-arrow:hover{transform:translateY(-50%) scale(1.09);background:var(--bg-alt)}
.lr-arrow:active{transform:translateY(-50%) scale(.95)}
.lr-arrow.prev{left:2px}.lr-arrow.next{right:2px}
.lr-arrow svg{width:20px;height:20px}
.lr-arrow[hidden]{display:none}
.lineup-row{display:flex;gap:6px;justify-content:flex-start;overflow-x:auto;padding:10px 4px 14px;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch}
.lineup-row{scrollbar-width:none}.lineup-row::-webkit-scrollbar{display:none}
@media(min-width:1000px){.lineup-row{justify-content:center}}
.lr-item{flex:0 0 auto;width:186px;display:flex;flex-direction:column;align-items:center;text-align:center;padding:14px 10px;border-radius:20px;scroll-snap-align:center;transition:background .3s var(--ease),transform .3s var(--ease);color:var(--text)}
.lr-item:hover{background:var(--bg-alt)}
.lr-media{position:relative;width:100%;height:210px;display:grid;place-items:center;background:#fff;border-radius:16px;margin-bottom:14px;overflow:hidden}
.lr-media img{max-height:190px;max-width:90%;object-fit:contain;transition:transform .45s var(--ease)}
.lr-item:hover .lr-media img{transform:scale(1.06)}
.lr-new{position:absolute;top:10px;left:50%;transform:translateX(-50%);color:var(--new);font-size:.66rem;font-weight:700;letter-spacing:.05em;z-index:1}
.lr-name{font-size:1.06rem;font-weight:600;margin-bottom:3px}
.lr-from{font-size:.8rem;color:var(--text-2);margin-bottom:9px}
.lr-cta{display:inline-flex;align-items:center;gap:2px;color:var(--accent);font-size:.85rem;font-weight:500;transition:.2s}
.lr-cta svg{width:13px;height:13px}
.lr-item:hover .lr-cta{color:var(--accent-2);gap:5px}
@media(max-width:560px){.lr-item{width:150px;padding:10px 6px}.lr-media{height:170px}.lr-media img{max-height:152px}.lr-arrow{top:104px;width:40px;height:40px}}
.promo.full .pimg{max-height:360px}
.showcase-2{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:20px}
.showcase-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:20px}
@media(max-width:860px){.showcase-3{grid-template-columns:1fr}}
.btn-pill{display:inline-flex;align-items:center;gap:6px;background:var(--accent);color:#fff;border:none;border-radius:980px;padding:10px 22px;font-weight:500;font-size:.95rem;cursor:pointer;transition:.25s}
.btn-pill:hover{background:var(--accent-2);transform:translateY(-1px)}
.btn-pill.ghost{background:transparent;color:var(--accent);border:1px solid color-mix(in srgb,var(--accent) 45%,transparent)}
.btn-pill.ghost:hover{background:color-mix(in srgb,var(--accent) 10%,transparent)}
.promo.dark .btn-pill.ghost{color:#5ac8fa;border-color:rgba(90,200,250,.5)}

/* ===== STORE BAR (all Apple products row) ===== */
.storebar-row{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.sb-item{text-align:center;padding:16px 8px;border-radius:18px;transition:.25s var(--ease);color:var(--text)}
.sb-item:hover{background:var(--bg-alt);transform:translateY(-4px)}
.sb-ic{height:100px;display:grid;place-items:center;margin-bottom:8px}
.sb-ic img{max-height:92px;max-width:100%;object-fit:contain}
.sb-item span{font-size:.9rem;font-weight:600}
@media(max-width:560px){.storebar-row{grid-template-columns:repeat(3,1fr);gap:6px}.sb-item{padding:12px 4px}.sb-ic{height:74px}.sb-ic img{max-height:68px}.sb-item span{font-size:.8rem}}

/* ===== BUY GRID (All models. Take your pick.) ===== */
.buy-grid-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;perspective:1300px}
.bgcard{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-lg);padding:30px 22px 26px;text-align:center;cursor:pointer;transform:rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) translateY(var(--ty,0)) scale(var(--sc,1));transform-style:preserve-3d;transition:transform .3s var(--ease),box-shadow .35s,border-color .35s;position:relative;display:flex;flex-direction:column;align-items:center}
.bgcard.tilting{transition:box-shadow .35s,border-color .35s}
.bgcard::before{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;z-index:0;background:radial-gradient(circle at var(--mx,50%) var(--my,0%),color-mix(in srgb,var(--accent) 12%,transparent),transparent 55%);opacity:0;transition:opacity .35s}
.bgcard:hover{--ty:-6px;--sc:1.01;box-shadow:var(--shadow-lg);border-color:color-mix(in srgb,var(--accent) 28%,var(--border-2))}
.bgcard:hover::before{opacity:1}
.bg-media,.bgcard h3,.bg-sw,.bg-price,.bgcard .add{position:relative;z-index:1}
.bg-new{position:absolute;top:16px;left:0;right:0;color:var(--new);font-weight:600;font-size:.74rem}
.bg-media{height:250px;display:grid;place-items:center;margin:8px 0 14px}
.bg-media img{max-height:240px;width:auto;object-fit:contain}
.bgcard h3{font-size:1.35rem;margin-bottom:14px}
.bg-sw{display:flex;gap:9px;justify-content:center;margin-bottom:16px;min-height:18px}
.bg-sw .sw{width:18px;height:18px}
.bg-price{font-size:.95rem;color:var(--text-2);margin-bottom:18px;line-height:1.5}
.bg-price small{display:block;color:var(--text-3);font-size:.82rem}
.bgcard .add{margin-top:auto;background:var(--accent);color:#fff;border:none;border-radius:980px;padding:11px 30px;font-size:.95rem;font-weight:600;cursor:pointer;transition:.25s}
.bgcard .add:hover{background:var(--accent-2)}
@media(max-width:860px){.buy-grid-cards{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.buy-grid-cards{grid-template-columns:1fr}}

/* ===== COMPARE MODELS table ===== */
.cmp-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
.cmp-table{width:100%;border-collapse:collapse;min-width:640px}
.cmp-table th,.cmp-table td{padding:14px 12px;text-align:center;border-bottom:1px solid var(--border-2);font-size:.92rem}
.cmp-table thead th{vertical-align:top;border-bottom:1px solid var(--border)}
.cmp-prod img{max-height:96px;width:auto;margin:0 auto 10px;object-fit:contain}
.cmp-prod span{display:block;font-weight:600;margin-bottom:10px}
.cmp-prod .add{background:var(--accent);color:#fff;border:none;border-radius:980px;padding:7px 16px;font-size:.82rem;font-weight:600;cursor:pointer}
.cmp-prod .add:hover{background:var(--accent-2)}
.cmp-lbl{text-align:left!important;color:var(--text-2);font-weight:600}

/* ===== compare table ===== */
.compare{max-width:740px;margin:0 auto;border:1px solid var(--border-2);border-radius:var(--r-lg);overflow:hidden;background:var(--surface);box-shadow:var(--shadow)}
.compare-row{display:grid;grid-template-columns:1.5fr 1fr 1fr;align-items:center;border-bottom:1px solid var(--border-2)}
.compare-row:last-child{border-bottom:none}
.compare-row>div{padding:15px 18px;font-size:.95rem}
.compare-row.head{font-weight:700;background:var(--bg-alt)}
.compare .c-label{font-weight:500}
.compare .c-z{text-align:center;font-weight:700;background:color-mix(in srgb,var(--accent) 8%,transparent)}
.compare-row.head .c-z{color:var(--accent)}
.compare .c-o{text-align:center;color:var(--text-3)}
.compare .yes{color:var(--ok);font-size:1.15rem}.compare .no{color:#ff3b30;font-size:1.15rem}

/* ===== CART PAGE ===== */
.cp-head{display:flex;align-items:baseline;gap:14px;margin-bottom:28px}
.cp-head h1{font-size:clamp(2rem,5vw,2.8rem);letter-spacing:-.02em}
.cp-head span{color:var(--text-2);font-size:1rem}
.cp-grid{display:grid;grid-template-columns:1fr 340px;gap:34px;align-items:start}
.cp-items{display:flex;flex-direction:column}
.cp-item{display:flex;align-items:center;gap:20px;padding:22px 0;border-top:1px solid var(--border)}
.cp-item:first-child{border-top:none}
.cp-img{width:96px;height:96px;border-radius:16px;background:var(--bg-alt);display:grid;place-items:center;flex-shrink:0;overflow:hidden}
.cp-img img{width:82%;height:82%;object-fit:contain}
.cp-info{flex:1;min-width:0}
.cp-info h3{font-size:1.12rem;font-weight:600;margin-bottom:3px}
.cp-info .cp-sub{font-size:.85rem;color:var(--text-2)}
.cp-info .cp-unit{font-size:.85rem;color:var(--text-3);margin:4px 0 8px}
.cp-rm{background:none;border:none;color:var(--accent);font-size:.85rem;font-weight:500;cursor:pointer;padding:0;font-family:inherit}
.cp-rm:hover{color:#ff3b30}
.cp-right{display:flex;flex-direction:column;align-items:flex-end;gap:12px;flex-shrink:0}
.cp-right .qty{display:flex;align-items:center;gap:14px;background:var(--bg-alt);border-radius:980px;padding:7px 14px}
.cp-right .qty button{background:none;border:none;font-size:1.1rem;cursor:pointer;color:var(--text);width:18px;line-height:1}
.cp-price{font-weight:700;font-size:1.05rem;white-space:nowrap}
.cp-sum{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-lg);padding:28px;position:sticky;top:80px}
.cp-sum h3{font-size:1.25rem;margin-bottom:18px}
.cp-row{display:flex;justify-content:space-between;color:var(--text-2);font-size:.95rem;padding:6px 0}
.cp-ship{display:flex;gap:7px;align-items:center;color:var(--ok);font-size:.86rem;font-weight:600;padding:10px 0;border-bottom:1px solid var(--border)}
.cp-grand{display:flex;justify-content:space-between;font-size:1.3rem;font-weight:700;margin:14px 0 18px}
.cp-sum .btn-primary{width:100%;justify-content:center;margin-bottom:12px}
.cp-cont{display:block;text-align:center;color:var(--accent);font-weight:600;font-size:.92rem}
.cp-cont:hover{color:var(--accent-2)}
.cp-empty{text-align:center;padding:80px 20px}
.cp-empty .ec-ico{font-size:3.4rem;margin-bottom:18px}
.cp-empty h2{font-size:1.6rem;margin-bottom:8px}
.cp-empty p{color:var(--text-2);margin-bottom:24px}
.cp-empty .btn{display:inline-flex}
@media(max-width:760px){.cp-grid{grid-template-columns:1fr}.cp-sum{position:static}.cp-img{width:74px;height:74px}}

/* ===== CHECKOUT (multi-step) ===== */
.ck-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:22px}
.ck-head h1{font-size:clamp(1.8rem,4vw,2.4rem);letter-spacing:-.02em}
.ck-cancel{color:var(--text-2);font-size:.9rem;font-weight:500}
.ck-cancel:hover{color:var(--accent)}
.ck-steps{display:flex;gap:10px;margin-bottom:30px;flex-wrap:wrap}
.ck-st{display:flex;align-items:center;gap:9px;font-size:.92rem;font-weight:600;color:var(--text-3);padding:8px 16px;border-radius:980px;background:var(--bg-alt);transition:.25s}
.ck-st .ck-stn{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;background:var(--border);color:var(--surface);font-size:.82rem}
.ck-st.active{color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,transparent)}
.ck-st.active .ck-stn{background:var(--accent);color:#fff}
.ck-st.done{color:var(--ok)}.ck-st.done .ck-stn{background:var(--ok);color:#fff}
.ck-grid{display:grid;grid-template-columns:1fr 340px;gap:34px;align-items:start}
.ck-fields{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:24px}
.ck-fields .field:nth-child(4),.ck-fields .field:nth-child(5){grid-column:1/-1}
.ck-q{font-size:1.15rem;font-weight:600;margin:6px 0 12px}
.ck-nav{display:flex;gap:12px;margin-top:26px}
.ck-nav .btn{flex:1;justify-content:center}
.ck-review{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.ck-rev-card{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r);padding:18px 20px}
.ck-rev-card.full{grid-column:1/-1}
.ck-rev-card h4{font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-3);margin-bottom:8px}
.ck-rev-card p{font-size:.95rem;line-height:1.5}
.ck-ri{display:flex;justify-content:space-between;font-size:.92rem;padding:6px 0;border-top:1px solid var(--border)}
.ck-ri:first-of-type{border-top:none}
.ck-sum{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-lg);padding:24px;position:sticky;top:80px}
.ck-sum h3{font-size:1.15rem;margin-bottom:16px}
.ck-sli{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}
.ck-sli-img{width:46px;height:46px;border-radius:10px;background:var(--bg-alt);display:grid;place-items:center;flex-shrink:0;overflow:hidden}
.ck-sli-img img{width:80%;height:80%;object-fit:contain}
.ck-sli-i{flex:1;min-width:0}
.ck-sli-i span{font-size:.9rem;font-weight:600;display:block}
.ck-sli-i small{font-size:.78rem;color:var(--text-2)}
.ck-sli b{font-size:.9rem;white-space:nowrap}
.ck-ship{display:flex;gap:7px;align-items:center;color:var(--ok);font-size:.84rem;font-weight:600;padding:12px 0}
.ck-done{max-width:520px;margin:30px auto;text-align:center;background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-lg);padding:44px 34px}
.ck-done .ok-ico{width:64px;height:64px;border-radius:50%;background:var(--ok);color:#fff;font-size:2rem;display:grid;place-items:center;margin:0 auto 18px}
.ck-done h1{font-size:1.8rem;margin-bottom:8px}
.ck-onum{color:var(--text-2);margin-bottom:6px}.ck-onum b{color:var(--text)}
.ck-done-total{display:flex;justify-content:space-between;max-width:280px;margin:22px auto;padding:14px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);font-size:1.1rem}
.ck-done-act{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
@media(max-width:760px){.ck-grid{grid-template-columns:1fr}.ck-sum{position:static;order:-1}.ck-fields{grid-template-columns:1fr}.ck-review{grid-template-columns:1fr}}

/* ===== ACCOUNT / AUTH ===== */
.acc-head{display:flex;align-items:baseline;gap:14px;margin-bottom:22px}
.acc-head h1{font-size:clamp(1.9rem,4.5vw,2.6rem);letter-spacing:-.02em}
.acc-head span{color:var(--text-2)}
.acc-tabs{display:flex;gap:8px;border-bottom:1px solid var(--border);margin-bottom:28px}
.acc-tab{background:none;border:none;font-family:inherit;font-size:.98rem;font-weight:600;color:var(--text-2);padding:10px 16px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:.2s}
.acc-tab:hover{color:var(--text)}
.acc-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.acc-profile{display:flex;align-items:center;gap:20px;background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-lg);padding:28px;margin-bottom:18px}
.acc-avatar{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#34c1ff);color:#fff;font-size:2rem;font-weight:700;display:grid;place-items:center;flex-shrink:0}
.acc-pinfo h3{font-size:1.3rem}.acc-pinfo p{color:var(--text-2);margin:2px 0 8px}
.acc-badge{display:inline-block;background:var(--bg-alt);color:var(--text-2);font-size:.78rem;font-weight:600;padding:4px 12px;border-radius:980px}
.acc-orders{display:flex;flex-direction:column;gap:16px}
.acc-order{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-lg);padding:20px 24px}
.ao-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px}
.ao-head b{font-size:1rem}.ao-head span{display:block;font-size:.84rem;color:var(--text-2);margin-top:2px}
.ao-status{background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--accent);font-size:.78rem;font-weight:600;padding:5px 12px;border-radius:980px}
.ao-items{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.ao-img{width:54px;height:54px;border-radius:12px;background:var(--bg-alt);display:grid;place-items:center;overflow:hidden}
.ao-img img{width:80%;height:80%;object-fit:contain}
.ao-foot{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--border);padding-top:12px;color:var(--text-2);font-size:.9rem}
.ao-foot b{color:var(--text);font-size:1.1rem}
.auth-card{max-width:420px;margin:20px auto;background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-lg);padding:34px}
.auth-tabs{display:flex;gap:6px;background:var(--bg-alt);border-radius:980px;padding:4px;margin-bottom:24px}
.auth-tabs button{flex:1;background:none;border:none;font-family:inherit;font-size:.92rem;font-weight:600;color:var(--text-2);padding:9px;border-radius:980px;cursor:pointer;transition:.2s}
.auth-tabs button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}
.auth-card h2{font-size:1.5rem;margin-bottom:4px}
.auth-card .msub{margin-bottom:22px}
.auth-switch{display:block;width:100%;text-align:center;background:none;border:none;color:var(--accent);font-family:inherit;font-size:.9rem;font-weight:600;margin-top:16px;cursor:pointer}
/* wishlist heart */
.wish-btn{position:absolute;top:14px;right:14px;z-index:4;width:34px;height:34px;border-radius:50%;border:none;background:var(--surface);box-shadow:var(--shadow-sm);color:var(--text-3);font-size:1rem;cursor:pointer;display:grid;place-items:center;transition:.2s;line-height:1}
.wish-btn:hover{transform:scale(1.12);color:#ff3b30}
.wish-btn.on{color:#ff3b30}
.wish-btn.pop{animation:heartPop .42s var(--ease)}
@keyframes heartPop{0%{transform:scale(1)}30%{transform:scale(1.45)}55%{transform:scale(.9)}100%{transform:scale(1)}}
@media (prefers-reduced-motion:reduce){.wish-btn.pop{animation:none}}
.pcard,.bgcard{position:relative}
/* product page swatches */
.prod-sw{display:flex;gap:11px;justify-content:center;margin:4px 0 6px;animation:heroUp .85s .34s var(--ease) both}
.psw{width:28px;height:28px;border-radius:50%;border:1px solid rgba(0,0,0,.18);cursor:pointer;padding:0;transition:.2s}
.psw:hover{transform:scale(1.12)}
.psw.active{box-shadow:0 0 0 2px var(--bg),0 0 0 4px var(--accent)}
.phero.dark .psw{border-color:rgba(255,255,255,.25)}
.phero.dark .psw.active{box-shadow:0 0 0 2px #000,0 0 0 4px #fff}
/* accessories grid */
.acc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.acc-grid .pcard{width:auto;min-width:0}
@media(max-width:980px){.acc-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:680px){.acc-grid{grid-template-columns:1fr 1fr}.acc-grid .pcard{width:auto;min-width:0}}

/* ===== TOOLS (compare / trade-in / calculator) ===== */
.ct-head{margin-bottom:24px}
.ct-head h1{font-size:clamp(1.9rem,4.5vw,2.6rem);letter-spacing:-.02em;margin-bottom:6px}
.sec-sub{color:var(--text-2);font-size:1.02rem}
.ct-cats{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:22px}
.ct-cat{padding:9px 18px;border:1.5px solid var(--border);border-radius:980px;font-family:inherit;font-size:.9rem;font-weight:600;color:var(--text-2);background:transparent;cursor:pointer;transition:.2s}
.ct-cat:hover{border-color:var(--text-3)}
.ct-cat.active{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--accent) 9%,transparent)}
.ct-pick-h{font-size:.86rem;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.04em;margin-bottom:12px}
.ct-pick-h span{color:var(--text-3);text-transform:none;letter-spacing:0;font-weight:500}
.ct-pick-grid{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:30px}
.ct-chip{display:flex;flex-direction:column;align-items:center;gap:6px;width:104px;padding:14px 8px;border:1.5px solid var(--border);border-radius:16px;background:var(--surface);cursor:pointer;transition:.2s;font-family:inherit}
.ct-chip img{height:54px;width:auto;object-fit:contain}
.ct-chip span{font-size:.78rem;font-weight:600;color:var(--text);text-align:center;line-height:1.2}
.ct-chip:hover{border-color:var(--text-3)}
.ct-chip.on{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 22%,transparent)}
.ct-hint{text-align:center;color:var(--text-2);padding:50px 20px;background:var(--bg-alt);border-radius:var(--r-lg);font-size:1.05rem}
.tools-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}
.tool-card{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-lg);padding:28px}
.tool-card h3{font-size:1.3rem;margin-bottom:14px}
.tool-lbl{display:block;font-size:.8rem;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.04em;margin:18px 0 10px}
.tool-select{width:100%;padding:13px 14px;border:1.5px solid var(--border);border-radius:12px;font-family:inherit;font-size:.95rem;background:var(--surface);color:var(--text);cursor:pointer}
.ti-conds{display:flex;gap:10px;flex-wrap:wrap}
.ti-cond{flex:1;min-width:90px;padding:11px 12px;border:1.5px solid var(--border);border-radius:12px;font-family:inherit;font-size:.88rem;font-weight:600;color:var(--text-2);background:transparent;cursor:pointer;transition:.2s}
.ti-cond:hover{border-color:var(--text-3)}
.ti-cond.active{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--accent) 9%,transparent)}
.ti-result{margin:22px 0 10px;padding:20px;background:var(--bg-alt);border-radius:16px;text-align:center}
.ti-result>span{font-size:.84rem;color:var(--text-2);font-weight:500}
.ti-amount{font-size:2.2rem;font-weight:800;letter-spacing:-.02em;color:var(--accent);margin-top:4px}
.ti-amount small{font-size:.9rem;font-weight:500;color:var(--text-2)}
.ti-note{font-size:.8rem;color:var(--text-3);line-height:1.5;margin-bottom:16px}
.calc-care{display:flex;align-items:center;gap:10px;margin:18px 0 4px;font-size:.92rem;font-weight:500;cursor:pointer}
.calc-care input{width:18px;height:18px;accent-color:var(--accent)}
.calc-total{display:flex;justify-content:space-between;align-items:center;margin-top:14px;padding-top:14px;border-top:1px solid var(--border);font-size:1rem}
.calc-total b{font-size:1.2rem}
@media(max-width:760px){.tools-grid{grid-template-columns:1fr}}

/* ===== SERVICE PAGES (support / contact / about) ===== */
.sup-cats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:60px}
.sup-cat{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-lg);padding:26px;transition:.3s var(--ease);display:block;color:var(--text)}
.sup-cat:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.sup-cat .sc-ic{font-size:2rem;margin-bottom:12px}
.sup-cat h4{font-size:1.2rem;margin-bottom:6px}
.sup-cat p{font-size:.92rem;color:var(--text-2);line-height:1.5}
.faq-wrap{max-width:780px;margin:0 auto 56px}
.faq-wrap h2{font-size:clamp(1.6rem,3.5vw,2.4rem);text-align:center;margin-bottom:24px}
.faq{display:flex;flex-direction:column;gap:10px}
.faq-item{background:var(--surface);border:1px solid var(--border-2);border-radius:16px;overflow:hidden}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:16px;padding:18px 22px;background:none;border:none;font-family:inherit;font-size:1.02rem;font-weight:600;color:var(--text);text-align:left;cursor:pointer}
.faq-ic{flex-shrink:0;width:22px;height:22px;position:relative}
.faq-ic::before,.faq-ic::after{content:"";position:absolute;background:var(--accent);border-radius:2px;transition:.3s var(--ease)}
.faq-ic::before{top:10px;left:3px;width:16px;height:2px}
.faq-ic::after{top:3px;left:10px;width:2px;height:16px}
.faq-item.open .faq-ic::after{transform:rotate(90deg);opacity:0}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s var(--ease)}
.faq-item.open .faq-a{max-height:260px}
.faq-a p{padding:0 22px 20px;color:var(--text-2);line-height:1.6;font-size:.96rem}
.sup-cta{text-align:center;background:var(--bg-alt);border-radius:var(--r-lg);padding:48px 24px;max-width:720px;margin:0 auto}
.sup-cta h3{font-size:1.6rem;margin-bottom:8px}
.sup-cta p{color:var(--text-2);margin-bottom:22px}
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:34px;align-items:start}
.contact-info{display:flex;flex-direction:column;gap:16px}
.ci-row{display:flex;gap:16px;align-items:flex-start;background:var(--surface);border:1px solid var(--border-2);border-radius:14px;padding:18px 20px}
.ci-ic{font-size:1.4rem}
.ci-h{font-size:.8rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-3);font-weight:600}
.ci-v{font-size:1.05rem;font-weight:500;margin-top:2px}
.contact-map{height:180px;border-radius:16px;background:linear-gradient(135deg,#dbe6f0,#c7d8ea);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:#3a5168;font-weight:600;position:relative;overflow:hidden}
.contact-map::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(0deg,rgba(255,255,255,.4) 0 1px,transparent 1px 28px),repeating-linear-gradient(90deg,rgba(255,255,255,.4) 0 1px,transparent 1px 28px)}
.contact-map .map-pin{font-size:2rem;position:relative;animation:heroUp .6s var(--ease) both}
.contact-map span{position:relative}
.contact-form{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-lg);padding:30px}
.contact-form h3{font-size:1.4rem;margin-bottom:18px}
.contact-form textarea{width:100%;padding:13px 14px;border:1.5px solid var(--border);border-radius:12px;font-family:inherit;font-size:.95rem;background:var(--surface);color:var(--text);resize:vertical}
.about-hero{text-align:center;max-width:760px;margin:10px auto 50px}
.about-hero h1{font-size:clamp(2rem,5vw,3.2rem);letter-spacing:-.03em;line-height:1.1;margin:10px 0 18px}
.about-hero p{font-size:1.1rem;color:var(--text-2);line-height:1.6}
.about-stats{display:flex;justify-content:center;gap:60px;flex-wrap:wrap;padding:36px 0 56px;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:56px}
.about-stats>div{text-align:center}
.about-stats .num{font-size:2.6rem;font-weight:800;letter-spacing:-.03em;background:linear-gradient(120deg,#5ac8fa,#0a84ff);-webkit-background-clip:text;background-clip:text;color:transparent}
.about-stats span{font-size:.86rem;color:var(--text-2)}
.about-vals{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:56px}
.about-val{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-lg);padding:32px}
.about-val .av-ic{font-size:2rem;margin-bottom:12px}
.about-val h3{font-size:1.25rem;margin-bottom:8px}
.about-val p{color:var(--text-2);line-height:1.55}
@media(max-width:860px){.sup-cats,.about-vals{grid-template-columns:1fr 1fr}.contact-grid{grid-template-columns:1fr}}
@media(max-width:560px){.sup-cats,.about-vals{grid-template-columns:1fr}.about-stats{gap:30px}}

/* ===== DRAWER (cart) ===== */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);backdrop-filter:blur(3px);z-index:1500;opacity:0;pointer-events:none;transition:.35s}
.overlay.open{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;right:0;width:420px;max-width:92vw;height:100%;background:var(--surface);border-left:1px solid var(--border-2);z-index:1600;transform:translateX(101%);transition:transform .45s var(--ease);display:flex;flex-direction:column}
.drawer.open{transform:none;box-shadow:var(--shadow-lg)}
.drawer-head{display:flex;justify-content:space-between;align-items:center;padding:22px 24px;border-bottom:1px solid var(--border-2)}
.drawer-head h3{font-size:1.3rem}
.close-x{background:none;border:none;color:var(--text);font-size:1.5rem;cursor:pointer;width:34px;height:34px;border-radius:50%;transition:.2s}
.close-x:hover{background:color-mix(in srgb,var(--text) 8%,transparent)}
.cart-items{flex:1;overflow-y:auto;padding:8px 24px}
.ci{display:flex;gap:14px;align-items:center;padding:16px 0;border-bottom:1px solid var(--border-2)}
.ci .ci-img{width:64px;height:64px;border-radius:12px;background:var(--media);display:grid;place-items:center;flex-shrink:0;overflow:hidden}
.ci .ci-img img{max-height:52px;width:auto;object-fit:contain}
.ci-info{flex:1;min-width:0}
.ci-info h4{font-size:.94rem;font-weight:600}
.ci-info .ci-sub{font-size:.8rem;color:var(--text-3)}
.ci-info .ci-price{color:var(--text-2);font-size:.85rem;margin-top:2px}
.ci-rm{background:none;border:none;color:var(--text-3);font-size:.78rem;cursor:pointer;margin-top:4px;padding:0}
.ci-rm:hover{color:#ff3b30}
.qty{display:flex;align-items:center;gap:6px;background:var(--bg-alt);border-radius:980px;padding:4px}
.qty button{width:26px;height:26px;border-radius:50%;background:var(--surface);border:1px solid var(--border-2);color:var(--text);font-size:1rem;cursor:pointer}
.qty span{min-width:18px;text-align:center;font-size:.9rem;font-weight:600}
.empty-cart{text-align:center;color:var(--text-2);margin-top:80px}
.empty-cart .ec-ico{font-size:3rem;margin-bottom:10px}
.drawer-foot{padding:20px 24px;border-top:1px solid var(--border-2)}
.ship-note{font-size:.8rem;color:var(--ok);margin-bottom:12px;display:flex;align-items:center;gap:6px}
.drawer-total{display:flex;justify-content:space-between;font-size:1.25rem;font-weight:700;margin-bottom:6px}
.drawer-sub{display:flex;justify-content:space-between;font-size:.84rem;color:var(--text-2);margin-bottom:14px}
.drawer-foot .btn{width:100%;justify-content:center;margin-bottom:8px}
.btn-clear{background:none;border:none;color:var(--text-3);font-size:.82rem;cursor:pointer;width:100%;padding:6px}
.btn-clear:hover{color:#ff3b30}

/* ===== MODAL (buy/checkout/info) ===== */
/* ===== SEARCH OVERLAY ===== */
.search-overlay{position:fixed;inset:0;z-index:1800;opacity:0;pointer-events:none;transition:.3s}
.search-overlay.open{opacity:1;pointer-events:auto}
.search-bg{position:absolute;inset:0;background:rgba(0,0,0,.4);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.search-panel{position:relative;background:var(--nav-bg);backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid var(--border-2);box-shadow:var(--shadow-lg);transform:translateY(-100%);transition:transform .4s var(--ease);max-height:86vh;overflow-y:auto}
.search-overlay.open .search-panel{transform:none}
.search-bar{max-width:720px;margin:0 auto;display:flex;align-items:center;gap:14px;padding:26px 22px 18px}
.search-bar .sb-ico{width:24px;height:24px;flex-shrink:0;fill:none;stroke:var(--text-3);stroke-width:2;stroke-linecap:round}
.search-bar input{flex:1;border:none;background:transparent;font-size:1.5rem;font-weight:500;color:var(--text);outline:none;font-family:inherit}
.search-bar input::placeholder{color:var(--text-3)}
.search-close{width:34px;height:34px;border-radius:50%;border:none;background:var(--bg-alt);color:var(--text-2);font-size:1rem;cursor:pointer;flex-shrink:0;transition:.2s}
.search-close:hover{background:var(--border);color:var(--text)}
.search-results{max-width:720px;margin:0 auto;padding:8px 22px 34px}
.search-sec{margin-bottom:22px}
.search-h{font-size:.74rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-3);margin-bottom:12px}
.search-quick{display:flex;gap:10px;flex-wrap:wrap}
.search-quick a{padding:8px 16px;border-radius:980px;background:var(--bg-alt);font-size:.9rem;font-weight:600;color:var(--text);transition:.2s}
.search-quick a:hover{background:var(--accent);color:#fff}
.search-grid{display:flex;flex-direction:column}
.search-row{display:flex;align-items:center;gap:16px;padding:12px 10px;border-radius:14px;transition:.18s}
.search-row:hover{background:var(--bg-alt)}
.sr-img{width:54px;height:54px;border-radius:12px;background:var(--bg-alt);display:grid;place-items:center;flex-shrink:0;overflow:hidden}
.sr-img img{width:80%;height:80%;object-fit:contain}
.sr-info{flex:1;min-width:0}
.sr-info h4{font-size:1rem;font-weight:600;margin:0}
.sr-info span{font-size:.82rem;color:var(--text-2);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sr-price{font-size:.9rem;font-weight:600;color:var(--text-2);white-space:nowrap}
.sr-arr{width:18px;height:18px;color:var(--text-3);flex-shrink:0}
.search-none{text-align:center;color:var(--text-2);padding:40px 0;font-size:1rem}
@media(max-width:560px){.search-bar input{font-size:1.2rem}.sr-info span{display:none}}

.modal-wrap{position:fixed;inset:0;z-index:1700;display:grid;place-items:center;padding:20px;opacity:0;pointer-events:none;transition:.3s}
.modal-wrap.open{opacity:1;pointer-events:auto}
.modal-wrap .mbg{position:absolute;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(4px)}
.modal{position:relative;background:var(--surface);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);transform:scale(.94);transition:.35s var(--ease);max-height:92vh;overflow-y:auto}
.modal-wrap.open .modal{transform:none}
.modal.checkout{max-width:460px;width:100%;padding:34px}
.modal.buy{max-width:880px;width:100%}
.mclose{position:absolute;top:14px;right:14px;z-index:6}
.buy-grid{display:grid;grid-template-columns:1.1fr 1fr}
.buy-media{background:var(--media);display:grid;place-items:center;padding:40px;min-height:420px;border-radius:var(--r-lg) 0 0 var(--r-lg)}
.buy-media.dark{background:radial-gradient(circle at 50% 45%,#1a1a20,#050507)}
.buy-media img{max-height:380px;width:auto;object-fit:contain;transition:.3s}
.buy-info{padding:40px 38px}
.buy-info .bnew{color:var(--new);font-weight:600;font-size:.85rem;margin-bottom:4px}
.buy-info h3{font-size:1.9rem;margin-bottom:6px}
.buy-info .bdesc{color:var(--text-2);font-size:.95rem;margin-bottom:20px}
.buy-info .blabel{font-size:.82rem;color:var(--text-2);font-weight:600;margin:18px 0 10px}
.color-opts{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.color-opt{display:flex;align-items:center;gap:10px;border:1.5px solid var(--border);border-radius:12px;padding:11px 13px;cursor:pointer;transition:.2s;font-size:.9rem;font-weight:500}
.color-opt:hover{border-color:var(--text-3)}
.color-opt.active{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 25%,transparent)}
.color-opt .cdot{width:22px;height:22px;border-radius:50%;border:1px solid rgba(0,0,0,.15);flex-shrink:0}
.buy-price{font-size:1.6rem;font-weight:700;margin:22px 0 4px}
.buy-mo{font-size:.86rem;color:var(--text-2);margin-bottom:20px}
.buy-perks{display:flex;gap:16px;margin:20px 0;padding:18px 0;border-top:1px solid var(--border-2);border-bottom:1px solid var(--border-2)}
.buy-perks .perk{flex:1;text-align:center;font-size:.74rem;color:var(--text-2);line-height:1.4}
.buy-perks .perk .pi{font-size:1.3rem;display:block;margin-bottom:5px}
.buy-actions{display:flex;gap:10px;margin-top:20px}
.buy-actions .btn{flex:1;justify-content:center}
.field{margin-bottom:14px}
.field label{display:block;font-size:.82rem;color:var(--text-2);margin-bottom:6px;font-weight:500}
.field input,.field select{width:100%;border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:12px;padding:13px 15px;font-size:.95rem;outline:none;transition:.2s}
.field input:focus,.field select:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 20%,transparent)}
.modal h3.co-title{font-size:1.5rem;margin-bottom:6px}
.modal .msub{color:var(--text-2);font-size:.92rem;margin-bottom:22px}
.modal .mtotal{display:flex;justify-content:space-between;font-size:1.05rem;font-weight:700;margin:18px 0;padding-top:16px;border-top:1px solid var(--border-2)}
.modal-success{text-align:center;padding:14px 0}
.modal-success .ok-ico{width:74px;height:74px;border-radius:50%;background:color-mix(in srgb,var(--ok) 16%,transparent);color:var(--ok);display:grid;place-items:center;margin:0 auto 18px;font-size:2.4rem}
.modal.info{max-width:640px;width:100%;padding:0;overflow:hidden}
.info-media{background:var(--media);display:grid;place-items:center;padding:30px;min-height:300px;position:relative}
.info-media.dark{background:radial-gradient(circle at 50% 45%,#1a1a20,#050507)}
.info-media img{max-height:280px;width:auto;object-fit:contain}
.info-body{padding:28px 32px 32px}
.info-body .inew{color:var(--new);font-weight:600;font-size:.82rem;margin-bottom:4px}
.info-body h3{font-size:1.7rem;margin-bottom:6px}
.info-body .isub{color:var(--text-2);margin-bottom:18px}
.info-feats{list-style:none;margin:0 0 22px;padding:0}
.info-feats li{display:flex;gap:10px;align-items:flex-start;padding:9px 0;border-bottom:1px solid var(--border-2);font-size:.95rem}
.info-feats li:last-child{border-bottom:none}
.info-feats li .fi{color:var(--accent);font-weight:800;flex-shrink:0}
.info-actions{display:flex;gap:10px}
.info-actions .btn{flex:1;justify-content:center}

/* ===== BUY CONFIGURATOR page ===== */
.cfg{display:grid;grid-template-columns:1.15fr .85fr;gap:40px;align-items:start;padding:40px 0 90px}
.cfg-stage{position:sticky;top:70px}
.cfg-media{background:var(--bg-alt);border-radius:var(--r-lg);min-height:560px;display:grid;place-items:center;padding:40px;position:relative;overflow:hidden}
.cfg-media img{max-height:480px;width:auto;object-fit:contain;transition:.35s var(--ease)}
.cfg-gallery-nav{display:flex;gap:14px;align-items:center;justify-content:center;margin-top:18px}
.cfg-gallery-nav .gdots{display:flex;gap:8px}
.cfg-arrow{width:40px;height:40px;border-radius:50%;background:var(--surface);border:1px solid var(--border-2);box-shadow:var(--shadow-sm);display:grid;place-items:center;cursor:pointer;color:var(--text);transition:.2s}
.cfg-arrow:hover{transform:scale(1.08)}
.cfg-panel h1{font-size:2.2rem;margin-bottom:4px}
.cfg-panel .cfg-tagline{color:var(--text-2);margin-bottom:24px}
.cfg-group{margin-bottom:28px}
.cfg-group .cfg-q{font-size:1.4rem;font-weight:600;margin-bottom:14px}
.cfg-group .cfg-q span{color:var(--text-3)}
.cfg-opt{display:flex;justify-content:space-between;align-items:center;gap:14px;border:1.5px solid var(--border);border-radius:14px;padding:15px 18px;cursor:pointer;transition:.2s;margin-bottom:10px}
.cfg-opt:hover{border-color:var(--text-3)}
.cfg-opt.active{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 22%,transparent)}
.cfg-opt .o-name{font-weight:600}
.cfg-opt .o-meta{font-size:.82rem;color:var(--text-2);margin-top:2px}
.cfg-opt .o-price{font-size:.82rem;color:var(--text-2);text-align:right;white-space:nowrap}
.cfg-colors{display:flex;gap:14px;flex-wrap:wrap}
.cfg-color{display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer}
.cfg-color .cc-dot{width:34px;height:34px;border-radius:50%;border:1px solid rgba(0,0,0,.15);transition:.2s}
.cfg-color.active .cc-dot{box-shadow:0 0 0 2px var(--bg),0 0 0 4px var(--accent)}
.cfg-color .cc-name{font-size:.74rem;color:var(--text-2)}
.cfg-summary{position:sticky;bottom:0;background:var(--surface);border-top:1px solid var(--border-2);padding:18px 0;margin-top:10px}
.cfg-summary .cfg-total{display:flex;justify-content:space-between;font-size:1.2rem;font-weight:700;margin-bottom:6px}
.cfg-summary .cfg-mo{font-size:.84rem;color:var(--text-2);margin-bottom:12px}
.cfg-summary .btn{width:100%;justify-content:center}
/* --- full configurator (P0.1) --- */
.cfg-top{grid-column:1/-1;display:flex;flex-direction:column;gap:16px;margin-bottom:6px}
.cfg-back{display:inline-flex;align-items:center;gap:5px;font-size:.85rem;font-weight:500;color:var(--text-2);transition:.2s;align-self:flex-start}
.cfg-back:hover{color:var(--accent)}
.cfg-models{display:flex;gap:10px;flex-wrap:wrap}
.cfg-mtab{padding:9px 17px;border:1.5px solid var(--border);border-radius:980px;font-size:.85rem;font-weight:600;cursor:pointer;transition:.2s;color:var(--text-2);background:transparent}
.cfg-mtab:hover{border-color:var(--text-3)}
.cfg-mtab.active{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--accent) 9%,transparent)}
.cfg-gallery{display:flex;flex-direction:column;gap:16px}
.cfg-bigimg{background:var(--bg-alt);border-radius:var(--r-lg);min-height:520px;display:grid;place-items:center;padding:36px;position:relative;overflow:hidden}
.cfg-bigimg img{max-height:448px;max-width:100%;object-fit:contain;transition:.35s var(--ease);animation:cfgImgIn .42s var(--ease)}
@keyframes cfgImgIn{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.cfg-bigimg img{animation:none}}
.cfg-gnav{position:absolute;top:50%;left:0;transform:translateY(-50%);width:100%;display:flex;justify-content:space-between;padding:0 14px;pointer-events:none}
.cfg-gnav .cfg-arrow{pointer-events:auto}
.cfg-thumbs{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}
.cfg-thumb{width:64px;height:64px;border-radius:14px;border:1.5px solid var(--border);background:var(--bg-alt);display:grid;place-items:center;cursor:pointer;overflow:hidden;transition:.2s;padding:0}
.cfg-thumb img{width:84%;height:84%;object-fit:contain}
.cfg-thumb:hover{border-color:var(--text-3)}
.cfg-thumb.active{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 22%,transparent)}
.cfg-q{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.cfg-opt .o-sub{font-size:.8rem;color:var(--text-2);margin-top:3px;line-height:1.35}
.cfg-curname{font-size:.86rem;color:var(--text-2);margin-top:12px;font-weight:500}
.cfg-banddot{display:inline-block;width:16px;height:16px;border-radius:50%;border:1px solid rgba(0,0,0,.15);margin-right:9px;vertical-align:-3px}
.cfg-help{margin-top:12px;background:var(--bg-alt);border-radius:12px;padding:0 16px}
.cfg-help summary{list-style:none;cursor:pointer;padding:13px 0;font-size:.88rem;font-weight:600;color:var(--accent);display:flex;align-items:center;gap:8px}
.cfg-help summary::-webkit-details-marker{display:none}
.cfg-help summary::before{content:"+";font-size:1.1rem;line-height:1;width:16px;text-align:center;transition:.25s}
.cfg-help[open] summary::before{content:"–"}
.cfg-help p{font-size:.86rem;color:var(--text-2);line-height:1.55;padding:0 0 15px 24px;margin:0}
.cfg-help[open] p{animation:cfgHelpOpen .3s var(--ease)}
@keyframes cfgHelpOpen{from{opacity:0;transform:translateY(-7px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.cfg-help[open] p{animation:none}}
.cfg-mat{border:1.5px solid var(--border);border-radius:14px;padding:16px 18px;cursor:pointer;transition:.2s;margin-bottom:10px}
.cfg-mat:hover{border-color:var(--text-3)}
.cfg-mat.active{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 22%,transparent)}
.cfg-mat .cm-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px}
.cfg-mat .cm-head b{font-size:1.05rem}
.cfg-mat .cm-from{font-size:.82rem;color:var(--text-2);margin-top:2px}
.cfg-mat .cm-desc{font-size:.85rem;color:var(--text-2);line-height:1.45;margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}
.cfg-sum-h{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-3);margin-bottom:10px}
.cfg-rows{margin-bottom:12px;border-bottom:1px solid var(--border);padding-bottom:10px}
.cfg-row{display:flex;justify-content:space-between;font-size:.9rem;color:var(--text-2);padding:4px 0}
.cfg-row.save{color:#34c759;font-weight:600}
.cfg-actions{display:flex;flex-direction:column;gap:10px}

/* ===== FOOTER (Apple-style directory) ===== */
.gfooter{background:var(--bg-alt);color:var(--text-2);font-size:.8rem;padding:0 0 22px}
.gf-in{max-width:1024px;margin:0 auto;padding:0 22px}
.gf-pitch{padding:18px 0;border-bottom:1px solid var(--border);font-size:.72rem;color:var(--text-3);line-height:1.6}
.gf-pitch b{color:var(--text-2);font-weight:600}
.gf-dir{display:grid;grid-template-columns:repeat(5,1fr);gap:26px;padding:22px 0}
.gf-col h5{font-size:.8rem;color:var(--text);font-weight:600;margin-bottom:10px}
.gf-col a{display:block;color:var(--text-2);font-size:.78rem;line-height:1.45;margin-bottom:7px;transition:.15s}
.gf-col a:hover{color:var(--text);text-decoration:underline}
.gf-brand{display:flex;align-items:center;gap:8px;font-weight:700;color:var(--text);font-size:1.05rem;margin-bottom:8px}
.gf-brand .mark{width:22px;height:22px;border-radius:6px;background:linear-gradient(135deg,#0a84ff,#30d5c8);display:grid;place-items:center}
.gf-brand .mark svg{width:76%;height:76%}
.gf-about{font-size:.76rem;line-height:1.6;max-width:230px;margin-bottom:12px}
.gf-socials{display:flex;gap:9px}
.gf-socials a{width:34px;height:34px;border-radius:10px;background:var(--surface);border:1px solid var(--border-2);display:grid;place-items:center;font-size:.95rem}
.gf-socials a:hover{transform:translateY(-2px)}
.gf-legal{border-top:1px solid var(--border);padding-top:18px;font-size:.72rem;color:var(--text-3);line-height:1.7}
.gf-legal .gf-row{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-top:8px}
.gf-legal .gf-links{display:flex;gap:14px;flex-wrap:wrap}
.gf-legal .gf-links a:hover{color:var(--text)}

/* ===== TOAST ===== */
.toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(140px);background:var(--text);color:var(--bg);padding:14px 24px;border-radius:980px;font-weight:600;font-size:.92rem;z-index:2000;transition:transform .45s var(--ease);box-shadow:var(--shadow-lg)}
.toast.show{transform:translateX(-50%) translateY(0)}

/* ===== reveal / mobile menu ===== */
.reveal{opacity:0;transform:translateY(32px);transition:.85s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal-scale{opacity:0;transform:scale(.9);transition:.9s var(--ease)}
.reveal-scale.in{opacity:1;transform:none}
/* staggered children in grids */
.why-adv .wa:nth-child(2),.services>*:nth-child(2),.specs-grid .spec-group:nth-child(2),.prod-feats .pf-card:nth-child(2){transition-delay:.08s}
.why-adv .wa:nth-child(3),.services>*:nth-child(3),.specs-grid .spec-group:nth-child(3),.prod-feats .pf-card:nth-child(3){transition-delay:.16s}
.services>*:nth-child(4),.specs-grid .spec-group:nth-child(4){transition-delay:.24s}
.services>*:nth-child(5){transition-delay:.32s}.services>*:nth-child(6){transition-delay:.4s}
.fstrip .fblock:nth-child(2){transition-delay:.06s}.fstrip .fblock:nth-child(3){transition-delay:.12s}

/* ===== HERO ENTRANCE ANIMATIONS (Apple-style on-load) ===== */
@keyframes heroUp{from{opacity:0;transform:translateY(38px)}to{opacity:1;transform:none}}
@keyframes heroZoom{from{opacity:0;transform:scale(1.14)}to{opacity:1;transform:none}}
@keyframes heroRise{from{opacity:0;transform:translateY(60px) scale(1.05)}to{opacity:1;transform:none}}
@keyframes heroFade{from{opacity:0}to{opacity:1}}
@keyframes heroFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.phero .pe{animation:heroUp .7s .05s var(--ease) both}
.phero h1{animation:heroUp .85s .14s var(--ease) both}
.phero .psub{animation:heroUp .85s .24s var(--ease) both}
.phero .pprice{animation:heroUp .85s .32s var(--ease) both}
.phero-cta{animation:heroUp .85s .4s var(--ease) both}
.phero-img{animation:heroRise 1.15s .18s var(--ease) both;will-change:transform,opacity}
.mhero .mh-eyebrow{animation:heroUp .7s .08s var(--ease) both}
.mhero h1{animation:heroUp .9s .18s var(--ease) both}
.mhero .mh-img{animation:heroZoom 1.25s .22s var(--ease) both;will-change:transform,opacity}
.hero>.reveal:not(.hero-img-stage)>*{animation:heroUp .9s var(--ease) both}
.hero>.reveal:not(.hero-img-stage)>.hero-logo{animation:heroZoom 1s var(--ease) both}
.hero>.reveal:not(.hero-img-stage)>.hero-eyebrow{animation-delay:.12s}
.hero>.reveal:not(.hero-img-stage)>h1{animation-delay:.2s}
.hero>.reveal:not(.hero-img-stage)>.sub{animation-delay:.3s}
.hero>.reveal:not(.hero-img-stage)>.hero-chips{animation-delay:.4s}
.hero>.reveal:not(.hero-img-stage)>.hero-cta{animation-delay:.5s}
.hero-img-stage img{animation:heroRise 1.2s .25s var(--ease) both,heroFloat 7s 1.7s ease-in-out infinite;will-change:transform,opacity}
/* scroll parallax (after entrance finishes) */
.phero-img.par{transform:translateY(var(--py,0))}
.mhero .mh-img.par{transform:translateY(var(--py,0))}
@media (prefers-reduced-motion:reduce){.promo .pimg,.phero-img.par,.mhero .mh-img.par{transform:none!important}}
.mobile-menu{position:fixed;inset:0;background:var(--bg);z-index:1400;display:flex;flex-direction:column;padding:80px 30px 30px;gap:6px;transform:translateY(-100%);transition:.4s var(--ease);overflow-y:auto}
.mobile-menu.open{transform:none}
.mobile-menu a{font-size:1.5rem;font-weight:600;padding:14px 0;border-bottom:1px solid var(--border-2)}

/* ===== responsive ===== */
@media (max-width:1024px){.services{grid-template-columns:repeat(3,1fr)}.buy-grid{grid-template-columns:1fr}.buy-media{border-radius:var(--r-lg) var(--r-lg) 0 0;min-height:300px}.buy-media img{max-height:260px}.cfg{grid-template-columns:1fr}.cfg-stage{position:static}.gf-dir{grid-template-columns:repeat(3,1fr)}}
@media (max-width:860px){.gnav-links{display:none}.burger{display:grid}.megamenu{display:none}.feature{grid-template-columns:1fr}.feature .fc{order:2;padding:40px}.feature.right .fc{order:2}.feature .fimg{min-height:300px}.feature .fimg img{max-height:300px}.services{grid-template-columns:1fr 1fr}.tgrid{grid-template-columns:1fr}.gf-dir{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.sec{padding:60px 0}.services{grid-template-columns:1fr}.showcase-2{grid-template-columns:1fr}.lcard,.pcard{width:80vw;min-width:80vw}.color-opts{grid-template-columns:1fr}.gf-dir{grid-template-columns:1fr 1fr}.hero-stats{gap:30px}}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}.car-track{scroll-behavior:auto}}
