/* ============================================================
   3DAX — section styles · part 2
   product detail · reviews · cart · checkout · footer
   ============================================================ */

/* shared overlay scrim + fade */
@keyframes ovFade{ from{ opacity:0; } to{ opacity:1; } }
@keyframes panelUp{ from{ opacity:0; transform:translateY(30px) scale(.99); } to{ opacity:1; transform:none; } }
@keyframes drawerIn{ from{ transform:translateX(100%); } to{ transform:none; } }

/* ---------------- PRODUCT DETAIL ---------------- */
.pd{ position:fixed; inset:0; z-index:120; display:flex; align-items:center; justify-content:center; padding:40px; }
.pd__scrim{ position:absolute; inset:0; background:rgba(44,26,16,.55); backdrop-filter:blur(8px); animation:ovFade .35s var(--ease); }
.pd__panel{ position:relative; z-index:2; width:min(1100px,100%); max-height:90vh; overflow:auto; background:var(--ink-2); border:1px solid var(--line); border-radius:var(--r-lg); animation:panelUp .5s var(--ease); }
.pd__panel::-webkit-scrollbar{ width:8px; } .pd__panel::-webkit-scrollbar-thumb{ background:var(--rust); border-radius:10px; }
.pd__close{ position:absolute; top:16px; right:16px; z-index:5; width:40px; height:40px; border-radius:50%; display:grid; place-items:center; color:var(--cream); background:var(--ink-3); border:1px solid var(--line); transition:background .3s, transform .3s; }
.pd__close:hover{ background:var(--rust); color:var(--on-dark); transform:rotate(90deg); }
.pd__grid{ display:grid; grid-template-columns:1.05fr .95fr; }
.pd__gallery{ padding:30px; border-right:1px solid var(--line-soft); background:radial-gradient(120% 100% at 50% 0%, rgba(217,138,43,.08), transparent 60%); }
.pd__viewer{ position:relative; aspect-ratio:1; display:flex; align-items:center; justify-content:center; overflow:hidden; border-radius:var(--r-md); cursor:crosshair; }
.pd__halo{ position:absolute; width:72%; aspect-ratio:1; border-radius:50%; background:radial-gradient(circle, rgba(217,138,43,.18), rgba(240,72,154,.10) 50%, transparent 70%); filter:blur(8px); }
.pd__img{ position:relative; z-index:2; max-width:88%; max-height:88%; width:auto; object-fit:contain; transition:transform .25s var(--ease-out); filter:var(--shadow-prod); }
.pd__zoomhint{ position:absolute; bottom:10px; left:50%; transform:translateX(-50%); font-family:var(--mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--cream-faint); z-index:3; }
.pd__thumbs{ display:flex; gap:10px; margin-top:18px; flex-wrap:wrap; }
.pd__thumb{ width:64px; height:64px; border-radius:var(--r-sm); border:1px solid var(--line-soft); overflow:hidden; padding:6px; background:var(--ink-3); transition:border-color .3s, transform .3s; }
.pd__thumb img{ width:100%; height:100%; object-fit:contain; }
.pd__thumb.on{ border-color:var(--gold); }
.pd__thumb:hover{ transform:translateY(-2px); }

