/* ============================================================
   TBCC — Home-only styles (hero, heritage, gifts, brands, journal)
   Shared components (nav, footer, cards, news, benefits) live in
   tbcc-design-system.css. This file only adds the home-unique blocks
   from the approved prototype (index.html).
   ============================================================ */

/* ---------- HERO ---------- */
.hero{display:grid;grid-template-columns:1.05fr 1fr;min-height:380px;background:var(--cream)}
.hero__copy{display:flex;flex-direction:column;justify-content:center;padding:clamp(32px,3vw,48px) clamp(20px,4.5vw,72px);position:relative}
.hero__copy h1{font-size:clamp(28px,3vw,42px);margin:14px 0 16px}
.hero__copy p.lead{font-size:clamp(15px,1.1vw,16.5px);color:var(--muted);max-width:44ch;margin-bottom:28px}
.hero__seal{position:absolute;right:clamp(20px,3.5vw,56px);bottom:30px;width:78px;opacity:.9}
.hero__media{position:relative;overflow:hidden;min-height:300px}
.hero__media img.bg{width:100%;height:100%;object-fit:cover}
.hero__card{position:absolute;bottom:24px;right:24px;background:var(--teal);color:var(--on-teal);padding:22px 26px;max-width:248px}
.hero__card .eyebrow{color:var(--gold-soft)}
.hero__card h3{font-size:24px;color:var(--on-teal);margin:14px 0 18px}
.hero__card a{font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:var(--gold-soft);display:inline-flex;gap:8px;align-items:center}

/* ---------- COLLECTIONS GRID ---------- */
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,2vw,26px)}

/* ---------- HERITAGE ---------- */
.heritage{background:var(--teal);color:var(--on-teal);position:relative;overflow:hidden}
.heritage .wrap{position:relative;z-index:2}
.heritage .eyebrow{color:var(--gold-soft)}
.heritage h2{color:var(--on-teal);max-width:16ch}
.heritage__orn{position:absolute;left:0;right:0;bottom:0;width:100%;opacity:.5;z-index:1;pointer-events:none;-webkit-mask-image:linear-gradient(to top,#000,transparent);mask-image:linear-gradient(to top,#000,transparent)}
.time{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;margin:clamp(36px,5vw,58px) 0 46px;border-top:1px solid rgba(244,236,229,.16);padding-top:46px}
.time .yr{font-family:var(--font-display);font-size:30px;color:var(--gold-soft);margin:18px 0 12px}
.time p{color:var(--on-teal-mut);font-size:14.5px;max-width:24ch}
.time .ic{color:var(--gold-soft)}

/* ---------- SPLIT (gift) ---------- */
.gifts{position:relative;overflow:hidden}
.gifts__palm{position:absolute;right:-30px;top:24px;width:160px;opacity:.32;mix-blend-mode:multiply;pointer-events:none}
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,6vw,90px);align-items:center;position:relative;z-index:2}
.split__media{aspect-ratio:4/3;overflow:hidden;background:var(--sand)}
.split__media img{width:100%;height:100%;object-fit:cover}
.split h2{margin:18px 0 22px}
.split p{color:var(--muted);max-width:46ch;margin-bottom:30px}

/* ---------- BRANDS (charcoal band, was "Accessories") ---------- */
.acc{background:var(--charcoal);color:var(--cream)}
.acc .eyebrow{color:var(--gold-soft)}
.acc h2{color:var(--cream)}
.acc__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,1.8vw,24px)}
.acc__item .ph{aspect-ratio:1;overflow:hidden;background:#161919}
.acc__item .ph img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.2,.7,.2,1)}
.acc__item:hover .ph img{transform:scale(1.05)}
.acc__item h3{color:var(--cream);font-size:17px;margin-top:18px;display:flex;justify-content:space-between;align-items:center}
.acc__item h3 .ar{color:var(--gold-soft)}

/* ---------- JOURNAL ---------- */
.jrnl{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.4vw,30px)}
.post .ph{aspect-ratio:3/2;overflow:hidden;background:var(--sand)}
.post .ph img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.2,.7,.2,1)}
.post:hover .ph img{transform:scale(1.04)}
.post .cat{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin:18px 0 10px;font-weight:700}
.post h3{font-size:23px;margin-bottom:10px}
.post .meta{font-size:12.5px;color:var(--muted)}

