/* ============================================================
   SEBS — Site multi-vues. Barlow Condensed + Barlow.
   Identité : bleu marine + rouge + blanc (couleurs du logo).
   --ink = bleu marine profond (structure + texte) · --amber = rouge (accent)
   ============================================================ */
:root{
  --ink:#0b2147;--ink-2:#143169;--amber:#d51f2b;--amber-d:#ad1620;
  --paper:#fff;--paper-2:#f2f5fa;--paper-3:#e7edf5;--line:#dbe3ee;--muted:#5b6575;
  --disp:"Barlow Condensed",sans-serif;--body:"Barlow",system-ui,sans-serif;
  --xof:#157347;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--body);color:var(--ink);background:var(--paper);font-size:16.5px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
::selection{background:var(--amber);color:#fff}
.wrap{max-width:1200px;margin-inline:auto;padding-inline:clamp(1.1rem,4vw,2.5rem)}
[hidden]{display:none!important}

.h2{font-family:var(--disp);font-weight:700;font-size:clamp(1.9rem,4.6vw,3.2rem);line-height:1.04;letter-spacing:-.01em}
.h2-inv{color:#fff}
.eyebrow{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--disp);font-weight:700;font-size:.95rem;letter-spacing:.18em;text-transform:uppercase;color:var(--amber-d)}
.eyebrow::before{content:"";width:1.8rem;height:3px;background:var(--amber)}
.eyebrow-inv{color:var(--amber)}
.sec-sub{margin-top:1rem;max-width:54ch;color:var(--muted);font-size:1.08rem}
.sec{padding:clamp(3.2rem,7vw,5.8rem) 0}
.sec-alt{background:var(--paper-2)}
.sec-head{margin-bottom:clamp(2rem,5vw,3.2rem)}
.sec-head-row{display:flex;align-items:flex-end;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-family:var(--disp);font-weight:600;font-size:1.02rem;letter-spacing:.04em;text-transform:uppercase;padding:.7rem 1.4rem;border:2px solid transparent;cursor:pointer;transition:.2s ease;white-space:nowrap}
.btn-lg{padding:.9rem 1.7rem;font-size:1.06rem}
.btn-block{width:100%;margin-top:.6rem}
.btn-primary{background:var(--amber);color:#fff}
.btn-primary:hover{background:var(--ink);color:#fff}
.btn-line{border-color:var(--ink);color:var(--ink)}
.btn-line:hover{background:var(--ink);color:#fff}
.btn-line-light{border-color:#fff;color:#fff}
.btn-line-light:hover{background:#fff;color:var(--ink)}
.btn-dark{background:var(--ink);color:#fff;align-self:flex-start;margin-top:1.6rem}
.btn-dark:hover{background:var(--amber)}
.link-arrow{font-family:var(--disp);font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--amber-d);transition:.2s}
.link-arrow:hover{color:var(--ink)}

/* ===== TOPBAR ===== */
.topbar{background:var(--ink);color:#c9ccd2;font-size:.86rem}
.topbar-in{display:flex;align-items:center;justify-content:space-between;height:42px}
.tb-left{display:flex;align-items:center;gap:1.4rem}
.tb-left a,.tb-hours{display:inline-flex;align-items:center;gap:.4rem;color:#c9ccd2;transition:.2s}
.tb-left a:hover{color:#fff}
.ic{width:15px;height:15px;fill:none;stroke:var(--amber);stroke-width:1.8}
.tb-right{display:flex;align-items:center;gap:1.4rem}
.tb-tag{font-family:var(--disp);letter-spacing:.12em;text-transform:uppercase;color:var(--amber);font-size:.82rem}
.tb-socials{display:flex;gap:.5rem}
.tb-socials a{color:#9aa0a8;transition:.2s}
.tb-socials a:hover{color:#fff}
.sic{width:16px;height:16px;fill:currentColor}
@media(max-width:820px){.tb-left .tb-hours,.tb-tag{display:none}}
@media(max-width:560px){.topbar{font-size:.8rem}.tb-left{gap:1rem}.tb-left a[href^="mailto"]{display:none}}

/* ===== HEADER ===== */
.header{position:sticky;top:0;z-index:100;background:#fff;border-bottom:1px solid var(--line);transition:box-shadow .3s}
.header.scrolled{box-shadow:0 6px 24px -14px rgba(0,0,0,.4)}
.header-in{display:flex;align-items:center;justify-content:space-between;height:74px;transition:height .3s;gap:1rem}
.header.scrolled .header-in{height:64px}
.brand{display:flex;align-items:center;gap:.6rem;flex:none}
.brand-logo{height:44px;width:auto;transition:height .3s}
.header.scrolled .brand-logo{height:38px}
.brand-fallback{width:42px;height:42px;background:var(--ink);color:var(--amber);font-family:var(--disp);font-weight:800;font-size:1.25rem;display:grid;place-items:center}
.brand-name{font-family:var(--disp);font-weight:800;font-size:1.65rem;letter-spacing:.02em}
.nav{display:none;gap:1.5rem}
@media(min-width:1020px){.nav{display:flex}}
.nav a{font-family:var(--disp);font-weight:600;font-size:1.05rem;letter-spacing:.04em;text-transform:uppercase;color:var(--ink);position:relative;padding:.3rem 0}
.nav a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;background:var(--amber);transition:right .25s}
.nav a:hover::after,.nav a.active::after{right:0}
.nav a.active{color:var(--amber-d)}
.header-cta{display:flex;align-items:center;gap:.7rem;flex:none}
.header-quote{display:none}
@media(min-width:1020px){.header-quote{display:inline-flex}}
.cart-btn{position:relative;background:none;border:0;cursor:pointer;padding:.4rem;color:var(--ink);display:grid;place-items:center}
.cart-btn svg{width:26px;height:26px;fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.cart-btn:hover{color:var(--amber-d)}
.cart-count{position:absolute;top:-2px;right:-4px;min-width:18px;height:18px;padding:0 4px;background:var(--amber);color:#fff;font-family:var(--disp);font-weight:700;font-size:.72rem;border-radius:9px;display:grid;place-items:center;line-height:1}
.burger{display:flex;flex-direction:column;gap:5px;background:none;border:0;padding:6px;cursor:pointer}
@media(min-width:1020px){.burger{display:none}}
.burger span{width:26px;height:2.5px;background:var(--ink);transition:.3s}
.burger.x span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.burger.x span:nth-child(2){opacity:0}
.burger.x span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
.mnav{display:none;flex-direction:column;padding:.5rem clamp(1.1rem,4vw,2.5rem) 1.2rem;border-top:1px solid var(--line)}
.mnav.open{display:flex}
.mnav a{font-family:var(--disp);font-weight:600;font-size:1.15rem;text-transform:uppercase;letter-spacing:.04em;padding:.85rem 0;border-bottom:1px solid var(--line)}
.mnav .btn{margin-top:1rem}

/* ===== VIEWS ===== */
.view{animation:viewIn .4s ease both}
@keyframes viewIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.page-head{background:var(--ink);color:#fff;padding:clamp(2.4rem,5vw,3.6rem) 0}
.crumb{font-family:var(--disp);font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;color:#8d929a}
.crumb b{color:var(--amber)}
.page-title{font-family:var(--disp);font-weight:800;font-size:clamp(2.4rem,6vw,4rem);line-height:1;margin:.4rem 0}
.page-sub{color:#c2c6cc;max-width:60ch;font-size:1.1rem}

/* ===== HERO CAROUSEL ===== */
.hero-c{position:relative;overflow:hidden;background:var(--ink)}
.hero-track{display:flex;transition:transform .7s cubic-bezier(.16,1,.3,1)}
.slide{min-width:100%;position:relative;color:#fff}
.slide::before{content:"";position:absolute;inset:0;opacity:.9}
.slide[data-theme="materiaux"]::before{background:linear-gradient(120deg,#16181c 0%,#16181c 42%,rgba(22,24,28,.55) 100%),url("assets/photo-materiaux.webp") center/cover}
.slide[data-theme="construction"]::before{background:linear-gradient(120deg,#16181c 0%,#16181c 42%,rgba(22,24,28,.55) 100%),url("assets/photo-construction.jpg") center/cover}
.slide[data-theme="academy"]::before{background:linear-gradient(120deg,#16181c 0%,#16181c 42%,rgba(22,24,28,.55) 100%),url("assets/photo-btp.jpg") center/cover}
.slide-in{position:relative;padding:clamp(3.2rem,9vw,6.5rem) 0;min-height:clamp(340px,52vw,480px);display:flex;align-items:center}
.slide-text{max-width:38rem}
.kick{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--disp);font-weight:600;font-size:.98rem;letter-spacing:.12em;text-transform:uppercase;color:var(--amber)}
.kick i{width:10px;height:10px;background:var(--amber);display:inline-block;transform:rotate(45deg)}
.slide h1{font-family:var(--disp);font-weight:800;font-size:clamp(2.6rem,7vw,5rem);line-height:.96;letter-spacing:-.015em;margin:1rem 0}
.slide h1 .hl{color:var(--amber)}
.slide p{font-size:1.15rem;color:#d7dade;max-width:42ch}
.slide-actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:1.8rem}
.hero-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:3rem;height:3rem;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.3);color:#fff;cursor:pointer;display:grid;place-items:center;transition:.2s;backdrop-filter:blur(4px)}
.hero-arrow:hover{background:var(--amber);border-color:var(--amber)}
.hero-arrow svg{width:1.3rem;height:1.3rem;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.hero-arrow.prev{left:clamp(.6rem,2vw,1.4rem)}
.hero-arrow.next{right:clamp(.6rem,2vw,1.4rem)}
@media(max-width:680px){.hero-arrow{display:none}}
.hero-dots{position:absolute;bottom:1.2rem;left:0;right:0;display:flex;justify-content:center;gap:.55rem;z-index:3}
.hero-dots button{width:30px;height:4px;background:rgba(255,255,255,.4);border:0;cursor:pointer;transition:.2s}
.hero-dots button.active{background:var(--amber);width:46px}

/* ===== HERO STRIP ===== */
.hero-strip{background:var(--ink-2);color:#fff;border-top:1px solid rgba(255,255,255,.08)}
.hero-strip-in{display:flex;align-items:center;gap:2rem;height:62px;flex-wrap:wrap}
.hs-label{font-family:var(--disp);font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;color:#8a8f97}
.hs-names{display:flex;gap:2.2rem;font-family:var(--disp);font-weight:700;font-size:1.2rem;letter-spacing:.05em}
.hs-names span,.hs-names a{color:#dfe2e6;transition:.2s;text-decoration:none}
.hs-names a:hover,.hs-names a:focus-visible{color:var(--amber)}

/* ===== ABOUT ===== */
.about-in{display:grid;grid-template-columns:1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
@media(min-width:900px){.about-in{grid-template-columns:1fr 1.05fr}}
.about-media{position:relative;padding-bottom:2rem;min-width:0}
.am-1{width:78%;aspect-ratio:4/3;object-fit:cover;border:1px solid var(--line)}
.am-2{position:absolute;right:0;bottom:0;width:52%;aspect-ratio:1;object-fit:cover;border:4px solid #fff;box-shadow:0 18px 40px -22px rgba(0,0,0,.5)}
.am-stat{position:absolute;left:0;bottom:-1.2rem;background:var(--amber);color:#fff;padding:.7rem 1.1rem;display:flex;align-items:center;gap:.6rem}
.am-stat b{font-family:var(--disp);font-weight:800;font-size:2rem;line-height:1}
.am-stat span{font-family:var(--disp);font-size:.82rem;line-height:1.15;text-transform:uppercase;letter-spacing:.04em;max-width:12ch}
.about-text p{margin-top:1rem;color:var(--ink-2)}
.about-text .claim{font-family:var(--disp);font-weight:600;font-size:1.4rem;color:var(--ink);border-left:4px solid var(--amber);padding-left:1rem;margin-top:1.6rem;line-height:1.2}

/* ===== OFFERS ===== */
.offers{display:grid;grid-template-columns:1fr;gap:clamp(1.5rem,3vw,2.2rem)}
@media(min-width:760px){.offers{grid-template-columns:1fr 1fr}}
.offer{background:#fff;border:1px solid var(--line);overflow:hidden;transition:.3s}
.offer:hover{box-shadow:0 24px 50px -28px rgba(0,0,0,.45);transform:translateY(-4px)}
.offer-img{overflow:hidden;aspect-ratio:16/10}
.offer-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.offer:hover .offer-img img{transform:scale(1.05)}
.offer-body{padding:1.6rem 1.6rem 1.8rem;position:relative}
.offer-no{font-family:var(--disp);font-weight:800;font-size:1rem;color:#fff;background:var(--amber);width:2.4rem;height:2.4rem;display:grid;place-items:center;position:absolute;top:-1.2rem;left:1.6rem}
.offer-body h3{font-family:var(--disp);font-weight:700;font-size:1.7rem;margin-top:.4rem}
.offer-body p{color:var(--muted);margin:.6rem 0 1rem}

/* ===== POLES ===== */
.poles{display:grid;grid-template-columns:1fr;gap:1px;background:var(--line);border:1px solid var(--line)}
@media(min-width:560px){.poles{grid-template-columns:1fr 1fr}}
@media(min-width:1000px){.poles{grid-template-columns:repeat(4,1fr)}}
.pole{background:#fff;padding:2rem 1.6rem;position:relative;transition:.3s}
.pole:hover{background:var(--ink)}
.pole-no{font-family:var(--disp);font-weight:800;font-size:.95rem;letter-spacing:.1em;color:var(--amber);position:absolute;top:1.3rem;right:1.4rem}
.pole-ic{width:3.2rem;height:3.2rem;border:2px solid var(--ink);display:grid;place-items:center;transition:.3s}
.pole-ic svg{width:1.7rem;height:1.7rem;fill:none;stroke:var(--ink);stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;transition:.3s}
.pole:hover .pole-ic{border-color:var(--amber);background:var(--amber)}
.pole:hover .pole-ic svg{stroke:#fff}
.pole h3{font-family:var(--disp);font-weight:700;font-size:1.45rem;margin:1.1rem 0 .4rem;transition:.3s}
.pole p{color:var(--muted);font-size:.98rem;transition:.3s}
.pole:hover h3{color:#fff}.pole:hover p{color:#b9bdc4}

/* ===== DARK VALUES ===== */
.sec-dark{background:var(--ink);color:#fff}
.sec-head-inv .eyebrow{color:var(--amber)}
.values{display:grid;grid-template-columns:1fr;gap:1px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.12)}
@media(min-width:560px){.values{grid-template-columns:1fr 1fr}}
@media(min-width:980px){.values{grid-template-columns:repeat(4,1fr)}}
.value{background:var(--ink);padding:2rem 1.5rem;transition:.3s}
.value:hover{background:var(--ink-2)}
.v-no{font-family:var(--disp);font-weight:800;font-size:2.6rem;color:var(--amber);line-height:1}
.value h4{font-family:var(--disp);font-weight:700;font-size:1.3rem;margin:.7rem 0 .4rem}
.value p{color:#a9adb4;font-size:.96rem}

/* ===== STATS ===== */
.stats-band{background:var(--amber)}
.stats-in{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem 1rem;padding:clamp(2.2rem,5vw,3.2rem) 0}
@media(min-width:820px){.stats-in{grid-template-columns:repeat(4,1fr)}}
.stat{text-align:center;color:#fff}
.stat b{font-family:var(--disp);font-weight:800;font-size:clamp(2.6rem,6vw,3.8rem);line-height:1;display:block}
.stat span{font-family:var(--disp);font-size:.92rem;letter-spacing:.06em;text-transform:uppercase;display:block;margin-top:.4rem;color:rgba(255,255,255,.9)}

/* ===== SHOPS (villes) ===== */
.shops{display:grid;grid-template-columns:1fr;gap:clamp(1rem,2.5vw,1.6rem)}
@media(min-width:560px){.shops{grid-template-columns:1fr 1fr}}
@media(min-width:920px){.shops{grid-template-columns:repeat(3,1fr)}}
.shop{position:relative;overflow:hidden;border:1px solid var(--line);aspect-ratio:16/10;display:block}
.shop img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.shop:hover img{transform:scale(1.06)}
.shop-ov{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:1.2rem;background:linear-gradient(to top,rgba(20,22,26,.85) 0%,rgba(20,22,26,.2) 55%,transparent 100%);color:#fff}
.shop-ov h3{font-family:var(--disp);font-weight:700;font-size:1.5rem;line-height:1.05}
.shop-ov span{font-family:var(--disp);font-size:.88rem;letter-spacing:.08em;text-transform:uppercase;color:var(--amber)}

/* ===== PRODUCT GRID / CARDS ===== */
.grid-products{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(.8rem,2vw,1.4rem)}
@media(min-width:680px){.grid-products{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1000px){.grid-products{grid-template-columns:repeat(4,1fr)}}
.pcard{background:#fff;border:1px solid var(--line);display:flex;flex-direction:column;transition:.25s;overflow:hidden}
.pcard:hover{box-shadow:0 20px 44px -26px rgba(0,0,0,.45);transform:translateY(-3px)}
.pcard-top{position:relative;aspect-ratio:4/3;display:grid;place-items:center;overflow:hidden}
.pcard-top svg{width:38%;height:38%;opacity:.92;stroke:#fff;fill:none;stroke-width:1.4;stroke-linecap:round;stroke-linejoin:round}
.pcard-photo{background:#fff}
.pcard-photo img{width:100%;height:100%;object-fit:contain;padding:.5rem;transition:transform .35s cubic-bezier(.16,1,.3,1)}
.pcard:hover .pcard-photo img{transform:scale(1.04)}
.pcard-photo .pcard-cat{color:#fff}
.pcard-photo .pcard-fb{display:none}
.pcard-cat{position:absolute;top:.6rem;left:.6rem;background:rgba(0,0,0,.45);color:#fff;font-family:var(--disp);font-weight:600;font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;padding:.18rem .5rem;backdrop-filter:blur(3px)}
.pcard-brand{position:absolute;top:.6rem;right:.6rem;background:#fff;color:var(--ink);font-family:var(--disp);font-weight:700;font-size:.72rem;letter-spacing:.04em;padding:.18rem .5rem}
.pcard-body{padding:.9rem 1rem 1.1rem;display:flex;flex-direction:column;gap:.5rem;flex:1}
.pcard-name{font-family:var(--disp);font-weight:600;font-size:1.18rem;line-height:1.08}
.pcard-unit{font-size:.82rem;color:var(--muted);margin-top:-.25rem}
.pcard-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:.5rem}
.pcard-price{font-family:var(--disp);font-weight:700;font-size:1.3rem;color:var(--ink);line-height:1.05;display:flex;flex-direction:column}
.pcard-price small{font-size:.7rem;color:var(--muted);font-weight:600}
.pcard-add{background:var(--amber);color:#fff;border:0;cursor:pointer;width:2.4rem;height:2.4rem;display:grid;place-items:center;transition:.2s;flex:none}
.pcard-add svg{width:1.2rem;height:1.2rem;fill:none;stroke:#fff;stroke-width:2;stroke-linecap:round}
.pcard-add:hover{background:var(--ink)}

/* ===== SHOP LAYOUT ===== */
.shop-layout{display:grid;grid-template-columns:1fr;gap:2rem;padding-block:clamp(2rem,5vw,3.2rem)}
@media(min-width:900px){.shop-layout{grid-template-columns:250px 1fr;align-items:start}}
.shop-aside{display:flex;flex-direction:column;gap:1.6rem}
@media(min-width:900px){.shop-aside{position:sticky;top:90px}}
.filter-box{border:1px solid var(--line);padding:1.1rem 1.2rem;background:var(--paper-2)}
.filter-h{display:block;font-family:var(--disp);font-weight:700;font-size:.9rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:.7rem;color:var(--ink)}
.search-wrap{position:relative}
.search-ic{position:absolute;left:.6rem;top:50%;transform:translateY(-50%);width:1.1rem;height:1.1rem;fill:none;stroke:var(--muted);stroke-width:2;stroke-linecap:round}
#shopSearch{width:100%;padding:.6rem .7rem .6rem 2.1rem;border:1px solid var(--line);background:#fff;font-family:var(--body);font-size:.95rem}
#shopSearch:focus{outline:none;border-color:var(--amber)}
.cat-list{display:flex;flex-direction:column;gap:.15rem}
.cat-list button{text-align:left;background:none;border:0;cursor:pointer;font-family:var(--body);font-size:.98rem;color:var(--ink-2);padding:.4rem .5rem;display:flex;justify-content:space-between;align-items:center;gap:.5rem;transition:.15s}
.cat-list button .n{font-family:var(--disp);font-size:.85rem;color:var(--muted)}
.cat-list button:hover{background:#fff;color:var(--ink)}
.cat-list button.active{background:var(--ink);color:#fff}
.cat-list button.active .n{color:rgba(255,255,255,.7)}
.shop-toolbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.4rem;flex-wrap:wrap}
.shop-count{font-family:var(--disp);font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}
.sort-wrap{font-family:var(--disp);font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-2);font-size:.92rem;display:flex;align-items:center;gap:.4rem}
.sort-wrap select{font-family:var(--body);text-transform:none;letter-spacing:0;border:1px solid var(--line);padding:.4rem .6rem;background:#fff;font-size:.92rem;cursor:pointer}
.sort-wrap select:focus{outline:none;border-color:var(--amber)}
.shop-empty{text-align:center;color:var(--muted);padding:3rem 0;font-size:1.1rem}

/* ===== MAP ===== */
.map-layout{display:grid;grid-template-columns:1fr;gap:1.5rem}
@media(min-width:880px){.map-layout{grid-template-columns:260px 1fr;align-items:start}}
.map-cities{display:flex;flex-direction:column;border:1px solid var(--line)}
.map-cities button{text-align:left;background:#fff;border:0;border-bottom:1px solid var(--line);cursor:pointer;padding:.9rem 1.1rem;font-family:var(--disp);font-weight:600;font-size:1.15rem;color:var(--ink);transition:.15s;display:flex;flex-direction:column}
.map-cities button:last-child{border-bottom:0}
.map-cities button small{font-family:var(--body);font-size:.8rem;font-weight:400;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.map-cities button:hover{background:var(--paper-2)}
.map-cities button.active{background:var(--ink);color:#fff}
.map-cities button.active small{color:var(--amber)}
.map-panel{border:1px solid var(--line);background:#fff;overflow:hidden}
.map-frame{aspect-ratio:16/9;background:var(--paper-3)}
.map-frame iframe{width:100%;height:100%;border:0;display:block}
.map-info{padding:1.4rem}
.map-kick{font-family:var(--disp);font-weight:600;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.contact-map{margin-top:1.6rem;border:1px solid var(--line);aspect-ratio:16/10}
.contact-map iframe{width:100%;height:100%;border:0;display:block}
.map-info h3{font-family:var(--disp);font-weight:700;font-size:1.6rem}
.map-region{font-family:var(--disp);font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;color:var(--amber-d);margin-top:.1rem}
.map-addr{color:var(--muted);margin:.7rem 0 1.1rem}
.map-actions{display:flex;gap:.7rem;flex-wrap:wrap}

/* ===== RECRUIT ===== */
.recruit{background-image:linear-gradient(rgba(20,22,26,.92),rgba(20,22,26,.92)),url("assets/photo-btp.jpg");background-size:cover;background-position:center;color:#fff}
.recruit-in{display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap;padding:clamp(3rem,7vw,5rem) 0}
.recruit-text{max-width:60ch}.recruit-text h2{margin:.7rem 0}.recruit-text p{color:#c2c6cc;font-size:1.1rem}

/* ===== CONTACT ===== */
.contact-in{display:grid;grid-template-columns:1fr;gap:clamp(2rem,5vw,3.5rem);padding-block:clamp(2rem,5vw,3.4rem)}
@media(min-width:900px){.contact-in{grid-template-columns:.85fr 1.15fr}}
.cinfo{list-style:none;margin-top:1.6rem;display:flex;flex-direction:column;gap:1rem}
.cinfo li{display:flex;align-items:center;gap:1rem}
.ci-ic{width:3rem;height:3rem;background:var(--paper-2);border:1px solid var(--line);display:grid;place-items:center;flex:none}
.ci-ic svg{width:1.4rem;height:1.4rem;fill:none;stroke:var(--amber-d);stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.cinfo div{display:flex;flex-direction:column;color:var(--muted)}
.cinfo b{font-family:var(--disp);font-weight:700;font-size:1.1rem;color:var(--ink)}
.contact-map{margin-top:1.6rem;border:1px solid var(--line);aspect-ratio:16/10}
.contact-map iframe{width:100%;height:100%;border:0;display:block}
.contact-form{background:var(--paper-2);border:1px solid var(--line);padding:clamp(1.4rem,3vw,2.2rem);align-self:start}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:540px){.row2{grid-template-columns:1fr}}
.field{margin-bottom:1rem;display:flex;flex-direction:column}
.field label{font-family:var(--disp);font-weight:600;font-size:.92rem;letter-spacing:.04em;text-transform:uppercase;margin-bottom:.35rem;color:var(--ink-2)}
.field input,.field textarea{border:1px solid var(--line);background:#fff;padding:.7rem .8rem;font-family:var(--body);font-size:1rem;color:var(--ink);resize:vertical}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--amber);box-shadow:0 0 0 3px rgba(224,123,0,.15)}
.cok{display:none;margin-top:1rem;font-family:var(--disp);font-weight:600;letter-spacing:.04em;color:var(--xof);background:#e7f6ec;border:1px solid #b8e3c4;padding:.7rem 1rem;text-align:center}
.cok.show{display:block}

/* ===== CART DRAWER ===== */
.cart-overlay{position:fixed;inset:0;background:rgba(20,22,26,.5);z-index:200;animation:fade .25s ease}
@keyframes fade{from{opacity:0}to{opacity:1}}
.cart-drawer{position:fixed;top:0;right:0;bottom:0;width:min(420px,100vw);background:#fff;z-index:201;display:flex;flex-direction:column;box-shadow:-20px 0 50px -20px rgba(0,0,0,.4);animation:slideIn .3s cubic-bezier(.16,1,.3,1)}
@keyframes slideIn{from{transform:translateX(100%)}to{transform:none}}
.cart-top{display:flex;align-items:center;justify-content:space-between;padding:1.2rem 1.3rem;border-bottom:1px solid var(--line)}
.cart-top h3{font-family:var(--disp);font-weight:700;font-size:1.5rem}
.cart-x{background:none;border:0;font-size:2rem;line-height:1;cursor:pointer;color:var(--ink-2)}
.cart-x:hover{color:var(--amber)}
.cart-items{flex:1;overflow-y:auto;padding:.6rem 1.3rem}
.cart-item{display:grid;grid-template-columns:auto 1fr auto;gap:.9rem;align-items:center;padding:.9rem 0;border-bottom:1px solid var(--line)}
.ci-thumb{width:3rem;height:3rem;display:grid;place-items:center;flex:none}
.ci-thumb svg{width:50%;height:50%;stroke:#fff;fill:none;stroke-width:1.6}
.ci-thumb-photo{background:#fff;border:1px solid var(--line)}
.ci-thumb-photo img{width:100%;height:100%;object-fit:contain;padding:2px}
.ci-thumb-photo .ci-fb{display:none}
.ci-mid{min-width:0}
.ci-name{font-family:var(--disp);font-weight:600;font-size:1.05rem;line-height:1.05}
.ci-price{color:var(--muted);font-size:.85rem}
.ci-qty{display:flex;align-items:center;gap:.5rem;margin-top:.4rem}
.ci-qty button{width:2.25rem;height:2.25rem;border:1px solid var(--line);background:#fff;cursor:pointer;font-weight:700;font-size:1.1rem;display:grid;place-items:center;line-height:1}
.ci-qty button:hover{border-color:var(--ink);background:var(--ink);color:#fff}
.ci-qty span{font-family:var(--disp);font-weight:600;min-width:1.4rem;text-align:center}
.ci-right{display:flex;flex-direction:column;align-items:flex-end;gap:.4rem}
.ci-line{font-family:var(--disp);font-weight:700}
.ci-del{background:none;border:0;cursor:pointer;color:var(--muted);font-size:.78rem;letter-spacing:.04em;text-transform:uppercase;font-family:var(--disp);padding:.35rem .1rem}
.ci-del:hover{color:#c0392b}
.cart-empty{flex:1;display:flex;flex-direction:column;justify-content:center;text-align:center;color:var(--muted);font-family:var(--disp);font-size:1.3rem;padding:0 1.5rem}
.cart-empty span{font-family:var(--body);font-size:.95rem;color:var(--muted)}
.cart-foot{border-top:1px solid var(--line);padding:1.2rem 1.3rem}
.cart-sum{display:flex;justify-content:space-between;align-items:baseline;font-family:var(--disp)}
.cart-sum span{text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.cart-sum b{font-size:1.6rem}
.cart-note{font-size:.78rem;color:var(--muted);margin:.5rem 0 .9rem}

/* ===== TOAST ===== */
.toast{position:fixed;bottom:1.4rem;left:50%;transform:translate(-50%,140%);z-index:300;background:var(--ink);color:#fff;padding:.85rem 1.3rem;font-family:var(--disp);font-weight:600;letter-spacing:.03em;box-shadow:0 16px 40px -16px rgba(0,0,0,.6);transition:transform .35s cubic-bezier(.16,1,.3,1),opacity .35s,visibility .35s;display:flex;align-items:center;gap:.6rem;opacity:0;visibility:hidden;pointer-events:none}
.toast.show{transform:translate(-50%,0);opacity:1;visibility:visible;pointer-events:auto}
.toast svg{width:1.2rem;height:1.2rem;fill:none;stroke:var(--amber);stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}

/* ===== FOOTER ===== */
.footer{background:var(--ink);color:#aeb2b9}
.footer-top{display:grid;grid-template-columns:1fr;gap:2.2rem;padding:clamp(3rem,6vw,4.5rem) 0 2.5rem}
@media(min-width:760px){.footer-top{grid-template-columns:1.7fr 1fr 1fr 1.3fr}}
.brand-name-f{color:#fff;font-size:2rem}
.f-brand p{margin:.8rem 0 1.2rem;max-width:34ch;line-height:1.6}
.f-socials{display:flex;gap:.6rem}
.f-socials a{width:2.4rem;height:2.4rem;background:rgba(255,255,255,.08);display:grid;place-items:center;color:#cfd2d7;transition:.2s}
.f-socials a:hover{background:var(--amber);color:#fff}
.f-col h4{font-family:var(--disp);font-weight:700;font-size:1.05rem;letter-spacing:.08em;text-transform:uppercase;color:#fff;margin-bottom:1rem}
.f-col a{display:block;padding:.3rem 0;transition:.2s;width:max-content}
.f-col a:hover{color:var(--amber)}
.f-cities{line-height:1.9;font-size:.95rem}
.footer-bottom{display:flex;flex-wrap:wrap;gap:.8rem;justify-content:space-between;padding:1.4rem 0;border-top:1px solid rgba(255,255,255,.1);font-family:var(--disp);font-size:.92rem;letter-spacing:.04em;text-transform:uppercase}
.f-credit{margin:0;padding-bottom:1.2rem;font-size:.72rem;color:rgba(255,255,255,.38);line-height:1.5}
.f-credit a{color:inherit;text-decoration:underline}

/* ===== TO TOP ===== */
.totop{position:fixed;right:1.3rem;bottom:1.3rem;z-index:90;width:3rem;height:3rem;background:var(--ink);color:#fff;border:0;cursor:pointer;display:grid;place-items:center;opacity:0;transform:translateY(12px);pointer-events:none;transition:.3s}
.totop.show{opacity:1;transform:none;pointer-events:auto}
.totop:hover{background:var(--amber)}
.totop svg{width:1.3rem;height:1.3rem;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}

/* ===== A11Y / DIVERS ===== */
.skip-link{position:absolute;left:.5rem;top:.5rem;z-index:400;background:var(--ink);color:#fff;padding:.6rem 1rem;font-family:var(--disp);font-weight:600;transform:translateY(-160%);transition:transform .2s}
.skip-link:focus{transform:none;outline:2px solid var(--amber);outline-offset:2px}
:focus-visible{outline:2px solid var(--amber);outline-offset:2px}
#shopSearch:focus-visible,.sort-wrap select:focus-visible,.field input:focus-visible,.field textarea:focus-visible{outline:2px solid var(--amber);outline-offset:2px}
[tabindex="-1"]:focus,[tabindex="-1"]:focus-visible{outline:none}
.shop-empty{display:flex;flex-direction:column;align-items:center;gap:1.2rem}
.hero-pause{position:absolute;bottom:1rem;right:clamp(.8rem,2vw,1.6rem);z-index:3;width:2.4rem;height:2.4rem;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.3);color:#fff;cursor:pointer;display:grid;place-items:center;backdrop-filter:blur(4px);transition:.2s}
.hero-pause:hover{background:var(--amber);border-color:var(--amber)}
.hero-pause svg{width:1.1rem;height:1.1rem;fill:currentColor;stroke:none}
.hero-pause .ic-play{display:none}
.hero-pause.is-paused .ic-pause{display:none}
.hero-pause.is-paused .ic-play{display:block}

/* ===== REVEAL ===== */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1!important;transform:none!important}
  html{scroll-behavior:auto}
}