.pd__info{ padding:42px 40px; }
.pd__char{ font-family:var(--mono); font-size:12px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); }
.pd__name{ font-size:clamp(30px,3.4vw,44px); margin:10px 0 14px; }
.pd__meta{ display:flex; align-items:center; gap:10px; font-size:13px; color:var(--cream-dim); flex-wrap:wrap; }
.pd__dot{ opacity:.4; }
.pd__stock{ color:var(--gold-soft); }
.pd__price{ font-family:var(--display); font-size:38px; color:var(--cream); margin:18px 0 16px; }
.pd__blurb{ color:var(--cream-dim); line-height:1.7; margin-bottom:26px; }
.pd__block{ margin-bottom:26px; }
.pd__label{ font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--cream-faint); margin-bottom:12px; }
.pd__label span{ color:var(--cream); }
.pd__ways{ display:flex; gap:12px; }
.pd__way{ width:46px; height:46px; border-radius:50%; padding:4px; border:1px solid var(--line); background:transparent; transition:border-color .3s, transform .3s; }
.pd__way span{ display:block; width:100%; height:100%; border-radius:50%; }
.pd__way.on{ border-color:var(--gold); }
.pd__way:hover{ transform:translateY(-2px); }
.pd__buy{ display:flex; gap:14px; align-items:stretch; margin-bottom:28px; }
.qty{ display:flex; align-items:center; border:1px solid var(--line); border-radius:100px; overflow:hidden; }
.qty button{ width:46px; height:100%; font-size:20px; color:var(--cream); transition:background .2s; }
.qty button:hover{ background:rgba(130,38,20,.08); }
.qty span{ min-width:34px; text-align:center; font-family:var(--mono); font-size:15px; }
.qty--sm{ height:36px; }
.qty--sm button{ width:34px; font-size:16px; }
.qty--sm span{ min-width:26px; font-size:13px; }
.pd__add{ flex:1; justify-content:space-between; }
.pd__add.is-added{ background:var(--gold); color:var(--on-dark); }
.pd__add-price{ font-family:var(--display); }
.pd__specs{ display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--line-soft); border:1px solid var(--line-soft); border-radius:var(--r-md); overflow:hidden; margin-bottom:22px; }
.pd__spec{ background:var(--ink-2); padding:14px 16px; }
.pd__spec-k{ display:block; font-family:var(--mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--cream-faint); margin-bottom:4px; }
.pd__spec-v{ font-size:14px; color:var(--cream); }
.pd__assur{ display:flex; gap:18px; flex-wrap:wrap; font-size:12px; color:var(--cream-dim); }
@media (max-width:820px){
  .pd{ padding:0; }
  .pd__panel{ max-height:100vh; height:100vh; border-radius:0; }
  .pd__grid{ grid-template-columns:1fr; }
  .pd__gallery{ border-right:0; border-bottom:1px solid var(--line-soft); }
  .pd__info{ padding:30px 24px 48px; }
}

/* ---------------- REVIEWS ---------------- */
.reviews{ padding:40px 0 120px; position:relative; }
.reviews__head{ display:flex; justify-content:space-between; align-items:flex-end; gap:30px; margin-bottom:50px; }
.reviews__title{ font-size:clamp(32px,4.4vw,58px); margin-top:14px; }
.reviews__title em{ font-style:italic; color:var(--rust); }
.reviews__score{ display:flex; align-items:center; gap:16px; }
.reviews__big{ font-size:64px; color:var(--gold); line-height:1; }
.reviews__count{ font-size:12px; color:var(--cream-faint); margin-top:6px; }
.reviews__grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
.review{ padding:30px; border:1px solid var(--line-soft); border-radius:var(--r-lg); background:var(--ink-2); transition:border-color .4s, transform .4s; }
.review:hover{ border-color:var(--line); transform:translateY(-3px); }
.review--feat{ grid-column:span 2; background:radial-gradient(120% 140% at 0% 0%, rgba(217,138,43,.10), rgba(240,72,154,.07) 50%, transparent 60%), var(--ink-2); }
.review__text{ font-family:var(--display); font-size:clamp(18px,1.8vw,24px); line-height:1.5; color:var(--cream); margin:18px 0 22px; }
.review--feat .review__text{ font-size:clamp(22px,2.6vw,32px); }
.review__foot{ display:flex; align-items:center; gap:14px; }
.review__avatar{ width:44px; height:44px; border-radius:50%; background:linear-gradient(135deg,var(--rust),var(--gold-deep)); display:grid; place-items:center; font-family:var(--display); font-size:18px; color:var(--cream); }
.review__name{ font-weight:600; font-size:15px; }
.review__place{ font-family:var(--mono); font-size:11px; color:var(--cream-faint); letter-spacing:.04em; }
.review__verified{ margin-left:auto; width:26px; height:26px; border-radius:50%; background:rgba(217,138,43,.14); color:var(--gold-deep); display:grid; place-items:center; font-size:13px; }
@media (max-width:820px){
  .reviews__head{ flex-direction:column; align-items:flex-start; }
  .reviews__grid{ grid-template-columns:1fr; }
  .review--feat{ grid-column:span 1; }
}

