/* =========================================================================
   HAVEN — Workspace Concept · Design System
   Marco minimalista (papel + tinta), el color lo aporta el producto.
   ========================================================================= */

:root{
  /* Base */
  --ink:#1C1B19;
  --ink-2:#47433C;
  --ink-3:#6E685E;
  --paper:#F1ECE3;
  --paper-2:#F8F4ED;
  --surface:#FFFFFF;
  --line:#E5DCCE;
  --line-2:#EFE8DC;

  /* Marca */
  --haven:#C2683C;        /* ámbar-arcilla: CTAs y el punto del wordmark */
  --haven-deep:#A2532E;
  --blush:#E7A6A0;        /* lavado cálido del hero */

  /* Tipografía */
  --serif:'Fraunces',Georgia,'Times New Roman',serif;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;

  /* Escala */
  --step--1:clamp(.8rem,.76rem + .2vw,.9rem);
  --step-0:clamp(1rem,.95rem + .25vw,1.1rem);
  --step-1:clamp(1.2rem,1.1rem + .5vw,1.45rem);
  --step-2:clamp(1.55rem,1.3rem + 1.2vw,2.1rem);
  --step-3:clamp(2.1rem,1.6rem + 2.4vw,3.4rem);
  --step-4:clamp(2.8rem,2rem + 4vw,5rem);

  /* Layout */
  --maxw:1200px;
  --gap:clamp(1.2rem,1rem + 1.5vw,2.4rem);
  --radius:22px;
  --radius-lg:30px;
  --radius-pill:999px;
  --shadow:0 18px 50px -22px rgba(28,27,25,.28);
  --shadow-soft:0 10px 30px -18px rgba(28,27,25,.30);
}

/* ----------------------------- Reset/base ----------------------------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--sans);color:var(--ink);background:var(--paper);
  font-size:var(--step-0);line-height:1.6;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
::selection{background:var(--haven);color:#fff}

.container{width:min(100% - 2.4rem,var(--maxw));margin-inline:auto}

.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:1rem;top:1rem;z-index:200;background:var(--ink);color:#fff;padding:.6rem 1rem;border-radius:10px}

/* ----------------------------- Tipografía ----------------------------- */
.display{
  font-family:var(--serif);font-weight:500;line-height:1.04;
  letter-spacing:-.015em;margin:0;font-optical-sizing:auto;
}
.display em{font-style:italic;font-weight:500;color:var(--haven)}
h1.display{font-size:var(--step-4)}
h2.display{font-size:var(--step-3)}
.eyebrow{
  display:inline-block;font-size:var(--step--1);font-weight:600;letter-spacing:.16em;
  text-transform:uppercase;color:var(--haven-deep);margin-bottom:1.1rem;
}
.lede{font-size:var(--step-1);color:var(--ink-2);line-height:1.5;max-width:46ch}
.from{font-style:italic;font-family:var(--serif);color:var(--ink-3);font-size:.82em;margin-right:.15em}

