/* ============================================================
   PRB — "Atelier" elevated theme  (v2)
   Warm editorial-luxe: bone · espresso · pine · clay · brass
   ============================================================ */

:root{
  /* Surfaces */
  --canvas:    #F2ECE1;   /* warm bone page bg */
  --paper:     #FBF7EF;   /* card / panel */
  --paper-2:   #EFE7D8;   /* inset tone */

  /* Ink */
  --ink:       #20191333;
  --ink:       #221C16;   /* espresso near-black */
  --ink-soft:  #4E443A;
  --muted:     #8A7E6E;

  /* Brand */
  --pine:      #20382E;   /* deep refined green */
  --pine-2:    #2C4B3C;
  --pine-deep: #182A22;

  /* Accents */
  --clay:      #BC5A33;   /* terracotta CTA */
  --clay-deep: #A24A28;
  --clay-soft: #E7C7B4;
  --brass:     #B0894F;   /* hairline / fine detail */
  --brass-lt:  #C9A877;

  /* Lines */
  --line:      #DED3C1;
  --line-soft: #E8E0D2;
  --line-dark: #36473E;

  --star:      #C8902E;

  /* Type */
  --display: "Bodoni Moda", "Didot", Georgia, serif;
  --sans:    "Hanken Grotesk", "Segoe UI", system-ui, sans-serif;

  --container: 1280px;
  --radius: 4px;        /* crisp, architectural — not pill-rounded */
  --shadow-sm: 0 1px 2px rgba(34,28,22,.05), 0 8px 24px rgba(34,28,22,.05);
  --shadow:    0 24px 60px rgba(34,28,22,.13);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0; font-family:var(--sans);
  color:var(--ink-soft); background:var(--canvas);
  font-size:16.5px; line-height:1.62;
  -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; }