/* ---------------- CART DRAWER ---------------- */
.cart{ position:fixed; inset:0; z-index:130; visibility:hidden; }
.cart.open{ visibility:visible; }
.cart__scrim{ position:absolute; inset:0; background:rgba(44,26,16,.5); opacity:0; transition:opacity .4s; }
.cart.open .cart__scrim{ opacity:1; }
.cart__panel{ position:absolute; top:0; right:0; height:100%; width:min(440px,100%); background:var(--ink-2); border-left:1px solid var(--line); display:flex; flex-direction:column; transform:translateX(100%); transition:transform .5s var(--ease-out); }
.cart.open .cart__panel{ transform:none; }
.cart__head{ display:flex; align-items:center; justify-content:space-between; padding:24px 26px; border-bottom:1px solid var(--line-soft); }
.cart__head h3{ font-size:24px; } .cart__head span{ color:var(--gold); }
.cart__close{ width:36px; height:36px; border-radius:50%; display:grid; place-items:center; border:1px solid var(--line); color:var(--cream); transition:background .3s,transform .3s; }
.cart__close:hover{ background:var(--rust); color:var(--on-dark); transform:rotate(90deg); }
.cart__empty{ flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:18px; color:var(--cream-dim); }
.cart__empty-glyph{ font-size:42px; opacity:.5; }
.cart__items{ flex:1; overflow-y:auto; padding:10px 26px; }
.cart__items::-webkit-scrollbar{ width:6px; } .cart__items::-webkit-scrollbar-thumb{ background:var(--rust); border-radius:10px; }
.line{ display:flex; gap:14px; padding:18px 0; border-bottom:1px solid var(--line-soft); position:relative; }
.line__media{ width:70px; height:70px; flex-shrink:0; border-radius:var(--r-sm); background:var(--ink-3); display:grid; place-items:center; overflow:hidden; padding:6px; }
.line__media img{ width:100%; height:100%; object-fit:contain; }
.line__ph{ width:100%; height:100%; border-radius:4px; }
.line__info{ flex:1; min-width:0; }
.line__name{ font-weight:600; font-size:15px; }
.line__way{ font-family:var(--mono); font-size:11px; color:var(--cream-faint); margin:3px 0 12px; }
.line__bottom{ display:flex; align-items:center; justify-content:space-between; }
.line__price{ font-family:var(--display); font-size:17px; }
.line__rm{ position:absolute; top:18px; right:0; color:var(--cream-faint); font-size:18px; width:24px; height:24px; transition:color .2s; }
.line__rm:hover{ color:var(--rust-bright); }
.cart__foot{ padding:22px 26px 26px; border-top:1px solid var(--line); }
.cart__freeship{ font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--gold); margin-bottom:14px; text-align:center; }
.cart__rowline{ display:flex; justify-content:space-between; font-size:14px; color:var(--cream-dim); margin-bottom:8px; }
.cart__total{ display:flex; justify-content:space-between; font-family:var(--display); font-size:22px; color:var(--cream); margin:14px 0 18px; padding-top:14px; border-top:1px solid var(--line-soft); }
.cart__safe{ text-align:center; font-size:11px; color:var(--cream-faint); margin-top:14px; }