/* ----------------------------- Botones ----------------------------- */
.btn{
  --bg:var(--ink);--fg:#fff;
  display:inline-flex;align-items:center;gap:.5em;justify-content:center;
  background:var(--bg);color:var(--fg);font-weight:600;font-size:var(--step--1);
  letter-spacing:.01em;padding:.85em 1.5em;border-radius:var(--radius-pill);
  transition:transform .25s ease,background .25s ease,box-shadow .25s ease;
  border:1px solid transparent;
}
.btn svg{width:18px;height:18px;transition:transform .25s ease}
.btn:hover{transform:translateY(-2px)}
.btn:hover svg{transform:translateX(3px)}
.btn:focus-visible{outline:2px solid var(--haven);outline-offset:3px}
.btn-accent{--bg:var(--haven);--fg:#fff}
.btn-accent:hover{background:var(--haven-deep)}
.btn-dark{--bg:var(--ink);--fg:#fff}
.btn-ghost{--bg:transparent;--fg:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:#fff}
.btn-block{display:flex;width:100%}
.btn.is-loading{opacity:.7;pointer-events:none}
.cta__notice{margin:0 0 .25rem;padding:.7rem 1rem;border-radius:14px;font-size:var(--step--1);font-weight:600}
.cta__notice--ok{background:rgba(167,196,160,.18);color:#dfe9da;border:1px solid rgba(167,196,160,.35)}
.cta__notice--err{background:rgba(231,166,160,.16);color:#f3d7d4;border:1px solid rgba(231,166,160,.35)}
.btn-lg{padding:1.05em 1.8em;font-size:var(--step-0)}

/* ----------------------------- Header ----------------------------- */
.site-header{
  position:sticky;top:0;z-index:100;background:color-mix(in srgb,var(--paper) 86%,transparent);
  backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid transparent;
  transition:border-color .3s ease,background .3s ease;
}
.site-header.is-scrolled{border-color:var(--line);background:color-mix(in srgb,var(--paper) 94%,transparent)}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1rem 0}

.brand{display:flex;flex-direction:column;line-height:1}
.brand__word{font-family:var(--serif);font-weight:600;font-size:1.5rem;letter-spacing:-.02em}
.brand__word--lg{font-size:2.4rem}
.brand__dot{color:var(--haven)}
.brand__sub{font-size:.58rem;letter-spacing:.32em;text-transform:uppercase;color:var(--ink-3);margin-top:.25rem}

.main-nav__list{display:flex;gap:1.9rem;list-style:none;margin:0;padding:0}
.main-nav a{font-size:var(--step--1);font-weight:500;color:var(--ink-2);position:relative;padding:.3rem 0}
.main-nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1.5px;background:var(--haven);transition:width .25s ease}
.main-nav a:hover{color:var(--ink)}
.main-nav a:hover::after{width:100%}

.header-actions{display:flex;align-items:center;gap:1.2rem}
.header-phone{display:inline-flex;align-items:center;gap:.45rem;font-size:var(--step--1);font-weight:500;color:var(--ink-2)}
.header-phone svg{color:var(--haven)}
.header-cart{position:relative;display:inline-flex;align-items:center}
.haven-cart-count{
  position:absolute;top:-8px;right:-10px;min-width:18px;height:18px;padding:0 4px;
  display:grid;place-items:center;background:var(--haven);color:#fff;font-size:.65rem;
  font-weight:600;border-radius:999px;
}
.nav-toggle{display:none;color:var(--ink)}

/* ----------------------------- Hero ----------------------------- */
.hero{
  position:relative;overflow:hidden;padding:clamp(2.5rem,2rem + 4vw,5.5rem) 0 clamp(3rem,2rem + 5vw,6rem);
  background:
    radial-gradient(120% 90% at 88% 10%, color-mix(in srgb,var(--blush) 40%,transparent) 0%, transparent 55%),
    radial-gradient(80% 70% at 10% 90%, color-mix(in srgb,#E9C46A 30%,transparent) 0%, transparent 50%),
    var(--paper);
}
.hero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:var(--gap);align-items:center}
.hero__copy h1{margin:.2rem 0 1.2rem;max-width:14ch}
.hero__cta{display:flex;gap:.8rem;flex-wrap:wrap;margin:1.8rem 0 2.4rem}
.hero__stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin:0;padding-top:1.6rem;border-top:1px solid var(--line)}
.hero__stats dt{font-family:var(--serif);font-size:var(--step-1);font-weight:500}
.hero__stats dd{margin:.3rem 0 0;font-size:var(--step--1);color:var(--ink-3);line-height:1.4}

.hero__stage{position:relative;display:grid;place-items:center;min-height:380px}
.hero__product{width:min(100%,460px);filter:drop-shadow(0 30px 40px rgba(28,27,25,.18))}
.hero-illu{animation:floaty 6s ease-in-out infinite}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

.float-card{
  position:absolute;right:-6px;bottom:6px;width:min(280px,72%);background:var(--surface);
  border-radius:var(--radius);padding:.9rem;box-shadow:var(--shadow);display:flex;gap:.9rem;align-items:center;
}
.float-card__thumb{width:74px;flex:0 0 74px;border-radius:16px;background:var(--paper-2);padding:.3rem}
.float-card__info{display:flex;flex-direction:column;gap:.15rem}
.float-card__info strong{font-family:var(--serif);font-size:var(--step-1);font-weight:500}
.float-card__price{font-size:var(--step--1);color:var(--ink-2)}
.float-card__link{display:inline-flex;align-items:center;gap:.3rem;font-size:.78rem;font-weight:600;color:var(--haven-deep);margin-top:.3rem}
.float-card__link svg{width:14px;height:14px}

/* ----------------------------- Secciones ----------------------------- */
.section{padding:clamp(3rem,2.4rem + 4vw,6rem) 0}
.section--paper{background:var(--paper)}
.section--white{background:var(--paper-2)}
.section--ink{background:var(--ink);color:var(--paper)}
.section--ink .display em{color:var(--blush)}
.section--ink .sec-head__note{color:#b8b0a4}

.sec-head{max-width:var(--maxw);margin-bottom:clamp(2rem,1.5rem + 2vw,3.2rem)}
.sec-head__title{max-width:18ch}
.sec-head__note{margin:1rem 0 0;color:var(--ink-3);max-width:48ch;font-size:var(--step-0)}
.sec-head--split{display:grid;grid-template-columns:1.2fr 1fr;gap:var(--gap);align-items:end}
.sec-head--split .sec-head__note{margin:0;padding-bottom:.4rem}
.sec-foot{margin-top:2.6rem;display:flex;justify-content:center}

/* ----------------------------- Tarjetas producto ----------------------------- */
.p-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.p-grid--shop{grid-template-columns:repeat(3,1fr)}
.p-card{
  background:var(--surface);border:1px solid var(--line-2);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;transition:transform .3s ease,box-shadow .3s ease;
}
.p-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft)}
.p-card__media{display:block;background:var(--paper-2);padding:1.4rem;aspect-ratio:1/1}
.p-card__media .haven-illu,.p-card__media img{width:100%;height:100%;object-fit:contain}
.p-card__body{padding:1.1rem 1.2rem 1.3rem;display:flex;flex-direction:column;gap:.55rem;flex:1}
.p-card__tag{font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);font-weight:600}
.p-card__name{font-family:var(--serif);font-size:var(--step-1);font-weight:500;margin:0;line-height:1.1}
.p-card__desc{font-size:var(--step--1);color:var(--ink-3);margin:0;line-height:1.45;flex:1}
.p-card__foot{display:flex;align-items:baseline;justify-content:space-between;margin-top:.2rem}
.p-card__price{font-weight:600;font-size:var(--step-0)}
.p-card__price .woocommerce-Price-amount{font-weight:600}
.p-card .btn{margin-top:.4rem}

/* Muestras de color (dots) */
.swatches{display:flex;gap:.42rem;flex-wrap:wrap}
.swatch{width:18px;height:18px;border-radius:50%;background:var(--sw);box-shadow:inset 0 0 0 1px rgba(28,27,25,.12);cursor:pointer;transition:transform .2s ease}
.swatch:hover,.swatch.is-active{transform:scale(1.18);box-shadow:inset 0 0 0 1px rgba(28,27,25,.12),0 0 0 2px var(--paper),0 0 0 3px var(--sw)}

/* ----------------------------- Showcase de color ----------------------------- */
.showcase{padding:clamp(3rem,2.4rem + 4vw,6rem) 0;background:var(--paper-2)}
.showcase__grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:var(--gap);align-items:center}
.showcase__copy .lede{margin-bottom:2rem}
.showcase__stack{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.color-block{
  position:relative;margin:0;border-radius:var(--radius);background:var(--bg,#eee);
  padding:1.4rem;overflow:hidden;aspect-ratio:4/3;display:grid;place-items:center;
}
.color-block--sm{aspect-ratio:1/1}
.color-block__illu{width:78%}
.hexchip{
  position:absolute;right:.9rem;bottom:.9rem;display:flex;flex-direction:column;align-items:flex-end;gap:.1rem;margin:0;
}
.hexchip__label{font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-2);opacity:.7}
.hexchip__code{
  font-family:var(--sans);font-weight:600;font-size:.8rem;letter-spacing:.04em;
  background:var(--chip);color:#fff;padding:.32em .7em;border-radius:8px;
  text-shadow:0 1px 2px rgba(0,0,0,.18);mix-blend-mode:normal;
}

/* ----------------------------- Features ----------------------------- */
.feature-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.feature{padding:1.6rem 0 0;border-top:2px solid var(--ink)}
.feature__idx{font-family:var(--serif);font-size:var(--step-1);color:var(--haven);display:block;margin-bottom:.7rem}
.feature h3{font-family:var(--serif);font-weight:500;font-size:var(--step-1);margin:0 0 .5rem}
.feature p{font-size:var(--step--1);color:var(--ink-3);margin:0;line-height:1.5}

/* ----------------------------- Materiales (acordeón) ----------------------------- */
.mat-grid{display:flex;flex-direction:column;border-top:1px solid rgba(241,236,227,.16)}
.mat{border-bottom:1px solid rgba(241,236,227,.16)}
.mat__head{display:flex;align-items:baseline;gap:1.2rem;width:100%;text-align:left;padding:1.5rem 0}
.mat__name{font-family:var(--serif);font-size:var(--step-2);font-weight:500;flex:0 0 auto}
.mat__sub{font-size:var(--step--1);letter-spacing:.1em;text-transform:uppercase;color:#a59c8f}
.mat__head::after{content:"+";margin-left:auto;font-size:1.6rem;color:var(--blush);transition:transform .3s ease}
.mat.is-open .mat__head::after{transform:rotate(45deg)}
.mat__body{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .4s ease}
.mat.is-open .mat__body{max-height:200px;padding-bottom:1.5rem}
.mat__body p{margin:0;max-width:60ch;color:#cfc7ba;font-size:var(--step-0)}

/* ----------------------------- Configurador ----------------------------- */
.config{background:var(--ink);color:var(--paper);padding:clamp(3rem,2.4rem + 4vw,6rem) 0}
.config__grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap);align-items:stretch}
.config__panel{background:#262420;border-radius:var(--radius-lg);padding:clamp(1.6rem,1.2rem + 1.5vw,2.6rem)}
.config__panel .display{color:var(--paper)}
.config__panel .display em{color:var(--blush)}
.config__lede{color:#b8b0a4;margin:.6rem 0 1.8rem}
.config__field{margin-bottom:1.4rem}
.config__label{display:block;font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:#a59c8f;margin-bottom:.7rem}
.chip-row,.swatch-row{display:flex;gap:.5rem;flex-wrap:wrap}
.chip{
  padding:.55em 1.05em;border-radius:var(--radius-pill);font-size:var(--step--1);font-weight:500;
  background:#322f2a;color:#d8d0c4;border:1px solid transparent;transition:all .2s ease;
}
.chip:hover{background:#3b372f}
.chip.is-active{background:var(--paper);color:var(--ink);font-weight:600}
.swatch-btn{width:30px;height:30px;border-radius:50%;background:var(--sw);box-shadow:inset 0 0 0 1px rgba(255,255,255,.18);transition:transform .2s ease}
.swatch-btn:hover{transform:scale(1.12)}
.swatch-btn.is-active{box-shadow:inset 0 0 0 1px rgba(255,255,255,.18),0 0 0 2px var(--ink),0 0 0 4px var(--sw)}
.config__foot{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-top:2rem;padding-top:1.6rem;border-top:1px solid rgba(241,236,227,.14);flex-wrap:wrap}
.config__price-label{display:block;font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:#a59c8f}
.config__price-val{font-family:var(--serif);font-size:var(--step-3);font-weight:500;line-height:1}

.config__viewer{background:#1f1d1a;border-radius:var(--radius-lg);padding:1.4rem;display:flex;flex-direction:column}
.config__viewer-bar{display:flex;justify-content:space-between;align-items:center;font-size:var(--step--1);color:#a59c8f}
.config__spin{display:inline-flex;align-items:center;gap:.4rem;color:#d8d0c4;font-size:.8rem;background:#2b2823;padding:.4em .9em;border-radius:999px}
.config__spin svg{width:15px;height:15px}
.config__stage{flex:1;display:grid;place-items:center;padding:1.5rem;min-height:300px}
.config__illu-wrap{grid-area:1/1;display:grid;place-items:center;width:100%}
.config__illu-wrap.is-hidden{display:none}
.config__stage .haven-illu{width:min(90%,360px);transition:transform .6s cubic-bezier(.2,.7,.2,1);filter:drop-shadow(0 24px 30px rgba(0,0,0,.4))}
.config__stage.is-spun .haven-illu{transform:rotateY(180deg)}
.config__hint{font-size:.74rem;color:#8d8579;text-align:center;margin:.4rem 0 0}

/* ----------------------------- Contexto / local ----------------------------- */
.context-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem}
.context{position:relative;margin:0;border-radius:var(--radius-lg);overflow:hidden;background:linear-gradient(160deg,var(--env,#eee),var(--surface));min-height:340px;display:grid;place-items:center;padding:2rem}
.context__scene{width:62%}
.context__card{
  position:absolute;left:1.4rem;bottom:1.4rem;width:min(290px,70%);background:var(--surface);
  border-radius:var(--radius);padding:1.1rem;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:.4rem;
}
.context__card strong{font-family:var(--serif);font-size:var(--step-1);font-weight:500}
.context__tag{font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3)}
.context__price{font-size:var(--step--1);color:var(--ink-2)}
.context__card .swatches{margin:.2rem 0 .4rem}

/* ----------------------------- Studio ----------------------------- */
.studio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.studio{border-top:1px solid var(--line);padding-top:1.4rem}
.studio__kicker{font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--haven-deep);font-weight:600}
.studio__title{font-family:var(--serif);font-weight:500;font-size:var(--step-2);line-height:1.12;margin:.7rem 0 .6rem}
.studio__title a:hover{color:var(--haven)}
.studio__excerpt{font-size:var(--step--1);color:var(--ink-3);margin:0 0 1rem}
.studio__more{display:inline-flex;align-items:center;gap:.35rem;font-size:.8rem;font-weight:600;color:var(--ink)}
.studio__more svg{width:15px;height:15px}

/* ----------------------------- CTA contacto ----------------------------- */
.cta{padding:clamp(3rem,2.4rem + 4vw,6rem) 0;background:var(--paper)}
.cta__card{background:var(--ink);color:var(--paper);border-radius:var(--radius-lg);padding:clamp(1.8rem,1.2rem + 3vw,3.4rem);display:grid;grid-template-columns:1.1fr .9fr;gap:var(--gap);align-items:center;position:relative;overflow:hidden}
.cta__copy{position:relative;z-index:2}
.cta__copy .display{color:var(--paper);max-width:14ch}
.cta__copy .display em{color:var(--blush)}
.cta__copy p{color:#cfc7ba;margin:1rem 0 0;max-width:42ch}
.cta__product{position:absolute;right:-8%;bottom:-12%;width:42%;opacity:.9;z-index:1}
.cta__form{position:relative;z-index:2;background:#262420;border-radius:var(--radius);padding:1.6rem;display:flex;flex-direction:column;gap:.9rem}
.field{display:flex;flex-direction:column;gap:.35rem}
.field__label{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:#a59c8f}
.field input,.field textarea{
  background:#1f1d1a;border:1px solid #38342d;border-radius:12px;padding:.8em 1em;color:var(--paper);
  font-family:inherit;font-size:var(--step--1);transition:border-color .2s ease;resize:vertical;
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--blush)}
.field input::placeholder,.field textarea::placeholder{color:#7c7468}
.cta__fine{font-size:.7rem;color:#8d8579;margin:.2rem 0 0;line-height:1.4}
.cta__wa{display:inline-flex;align-items:center;gap:.5rem;font-size:.82rem;font-weight:600;color:var(--blush);margin-top:.2rem}
.cta__wa svg{width:17px;height:17px}
.haven-form--sent .field,.haven-form--sent .btn{opacity:.5;pointer-events:none}

/* ----------------------------- Footer ----------------------------- */
.site-footer{background:var(--ink);color:var(--paper);padding:clamp(2.5rem,2rem + 3vw,4.5rem) 0 2rem}
.site-footer__grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:var(--gap)}
.site-footer__claim{color:#b8b0a4;font-size:var(--step--1);max-width:34ch;margin:1rem 0}
.site-footer__claim em{font-family:var(--serif);font-style:italic;color:var(--blush)}
.site-footer__zone{font-size:.78rem;color:#8d8579;letter-spacing:.02em}
.site-footer__col h4{font-family:var(--serif);font-weight:500;font-size:var(--step-1);margin:0 0 1rem}
.site-footer__col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.6rem}
.site-footer__col a{font-size:var(--step--1);color:#cfc7ba}
.site-footer__col a:hover{color:var(--blush)}
.site-footer__bottom{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-top:2.6rem;padding-top:1.6rem;border-top:1px solid rgba(241,236,227,.14);font-size:.76rem;color:#8d8579;flex-wrap:wrap}
.site-footer__legal{display:flex;gap:1.2rem;list-style:none;margin:0;padding:0}
.site-footer__legal a{color:#8d8579}

/* ----------------------------- WooCommerce: archive ----------------------------- */
.archive-head{padding:clamp(2.5rem,2rem + 3vw,4.5rem) 0 1.5rem;background:var(--paper)}
.archive-head h1{margin:.3rem 0 1.4rem;max-width:16ch}
.silo-tabs{display:flex;gap:.6rem;flex-wrap:wrap}
.silo-tab{padding:.55em 1.2em;border-radius:var(--radius-pill);border:1px solid var(--line);font-size:var(--step--1);font-weight:500;color:var(--ink-2);transition:all .2s ease}
.silo-tab:hover{border-color:var(--ink)}
.silo-tab.is-active{background:var(--ink);color:#fff;border-color:var(--ink)}
.archive-head__desc{margin-top:1.2rem;color:var(--ink-3);max-width:60ch}
.archive-body{padding:2rem 0 4rem}
.archive-toolbar{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.6rem;flex-wrap:wrap}
.archive-toolbar .woocommerce-result-count{color:var(--ink-3);font-size:var(--step--1);margin:0}
.archive-toolbar select{padding:.5em 1em;border:1px solid var(--line);border-radius:var(--radius-pill);background:var(--surface);font-family:inherit}

/* ----------------------------- WooCommerce: single ----------------------------- */
.single-product-editorial{padding:clamp(2rem,1.5rem + 3vw,4rem) 0}
.sp-hero{display:grid;grid-template-columns:1fr 1fr;grid-template-areas:"copy buy" "gallery buy";gap:var(--gap) clamp(2rem,1.5rem+2vw,4rem);align-items:start}
.sp-hero__copy{grid-area:copy}
.sp-hero__gallery{grid-area:gallery}
.sp-buy{grid-area:buy;position:sticky;top:90px}
.sp-hero__title{margin:.3rem 0 1.2rem}
.sp-hero__excerpt{color:var(--ink-2);font-size:var(--step-1);max-width:46ch}
.sp-hero__gallery img{border-radius:var(--radius);background:var(--paper-2)}
.woocommerce-product-gallery{position:relative}
.flex-control-thumbs{display:flex;gap:.6rem;list-style:none;padding:0;margin:1rem 0 0}
.flex-control-thumbs li{width:72px}
.flex-control-thumbs img{border-radius:12px;cursor:pointer;opacity:.6}
.flex-control-thumbs img:hover,.flex-control-thumbs .flex-active{opacity:1}

.sp-buy__card{background:var(--surface);border:1px solid var(--line-2);border-radius:var(--radius-lg);padding:1.6rem;box-shadow:var(--shadow-soft)}
.sp-buy__thumb{background:var(--paper-2);border-radius:var(--radius);padding:1.2rem;margin-bottom:1.2rem}
.sp-buy__name{font-family:var(--serif);font-weight:500;font-size:var(--step-2);margin:0 0 .5rem}
.sp-buy__short{color:var(--ink-3);font-size:var(--step--1);margin-bottom:1.2rem}
.sp-buy__price{font-size:var(--step-2);font-family:var(--serif);margin-bottom:1.2rem}
.sp-buy__price .woocommerce-Price-amount{font-weight:500}
.sp-buy__price del{color:var(--ink-3);font-size:.7em;margin-right:.4em}
.sp-buy__swatches{margin-bottom:1.3rem}
.sp-buy__swatches .config__label{color:var(--ink-3)}
.sp-buy__cart .button,.sp-buy__cart button{width:100%;background:var(--ink);color:#fff;border-radius:var(--radius-pill);padding:1em 1.5em;font-weight:600;font-size:var(--step-0);border:0;transition:background .2s ease,transform .2s ease}
.sp-buy__cart .button:hover{background:var(--haven);transform:translateY(-2px)}
.sp-buy__cart .quantity{margin-bottom:.8rem;display:inline-flex}
.sp-buy__cart .quantity input{width:72px;padding:.7em;border:1px solid var(--line);border-radius:12px;text-align:center}
.sp-buy__wa{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:.9rem;font-size:.82rem;font-weight:600;color:var(--haven-deep)}
.sp-buy__meta{display:flex;align-items:center;gap:.4rem;font-size:.74rem;color:var(--ink-3);margin:1rem 0 0}
.sp-buy__meta svg{width:15px;height:15px;color:var(--haven)}

.sp-colors{margin-top:clamp(3rem,2rem+3vw,5rem)}
.sp-colors__row{display:grid;grid-template-columns:repeat(6,1fr);gap:.9rem}
.sp-detail{margin-top:clamp(2.5rem,2rem+2vw,4rem)}
.woocommerce-tabs .tabs{display:flex;gap:.5rem;list-style:none;padding:0;margin:0 0 1.5rem;border-bottom:1px solid var(--line);flex-wrap:wrap}
.woocommerce-tabs .tabs a{display:inline-block;padding:.7em 1.2em;font-weight:600;font-size:var(--step--1);color:var(--ink-3)}
.woocommerce-tabs .tabs .active a{color:var(--ink);box-shadow:inset 0 -2px 0 var(--haven)}
.woocommerce-tabs .panel h2{font-family:var(--serif);font-weight:500}
.related.products,.upsells.products{margin-top:clamp(2.5rem,2rem+2vw,4rem)}
.related.products>h2,.upsells.products>h2{font-family:var(--serif);font-weight:500;font-size:var(--step-2);margin-bottom:1.5rem}
.related .products,.upsells .products{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}

/* WooCommerce notices */
.woocommerce-message,.woocommerce-info,.woocommerce-error{
  list-style:none;background:var(--surface);border-left:3px solid var(--haven);
  border-radius:12px;padding:1em 1.2em;margin:0 0 1.5rem;font-size:var(--step--1);box-shadow:var(--shadow-soft)
}
.woocommerce-message .button,.woocommerce-info .button{float:right;background:var(--ink);color:#fff;border-radius:var(--radius-pill);padding:.4em 1em}

/* ----------------------------- Posts ----------------------------- */
.post-wrap{padding:clamp(2.5rem,2rem+3vw,5rem) 0}
.post-wrap--narrow{max-width:760px}
.post-content{font-size:var(--step-0);line-height:1.75;color:var(--ink-2);max-width:70ch}
.post-content h2,.post-content h3{font-family:var(--serif);font-weight:500;color:var(--ink)}
.post-content a{color:var(--haven-deep);text-decoration:underline}
.post-single__head{margin-bottom:1.6rem}
.post-single__meta{color:var(--ink-3);font-size:var(--step--1)}
.post-single__media{margin:1.5rem 0}
.post-single__media img{border-radius:var(--radius)}
.post-empty{color:var(--ink-3);padding:2rem 0}

/* ----------------------------- Reveal / motion ----------------------------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.is-in{opacity:1;transform:none}

/* ----------------------------- Responsive ----------------------------- */
@media (max-width:1024px){
  .p-grid{grid-template-columns:repeat(2,1fr)}
  .p-grid--shop{grid-template-columns:repeat(2,1fr)}
  .feature-grid{grid-template-columns:repeat(2,1fr);gap:1.6rem}
  .studio-grid{grid-template-columns:1fr 1fr}
  .related .products,.upsells .products{grid-template-columns:repeat(2,1fr)}
  .sp-colors__row{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:860px){
  .main-nav,.header-phone{display:none}
  .nav-toggle{display:inline-flex}
  body.nav-open{overflow:hidden}
  .main-nav.is-open{
    display:block;position:fixed;inset:0;top:0;background:var(--paper);z-index:120;
    padding:6rem 1.5rem 2rem;animation:slidein .3s ease;
  }
  .main-nav.is-open .main-nav__list{flex-direction:column;gap:1.4rem}
  .main-nav.is-open a{font-family:var(--serif);font-size:var(--step-2)}
  .nav-toggle[aria-expanded="true"]{position:fixed;right:1.5rem;top:1.4rem;z-index:130}
  @keyframes slidein{from{opacity:0}to{opacity:1}}

  .hero__grid{grid-template-columns:1fr;gap:2.5rem}
  .hero__stage{min-height:300px}
  .showcase__grid,.config__grid,.sec-head--split,.context-grid,.cta__card{grid-template-columns:1fr}
  .sp-hero{grid-template-columns:1fr;grid-template-areas:"copy" "buy" "gallery"}
  .sp-buy{position:static}
  .site-footer__grid{grid-template-columns:1fr 1fr}
  .cta__product{display:none}
}
@media (max-width:540px){
  .p-grid,.p-grid--shop{grid-template-columns:1fr}
  .feature-grid{grid-template-columns:1fr}
  .studio-grid{grid-template-columns:1fr}
  .hero__stats{grid-template-columns:1fr;gap:.9rem}
  .sp-colors__row{grid-template-columns:repeat(2,1fr)}
  .site-footer__grid{grid-template-columns:1fr}
  .float-card{position:static;width:100%;margin-top:1.5rem}
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important}
  .reveal{opacity:1;transform:none}
  .hero-illu{animation:none}
}

:where(a,button,input,textarea,select):focus-visible{outline:2px solid var(--haven);outline-offset:2px}
