/*
Theme Name: Occely
Theme URI: https://occely.com
Author: Occely
Description: Premium minimal WooCommerce theme for Occely - men's & women's shirts. Converted from the approved mockup.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
License: GPL-2.0-or-later
Text Domain: occely
WC requires at least: 7.0
WC tested up to: 9.4
*/
/* ============================================================
   OCCELY â€” shared design system
   One source of truth for tokens, chrome and components.
   ============================================================ */

:root{
  --ink:#0b0b0b;
  --paper:#ffffff;
  --bone:#f4f3f0;
  --stone:#8d8880;
  --line:#e6e3dd;
  --hdr:70px;
  --bar:34px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Jost",system-ui,-apple-system,"Segoe UI",sans-serif;
  color:var(--ink);background:var(--paper);
  font-weight:300;line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
:focus-visible{outline:1.5px solid var(--ink);outline-offset:3px}

/* ---------- shared type ---------- */
.eyebrow{font-size:11px;letter-spacing:.32em;text-transform:uppercase;font-weight:400}
.index{font-size:11px;letter-spacing:.3em;text-transform:uppercase;font-weight:400;opacity:.85}
.display{font-weight:300;text-transform:uppercase;line-height:1.02;letter-spacing:.06em;font-size:clamp(2.1rem,6.2vw,5rem)}
.serif{font-family:"Cormorant Garamond",Georgia,serif}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:14px 34px;font-size:11px;letter-spacing:.24em;text-transform:uppercase;font-weight:400;
  border:1px solid #fff;color:#fff;background:transparent;
  transition:background .35s var(--ease),color .35s var(--ease);
}
.btn:hover{background:#fff;color:var(--ink)}
.btn--solid{background:#fff;color:var(--ink)}
.btn--solid:hover{background:transparent;color:#fff}
.btn--ink{border-color:var(--ink);color:var(--ink)}
.btn--ink:hover{background:var(--ink);color:#fff}
.btn--block{width:100%}
/* keep editorial text + outline CTAs legible over photography (generated images can be light) */
.hero__content,.panel__content,.ed-hero__content{text-shadow:0 1px 22px rgba(0,0,0,.5)}
.hero__content .btn:not(.btn--solid),
.panel__content .btn:not(.btn--solid){background:rgba(12,12,12,.34);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);text-shadow:0 1px 8px rgba(0,0,0,.55)}
.hero__content .btn:not(.btn--solid):hover,
.panel__content .btn:not(.btn--solid):hover{background:#fff;color:var(--ink);text-shadow:none}

/* ---------- announcement ---------- */
.announce{
  height:var(--bar);background:var(--ink);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:10.5px;letter-spacing:.26em;text-transform:uppercase;font-weight:400;
  text-align:center;padding:0 16px;white-space:nowrap;
}

/* ---------- header ---------- */
.header{
  position:sticky;top:0;z-index:60;height:var(--hdr);background:var(--paper);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 clamp(18px,4vw,46px);
  border-bottom:1px solid transparent;
  transition:border-color .4s var(--ease),box-shadow .4s var(--ease);
}
.header.scrolled{border-color:var(--line);box-shadow:0 1px 24px rgba(0,0,0,.04)}
.menu-btn{display:flex;align-items:center;gap:11px;font-size:11px;letter-spacing:.26em;text-transform:uppercase}
.menu-btn .lines{display:inline-flex;flex-direction:column;gap:4px;width:20px}
.menu-btn .lines span{height:1px;background:var(--ink);width:100%}
.brand{
  position:absolute;left:50%;transform:translateX(-50%);
  font-size:clamp(20px,2.4vw,27px);font-weight:500;letter-spacing:.42em;text-indent:.42em;
}
.tools{display:flex;align-items:center;gap:clamp(14px,2vw,24px)}
.tools button,.tools a{display:inline-flex;line-height:0;position:relative}
.tools svg{width:20px;height:20px;stroke:var(--ink);stroke-width:1.1;fill:none}
.tools .badge{
  position:absolute;top:-6px;right:-8px;min-width:15px;height:15px;border-radius:50%;
  background:var(--ink);color:#fff;font-size:9px;display:flex;align-items:center;justify-content:center;letter-spacing:0;
}

/* ---------- desktop nav bar (sits under the logo, Chanel-style; mobile keeps the drawer) ---------- */
.header-nav{
  position:sticky;top:var(--hdr);z-index:55;background:var(--paper);
  border-bottom:1px solid var(--line);display:flex;justify-content:center;
}
.header-nav__list{
  display:flex;flex-wrap:wrap;justify-content:center;align-items:center;
  gap:clamp(18px,2.6vw,46px);list-style:none;margin:0;padding:13px clamp(16px,4vw,46px);
}
.header-nav__list li{margin:0}
.header-nav__list a{
  display:inline-block;position:relative;padding:3px 0;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:400;color:var(--ink);
}
.header-nav__list a::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;background:var(--ink);
  transform:scaleX(0);transform-origin:center;transition:transform .3s var(--ease);
}
.header-nav__list a:hover::after,.header-nav__list .current-menu-item>a::after{transform:scaleX(1)}
@media(max-width:900px){.header-nav{display:none}}

/* ---------- drawer ---------- */
.scrim{
  position:fixed;inset:0;z-index:70;background:rgba(11,11,11,.42);
  opacity:0;visibility:hidden;transition:opacity .45s var(--ease),visibility .45s;backdrop-filter:blur(1px);
}
.scrim.open{opacity:1;visibility:visible}
.drawer{
  position:fixed;top:0;left:0;z-index:80;height:100%;width:min(390px,86vw);
  background:var(--paper);transform:translateX(-102%);transition:transform .5s var(--ease);
  display:flex;flex-direction:column;padding:26px 0 0;
}
.drawer.open{transform:translateX(0)}
.drawer__top{display:flex;justify-content:flex-end;padding:0 26px 14px}
.drawer__close{display:inline-flex;line-height:0;padding:6px}
.drawer__close svg{width:22px;height:22px;stroke:var(--ink);stroke-width:1.1;fill:none}
.drawer__scroll{overflow-y:auto;flex:1;padding:6px 0 40px}
.nav-group{padding:8px 0}
.nav-group + .nav-group{border-top:1px solid var(--line);margin-top:6px;padding-top:14px}
.nav-label{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--stone);padding:0 30px 8px}
.nav-item{
  display:flex;align-items:center;justify-content:space-between;width:100%;text-align:left;
  padding:15px 30px;font-size:14px;letter-spacing:.18em;text-transform:uppercase;font-weight:400;
  transition:background .25s var(--ease);
}
.nav-item:hover{background:var(--bone)}
.nav-item.active{font-weight:500}
.nav-item.active::before{content:"";position:absolute;left:0;width:3px;height:20px;background:var(--ink)}
.nav-item{position:relative}
.nav-item svg{width:14px;height:14px;stroke:var(--ink);stroke-width:1.1;fill:none;transition:transform .35s var(--ease)}
.nav-item.open svg{transform:rotate(90deg)}
.submenu{max-height:0;overflow:hidden;transition:max-height .45s var(--ease);background:var(--bone)}
.submenu a{display:block;padding:12px 30px 12px 42px;font-size:12.5px;letter-spacing:.12em;text-transform:uppercase;color:#4a4842;font-weight:300}
.submenu a:hover{color:var(--ink)}
.drawer__foot{border-top:1px solid var(--line);padding:18px 30px 26px;display:flex;flex-direction:column;gap:14px}
.drawer__foot a{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:#4a4842}

/* ---------- media placeholder (full-bleed sections) ---------- */
.media{
  position:absolute;inset:0;overflow:hidden;
  background-color:#0e0e0e;background-size:cover;background-position:center;background-repeat:no-repeat;
  background-image:linear-gradient(160deg,#2c2c2c,#0e0e0e 72%);
}
.media::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 110% at 50% 50%,rgba(0,0,0,.34),rgba(0,0,0,.54))}
/* Drop images into images\ (h1/m1/w1/c1/j1.jpg) and they auto-load over the gradient. */
.media--hero{background-image:url('images/h1.jpg'),linear-gradient(160deg,#2c2c2c,#0e0e0e 72%)}
.media--m{background-image:url('images/m1.jpg'),linear-gradient(150deg,#3b3b3b,#141414)}
.media--w{background-image:url('images/w1.jpg'),linear-gradient(150deg,#4b463f,#1d1b17)}
.media--coming{background-image:url('images/c1.jpg'),linear-gradient(160deg,#1a1a1a,#070707)}
.media--journal{background-image:url('images/j1.jpg'),linear-gradient(160deg,#34322e,#100f0d)}
.media--about{background-image:url('images/about.jpg'),linear-gradient(155deg,#37342f,#0f0e0c)}
.slot{display:none}/* dev placeholder labels â€” hidden once real images are in */
.slot::before{content:"";width:18px;height:1px;background:rgba(255,255,255,.4)}

/* ---------- hero ---------- */
.hero{position:relative;height:calc(100vh - var(--hdr) - var(--bar));min-height:520px}
.hero__content{position:absolute;inset:0;z-index:5;color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:0 22px}
.hero .eyebrow{margin-bottom:22px;opacity:.92}
.hero .display{margin-bottom:18px}
.hero__sub{font-size:14px;letter-spacing:.08em;font-weight:300;max-width:30ch;margin-bottom:34px;opacity:.9}
.cta-row{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}

/* ---------- campaign panels ---------- */
.panel{position:relative;height:92vh;min-height:560px}
.panel__content{position:absolute;inset:0;z-index:5;color:#fff;display:flex;flex-direction:column;justify-content:center;padding:0 clamp(28px,8vw,120px)}
.panel--left .panel__content{align-items:flex-start;text-align:left}
.panel--right .panel__content{align-items:flex-end;text-align:right}
.panel--center .panel__content{align-items:center;text-align:center}
.panel .index{margin-bottom:18px}
.panel .display{margin-bottom:26px}
.panel .eyebrow{opacity:.85;margin-bottom:6px}
.panel--journal{height:88vh}

/* ---------- philosophy ---------- */
.philosophy{background:var(--bone);padding:clamp(80px,14vw,170px) 22px;text-align:center}
.philosophy .index{color:var(--stone);margin-bottom:30px;display:inline-block}
.philosophy__statement{font-family:"Cormorant Garamond",Georgia,serif;font-weight:400;font-size:clamp(1.7rem,4.4vw,3.3rem);line-height:1.24;letter-spacing:.01em;max-width:20ch;margin:0 auto 38px;color:var(--ink)}
.philosophy__statement em{font-style:italic;color:#3a3833}
.philosophy__body{max-width:46ch;margin:0 auto 40px;font-size:15px;letter-spacing:.03em;color:#3f3d38}

/* ============================================================
   SUBPAGE COMPONENTS
   ============================================================ */

.wrap{max-width:1320px;margin:0 auto;padding:0 clamp(18px,4vw,46px)}

/* breadcrumb */
.crumb{padding:26px clamp(18px,4vw,46px) 0;font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--stone)}
.crumb a:hover{color:var(--ink)}
.crumb span{margin:0 8px}

/* category head */
.cat-head{text-align:center;padding:clamp(34px,5vw,60px) 22px clamp(20px,3vw,34px)}
.cat-head .eyebrow{color:var(--stone);margin-bottom:16px}
.cat-title{font-weight:300;text-transform:uppercase;letter-spacing:.08em;font-size:clamp(1.9rem,5vw,3.4rem)}
.cat-sub{margin-top:16px;font-size:14px;letter-spacing:.04em;color:#4a4842;max-width:44ch;margin-inline:auto}

/* filter / sort bar */
.cat-bar{
  display:flex;align-items:center;justify-content:space-between;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:14px clamp(18px,4vw,46px);margin-top:14px;
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:#4a4842;
}
.cat-bar button{font-size:11px;letter-spacing:.2em;text-transform:uppercase;display:inline-flex;align-items:center;gap:8px}
.cat-bar .filters{display:flex;gap:26px}
.cat-bar .filters button:hover{color:var(--ink)}

/* ---------- editorial category page (hero poster + intro) ---------- */
.cat-hero{position:relative;height:72vh;min-height:440px}
.cat-hero .media{position:absolute;inset:0}
.cat-hero__content{position:absolute;inset:0;z-index:5;color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:0 22px;text-shadow:0 1px 22px rgba(0,0,0,.5)}
.cat-hero .eyebrow{opacity:.92;margin-bottom:18px}
.cat-hero .display{margin-bottom:16px}
.cat-hero__sub{font-size:14px;letter-spacing:.08em;opacity:.92;max-width:34ch}
.cat-intro{text-align:center;padding:clamp(58px,9vw,120px) 22px clamp(18px,3vw,38px);max-width:64ch;margin:0 auto}
.cat-intro .index{color:var(--stone);margin-bottom:20px;display:inline-block}
.cat-intro__lead{font-family:"Cormorant Garamond",Georgia,serif;font-weight:400;font-size:clamp(1.4rem,3.1vw,2.3rem);line-height:1.34;letter-spacing:.01em;color:var(--ink)}

/* ---------- page banner (cart / checkout / account headers) ---------- */
.page-banner{position:relative;height:34vh;min-height:230px;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.page-banner h1{position:relative;z-index:5;color:#fff;font-weight:300;text-transform:uppercase;letter-spacing:.12em;font-size:clamp(1.7rem,4vw,2.8rem);text-shadow:0 1px 22px rgba(0,0,0,.5)}

/* ---------- product grid (IMAGE + TITLE ONLY â€” NO PRICE) ---------- */
.grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:clamp(12px,2vw,30px) clamp(10px,1.4vw,22px);
  padding:clamp(22px,3vw,44px) clamp(18px,4vw,46px) clamp(56px,7vw,100px);
}
@media(max-width:1080px){.grid{grid-template-columns:repeat(3,1fr)}}
.card{display:block;text-align:center}
.thumb{
  position:relative;aspect-ratio:3/4;overflow:hidden;background:#1a1a1a;
  background-size:cover;background-position:center;
}
.thumb::after{
  content:"OCCELY";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-size:11px;letter-spacing:.36em;color:rgba(255,255,255,.16);text-indent:.36em;
}
.thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;transition:transform 1.1s var(--ease)}
.card:hover .thumb img{transform:scale(1.04)}
/* tonal variety so the empty grid still reads premium */
.card:nth-child(6n+1) .thumb{background-image:linear-gradient(150deg,#3a3a3a,#161616)}
.card:nth-child(6n+2) .thumb{background-image:linear-gradient(150deg,#4a463f,#1d1b17)}
.card:nth-child(6n+3) .thumb{background-image:linear-gradient(160deg,#2f2f2f,#101010)}
.card:nth-child(6n+4) .thumb{background-image:linear-gradient(150deg,#45433d,#19120e)}
.card:nth-child(6n+5) .thumb{background-image:linear-gradient(160deg,#343434,#121212)}
.card:nth-child(6n+6) .thumb{background-image:linear-gradient(150deg,#4d4840,#201d18)}
.card__title{
  margin-top:13px;font-size:11px;letter-spacing:.13em;text-transform:uppercase;font-weight:400;color:var(--ink);
  transition:opacity .25s;
}
.card:hover .card__title{opacity:.6}
.card__tag{display:block;margin-top:7px;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--stone)}
/* deliberately NO .card__price â€” price lives only on the product page */

/* ---------- product detail (PDP) ---------- */
.pdp{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(24px,4vw,64px);padding:18px clamp(18px,4vw,46px) clamp(60px,8vw,100px);align-items:start}
.pdp__gallery{display:flex;flex-direction:column;gap:12px}
.pdp__img{position:relative;aspect-ratio:3/4;background:#1a1a1a;background-size:cover;background-position:center}
.pdp__img:nth-child(1){background-image:linear-gradient(150deg,#3a3a3a,#161616)}
.pdp__img:nth-child(2){background-image:linear-gradient(155deg,#403c35,#18120e)}
.pdp__img:nth-child(3){background-image:linear-gradient(160deg,#2f2f2f,#101010)}
.pdp__img::after{content:attr(data-slot);position:absolute;left:18px;bottom:14px;font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.4)}
.pdp__img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
.pdp__info{position:sticky;top:calc(var(--hdr) + 28px)}
.pdp__info .eyebrow{color:var(--stone);margin-bottom:14px}
.pdp__title{font-weight:300;text-transform:uppercase;letter-spacing:.07em;font-size:clamp(1.5rem,3vw,2.2rem);line-height:1.1}
.pdp__price{margin-top:18px;font-size:17px;letter-spacing:.12em;font-weight:300}/* PRICE â€” only revealed here */
.pdp__tax{font-size:11px;letter-spacing:.08em;color:var(--stone);margin-top:6px}
.pdp__opt{margin-top:30px}
.pdp__opt h4{font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;margin-bottom:14px;font-weight:500}
.pdp__opt h4 span{color:var(--stone);font-weight:300;margin-left:6px}
.swatches{display:flex;gap:12px}
.swatch{width:26px;height:26px;border-radius:50%;border:1px solid var(--line);position:relative;cursor:pointer}
.swatch[aria-pressed="true"]{outline:1px solid var(--ink);outline-offset:3px}
.sizes{display:flex;gap:10px;flex-wrap:wrap}
.size{min-width:48px;padding:13px 6px;border:1px solid var(--line);font-size:12px;letter-spacing:.12em;text-align:center;transition:border-color .25s,background .25s}
.size:hover{border-color:var(--ink)}
.size[aria-pressed="true"]{background:var(--ink);color:#fff;border-color:var(--ink)}
.size.sold{color:var(--stone);text-decoration:line-through;cursor:not-allowed}
.pdp__actions{display:flex;flex-direction:column;gap:12px;margin-top:30px}
.pdp__link{font-size:11px;letter-spacing:.2em;text-transform:uppercase;text-align:center;color:#4a4842;display:inline-flex;gap:8px;align-items:center;justify-content:center}
.pdp__link:hover{color:var(--ink)}

/* accordion */
.acc{margin-top:36px;border-top:1px solid var(--line)}
.acc__item{border-bottom:1px solid var(--line)}
.acc__head{width:100%;display:flex;align-items:center;justify-content:space-between;padding:18px 2px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;text-align:left}
.acc__head svg{width:13px;height:13px;stroke:var(--ink);stroke-width:1.2;fill:none;transition:transform .35s var(--ease)}
.acc__head.open svg{transform:rotate(45deg)}
.acc__body{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.acc__body p{padding:2px 2px 20px;font-size:13.5px;line-height:1.7;color:#46443f;letter-spacing:.02em;max-width:52ch}

/* related */
.related{padding:clamp(40px,6vw,80px) 0}
.related h2{text-align:center;font-size:12px;letter-spacing:.28em;text-transform:uppercase;margin-bottom:8px;font-weight:500}

/* ---------- cart ---------- */
.cart{display:grid;grid-template-columns:1.5fr .8fr;gap:clamp(28px,5vw,70px);padding:8px clamp(18px,4vw,46px) clamp(60px,8vw,100px);align-items:start}
.page-title{text-align:center;padding:clamp(34px,5vw,56px) 22px clamp(20px,3vw,30px);font-weight:300;text-transform:uppercase;letter-spacing:.1em;font-size:clamp(1.6rem,4vw,2.6rem)}
.line{display:grid;grid-template-columns:96px 1fr auto;gap:20px;padding:24px 0;border-top:1px solid var(--line)}
.line:last-child{border-bottom:1px solid var(--line)}
.line__img{aspect-ratio:3/4;background:linear-gradient(150deg,#3a3a3a,#161616);background-size:cover;background-position:center}
.line__name{font-size:13px;letter-spacing:.12em;text-transform:uppercase}
.line__meta{margin-top:8px;font-size:11.5px;letter-spacing:.05em;color:var(--stone);line-height:1.9}
.line__remove{margin-top:10px;font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--stone);text-decoration:underline}
.line__price{font-size:13px;letter-spacing:.08em;white-space:nowrap}
.summary{background:var(--bone);padding:clamp(24px,3vw,38px)}
.summary h3{font-size:11px;letter-spacing:.26em;text-transform:uppercase;margin-bottom:22px;font-weight:500}
.summary .row{display:flex;justify-content:space-between;font-size:13px;letter-spacing:.05em;padding:11px 0;color:#46443f}
.summary .row--total{border-top:1px solid var(--line);margin-top:8px;padding-top:18px;color:var(--ink);font-size:15px;letter-spacing:.08em}
.summary .btn{margin-top:24px}
.summary .note{margin-top:16px;font-size:11px;letter-spacing:.04em;color:var(--stone);text-align:center}

/* ---------- about / editorial ---------- */
.ed-hero{position:relative;height:74vh;min-height:460px}
.ed-hero__content{position:absolute;inset:0;z-index:5;color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:0 22px}
.ed-hero .eyebrow{opacity:.9;margin-bottom:18px}
.ed-statement{background:var(--paper);text-align:center;padding:clamp(70px,11vw,150px) 22px}
.ed-statement p{font-family:"Cormorant Garamond",Georgia,serif;font-size:clamp(1.6rem,4vw,3rem);line-height:1.28;max-width:22ch;margin:0 auto;color:var(--ink)}
.ed-statement em{font-style:italic}
.ed-split{display:grid;grid-template-columns:1fr 1fr;align-items:center;min-height:64vh}
.ed-split--flip .ed-split__text{order:-1}
.ed-split__media{position:relative;align-self:stretch;min-height:48vh;background:#1a1a1a;background-size:cover;background-position:center}
.ed-split:nth-of-type(odd) .ed-split__media{background-image:linear-gradient(150deg,#3a3a3a,#161616)}
.ed-split:nth-of-type(even) .ed-split__media{background-image:linear-gradient(150deg,#45413a,#1a1410)}
.ed-split__text{padding:clamp(36px,6vw,90px)}
.ed-split__text .index{color:var(--stone);margin-bottom:20px;display:inline-block}
.ed-split__text h2{font-weight:300;text-transform:uppercase;letter-spacing:.06em;font-size:clamp(1.4rem,3vw,2.2rem);margin-bottom:20px}
.ed-split__text p{font-size:14.5px;line-height:1.8;color:#46443f;letter-spacing:.02em;max-width:46ch}
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border-block:1px solid var(--line)}
.values div{background:var(--paper);padding:clamp(34px,5vw,64px) clamp(20px,3vw,40px);text-align:center}
.values h3{font-size:11px;letter-spacing:.24em;text-transform:uppercase;margin-bottom:14px;font-weight:500}
.values p{font-size:13px;line-height:1.7;color:#46443f}

/* ---------- journal grid ---------- */
.jgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(10px,2.4vw,40px) clamp(10px,1.6vw,28px);padding:clamp(28px,4vw,52px) clamp(18px,4vw,46px) clamp(60px,8vw,110px)}
.jcard__media{position:relative;aspect-ratio:4/3;overflow:hidden;background:linear-gradient(150deg,#34322e,#100f0d);background-size:cover;background-position:center}
.jcard__media::after{content:"OCCELY";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:12px;letter-spacing:.4em;color:rgba(255,255,255,.14);text-indent:.4em}
.jcard__cat{margin-top:18px;font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--stone)}
.jcard__title{margin-top:10px;font-size:16px;letter-spacing:.02em;line-height:1.35;max-width:30ch}
.jcard:hover .jcard__title{opacity:.6}

/* ---------- contact ---------- */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,6vw,90px);padding:8px clamp(18px,4vw,46px) clamp(64px,8vw,110px);align-items:start}
.contact__intro p{font-size:14.5px;line-height:1.8;color:#46443f;max-width:42ch;margin-bottom:30px}
.contact__block{margin-bottom:26px}
.contact__block h4{font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;margin-bottom:10px;font-weight:500}
.contact__block a,.contact__block p{font-size:14px;color:#46443f;letter-spacing:.03em;line-height:1.7}
.form{display:flex;flex-direction:column;gap:22px}
.field label{display:block;font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;margin-bottom:10px;color:#46443f}
.field input,.field textarea{width:100%;border:0;border-bottom:1px solid var(--ink);background:none;padding:10px 2px;font-family:inherit;font-size:14px;letter-spacing:.03em;color:var(--ink);resize:vertical}
.field input::placeholder,.field textarea::placeholder{color:var(--stone)}

/* ============================================================
   ACCOUNT / AUTH / CHECKOUT (themed to override WooCommerce defaults)
   ============================================================ */

/* ---------- auth (login / register) ---------- */
.auth{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,6vw,80px);max-width:1000px;margin:0 auto;padding:8px clamp(18px,4vw,46px) clamp(64px,8vw,110px)}
.auth__col h2{font-weight:300;text-transform:uppercase;letter-spacing:.1em;font-size:clamp(1.2rem,2.4vw,1.6rem);margin-bottom:12px}
.auth__col > p{font-size:13.5px;color:#46443f;line-height:1.7;margin-bottom:30px;max-width:42ch}
.auth__col--register{border-left:1px solid var(--line);padding-left:clamp(34px,6vw,80px)}
.checkbox{display:flex;align-items:center;gap:10px;font-size:12px;letter-spacing:.06em;color:#46443f}
.checkbox input{width:15px;height:15px;accent-color:var(--ink)}
.forgot{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#4a4842}
.forgot:hover{color:var(--ink)}

/* ---------- my account ---------- */
.account{display:grid;grid-template-columns:230px 1fr;gap:clamp(28px,4vw,60px);padding:8px clamp(18px,4vw,46px) clamp(64px,8vw,110px);align-items:start}
.acct-nav{display:flex;flex-direction:column;border-top:1px solid var(--line)}
.acct-nav a{padding:15px 4px;border-bottom:1px solid var(--line);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:#4a4842;transition:color .25s,padding-left .25s}
.acct-nav a:hover{color:var(--ink);padding-left:8px}
.acct-nav a.active{color:var(--ink);font-weight:500}
.acct-main h2{font-weight:300;text-transform:uppercase;letter-spacing:.08em;font-size:clamp(1.2rem,2.4vw,1.6rem);margin-bottom:18px}
.acct-main > p{font-size:14px;color:#46443f;line-height:1.8;margin-bottom:26px;max-width:56ch}
.acct-main p a{text-decoration:underline}
.acct-block{margin-top:46px}
.acct-block h3{font-size:11px;letter-spacing:.24em;text-transform:uppercase;margin-bottom:18px;font-weight:500}
.orders{width:100%;border-collapse:collapse}
.orders th,.orders td{text-align:left;padding:15px 14px;border-bottom:1px solid var(--line);font-size:12.5px;letter-spacing:.04em;color:#46443f}
.orders th{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--stone);font-weight:500}
.orders td:first-child{color:var(--ink)}
.status{display:inline-block;font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;padding:5px 12px;border:1px solid var(--line);border-radius:40px}
.view{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;text-decoration:underline;white-space:nowrap}
.addr-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.addr{border:1px solid var(--line);padding:24px}
.addr h4{font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;margin-bottom:14px;font-weight:500}
.addr p{font-size:13px;line-height:1.85;color:#46443f}
.addr a{display:inline-block;margin-top:14px;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;text-decoration:underline}

/* ---------- checkout ---------- */
.checkout{display:grid;grid-template-columns:1.2fr .8fr;gap:clamp(28px,5vw,70px);padding:8px clamp(18px,4vw,46px) clamp(64px,8vw,110px);align-items:start}
.co-login{font-size:12px;letter-spacing:.04em;color:#46443f;border:1px solid var(--line);padding:16px 20px;margin-bottom:34px}
.co-login a{text-decoration:underline;color:var(--ink)}
.co-sec{margin-bottom:38px}
.co-sec h2{font-size:11px;letter-spacing:.24em;text-transform:uppercase;margin-bottom:24px;font-weight:500;padding-bottom:14px;border-bottom:1px solid var(--line)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.co-review{background:var(--bone);padding:clamp(24px,3vw,38px);position:sticky;top:calc(var(--hdr) + 28px)}
.co-review h3{font-size:11px;letter-spacing:.26em;text-transform:uppercase;margin-bottom:6px;font-weight:500}
.co-line{display:flex;justify-content:space-between;gap:14px;font-size:12.5px;letter-spacing:.04em;padding:16px 0;border-bottom:1px solid var(--line)}
.co-line .n{color:var(--ink)}
.co-line .n span{color:var(--stone);display:block;font-size:11px;margin-top:4px}
.co-line .p{white-space:nowrap}
.co-row{display:flex;justify-content:space-between;font-size:13px;padding:11px 0;color:#46443f}
.co-row--total{border-top:1px solid var(--line);margin-top:6px;padding-top:16px;color:var(--ink);font-size:15px;letter-spacing:.08em}
.pay{margin:18px 0 0;border-top:1px solid var(--line)}
.pay label{display:flex;align-items:center;gap:12px;padding:15px 0;border-bottom:1px solid var(--line);font-size:12.5px;letter-spacing:.06em;cursor:pointer}
.pay input{accent-color:var(--ink)}
.co-review .btn{margin-top:24px}
.co-review .note{margin-top:14px;font-size:11px;letter-spacing:.04em;color:var(--stone);text-align:center}

/* ---------- cart extras (qty stepper + coupon) ---------- */
.qty{display:inline-flex;align-items:center;border:1px solid var(--line);margin-top:14px}
.qty button{width:32px;height:32px;font-size:15px;color:#46443f}
.qty button:hover{color:var(--ink)}
.qty span{min-width:36px;text-align:center;font-size:12px;letter-spacing:.05em}
.cart__coupon{display:flex;border-bottom:1px solid var(--ink);max-width:330px;margin-top:34px}
.cart__coupon input{flex:1;border:0;background:none;padding:11px 2px;font-family:inherit;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink)}
.cart__coupon input::placeholder{color:var(--stone)}
.cart__coupon button{font-size:11px;letter-spacing:.2em;text-transform:uppercase;padding:0 6px}

/* ---------- footer ---------- */
.footer{background:var(--ink);color:#f3f2ef;border-top:1px solid var(--ink)}
.footer__main{max-width:1280px;margin:0 auto;padding:clamp(54px,7vw,84px) clamp(22px,5vw,48px);display:grid;grid-template-columns:1.1fr 1fr 1.4fr;gap:clamp(34px,5vw,72px)}
.footer h4{font-size:10.5px;letter-spacing:.3em;text-transform:uppercase;font-weight:500;margin-bottom:22px;color:#fff}
.footer ul{list-style:none}
.footer li{margin-bottom:13px}
.footer li a{font-size:13px;letter-spacing:.05em;color:#a7a39b;font-weight:300;transition:color .25s}
.footer li a:hover{color:#fff}
.news p{font-size:13px;color:#a7a39b;margin-bottom:18px;letter-spacing:.03em;max-width:34ch}
.news__form{display:flex;border-bottom:1px solid rgba(255,255,255,.4);max-width:330px}
.news__form input{flex:1;border:0;background:none;padding:10px 2px;font-family:inherit;font-size:13px;letter-spacing:.05em;color:#fff}
.news__form input::placeholder{color:#857f76}
.news__form button{font-size:11px;letter-spacing:.22em;text-transform:uppercase;padding:0 4px;color:#fff}
.social{display:flex;gap:18px;margin-top:30px}
.social a{line-height:0}
.social svg{width:18px;height:18px;stroke:#c9c5be;stroke-width:1.1;fill:none;transition:stroke .25s}
.social a:hover svg{stroke:#fff}
.footer__bar{border-top:1px solid rgba(255,255,255,.14);max-width:1280px;margin:0 auto;padding:22px clamp(22px,5vw,48px);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}
.footer__bar .legal{display:flex;gap:24px;flex-wrap:wrap}
.footer__bar a,.footer__bar span,.country{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#a7a39b;font-weight:300}
.footer__bar a{transition:color .25s}
.footer__bar a:hover{color:#fff}
.country{display:inline-flex;align-items:center;gap:9px}
.country svg{width:13px;height:13px;stroke:#a7a39b;stroke-width:1.1;fill:none}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.is-visible{opacity:1;transform:none}

/* ---------- mobile-only components ---------- */
.pdp-bar{display:none}
.orders-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}

/* ---------- responsive ---------- */
@media(max-width:900px){
  .pdp{grid-template-columns:1fr;padding-bottom:92px}
  .pdp__info{position:static}
  .cart{grid-template-columns:1fr}
  .contact{grid-template-columns:1fr}
  .ed-split{grid-template-columns:1fr}
  .ed-split--flip .ed-split__text{order:0}
  .ed-split__media{min-height:54vh}
  .values{grid-template-columns:1fr}
  .account,.checkout,.auth{grid-template-columns:1fr}
  .co-review{position:static}
  .auth__col--register{border-left:0;padding-left:0;border-top:1px solid var(--line);padding-top:34px}
  .addr-grid,.field-row{grid-template-columns:1fr}
  .acct-nav{flex-direction:row;flex-wrap:wrap}
  .acct-nav a{border-bottom:0;margin-right:22px;padding:8px 0}
  .pdp-bar{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:55;align-items:center;justify-content:space-between;gap:14px;background:var(--paper);border-top:1px solid var(--line);padding:11px clamp(16px,4vw,24px);box-shadow:0 -2px 20px rgba(0,0,0,.07)}
  .pdp-bar__price{font-size:15px;letter-spacing:.1em}
  .pdp-bar .btn{flex:1;max-width:62%;padding:14px}
}
@media(max-width:760px){
  .brand{font-size:18px;letter-spacing:.3em;text-indent:.3em}
  .menu-btn .txt{display:none}
  .panel__content{padding:0 26px}
  .panel--left .panel__content,.panel--right .panel__content{align-items:center;text-align:center}
  .panel{height:80vh;min-height:440px}
  .footer__main{grid-template-columns:1fr;gap:36px}
  .footer__bar{flex-direction:column;align-items:flex-start}
  .hero__sub{font-size:13px}
  .grid,.jgrid{grid-template-columns:repeat(2,1fr)}
  .jgrid{gap:22px 14px}
  .pdp__gallery{flex-direction:column;gap:10px}
  .pdp{padding-left:clamp(16px,4vw,46px);padding-right:clamp(16px,4vw,46px)}
  .orders{min-width:480px}
  /* mobile hero: full-bleed but a touch shorter so the wide photo shows a wider slice (both models + room); crop biased toward the woman on the left */
  .hero{height:72vh;min-height:440px}
  .media--hero{background-position:63% center}
}
@media(max-width:520px){
  .header{padding:0 16px}
  .tools{gap:16px}
  .tools .hide-sm{display:none}
  .announce{font-size:clamp(7px,2.3vw,10px);letter-spacing:.05em;padding:0 8px}
  .drawer{width:100%}
  .cat-head{padding:26px 16px 16px}
  .cat-bar{padding:13px 16px}
  .grid{gap:14px 10px;padding:18px 14px 60px}
  .card__title{font-size:10px;margin-top:11px;letter-spacing:.1em}
  .page-title{font-size:1.5rem;padding-top:34px}
  .line{grid-template-columns:72px 1fr}
  .line__price{grid-column:2;justify-self:start;margin-top:8px}
  .summary{padding:22px}
  .acct-nav a{margin-right:16px;font-size:10px}
  .pay label{font-size:12px}
  .field-row{gap:18px}
}
@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto}
  .reveal{opacity:1;transform:none;transition:none}
  .thumb img,.card:hover .thumb img{transition:none}
}