/* ---------- RESPONSIVE (home-specific) ---------- */
@media(max-width:1024px){
  .grid4,.acc__grid{grid-template-columns:repeat(2,1fr)}
  .time{grid-template-columns:repeat(2,1fr);gap:36px}
}
@media(max-width:860px){
  .hero{grid-template-columns:1fr;min-height:0}
  .hero__media{order:-1;display:flex;flex-direction:column}
  .hero__media img.bg{height:auto;aspect-ratio:16/11}
  .hero__copy{padding:clamp(40px,7vw,56px) clamp(20px,6vw,40px) clamp(56px,8vw,64px)}
  .hero__seal{display:none}
  .hero__card{position:static;max-width:none;padding:24px clamp(20px,6vw,40px)}
  .jrnl{grid-template-columns:1fr;max-width:520px;margin-inline:auto}
  .split{grid-template-columns:1fr}
  .split__media{aspect-ratio:16/10}
  .gifts__palm{display:none}
}
@media(max-width:560px){
  /* products stay 2 columns on mobile */
  .grid4{grid-template-columns:repeat(2,1fr);gap:14px}
  .grid4 .card h3{font-size:16px}
  .grid4 .card .cat{font-size:10px;margin-top:14px}
  .grid4 .card .price{font-size:15px}
  .grid4 .card .shop{font-size:10px}
  .acc__grid{grid-template-columns:repeat(2,1fr);gap:14px;max-width:440px;margin-inline:auto}
  .time{grid-template-columns:1fr;gap:30px}
}

/* Hide Flatsome elements injected via wp_footer() (off-canvas menu, search,
   login lightbox, PhotoSwipe). They lose their hiding when Flatsome CSS is
   dequeued on the home, so re-hide them here. */
.mfp-hide{display:none!important}
#main-menu,.mobile-sidebar,.header-search-form-wrapper,#login-form-popup,.pswp,.cr-pswp{display:none!important}

/* ---------- SHOP BY CATEGORY — circles ---------- */
.cats{display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(20px,3vw,46px);margin-top:8px}
.catc{display:flex;flex-direction:column;align-items:center;gap:16px;width:140px;text-align:center}
.catc__disc{position:relative;width:clamp(100px,11vw,124px);height:clamp(100px,11vw,124px);border-radius:50%;background:var(--surface);border:1px solid var(--border-strong);display:grid;place-items:center;transition:transform .3s,box-shadow .3s,background .3s,border-color .3s}
.catc__disc::before{content:"";position:absolute;inset:8px;border-radius:50%;border:1px solid var(--gold-soft);opacity:.5;transition:.3s}
.catc__disc span{font-family:var(--font-display);font-size:clamp(26px,3vw,36px);font-weight:500;color:var(--teal);transition:color .3s}
.catc:hover .catc__disc{background:var(--teal);border-color:var(--teal);transform:translateY(-5px);box-shadow:0 14px 30px rgba(15,62,60,.18)}
.catc:hover .catc__disc::before{opacity:.95}
.catc:hover .catc__disc span{color:var(--gold-soft)}
.catc b{font-family:var(--font-body);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--ink)}

/* ---------- PRODUCT CARDS (home) — uniform 4:3 framed tile (consistent
   regardless of source-photo orientation), gold eyebrow, Playfair name ---------- */
.grid4 .card{background:transparent;display:flex;flex-direction:column;transition:transform .25s}
.grid4 .card:hover{transform:translateY(-4px)}
.grid4 .card__img{aspect-ratio:5/6;background:#fff;border:1px solid var(--border);overflow:hidden;display:grid;place-items:center;padding:10px;transition:box-shadow .25s,border-color .25s}
.grid4 .card:hover .card__img{border-color:var(--gold-soft);box-shadow:0 14px 30px rgba(15,62,60,.12)}
.grid4 .card__img img{width:100%;height:100%;object-fit:contain;transition:transform .4s cubic-bezier(.2,.7,.2,1)}
.grid4 .card:hover .card__img img{transform:scale(1.04)}
.grid4 .card__body{padding:16px 2px 0;display:flex;flex-direction:column;flex:1}
.grid4 .card .cat{color:var(--gold);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;margin:0 0 7px}
.grid4 .card h3{font-size:17px;line-height:1.18;margin:0 0 12px}
.grid4 .card .row{margin-top:auto;align-items:center}
.grid4 .card .price{font-size:16px;font-weight:700;color:var(--ink)}
.grid4 .card .shop{font-size:10.5px;letter-spacing:.14em;cursor:pointer}

@media(max-width:560px){
  .cats{gap:20px 12px}
  .catc{width:30%;min-width:90px}
  .grid4 .card__img{padding:12px}
  .grid4 .card__body{padding:0 12px 14px}
}

/* ---------- COMPACT vertical rhythm (less scrolling to reach products) ---------- */
.sec{padding:clamp(34px,4vw,60px) 0}           /* was up to 118px */
.head{margin-bottom:clamp(22px,2.6vw,34px)}    /* tighter section headers */
.hero__copy p.lead{margin-bottom:22px}
.time{margin:clamp(26px,3vw,40px) 0 30px;padding-top:34px}
.news__top{padding-bottom:clamp(28px,3vw,40px)}
.trust{padding-top:0}
@media(max-width:560px){ .sec{padding:32px 0} }