/* ---------------- CHECKOUT ---------------- */
.co{ position:fixed; inset:0; z-index:140; display:flex; align-items:center; justify-content:center; padding:30px; }
.co__scrim{ position:absolute; inset:0; background:rgba(44,26,16,.62); backdrop-filter:blur(8px); animation:ovFade .35s var(--ease); }
.co__panel{ position:relative; z-index:2; width:min(1000px,100%); max-height:92vh; overflow:auto; background:var(--ink); border:1px solid var(--line); border-radius:var(--r-lg); animation:panelUp .5s var(--ease); }
.co__panel::-webkit-scrollbar{ width:8px; } .co__panel::-webkit-scrollbar-thumb{ background:var(--rust); border-radius:10px; }
.co__bar{ display:flex; align-items:center; justify-content:space-between; padding:20px 30px; border-bottom:1px solid var(--line-soft); position:sticky; top:0; background:rgba(251,242,225,.92); backdrop-filter:blur(10px); z-index:5; }
.co__steps{ display:flex; align-items:center; gap:12px; }
.co__step{ font-family:var(--mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--cream-faint); }
.co__step.on{ color:var(--gold); }
.co__sep{ width:24px; height:1px; background:var(--line); }
.co__close{ width:38px; height:38px; border-radius:50%; display:grid; place-items:center; border:1px solid var(--line); color:var(--cream); transition:background .3s,transform .3s; }
.co__close:hover{ background:var(--rust); transform:rotate(90deg); }
.co__grid{ display:grid; grid-template-columns:1.25fr .75fr; }
.co__form{ padding:36px 38px; }
.co__sect{ animation:ovFade .4s var(--ease); }
.co__h{ font-family:var(--display); font-size:24px; margin-bottom:22px; }
.co__back{ font-family:var(--mono); font-size:12px; color:var(--cream-dim); margin-bottom:16px; transition:color .2s; }
.co__back:hover{ color:var(--gold); }
.co__row2{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.co__row3{ display:grid; grid-template-columns:1.4fr .8fr 1fr; gap:14px; }

.field{ display:block; margin-bottom:16px; }
.field__label{ display:flex; justify-content:space-between; font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--cream-faint); margin-bottom:7px; }
.field__msg{ color:var(--rust-bright); text-transform:none; letter-spacing:0; }
.field input, .field select{ width:100%; height:50px; padding:0 16px; background:var(--ink-2); border:1px solid var(--line-soft); border-radius:var(--r-sm); color:var(--cream); font-family:var(--body); font-size:15px; transition:border-color .25s, box-shadow .25s; }
.field input:focus, .field select:focus{ outline:none; border-color:var(--gold); box-shadow:0 0 0 3px rgba(217,138,43,.16); }
.field input::placeholder{ color:rgba(44,26,16,.34); }
.field--err input{ border-color:var(--rust-bright); }