::selection{ background:var(--clay); color:#fff; }

h1,h2,h3,h4{ font-family:var(--display); color:var(--ink); font-weight:600; line-height:1.04; margin:0; letter-spacing:-.01em; }
h1{ font-size:clamp(2.8rem,5vw,4.6rem); font-weight:600; }
h2{ font-size:clamp(2rem,3.4vw,3.1rem); }
h3{ font-size:1.7rem; }
p{ margin:0 0 1rem; text-wrap:pretty; }
strong,b{ color:var(--ink); font-weight:700; }

.container{ width:100%; max-width:var(--container); margin:0 auto; padding:0 32px; }
.section{ padding:96px 0; }
.center{ text-align:center; }

.eyebrow{
  font-family:var(--sans); text-transform:uppercase;
  letter-spacing:.32em; font-size:.72rem; font-weight:700;
  color:var(--clay); display:inline-flex; align-items:center; gap:12px;
}
.eyebrow::before{ content:""; width:26px; height:1px; background:var(--brass); display:inline-block; }
.eyebrow.no-rule::before{ display:none; }
.muted{ color:var(--muted); }
.lead{ font-size:1.12rem; color:var(--ink-soft); }
.serif-accent{ font-family:var(--display); font-style:italic; }

/* hairline divider */
.rule{ height:1px; background:var(--line); border:0; margin:0; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.6rem;
  border:none; border-radius:var(--radius);
  padding:1rem 1.9rem; font-weight:700; font-size:.92rem;
  letter-spacing:.04em; text-transform:uppercase;
  transition:.25s cubic-bezier(.2,.7,.3,1); white-space:nowrap;
}
.btn-primary{ background:var(--clay); color:#fff; }
.btn-primary:hover{ background:var(--clay-deep); transform:translateY(-2px); box-shadow:0 12px 26px rgba(162,74,40,.3); }
.btn-pine{ background:var(--pine); color:#F2ECE1; }
.btn-pine:hover{ background:var(--pine-2); transform:translateY(-2px); }
.btn-outline{ background:transparent; border:1px solid var(--ink); color:var(--ink); }
.btn-outline:hover{ background:var(--ink); color:var(--canvas); }
.btn-ghost{ background:transparent; border:1px solid var(--line-dark); color:#E9E0D0; }
.btn-ghost:hover{ background:rgba(255,255,255,.06); }
.btn-lg{ padding:1.15rem 2.3rem; font-size:.95rem; }
.btn-block{ width:100%; }

/* ============================================================
   HEADER
   ============================================================ */
.topbar{ background:var(--pine-deep); color:#C9D6CC; font-size:.78rem; letter-spacing:.06em; }
.topbar .container{ display:flex; justify-content:space-between; align-items:center; height:40px; }
.topbar a{ color:#C9D6CC; }
.topbar a:hover{ color:#fff; }
.topbar .tb-right{ display:flex; gap:26px; align-items:center; }
.topbar .acc{ color:var(--brass-lt); }

.site-header{ position:sticky; top:0; z-index:60; background:rgba(248,243,234,.88); backdrop-filter:blur(12px); border-bottom:1px solid var(--line); }
.nav{ display:flex; align-items:center; gap:30px; height:84px; }
.brand{ display:flex; align-items:center; gap:14px; flex-shrink:0; }
.brand .mono{ width:46px; height:46px; flex-shrink:0; }
.brand .wm{ display:flex; flex-direction:column; line-height:1; }
.brand .wm b{ font-family:var(--display); font-size:1.5rem; color:var(--ink); letter-spacing:.02em; font-weight:600; }
.brand .wm small{ font-family:var(--sans); font-size:.56rem; letter-spacing:.42em; text-transform:uppercase; color:var(--brass); font-weight:700; margin-top:3px; }

.nav-menu{ display:flex; align-items:center; gap:4px; margin:0 auto; list-style:none; padding:0; }
.nav-menu > li{ position:relative; }
.nav-menu > li > a, .nav-menu > li > button{
  display:flex; align-items:center; gap:7px; background:none; border:none;
  font-family:var(--sans); font-weight:600; font-size:.86rem; letter-spacing:.04em;
  text-transform:uppercase; color:var(--ink); padding:14px 14px;
}
.nav-menu > li > a:hover, .nav-menu > li > button:hover{ color:var(--clay); }
.nav-menu .caret{ width:7px; height:7px; border-right:1.5px solid currentColor; border-bottom:1.5px solid currentColor; transform:rotate(45deg) translateY(-2px); opacity:.6; transition:.2s; }
.nav-menu > li:hover .caret{ transform:rotate(225deg); }

.nav-actions{ display:flex; align-items:center; gap:20px; flex-shrink:0; }
.icon-btn{ background:none; border:none; color:var(--ink); display:flex; align-items:center; gap:7px; font-weight:700; font-size:.85rem; position:relative; }
.icon-btn:hover{ color:var(--clay); }
.icon-btn svg{ width:21px; height:21px; }
.icon-btn .cart-n{ position:absolute; top:-8px; right:-10px; background:var(--clay); color:#fff; font-size:.62rem; width:17px; height:17px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-weight:800; }

.dropdown{ position:absolute; top:100%; left:50%; transform:translateX(-50%) translateY(10px); background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow); padding:14px; opacity:0; visibility:hidden; transition:.22s ease; z-index:80; }
.nav-menu > li:hover .dropdown{ opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
.dropdown.dd-shop{ width:780px; display:grid; grid-template-columns:repeat(3,1fr); gap:2px 18px; }
.dropdown.dd-wide{ width:560px; }
.dd-link{ display:block; padding:11px 14px; border-radius:var(--radius); transition:.18s; }
.dd-link:hover{ background:var(--paper-2); }
.dd-link strong{ display:block; color:var(--ink); font-size:.92rem; font-weight:700; }
.dd-link span{ font-size:.74rem; color:var(--muted); letter-spacing:.04em; }
.dd-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:2px 14px; }

.burger{ display:none; background:none; border:none; flex-direction:column; gap:5px; padding:8px; }
.burger span{ width:26px; height:2px; background:var(--ink); }

/* ============================================================
   PLACEHOLDER BOX SHOTS — warm, embossed, brass monogram
   ============================================================ */
.boxshot{ position:relative; aspect-ratio:1/1; border-radius:var(--radius); overflow:hidden; display:flex; align-items:center; justify-content:center; background:var(--paper-2); }
.boxshot::after{ content:""; position:absolute; inset:0; background:radial-gradient(120% 90% at 30% 20%, rgba(255,255,255,.35), transparent 60%), linear-gradient(140deg, rgba(0,0,0,0), rgba(0,0,0,.12)); pointer-events:none; }
.boxshot .mono-mark{ position:relative; z-index:1; display:flex; flex-direction:column; align-items:center; gap:9px; }
.boxshot .mono-mark .ring{ width:54px; height:54px; border:1px solid var(--brass); border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:var(--display); font-size:1.3rem; color:var(--brass); }
.boxshot .mono-mark .cap{ font-family:var(--sans); font-size:.58rem; letter-spacing:.34em; text-transform:uppercase; font-weight:700; }
.boxshot.on-dark .mono-mark .ring,.boxshot.on-dark .mono-mark .cap{ color:var(--brass-lt); border-color:var(--brass-lt); }
.boxshot.on-light .mono-mark .ring,.boxshot.on-light .mono-mark .cap{ color:#A7906E; border-color:#BCA57F; }
.boxshot.on-dark .mono-mark .cap{ color:rgba(201,168,119,.9); }
.boxshot.on-light .mono-mark .cap{ color:rgba(122,108,86,.8); }

.badge-stock{ position:absolute; top:14px; left:14px; z-index:2; background:var(--pine); color:#E9E0D0; font-size:.66rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; padding:6px 12px; border-radius:2px; }

/* ============================================================
   BREADCRUMB
   ============================================================ */
.crumb{ font-size:.78rem; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); padding:22px 0; font-weight:600; }
.crumb a:hover{ color:var(--clay); }
.crumb .sep{ margin:0 10px; color:var(--brass); }
.crumb .cur{ color:var(--ink); }

/* ============================================================
   PRODUCT PAGE
   ============================================================ */
.pp-split{ display:grid; grid-template-columns:1.05fr 1fr; gap:64px; align-items:start; }
.pp-left{ position:sticky; top:108px; }

.gallery{ display:grid; grid-template-columns:88px 1fr; gap:18px; }
.thumbs{ display:flex; flex-direction:column; gap:14px; }
.thumb-s{ aspect-ratio:1/1; border-radius:var(--radius); cursor:pointer; position:relative; transition:.2s; }
.thumb-s::before{ content:""; position:absolute; inset:0; border:1px solid var(--line); border-radius:var(--radius); transition:.2s; }
.thumb-s.active::before{ border:1.5px solid var(--brass); box-shadow:0 0 0 3px rgba(176,137,79,.16); }
.thumb-s:hover::before{ border-color:var(--brass); }
.main-img{ aspect-ratio:1/1; border-radius:var(--radius); box-shadow:var(--shadow-sm); }

/* trust strip under gallery */
.trust-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; margin-top:34px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.trust-cell{ background:var(--paper); padding:20px 12px; text-align:center; transition:.2s; }
.trust-cell:hover{ background:var(--paper-2); }
.trust-cell svg{ width:26px; height:26px; color:var(--pine); margin:0 auto 9px; stroke-width:1.4; }
.trust-cell span{ font-size:.74rem; font-weight:600; color:var(--ink); letter-spacing:.02em; line-height:1.35; display:block; }
.pay-strip{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin-top:22px; }
.pay-strip .lbl{ font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); font-weight:700; margin-right:4px; }
.pay-strip .pay{ font-size:.72rem; font-weight:700; color:var(--ink-soft); border:1px solid var(--line); border-radius:3px; padding:6px 11px; background:var(--paper); letter-spacing:.02em; }

/* right column */
.pp-cat{ font-size:.74rem; letter-spacing:.24em; text-transform:uppercase; color:var(--clay); font-weight:700; }
.pp-title{ font-size:clamp(2.6rem,4.4vw,3.8rem); margin:14px 0 14px; }
.pp-rate{ display:flex; align-items:center; gap:12px; margin-bottom:22px; }
.pp-rate .stars{ color:var(--star); letter-spacing:3px; font-size:1rem; }
.pp-rate .rv{ font-size:.84rem; color:var(--muted); letter-spacing:.04em; }
.pp-desc{ font-size:1.06rem; color:var(--ink-soft); max-width:52ch; }

.pp-check{ list-style:none; padding:0; margin:24px 0; display:grid; grid-template-columns:1fr 1fr; gap:13px 24px; }
.pp-check li{ display:flex; gap:11px; align-items:flex-start; font-size:.95rem; color:var(--ink-soft); }
.pp-check .tick{ color:var(--clay); flex-shrink:0; margin-top:2px; }

.price-row{ display:flex; align-items:baseline; gap:14px; padding:22px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); margin:6px 0 0; }
.price-row .from{ font-size:.78rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); font-weight:700; }
.price-row .amt{ font-family:var(--display); font-size:2.6rem; color:var(--ink); line-height:1; }
.price-row .per{ font-size:.95rem; color:var(--muted); }
.price-note{ font-size:.88rem; color:var(--muted); margin:12px 0 0; font-style:italic; }

/* coupon ticket */
.ticket{ position:relative; display:flex; align-items:center; gap:16px; background:var(--pine); color:#EDE3D2; border-radius:var(--radius); padding:18px 22px; margin:24px 0; overflow:hidden; }
.ticket::before,.ticket::after{ content:""; position:absolute; width:18px; height:18px; border-radius:50%; background:var(--canvas); top:50%; transform:translateY(-50%); }
.ticket::before{ left:-9px; } .ticket::after{ right:-9px; }
.ticket .tk-ico{ font-size:1.5rem; }
.ticket b{ color:#fff; }
.ticket .code{ display:inline-block; font-family:var(--sans); font-weight:800; letter-spacing:.1em; color:var(--pine); background:var(--brass-lt); padding:3px 10px; border-radius:3px; margin-top:4px; }

/* configurator */
.config{ margin-top:30px; }
.config h4{ font-family:var(--sans); font-weight:700; font-size:.82rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink); margin-bottom:16px; }
.cfg-grid{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.cfg-field{ display:flex; flex-direction:column; gap:6px; }
.cfg-field.full{ grid-column:1/-1; }
.cfg-field label{ font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); font-weight:700; }
.field{ width:100%; background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:13px 15px; font-family:inherit; font-size:.94rem; color:var(--ink); transition:.18s; }
.field:focus{ outline:none; border-color:var(--brass); box-shadow:0 0 0 3px rgba(176,137,79,.14); }
.field::placeholder{ color:#A99C8A; }
select.field{ appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%238A7E6E' d='M6 8L0 0h12z'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 15px center; padding-right:36px; }
textarea.field{ min-height:96px; resize:vertical; }

/* swatch chips */
.swatches{ display:flex; gap:10px; flex-wrap:wrap; }
.swatch{ width:38px; height:38px; border-radius:50%; border:1px solid var(--line); cursor:pointer; position:relative; transition:.15s; }
.swatch.active{ box-shadow:0 0 0 2px var(--canvas), 0 0 0 3.5px var(--brass); }
.size-chips{ display:flex; gap:10px; flex-wrap:wrap; }
.chip{ border:1px solid var(--line); background:var(--paper); border-radius:var(--radius); padding:9px 16px; font-size:.86rem; font-weight:600; color:var(--ink-soft); cursor:pointer; transition:.15s; }
.chip.active{ border-color:var(--clay); background:var(--clay); color:#fff; }

/* qty + cart */
.buy-bar{ display:flex; gap:14px; align-items:stretch; margin-top:26px; flex-wrap:wrap; }
.qty{ display:flex; align-items:center; border:1px solid var(--ink); border-radius:var(--radius); overflow:hidden; }
.qty button{ width:46px; background:transparent; color:var(--ink); border:none; font-size:1.3rem; }
.qty button:hover{ background:var(--ink); color:var(--canvas); }
.qty input{ width:54px; text-align:center; border:none; border-left:1px solid var(--line); border-right:1px solid var(--line); font-size:1rem; font-weight:700; background:transparent; color:var(--ink); }
.buy-bar .btn-primary{ flex:1; }

.assurance{ display:flex; gap:22px; flex-wrap:wrap; margin-top:20px; }
.assurance span{ display:flex; align-items:center; gap:8px; font-size:.84rem; color:var(--muted); font-weight:600; }
.assurance svg{ width:17px; height:17px; color:var(--pine); }

/* ============================================================
   SECTION HEADINGS
   ============================================================ */
.sec-head{ text-align:center; max-width:60ch; margin:0 auto 56px; }
.sec-head .eyebrow{ margin-bottom:18px; }
.sec-head .eyebrow::before{ display:none; }
.sec-head h2{ margin-bottom:14px; }

/* testimonials */
.testi{ background:var(--pine); color:#E5DBC9; }
.testi h2{ color:#FBF7EF; }
.testi .eyebrow{ color:var(--brass-lt); }
.testi-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.testi-card{ background:var(--pine-2); border:1px solid var(--line-dark); border-radius:var(--radius); padding:30px; }
.testi-card .stars{ color:var(--brass-lt); letter-spacing:3px; margin-bottom:14px; }
.testi-card .quote-txt{ font-family:var(--display); font-size:1.22rem; line-height:1.5; color:#F4ECDD; margin-bottom:22px; }
.testi-card .who{ display:flex; align-items:center; gap:12px; padding-top:18px; border-top:1px solid var(--line-dark); }
.testi-card .avatar{ width:44px; height:44px; border-radius:50%; background:var(--brass); color:var(--pine-deep); display:flex; align-items:center; justify-content:center; font-family:var(--display); font-weight:700; }
.testi-card .nm{ font-weight:700; color:#fff; font-size:.95rem; }
.testi-card .vb{ font-size:.74rem; color:var(--brass-lt); letter-spacing:.06em; }

/* tabbed description */
.ctab{ display:flex; gap:30px; justify-content:center; border-bottom:1px solid var(--line); margin-bottom:48px; flex-wrap:wrap; }
.ctab .tab{ background:none; border:none; border-bottom:2px solid transparent; color:var(--muted); padding:0 2px 16px; font-size:.82rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; margin-bottom:-1px; transition:.2s; }
.ctab .tab:hover{ color:var(--ink); }
.ctab .tab.active{ color:var(--clay); border-color:var(--clay); }
.prose{ max-width:760px; margin:0 auto; }
.prose h3{ font-family:var(--sans); font-weight:700; font-size:1.3rem; color:var(--ink); margin:32px 0 12px; letter-spacing:-.01em; }
.prose p{ font-size:1.05rem; line-height:1.8; }
.prose ul{ padding-left:0; list-style:none; display:flex; flex-direction:column; gap:12px; margin:18px 0; }
.prose ul li{ padding-left:30px; position:relative; }
.prose ul li::before{ content:""; position:absolute; left:0; top:.62em; width:14px; height:1px; background:var(--clay); }
.spec-table{ width:100%; border-collapse:collapse; }
.spec-table td{ padding:15px 0; border-bottom:1px solid var(--line); font-size:.98rem; vertical-align:top; }
.spec-table td:first-child{ width:34%; font-weight:700; color:var(--ink); letter-spacing:.02em; }
.fin-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:26px; max-width:860px; margin:0 auto; }
.fin-card{ display:flex; gap:18px; align-items:flex-start; }
.fin-card .fc-shot{ width:96px; height:96px; flex-shrink:0; border-radius:var(--radius); }
.fin-card h4{ font-family:var(--sans); font-weight:700; font-size:1.02rem; color:var(--ink); margin-bottom:6px; }
.fin-card p{ font-size:.92rem; margin:0; }

/* FAQ */
.faq{ max-width:860px; margin:0 auto; }
.faq-item{ border-bottom:1px solid var(--line); }
.faq-q{ width:100%; text-align:left; background:none; border:none; display:flex; justify-content:space-between; align-items:center; gap:18px; padding:26px 0; font-weight:700; color:var(--ink); font-size:1.12rem; font-family:var(--display); }
.faq-q .pm{ position:relative; width:18px; height:18px; flex-shrink:0; }
.faq-q .pm::before,.faq-q .pm::after{ content:""; position:absolute; background:var(--clay); transition:.25s; }
.faq-q .pm::before{ top:50%; left:0; right:0; height:1.5px; transform:translateY(-50%); }
.faq-q .pm::after{ left:50%; top:0; bottom:0; width:1.5px; transform:translateX(-50%); }
.faq-item.open .pm::after{ transform:translateX(-50%) scaleY(0); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .3s ease; }
.faq-a-inner{ padding:0 0 26px; color:var(--ink-soft); font-size:1rem; max-width:64ch; }

/* product grid (related) */
.pop-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:26px; }
.pop-card .boxshot{ margin-bottom:16px; }
.pop-card .name{ text-align:center; font-family:var(--display); font-size:1.2rem; color:var(--ink); }
.pop-card:hover .name{ color:var(--clay); }
.pop-card .pc-from{ text-align:center; font-size:.8rem; color:var(--muted); letter-spacing:.08em; text-transform:uppercase; margin-top:4px; }

/* ============================================================
   CTA band + FOOTER
   ============================================================ */
.cta-band{ background:var(--clay); color:#FBEFE6; }
.cta-band .row{ display:flex; align-items:center; justify-content:space-between; gap:40px; padding:60px 0; flex-wrap:wrap; }
.cta-band h2{ color:#fff; max-width:18ch; }
.cta-band .news{ display:flex; gap:12px; }
.cta-band .news input{ background:rgba(255,255,255,.16); border:1px solid rgba(255,255,255,.4); color:#fff; border-radius:var(--radius); padding:1rem 1.3rem; min-width:280px; font-size:.95rem; }
.cta-band .news input::placeholder{ color:#F3DDD0; }
.cta-band .btn-pine{ background:var(--pine-deep); }

.site-footer{ background:var(--pine-deep); color:#A9B8AD; padding:72px 0 0; }
.foot-top{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1.4fr; gap:40px; padding-bottom:48px; border-bottom:1px solid var(--line-dark); }
.foot-about .brand .wm b{ color:#FBF7EF; }
.foot-about p{ font-size:.92rem; color:#94A399; margin-top:20px; max-width:34ch; }
.foot-rev{ display:flex; gap:12px; margin-top:20px; }
.foot-rev .chip{ background:rgba(255,255,255,.06); border:1px solid var(--line-dark); border-radius:3px; padding:8px 13px; font-size:.76rem; color:#C9D6CC; display:flex; gap:7px; align-items:center; }
.foot-rev .chip .s{ color:var(--brass-lt); }
.foot-col h5{ font-family:var(--sans); text-transform:uppercase; letter-spacing:.18em; font-size:.72rem; color:#fff; margin:0 0 20px; font-weight:700; }
.foot-col ul{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:12px; }
.foot-col a{ color:#94A399; font-size:.9rem; }
.foot-col a:hover{ color:var(--brass-lt); }
.foot-contact li{ display:flex; gap:11px; margin-bottom:14px; font-size:.88rem; align-items:flex-start; color:#94A399; }
.foot-contact svg{ width:17px; height:17px; color:var(--brass-lt); flex-shrink:0; margin-top:2px; }
.foot-bottom{ display:flex; justify-content:space-between; align-items:center; padding:24px 0; flex-wrap:wrap; gap:16px; }
.foot-bottom .copy{ font-size:.82rem; color:#74837A; letter-spacing:.04em; }
.socials{ display:flex; gap:10px; }
.socials a{ width:36px; height:36px; border-radius:50%; border:1px solid var(--line-dark); display:flex; align-items:center; justify-content:center; transition:.2s; }
.socials a:hover{ background:var(--brass); border-color:var(--brass); }
.socials a:hover svg{ color:var(--pine-deep); }
.socials svg{ width:15px; height:15px; color:#A9B8AD; }

/* mobile drawer */
.mobile-drawer{ position:fixed; inset:0 0 0 auto; width:86%; max-width:380px; background:var(--paper); z-index:120; transform:translateX(100%); transition:.3s; padding:28px; overflow-y:auto; box-shadow:-12px 0 44px rgba(0,0,0,.18); }
.mobile-drawer.open{ transform:translateX(0); }
.mobile-backdrop{ position:fixed; inset:0; background:rgba(24,20,16,.5); z-index:110; opacity:0; visibility:hidden; transition:.3s; }
.mobile-backdrop.open{ opacity:1; visibility:visible; }
.mobile-drawer a{ display:block; padding:15px 4px; border-bottom:1px solid var(--line); font-weight:600; color:var(--ink); text-transform:uppercase; letter-spacing:.06em; font-size:.9rem; }
.mobile-drawer .mclose{ background:none; border:none; font-size:2rem; float:right; color:var(--ink); line-height:1; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .nav-menu{ display:none; }
  .burger{ display:flex; }
  .testi-grid, .pop-grid{ grid-template-columns:repeat(2,1fr); }
  .foot-top{ grid-template-columns:1fr 1fr; }
}
@media (max-width:920px){
  .pp-split{ grid-template-columns:1fr; gap:44px; }
  .pp-left{ position:static; }
}
@media (max-width:600px){
  .section{ padding:64px 0; }
  .gallery{ grid-template-columns:64px 1fr; gap:12px; }
  .pp-check{ grid-template-columns:1fr; }
  .cfg-grid{ grid-template-columns:1fr; }
  .trust-grid{ grid-template-columns:repeat(2,1fr); }
  .testi-grid, .pop-grid, .fin-grid{ grid-template-columns:1fr; }
  .foot-top{ grid-template-columns:1fr; }
  .container{ padding:0 20px; }
}
