:root{ --c-bg: #ffffff;
--c-bg-soft: #f5f7fb;
--c-bg-deep: #eef1f7;
--c-ink: #0b1220;
--c-ink-2: #2a3142;
--c-ink-3: #5a6478;
--c-ink-4: #8d97aa;
--c-line: #e3e8f1;
--c-line-2: #d3dae6;
--c-blue: #0b4dff;
--c-blue-deep: #0838c2;
--c-blue-soft: #e7eeff;
--c-blue-ink: #001b6e;
--c-orange: #ff6a13;
--c-orange-deep: #e55300;
--c-orange-soft: #fff1e6;
--c-green: #0a8754;
--c-green-soft: #e3f5ec;
--c-red: #d93545;
--c-red-soft: #fde7e9;
--c-amber: #c47a00;
--c-amber-soft: #fff4d6; --font-sans: "Inter", "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
--font-display: "Manrope", "Inter", sans-serif;
--font-mono: "JetBrains Mono", ui-monospace, monospace; --r-1: 4px;
--r-2: 8px;
--r-3: 12px;
--r-4: 16px;
--r-pill: 999px; --sh-1: 0 1px 2px rgba(11,18,32,.04), 0 0 0 1px rgba(11,18,32,.04);
--sh-2: 0 4px 12px rgba(11,18,32,.06), 0 0 0 1px rgba(11,18,32,.04);
--sh-3: 0 10px 30px rgba(11,18,32,.08), 0 0 0 1px rgba(11,18,32,.04);
--sh-blue: 0 8px 24px rgba(11,77,255,.18);
--sh-orange: 0 8px 24px rgba(255,106,19,.22); --max: 1280px;
--pad: 32px;
}
*,*:before,*:after{ box-sizing: border-box; }
html,body{ margin:0; padding:0; }
body{
font-family: var(--font-sans);
color: var(--c-ink);
background: var(--c-bg);
font-size: 15px;
line-height: 1.5;
-webkit-font-smoothing: antialiased;
text-rendering: optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color: inherit; text-decoration: none; }
button{ font-family: inherit; cursor: pointer; }
input,select,textarea{ font-family: inherit; } .container{ max-width: var(--max); margin: 0 auto; padding: 0 var(--pad); }
.muted{ color: var(--c-ink-3); }
.tiny{ font-size: 11px; letter-spacing: .04em; text-transform: uppercase; color: var(--c-ink-4); font-weight:600; }
.h1{ font-family: var(--font-display); font-size: 56px; line-height: 1.05; letter-spacing: -0.02em; font-weight: 800; margin: 0; }
.h2{ font-family: var(--font-display); font-size: 36px; line-height: 1.1; letter-spacing: -0.015em; font-weight: 800; margin: 0; }
.h3{ font-family: var(--font-display); font-size: 22px; line-height: 1.2; font-weight: 700; margin: 0; }
.h4{ font-family: var(--font-display); font-size: 17px; font-weight: 700; margin: 0; } .topbar{
background: var(--c-ink);
color: #cfd6e4;
font-size: 12.5px;
}
.topbar .container{ display:flex; align-items:center; justify-content:space-between; height:36px; gap: 24px; }
.topbar a{ color:#cfd6e4; }
.topbar a:hover{ color:#fff; }
.topbar .geo{ display:flex; align-items:center; gap:6px; }
.topbar .links{ display:flex; gap: 20px; align-items:center; }
.header{
position: sticky; top: 0; z-index: 50;
background: var(--c-bg);
border-bottom: 1px solid var(--c-line);
}
.header-row{ display:grid; grid-template-columns: auto 1fr auto; gap: 24px; align-items:center; padding: 14px 0; }
.brand{ display:flex; align-items:center; gap:10px; font-family: var(--font-display); font-weight: 800; font-size: 22px; letter-spacing:-.02em; }
.brand-mark{
width: 36px; height: 36px; border-radius: 9px;
background: var(--c-blue); position: relative;
display:grid; place-items:center;
box-shadow: var(--sh-blue);
}
.brand-mark::before{
content:""; width:18px; height:18px; border-radius: 4px;
background: var(--c-orange);
transform: rotate(45deg) translate(-2px,-2px);
}
.brand small{ display:block; font-size:10px; font-weight:600; color: var(--c-ink-3); letter-spacing:.06em; text-transform: uppercase; }
.search{
display:grid; grid-template-columns: auto 1fr auto; align-items:center;
background: var(--c-bg-soft);
border: 1px solid var(--c-line);
border-radius: var(--r-2);
height: 48px;
padding: 0 4px 0 14px;
gap: 10px;
}
.search:focus-within{ border-color: var(--c-blue); background:#fff; box-shadow: 0 0 0 3px var(--c-blue-soft); }
.search .cat-pick{ height: 40px; padding: 0 12px; border:0; background:#fff; border-radius: 6px; font-size: 13px; font-weight:600; color: var(--c-ink-2); appearance:none; cursor:pointer; }
.search input{ border:0; background:transparent; outline:none; height: 100%; font-size: 15px; }
.search .go{
height: 40px; border:0; background: var(--c-blue); color:#fff; border-radius: 6px;
padding: 0 18px; font-weight:600; font-size: 14px;
}
.search .go:hover{ background: var(--c-blue-deep); }
.header-actions{ display:flex; gap: 6px; align-items:center; }
.icon-btn{
display:grid; place-items:center; gap: 2px; padding: 6px 10px; border-radius: 8px;
background: transparent; border: 0; min-width: 60px;
font-size: 11px; color: var(--c-ink-3); font-weight: 500;
}
.icon-btn .ico{ width: 22px; height: 22px; color: var(--c-ink-2); }
.icon-btn:hover{ background: var(--c-bg-soft); color: var(--c-ink); }
.icon-btn.has-badge{ position:relative; }
.icon-btn .badge{
position:absolute; top: 2px; right: 6px;
background: var(--c-orange); color:#fff; font-size: 10px; font-weight:700;
border-radius: 999px; padding: 1px 5px; min-width: 16px; text-align:center;
}
.nav{
border-bottom: 1px solid var(--c-line);
background: var(--c-bg);
}
.nav-row{ display:flex; align-items:center; gap: 4px; height: 48px; }
.cat-toggle{
display:flex; align-items:center; gap: 10px;
background: var(--c-blue); color:#fff;
height: 40px; padding: 0 18px; border-radius: 8px; border:0;
font-weight: 600; font-size: 14px;
}
.cat-toggle:hover{ background: var(--c-blue-deep); }
.cat-toggle .burger{ display:flex; flex-direction: column; gap: 3px; }
.cat-toggle .burger span{ width: 14px; height: 2px; background:#fff; border-radius:1px; }
.nav-link{ padding: 0 14px; height: 40px; display:flex; align-items:center; font-size: 14px; font-weight:500; color: var(--c-ink-2); border-radius: 8px; }
.nav-link:hover{ background: var(--c-bg-soft); color: var(--c-ink); }
.nav-link.active{ color: var(--c-blue); }
.nav-spacer{ flex: 1; }
.nav .phone{ font-weight: 700; font-size: 15px; color: var(--c-ink); }
.nav .phone-cta{
font-size: 11px; color: var(--c-blue); font-weight: 600;
text-transform: uppercase; letter-spacing: .04em;
} .btn{
display:inline-flex; align-items:center; justify-content:center; gap: 8px;
height: 44px; padding: 0 22px; border-radius: 8px; border: 0;
font-weight: 600; font-size: 14px; cursor: pointer;
transition: transform .04s ease, background .15s ease, box-shadow .15s ease;
}
.btn-primary{ background: var(--c-blue); color: #fff; box-shadow: var(--sh-blue); }
.btn-primary:hover{ background: var(--c-blue-deep); }
.btn-orange{ background: var(--c-orange); color: #fff; box-shadow: var(--sh-orange); }
.btn-orange:hover{ background: var(--c-orange-deep); }
.btn-ghost{ background: var(--c-bg-soft); color: var(--c-ink); }
.btn-ghost:hover{ background: var(--c-bg-deep); }
.btn-outline{ background: #fff; color: var(--c-ink); box-shadow: inset 0 0 0 1px var(--c-line-2); }
.btn-outline:hover{ box-shadow: inset 0 0 0 1px var(--c-ink); }
.btn-dark{ background: var(--c-ink); color:#fff; }
.btn-dark:hover{ background: var(--c-ink-2); }
.btn-lg{ height: 52px; padding: 0 28px; font-size: 15px; }
.btn-sm{ height: 34px; padding: 0 14px; font-size: 13px; border-radius: 6px; }
.btn:active{ transform: translateY(1px); }
.btn-block{ width: 100%; } .chip{
display:inline-flex; align-items:center; gap: 6px;
height: 26px; padding: 0 10px; border-radius: var(--r-pill);
font-size: 12px; font-weight: 600;
background: var(--c-bg-soft); color: var(--c-ink-2);
}
.chip-blue{ background: var(--c-blue-soft); color: var(--c-blue-ink); }
.chip-orange{ background: var(--c-orange-soft); color: var(--c-orange-deep); }
.chip-green{ background: var(--c-green-soft); color: var(--c-green); }
.chip-red{ background: var(--c-red-soft); color: var(--c-red); }
.chip-dark{ background: var(--c-ink); color:#fff; }
.chip-amber{ background: var(--c-amber-soft); color: var(--c-amber); }
.dot{ width: 8px; height: 8px; border-radius:50%; background: currentColor; display:inline-block; } .footer{
background: var(--c-ink); color: #b9c1d3;
padding: 56px 0 24px; margin-top: 80px;
font-size: 13px;
}
.footer h4{ color:#fff; font-size: 13px; font-weight: 700; margin: 0 0 16px; letter-spacing:.02em; text-transform: uppercase; }
.footer .grid{ display:grid; grid-template-columns: 1.5fr 1fr 1fr 1fr 1fr; gap: 40px; padding-bottom: 32px; border-bottom: 1px solid #1c2638; }
.footer ul{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap: 8px; }
.footer a:hover{ color: #fff; }
.footer .legal{ display:flex; justify-content:space-between; padding-top: 24px; color: #6e7791; font-size: 12px; }
.footer .pay{ display:flex; gap: 8px; flex-wrap: wrap; }
.footer .pay-card{
width: 42px; height: 26px; border-radius: 4px;
background: rgba(255,255,255,.07); display:grid; place-items:center;
font-size: 9px; font-weight: 700; color:#cfd6e4;
} .products-grid{
display:grid;
grid-template-columns: repeat(4, 1fr);
gap: 16px;
}
.products-grid.cols-3{ grid-template-columns: repeat(3, 1fr); } .card.style-classic{
background:#fff; border-radius: var(--r-3); border: 1px solid var(--c-line);
display:flex; flex-direction:column; overflow:hidden; position:relative;
transition: box-shadow .15s ease, transform .15s ease;
}
.card.style-classic:hover{ box-shadow: var(--sh-3); transform: translateY(-2px); }
.card.style-classic .img{ aspect-ratio: 1/1; background: var(--c-bg-soft); position:relative; }
.card.style-classic .badges{ position:absolute; top: 10px; left: 10px; display:flex; flex-direction:column; gap: 4px; }
.card.style-classic .fav{ position:absolute; top: 10px; right: 10px; width:32px; height:32px; border-radius:50%; background:#fff; border:1px solid var(--c-line); display:grid; place-items:center; }
.card.style-classic .body{ padding: 14px; display:flex; flex-direction: column; gap: 10px; flex: 1; }
.card.style-classic .price-row{ display:flex; align-items:baseline; gap: 8px; }
.card.style-classic .price{ font-family: var(--font-display); font-size: 22px; font-weight: 800; }
.card.style-classic .price .cur{ font-size: 14px; font-weight: 700; color: var(--c-ink-2); }
.card.style-classic .price-old{ font-size: 13px; text-decoration: line-through; color: var(--c-ink-4); }
.card.style-classic .name{ font-size: 13.5px; line-height: 1.35; font-weight: 500; color: var(--c-ink-2); display:-webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.card.style-classic .stock{ display:flex; align-items:center; gap:6px; font-size: 12px; color: var(--c-green); font-weight: 600; }
.card.style-classic .actions{ display:flex; gap: 8px; margin-top:auto; }
.card.style-classic .add{ flex:1; } .card.style-minimal{
background:#fff; border-radius: var(--r-3); border: 1px solid var(--c-line);
display:flex; flex-direction:column; overflow:hidden; position:relative;
}
.card.style-minimal .img{ aspect-ratio: 4/3; background: linear-gradient(180deg, #f7f9fc 0%, #eaeef5 100%); position:relative; }
.card.style-minimal .body{ padding: 18px; display:flex; flex-direction: column; gap: 8px; }
.card.style-minimal .name{ font-size: 15px; font-weight: 600; color: var(--c-ink); }
.card.style-minimal .meta{ font-size: 12.5px; color: var(--c-ink-3); }
.card.style-minimal .footer-row{ display:flex; align-items:center; justify-content:space-between; padding-top: 12px; margin-top: 4px; border-top: 1px solid var(--c-line); }
.card.style-minimal .price{ font-family: var(--font-display); font-size: 18px; font-weight: 700; }
.card.style-minimal .add{ width: 36px; height: 36px; border-radius:50%; background: var(--c-ink); color:#fff; border:0; display:grid; place-items:center; }
.card.style-minimal .add:hover{ background: var(--c-blue); } .card.style-tech{
background:#fff; border-radius: var(--r-2); border: 1px solid var(--c-line);
display:grid; grid-template-columns: 120px 1fr; padding: 12px; gap: 14px; position:relative;
}
.card.style-tech .img{ aspect-ratio: 1/1; background: var(--c-bg-soft); border-radius: var(--r-2); }
.card.style-tech .name{ font-size: 14px; font-weight: 600; color: var(--c-ink); margin-bottom: 6px; line-height: 1.3; }
.card.style-tech .specs{ display:flex; flex-direction:column; gap: 2px; font-size: 11.5px; color: var(--c-ink-3); margin-bottom: 8px; }
.card.style-tech .specs span b{ color: var(--c-ink-2); font-weight: 600; }
.card.style-tech .price-row{ display:flex; align-items:baseline; gap: 6px; margin-bottom: 8px; }
.card.style-tech .price{ font-family: var(--font-display); font-size: 18px; font-weight: 800; }
.card.style-tech .unit{ font-size: 11px; color: var(--c-ink-4); }
.card.style-tech .add-row{ display:flex; gap: 6px; align-items:center; }
.card.style-tech .qty{ display:flex; height: 30px; border:1px solid var(--c-line); border-radius: 5px; overflow:hidden; }
.card.style-tech .qty button{ width: 28px; border:0; background:#fff; font-size: 14px; color: var(--c-ink-2); }
.card.style-tech .qty input{ width: 40px; border:0; text-align:center; font-size: 13px; font-weight: 600; outline:none; } .skeleton-img{
display:grid; place-items:center; color: var(--c-ink-4);
background: repeating-linear-gradient(45deg, transparent 0 10px, rgba(0,0,0,.018) 10px 20px), var(--c-bg-soft);
} .hero{ padding: 32px 0 56px; }
.hero-grid{ display:grid; grid-template-columns: 1.4fr 1fr; gap: 16px; }
.hero-main{
position:relative; overflow:hidden; border-radius: var(--r-4);
background: linear-gradient(135deg, #001b6e 0%, #0b4dff 60%, #2864ff 100%);
color: #fff; padding: 56px; min-height: 440px;
display:flex; flex-direction: column; justify-content: space-between;
}
.hero-main::before{
content:""; position:absolute; right: -80px; bottom: -80px; width: 420px; height: 420px;
background: var(--c-orange); border-radius: 30% 70% 60% 40% / 50% 40% 60% 50%;
filter: blur(2px); opacity:.95;
transform: rotate(-12deg);
}
.hero-main::after{
content:""; position:absolute; right: 80px; top: -40px; width: 200px; height: 200px;
border: 8px solid rgba(255,255,255,.15); border-radius: 50%;
}
.hero-main > *{ position:relative; z-index: 1; }
.hero-main .eyebrow{ display:inline-flex; gap: 8px; align-items:center; background: rgba(255,255,255,.12); padding: 6px 12px; border-radius: var(--r-pill); font-size: 12px; font-weight: 600; width: fit-content; backdrop-filter: blur(10px); }
.hero-main h1{ font-family: var(--font-display); font-size: 64px; line-height: 1; letter-spacing: -0.025em; font-weight: 800; margin: 16px 0 20px; max-width: 580px; }
.hero-main .lede{ font-size: 18px; opacity: .9; max-width: 440px; margin: 0 0 28px; }
.hero-main .cta-row{ display:flex; gap: 12px; }
.hero-main .stats{ display:flex; gap: 40px; margin-top: 28px; }
.hero-main .stat-num{ font-family: var(--font-display); font-size: 28px; font-weight: 800; }
.hero-main .stat-lbl{ font-size: 12px; opacity: .8; }
.hero-side{ display:grid; grid-template-rows: 1fr 1fr; gap: 16px; }
.hero-card{
border-radius: var(--r-4); padding: 28px;
display:flex; flex-direction:column; justify-content: space-between;
position: relative; overflow: hidden;
min-height: 212px;
}
.hero-card.orange{ background: var(--c-orange); color:#fff; }
.hero-card.orange::after{
content:""; position:absolute; right:-20px; bottom:-30px; width:160px; height:160px;
background: rgba(255,255,255,.15); border-radius:50%;
}
.hero-card.dark{ background: var(--c-ink); color:#fff; }
.hero-card.dark::after{
content:""; position:absolute; right:-30px; top:-30px; width:140px; height:140px;
border: 6px solid var(--c-orange); border-radius:8px; transform: rotate(20deg);
}
.hero-card h3{ font-family: var(--font-display); font-size: 22px; line-height: 1.15; margin: 0; max-width: 260px; }
.hero-card .arrow{
width: 44px; height: 44px; border-radius: 50%; background: rgba(255,255,255,.2);
display:grid; place-items:center; align-self: flex-end;
}
.hero-card .arrow svg{ stroke: #fff; }
.hero-card.orange .arrow{ background: rgba(255,255,255,.25); }
.hero-card .topline{ font-size: 12px; font-weight: 600; opacity: .8; text-transform: uppercase; letter-spacing: .04em; } .section{ padding: 56px 0; }
.section-head{ display:flex; align-items:end; justify-content:space-between; margin-bottom: 28px; gap: 24px; }
.section-head .titles h2{ margin: 0 0 4px; }
.section-head .titles .sub{ color: var(--c-ink-3); font-size: 14px; }
.section-head .more{ color: var(--c-blue); font-weight: 600; font-size: 14px; display:inline-flex; align-items:center; gap: 6px; } .cats-grid{ display:grid; grid-template-columns: repeat(6, 1fr); gap: 12px; }
.cat-tile{
background: var(--c-bg-soft); border-radius: var(--r-3);
padding: 18px; aspect-ratio: 1/1.05;
display:flex; flex-direction: column; justify-content: space-between; gap: 12px;
position: relative; overflow: hidden;
transition: transform .15s ease, background .15s ease;
}
.cat-tile:hover{ background: var(--c-blue-soft); transform: translateY(-2px); }
.cat-tile .ico-wrap{ width: 56px; height: 56px; border-radius: var(--r-2); background:#fff; display:grid; place-items:center; }
.cat-tile h4{ font-size: 15px; line-height: 1.2; }
.cat-tile .count{ font-size: 12px; color: var(--c-ink-3); }
.cat-tile.featured{ background: var(--c-ink); color:#fff; grid-column: span 2; aspect-ratio: 2.05/1.05; }
.cat-tile.featured .ico-wrap{ background: var(--c-orange); }
.cat-tile.featured .count{ color: rgba(255,255,255,.6); } .banner-row{ display:grid; grid-template-columns: 2fr 1fr; gap: 16px; }
.promo{
border-radius: var(--r-4); padding: 36px 40px;
display:flex; align-items:center; justify-content:space-between; gap: 24px;
position:relative; overflow:hidden;
}
.promo.b1{ background: linear-gradient(110deg, #fff1e6 0%, #ffd5b3 100%); }
.promo.b2{ background: linear-gradient(110deg, #e7eeff 0%, #c4d3ff 100%); }
.promo h3{ font-family: var(--font-display); font-size: 28px; line-height: 1.1; margin: 0 0 8px; max-width: 360px; }
.promo p{ color: var(--c-ink-3); margin: 0; max-width: 320px; font-size: 14px; }
.promo .promo-img{
width: 180px; height: 140px; background: rgba(255,255,255,.5); border-radius: var(--r-2);
display:grid; place-items:center;
} .spec-table{ width: 100%; border-collapse: collapse; }
.spec-table tr{ border-bottom: 1px solid var(--c-line); }
.spec-table td{ padding: 10px 0; font-size: 13.5px; }
.spec-table td:first-child{ color: var(--c-ink-3); width: 40%; }
.spec-table td:last-child{ color: var(--c-ink); font-weight: 500; } .subfooter{
background: var(--c-bg-soft); padding: 36px 0; margin-top: 60px;
}
.advantages{ display:grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.advantage{
background:#fff; border-radius: var(--r-3); padding: 18px;
display:flex; gap: 14px; align-items: flex-start;
border: 1px solid var(--c-line);
}
.advantage .ico-wrap{
width: 44px; height: 44px; border-radius: var(--r-2); background: var(--c-blue-soft);
display:grid; place-items:center; flex-shrink: 0; color: var(--c-blue);
}
.advantage h4{ margin: 0 0 4px; font-size: 14px; }
.advantage p{ margin: 0; font-size: 12.5px; color: var(--c-ink-3); } .mobile-stage{
display:flex; gap: 40px; padding: 40px 32px; flex-wrap:wrap; justify-content:center; background: #f0f3f8;
}
.phone{
width: 390px; background:#000; border-radius: 44px; padding: 12px;
box-shadow: 0 30px 60px rgba(11,18,32,.18), 0 0 0 1px rgba(0,0,0,.4);
}
.phone-screen{
width: 100%; height: 800px; background:#fff; border-radius: 32px; overflow: hidden; position: relative;
}
.phone-screen .notch{
position:absolute; top: 8px; left:50%; transform: translateX(-50%);
width: 110px; height: 28px; background:#000; border-radius: 999px; z-index: 100;
}
.phone-screen .statusbar{
position:absolute; top: 0; left:0; right:0; height: 44px; padding: 14px 28px 0;
display:flex; justify-content:space-between; font-size: 13px; font-weight: 600; z-index: 99;
}
.phone-content{ padding-top: 44px; height: 100%; overflow-y: auto; -webkit-overflow-scrolling: touch; }
.phone-tabbar{
position:absolute; bottom:0; left:0; right:0; height: 78px; background:#fff; border-top:1px solid var(--c-line);
display:flex; padding: 8px 0 24px;
}
.phone-tab{ flex:1; display:flex; flex-direction:column; align-items:center; gap: 2px; font-size: 10px; color: var(--c-ink-3); }
.phone-tab.active{ color: var(--c-blue); }
.label-tag{
display:inline-block; background: var(--c-ink); color:#fff;
padding: 6px 12px; border-radius: 999px; font-size: 12px; font-weight: 600;
margin-bottom: 12px;
} .crumbs{ display:flex; align-items:center; gap: 8px; font-size: 13px; color: var(--c-ink-3); padding: 16px 0; }
.crumbs a:hover{ color: var(--c-blue); }
.crumbs .sep{ color: var(--c-ink-4); } .cat-layout{ display:grid; grid-template-columns: 264px 1fr; gap: 24px; align-items: start; padding: 16px 0 80px; }
.sidebar{
background:#fff; border:1px solid var(--c-line); border-radius: var(--r-3); padding: 18px; position: sticky; top: 100px;
}
.filter-block{ padding: 16px 0; border-bottom: 1px solid var(--c-line); }
.filter-block:last-child{ border-bottom: 0; }
.filter-block h4{ font-size: 14px; margin: 0 0 12px; }
.filter-block .opt{ display:flex; align-items:center; gap: 10px; font-size: 13.5px; padding: 6px 0; color: var(--c-ink-2); }
.filter-block .opt input{ accent-color: var(--c-blue); }
.filter-block .opt .count{ color: var(--c-ink-4); font-size: 12px; margin-left:auto; }
.range-row{ display:flex; gap: 8px; }
.range-row input{
flex: 1; min-width: 0; padding: 8px 10px; border-radius: 6px;
border: 1px solid var(--c-line); font-size: 13px;
} .toolbar{
display:flex; align-items:center; justify-content:space-between; padding: 0 0 16px;
gap: 12px; flex-wrap: wrap;
}
.toolbar .left{ display:flex; gap: 8px; flex-wrap: wrap; }
.toolbar .right{ display:flex; gap: 8px; align-items:center; }
.view-toggle{ display:inline-flex; background: var(--c-bg-soft); padding: 3px; border-radius: 7px; }
.view-toggle button{
border:0; background: transparent; padding: 6px 10px; border-radius: 5px; font-size: 12px; color: var(--c-ink-3);
}
.view-toggle button.active{ background:#fff; color: var(--c-ink); box-shadow: var(--sh-1); }
.sort{
height: 36px; padding: 0 32px 0 12px; border:1px solid var(--c-line); border-radius: 7px; font-size: 13px;
background: #fff url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="12" fill="%235a6478" viewBox="0 0 16 16"><path d="M8 11L3 6h10z"/></svg>') no-repeat right 10px center;
appearance: none;
} .calc-grid{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.calc-tile{
background: #fff; border: 1px solid var(--c-line); border-radius: var(--r-3); padding: 22px;
display:flex; flex-direction: column; gap: 12px; position:relative; cursor:pointer;
transition: border .15s, box-shadow .15s, transform .15s;
}
.calc-tile:hover, .calc-tile.active{ border-color: var(--c-blue); box-shadow: 0 0 0 3px var(--c-blue-soft); }
.calc-tile.active{ background: var(--c-blue-soft); }
.calc-tile .ico-big{ width: 56px; height: 56px; border-radius: var(--r-3); background: var(--c-blue-soft); display:grid; place-items:center; color: var(--c-blue); }
.calc-tile.active .ico-big{ background: var(--c-blue); color:#fff; }
.calc-tile h4{ margin: 0; font-size: 16px; }
.calc-tile p{ margin: 0; font-size: 12.5px; color: var(--c-ink-3); }
.calc-form{
display:grid; grid-template-columns: 1.4fr 1fr; gap: 24px; align-items: start;
background: #fff; border: 1px solid var(--c-line); border-radius: var(--r-3);
overflow: hidden;
}
.calc-form .pane{ padding: 28px; }
.calc-form .right-pane{ background: var(--c-ink); color:#fff; padding: 28px; min-height: 100%; }
.field-group{ display:grid; gap: 6px; margin-bottom: 16px; }
.field-group label{ font-size: 12.5px; color: var(--c-ink-3); font-weight: 600; }
.field-group .input,
.field-group select,
.field-group input{
height: 44px; padding: 0 14px; border-radius: 8px; border: 1px solid var(--c-line);
font-size: 14px; background:#fff; outline: none;
}
.field-group .input:focus, .field-group select:focus, .field-group input:focus{ border-color: var(--c-blue); box-shadow: 0 0 0 3px var(--c-blue-soft); }
.row-2{ display:grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.row-3{ display:grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; }
.field-group .seg{ display:flex; gap: 0; border:1px solid var(--c-line); border-radius: 8px; overflow: hidden; }
.seg-btn{ flex:1; height: 42px; border:0; background:#fff; font-size: 13px; font-weight: 500; color: var(--c-ink-2); border-right: 1px solid var(--c-line); }
.seg-btn:last-child{ border-right: 0; }
.seg-btn.active{ background: var(--c-blue); color:#fff; }
.summary-row{ display:flex; justify-content:space-between; padding: 10px 0; border-bottom: 1px solid rgba(255,255,255,.08); font-size: 13.5px; }
.summary-row b{ font-weight: 600; }
.summary-total{ display:flex; justify-content:space-between; align-items:baseline; padding: 16px 0 8px; border-top: 1px solid rgba(255,255,255,.18); margin-top: 8px; }
.summary-total .lbl{ font-size: 13px; opacity: .7; }
.summary-total .v{ font-family: var(--font-display); font-size: 32px; font-weight: 800; } .pdp{ display:grid; grid-template-columns: 1fr 1fr; gap: 32px; padding: 24px 0 64px; }
.pdp-gallery{ display:grid; grid-template-columns: 80px 1fr; gap: 12px; }
.pdp-gallery .thumbs{ display:flex; flex-direction: column; gap: 8px; }
.pdp-gallery .thumb{ width: 80px; height: 80px; border-radius: 8px; border: 1px solid var(--c-line); background: var(--c-bg-soft); display:grid; place-items:center; cursor:pointer; }
.pdp-gallery .thumb.active{ border-color: var(--c-blue); box-shadow: 0 0 0 2px var(--c-blue-soft); }
.pdp-gallery .main{ aspect-ratio: 1/1; background: var(--c-bg-soft); border-radius: var(--r-3); display:grid; place-items:center; color: var(--c-ink-4); position:relative; }
.pdp-info h1{ font-family: var(--font-display); font-size: 32px; line-height:1.1; margin: 4px 0 12px; }
.pdp-info .price-box{ background: var(--c-bg-soft); border-radius: var(--r-3); padding: 20px; margin: 20px 0; }
.pdp-info .big-price{ font-family: var(--font-display); font-size: 40px; font-weight: 800; line-height:1; }
.pdp-info .qty-block{ display:flex; gap: 12px; align-items:center; margin: 20px 0; }
.qty-stepper{ display:flex; height: 48px; border:1px solid var(--c-line); border-radius: 8px; overflow:hidden; }
.qty-stepper button{ width: 44px; border: 0; background:#fff; font-size: 18px; color: var(--c-ink-2); }
.qty-stepper input{ width: 60px; border: 0; text-align:center; font-size: 16px; font-weight: 600; outline: none; }
.delivery-card{ display:flex; gap: 12px; padding: 14px; background: var(--c-green-soft); border-radius: 10px; margin: 12px 0; align-items:flex-start; }
.delivery-card .ico-wrap{ width: 36px; height: 36px; border-radius: 8px; background:#fff; display:grid; place-items:center; flex-shrink: 0; color: var(--c-green); } .dark-hero{
background: var(--c-ink); color:#fff; border-radius: var(--r-4);
padding: 64px; position:relative; overflow:hidden;
}
.dark-hero h1{ font-family: var(--font-display); font-size: 64px; line-height:1; letter-spacing:-.025em; font-weight: 800; margin: 0 0 20px; max-width: 620px; }
.dark-hero p{ font-size: 18px; color: rgba(255,255,255,.7); max-width: 520px; margin: 0 0 28px; }
.dark-hero .glyph{
position:absolute; right: -40px; top: 50%; transform: translateY(-50%);
font-family: var(--font-display); font-size: 280px; font-weight: 900; color: rgba(255,255,255,.04);
letter-spacing: -.04em; line-height:1;
}
.feat-grid{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.feat-card{
background:#fff; border: 1px solid var(--c-line); border-radius: var(--r-3); padding: 28px;
display:flex; flex-direction: column; gap: 14px;
}
.feat-card .num{ font-family: var(--font-display); font-size: 28px; font-weight: 800; color: var(--c-orange); }
.feat-card h3{ margin: 0; font-size: 18px; }
.feat-card p{ margin: 0; font-size: 14px; color: var(--c-ink-3); } .cart-layout{ display:grid; grid-template-columns: 1.6fr 1fr; gap: 24px; padding: 16px 0 80px; align-items: start; }
.cart-list{ background:#fff; border: 1px solid var(--c-line); border-radius: var(--r-3); }
.cart-row{
display:grid; grid-template-columns: 80px 1fr auto auto auto auto; gap: 16px;
padding: 16px; border-bottom: 1px solid var(--c-line); align-items:center;
}
.cart-row:last-child{ border-bottom: 0; }
.cart-row .img{ width:80px; height:80px; border-radius: 8px; background: var(--c-bg-soft); }
.cart-row .nm{ font-size: 13.5px; font-weight: 500; line-height:1.3; }
.cart-row .nm small{ display:block; color: var(--c-ink-3); font-size:12px; margin-top:4px; }
.cart-row .px{ font-weight: 700; font-family: var(--font-display); font-size: 16px; }
.cart-row .rm{ background:transparent; border:0; color: var(--c-ink-4); padding: 6px; }
.summary-card{
background:#fff; border:1px solid var(--c-line); border-radius: var(--r-3); padding: 22px; position: sticky; top: 100px;
}
.summary-card h3{ margin: 0 0 16px; }
.summary-card .row{ display:flex; justify-content:space-between; padding: 8px 0; font-size: 14px; }
.summary-card .row.tot{ font-family: var(--font-display); font-size: 22px; font-weight: 800; padding-top: 16px; margin-top: 8px; border-top: 1px solid var(--c-line); }
.summary-card .promo-input{ display:flex; gap: 6px; margin: 14px 0; }
.summary-card .promo-input input{ flex:1; height: 38px; padding: 0 12px; border-radius: 7px; border:1px solid var(--c-line); font-size: 13px; outline: none; } .mega{
position:absolute; top: 100%; left: 0; right: 0;
background:#fff; border: 1px solid var(--c-line); border-top: 0;
border-radius: 0 0 var(--r-3) var(--r-3); padding: 24px;
box-shadow: var(--sh-3); display: none; z-index: 60;
}
.mega.open{ display:grid; grid-template-columns: 220px 1fr; gap: 32px; }
.mega .l1{ display:flex; flex-direction:column; }
.mega .l1 a{ padding: 10px 12px; border-radius: 7px; font-size: 14px; color: var(--c-ink-2); display:flex; align-items:center; gap: 10px; }
.mega .l1 a:hover, .mega .l1 a.active{ background: var(--c-blue-soft); color: var(--c-blue); }
.mega .l1 a .arr{ margin-left:auto; color: var(--c-ink-4); }
.mega .l2-grid{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.mega .l2 h5{ font-size: 13px; margin: 0 0 8px; color: var(--c-ink); }
.mega .l2 ul{ list-style:none; padding:0; margin:0; }
.mega .l2 li{ padding: 4px 0; }
.mega .l2 a{ font-size: 13px; color: var(--c-ink-3); }
.mega .l2 a:hover{ color: var(--c-blue); } .range-double{ position:relative; height: 32px; padding: 14px 0; }
.range-track{ height: 4px; background: var(--c-line); border-radius: 999px; position: relative; }
.range-fill{ position:absolute; top: 0; bottom: 0; background: var(--c-blue); border-radius: 999px; } .tags{ display:flex; gap: 6px; flex-wrap: wrap; }
.tag{ font-size: 12px; padding: 5px 10px; border-radius: 999px; background: var(--c-bg-soft); color: var(--c-ink-2); } .bdg{
display:inline-block; padding: 2px 8px; border-radius: 4px;
font-size: 11px; font-weight: 700; line-height: 1.4;
}
.bdg-orange{ background: var(--c-orange); color:#fff; }
.bdg-green{ background: var(--c-green); color:#fff; }
.bdg-blue{ background: var(--c-blue); color:#fff; }
.bdg-dark{ background: var(--c-ink); color:#fff; } .page{ padding-bottom: 0; }
.page-title{ font-family: var(--font-display); font-size: 36px; line-height: 1.1; font-weight: 800; margin: 8px 0 24px; } .placeholder-img{
width:100%; height:100%;
background:
linear-gradient(135deg, rgba(255,255,255,.04) 25%, transparent 25%, transparent 50%, rgba(255,255,255,.04) 50%, rgba(255,255,255,.04) 75%, transparent 75%, transparent),
var(--c-bg-soft);
background-size: 24px 24px;
display:grid; place-items:center;
color: var(--c-ink-4); font-size: 11px; text-transform: uppercase; letter-spacing: .1em; font-weight: 600;
} .ico-sm svg, svg.ico-sm{ width: 16px; height: 16px; }
.ico-md svg, svg.ico-md{ width: 22px; height: 22px; }
.ico-lg svg, svg.ico-lg{ width: 32px; height: 32px; }
.ico-xl svg, svg.ico-xl{ width: 42px; height: 42px; } .row-4{ display:grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.page-hero h1{ color: inherit; }
.success-box{ background: var(--c-green-soft); border: 1px solid #c5e7d6; border-radius: 12px; padding: 20px 24px; color: var(--c-ink); margin: 16px 0; }
.error-box{ background: var(--c-red-soft); border: 1px solid #f5b8c0; border-radius: 12px; padding: 20px 24px; color: var(--c-red); margin: 16px 0; }