.co__methods{ display:flex; gap:12px; margin-bottom:22px; }
.co__method{ flex:1; display:flex; align-items:center; gap:10px; justify-content:center; height:58px; border:1px solid var(--line); border-radius:var(--r-md); color:var(--cream); font-weight:600; font-size:14px; transition:border-color .3s, background .3s; }
.co__method.on{ border-color:var(--gold); background:rgba(217,138,43,.08); }
.co__method-ic{ font-size:18px; }
.co__cards{ display:flex; gap:4px; }
.co__cards b{ font-family:var(--mono); font-size:9px; padding:2px 4px; border:1px solid var(--line); border-radius:3px; color:var(--cream-faint); }
.co__pp{ font-family:Arial,sans-serif; font-weight:800; font-size:20px; font-style:italic; }
.co__pp i, .co__ppbtn i{ font-style:italic; }
.co__pp i:first-child{ color:#7fb2e0; } .co__pp i:last-child{ color:#d9e6f2; }
.co__card, .co__paypal{ animation:ovFade .3s var(--ease); }
.co__cardnum{ position:relative; }
.co__brand{ position:absolute; right:14px; top:50%; transform:translateY(-50%); font-family:var(--mono); font-size:11px; letter-spacing:.1em; color:var(--gold); }
.co__pay{ margin-top:8px; justify-content:center; gap:8px; }
.co__powered{ text-align:center; font-size:11px; color:var(--cream-faint); margin-top:14px; }
.co__powered b{ color:var(--cream-dim); font-style:italic; }
.co__pphint{ font-size:14px; color:var(--cream-dim); margin-bottom:18px; text-align:center; }
.co__ppbtn{ width:100%; height:54px; border-radius:100px; background:#ffc439; color:#003087; font-family:Arial,sans-serif; font-weight:800; font-size:20px; font-style:italic; display:flex; align-items:center; justify-content:center; transition:filter .3s, transform .2s; }
.co__ppbtn:hover{ filter:brightness(1.05); } .co__ppbtn:active{ transform:scale(.98); }
.co__ppbtn i:first-child{ color:#003087; } .co__ppbtn i:last-child{ color:#0070ba; }
.co__safe{ text-align:center; font-size:11px; color:var(--cream-faint); margin-top:18px; }

.spin{ width:20px; height:20px; border-radius:50%; border:2px solid rgba(251,242,225,.3); border-top-color:var(--cream); animation:spin .7s linear infinite; }
.spin--dark{ border-color:rgba(0,48,135,.3); border-top-color:#003087; }
@keyframes spin{ to{ transform:rotate(360deg); } }

.co__summary{ padding:36px 30px; background:var(--ink-2); border-left:1px solid var(--line-soft); }
.co__sumhead{ font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--cream-faint); margin-bottom:20px; }
.co__sumline{ display:flex; align-items:center; gap:12px; margin-bottom:16px; }
.co__sumthumb{ position:relative; width:50px; height:50px; flex-shrink:0; border-radius:var(--r-sm); background:var(--ink-3); overflow:hidden; padding:5px; }
.co__sumthumb img{ width:100%; height:100%; object-fit:contain; }
.co__sumqty{ position:absolute; top:-6px; right:-6px; width:20px; height:20px; border-radius:50%; background:var(--rust); color:var(--cream); font-family:var(--mono); font-size:11px; display:grid; place-items:center; border:2px solid var(--ink-2); }
.co__suminfo{ flex:1; min-width:0; font-size:14px; } .co__suminfo small{ display:block; font-family:var(--mono); font-size:11px; color:var(--cream-faint); margin-top:2px; }
.co__sumprice{ font-family:var(--display); font-size:15px; }
.co__sumtot{ border-top:1px solid var(--line-soft); padding-top:16px; margin-top:8px; }
.co__sumtot > div{ display:flex; justify-content:space-between; font-size:14px; color:var(--cream-dim); margin-bottom:8px; }
.co__grand{ font-family:var(--display); font-size:22px; color:var(--cream)!important; padding-top:10px; border-top:1px solid var(--line-soft); margin-top:6px; }
.co__perks{ display:flex; flex-direction:column; gap:8px; margin-top:24px; font-size:12px; color:var(--cream-dim); }

.co__done{ padding:60px 40px; text-align:center; max-width:560px; margin:0 auto; animation:panelUp .5s var(--ease); }
.co__check{ width:74px; height:74px; border-radius:50%; background:var(--gold); color:var(--on-dark); font-size:38px; display:grid; place-items:center; margin:0 auto 24px; animation:pop .5s var(--ease); }
@keyframes pop{ 0%{ transform:scale(0); } 60%{ transform:scale(1.15); } 100%{ transform:scale(1); } }
.co__done h2{ font-size:clamp(32px,4vw,48px); margin-bottom:14px; }
.co__done .lead{ margin-bottom:28px; }
.co__doneitems{ text-align:left; background:var(--ink-2); border:1px solid var(--line-soft); border-radius:var(--r-md); padding:18px 20px; margin-bottom:28px; }
.co__doneitem{ display:flex; justify-content:space-between; font-size:14px; color:var(--cream-dim); padding:8px 0; }
.co__doneitem--tot{ border-top:1px solid var(--line-soft); margin-top:6px; padding-top:14px; font-family:var(--display); font-size:18px; color:var(--cream); }
@media (max-width:820px){
  .co{ padding:0; }
  .co__panel{ max-height:100vh; height:100vh; border-radius:0; }
  .co__grid{ grid-template-columns:1fr; }
  .co__summary{ border-left:0; border-top:1px solid var(--line-soft); order:-1; }
  .co__row3{ grid-template-columns:1fr 1fr; }
}

.showcase{ padding:60px 0 90px; position:relative; }
.showcase__grid{ display:grid; grid-template-columns:1fr 1fr; gap:54px; align-items:center; }
.showcase__title{ font-size:clamp(32px,4.2vw,56px); margin-top:16px; }
.showcase__title em{ font-style:italic; color:var(--rust); }
.showcase__list{ list-style:none; margin-top:22px; display:flex; flex-direction:column; gap:10px; }
.showcase__list li{ position:relative; padding-left:22px; font-size:14px; color:var(--cream-dim); }
.showcase__list li::before{ content:"▸"; position:absolute; left:0; color:var(--gold); }
.showcase__slots{ display:flex; flex-direction:column; gap:16px; }
.showcase__mini{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
@media (max-width:880px){
  .showcase__grid{ grid-template-columns:1fr; gap:30px; }
}

/* ---------------- FRANCHISE BAND ---------------- */
.franchises{ margin-top:64px; padding-top:50px; border-top:1px solid var(--line-soft); }
.franchises__head{ display:flex; justify-content:space-between; align-items:baseline; gap:20px; margin-bottom:26px; flex-wrap:wrap; }
.franchises__head h3{ font-family:var(--display); font-size:clamp(22px,2.6vw,32px); }
.franchises__head p{ font-size:14px; color:var(--cream-dim); max-width:420px; }
.franchises__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.fcard{ display:flex; flex-direction:column; gap:6px; padding:22px; border:1px solid var(--line-soft); border-radius:var(--r-md); background:var(--ink-2); transition:border-color .35s, transform .35s; }
.fcard:hover{ border-color:var(--gold); transform:translateY(-3px); }
.fcard__top{ display:flex; align-items:baseline; justify-content:space-between; gap:10px; }
.fcard__name{ font-family:var(--display); font-size:20px; }
.fcard__count{ font-family:var(--mono); font-size:12px; color:var(--gold); }
.fcard__note{ font-size:12.5px; color:var(--cream-faint); line-height:1.5; }
.fcard{ cursor:pointer; text-align:left; font-family:inherit; width:100%; }
.fcard__go{ font-family:var(--mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--rust); margin-top:6px; opacity:0; transform:translateX(-4px); transition:opacity .3s, transform .3s; }
.fcard:hover .fcard__go{ opacity:1; transform:none; }
@media (max-width:880px){ .franchises__grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .franchises__grid{ grid-template-columns:1fr; } }

/* collection filter tabs */
.catfilter{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom:36px; }
.catfilter__tab{ display:inline-flex; align-items:center; gap:8px; padding:10px 18px; border-radius:100px; border:1px solid var(--line); background:var(--ink-2); color:var(--cream-dim); font-family:var(--body); font-weight:600; font-size:14px; transition:border-color .25s, color .25s, background .25s, transform .15s; }
.catfilter__tab:hover{ border-color:var(--gold); color:var(--cream); }
.catfilter__tab:active{ transform:scale(.97); }
.catfilter__tab.on{ background:var(--rust); border-color:var(--rust); color:var(--on-dark); }
.catfilter__n{ font-family:var(--mono); font-size:11px; opacity:.7; }
.catfilter__tab.on .catfilter__n{ opacity:.85; }

/* collection empty state */
.catalog__empty{ text-align:center; max-width:480px; margin:20px auto 10px; padding:50px 30px; border:1px dashed var(--line); border-radius:var(--r-lg); background:var(--ink-2); }
.catalog__empty-ic{ font-size:42px; color:var(--gold); opacity:.5; }
.catalog__empty h3{ font-size:24px; margin:14px 0 10px; }
.catalog__empty p{ color:var(--cream-dim); font-size:15px; line-height:1.7; margin-bottom:22px; }

/* ---------------- FOOTER ---------------- */
.footer{ position:relative; padding:74px 0 30px; background:var(--rust-deep); color:var(--on-dark); }
.footer .brand__mark{ color:var(--on-dark); }
.footer__inner{ display:grid; grid-template-columns:1.2fr 2fr; gap:50px; margin-bottom:50px; }
.footer__tag{ color:rgba(253,246,232,.72); font-size:14px; line-height:1.7; margin:16px 0 20px; }
.footer__social{ display:flex; gap:18px; }
.footer__social a{ font-family:var(--mono); font-size:12px; letter-spacing:.08em; color:rgba(253,246,232,.72); transition:color .2s; }
.footer__social a:hover{ color:var(--gold-soft); }
.footer__cols{ display:grid; grid-template-columns:repeat(3,1fr); gap:30px; }
.footer__col h4{ font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:rgba(253,246,232,.5); margin-bottom:16px; font-weight:500; }
.footer__col a{ display:block; font-size:14px; color:rgba(253,246,232,.78); margin-bottom:11px; transition:color .2s; }
.footer__col a:hover{ color:var(--on-dark); }
.footer__bottom{ display:flex; justify-content:space-between; gap:20px; padding-top:24px; border-top:1px solid rgba(253,246,232,.16); font-size:12px; color:rgba(253,246,232,.5); }
@media (max-width:820px){
  .footer__inner{ grid-template-columns:1fr; gap:34px; }
  .footer__bottom{ flex-direction:column; gap:8px; }
}
