/* ============================================================
   EL RANQUEL — Sistema visual
   Catálogo institucional de jardinería
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600&display=swap');

:root{
  /* Paleta */
  --bg:#FAF8F4;
  --bg-tile:#F2EEE6;
  --bg-tile-2:#ECE6DB;
  --ink:#1C1410;
  --ink-soft:#6A5E50;
  --ink-faint:#9A8E7F;
  --line:#E4DDD2;
  --line-soft:#EDE7DD;

  /* Acento — verde tierra, con MUCHA moderación */
  --sage:#6B7F5E;
  --sage-deep:#56684B;
  --sage-tint:#EDF0E8;

  /* Tonos de placeholder (vienen de "fotos") */
  --ph-green:#7E9270;
  --ph-green-d:#5E7350;
  --ph-terra:#BD8466;
  --ph-terra-d:#A06A4E;
  --ph-sand:#CDBBA0;
  --ph-clay:#9A7A64;

  /* Footer */
  --footer-bg:#2A211A;
  --footer-ink:#EAE2D6;
  --footer-soft:#A99B89;
  --footer-line:#473B30;

  /* Tipos */
  --display:'Cormorant Garamond',Georgia,serif;
  --body:'DM Sans',system-ui,sans-serif;

  /* Layout */
  --maxw:1320px;
  --gutter:clamp(20px,5vw,64px);
  --nav-h:74px;
}

*,*::before,*::after{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--body);
  font-size:16px;
  line-height:1.6;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;}

.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter);}

/* Eyebrow mono-ish label */
.eyebrow{
  font-family:var(--body);
  font-size:11px;
  font-weight:500;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--sage-deep);
}
.eyebrow--soft{color:var(--ink-faint);}

/* Section heading */
.s-head{
  font-family:var(--display);
  font-weight:500;
  font-size:clamp(2rem,4vw,3rem);
  line-height:1.05;
  letter-spacing:.005em;
  margin:0;
}

hr.rule{
  border:0;
  height:1px;
  background:var(--line);
  margin:0;
}

/* ============================================================
   NAVBAR
   ============================================================ */
.nav{
  position:sticky;top:0;z-index:1000;
  background:color-mix(in srgb,var(--bg) 88%,transparent);
  backdrop-filter:saturate(120%) blur(8px);
  border-bottom:1px solid transparent;
  transition:border-color .3s;
}
.nav[data-scrolled="1"]{border-bottom-color:var(--line);}
.nav__inner{
  max-width:var(--maxw);margin:0 auto;
  padding-inline:var(--gutter);
  height:var(--nav-h);
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;
}
.brand{
  font-family:var(--display);
  font-weight:600;
  font-size:24px;
  letter-spacing:.01em;
  line-height:1;
  white-space:nowrap;
  color:var(--ink);
  display:inline-flex;
  align-items:center;
  gap:12px;
}
.brand__logo{height:2.4em;width:auto;flex-shrink:0;border-radius:4px;display:block;}
.brand__text{display:block;}
.brand small{
  display:block;
  font-family:var(--body);
  font-size:9px;
  font-weight:500;
  letter-spacing:.26em;
  text-transform:uppercase;
  color:var(--ink-faint);
  margin-top:4px;
  line-height:1.5;
  white-space:normal;
  max-width:280px;
}
.brand small .brand__sub2{display:block;letter-spacing:.08em;margin-top:1px;}
.nav__links{
  display:flex;align-items:center;gap:clamp(18px,2.4vw,38px);
  list-style:none;margin:0;padding:0;
}
.nav__links a{
  font-size:13.5px;
  font-weight:500;
  letter-spacing:.02em;
  color:var(--ink-soft);
  padding:6px 0;
  position:relative;
  transition:color .2s;
}
.nav__links a::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;
  background:var(--sage);transform:scaleX(0);transform-origin:left;
  transition:transform .28s cubic-bezier(.4,.7,.3,1);
}
.nav__links a:hover{color:var(--ink);}
.nav__links a:hover::after,
.nav__links a[aria-current="page"]::after{transform:scaleX(1);}
.nav__links a[aria-current="page"]{color:var(--ink);}

.nav__burger{
  display:none;border:0;background:transparent;cursor:pointer;
  width:40px;height:40px;align-items:center;justify-content:center;
  flex-direction:column;gap:5px;padding:0;
}
.nav__burger span{display:block;width:22px;height:1.5px;background:var(--ink);transition:.3s;}
.nav__burger[aria-expanded="true"] span:nth-child(1){transform:translateY(6.5px) rotate(45deg);}
.nav__burger[aria-expanded="true"] span:nth-child(2){opacity:0;}
.nav__burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);}

/* Nav variation: center logo */
[data-nav="center"] .nav__inner{display:grid;grid-template-columns:1fr auto 1fr;grid-template-rows:1fr;}
[data-nav="center"] .nav__links{justify-content:initial;}
[data-nav="center"] .brand{grid-column:2;grid-row:1;text-align:center;}
[data-nav="center"] .nav__links--main{grid-column:1;grid-row:1;}
[data-nav="center"] .nav__links--end{grid-column:3;grid-row:1;justify-self:end;}
.nav__links--end{display:none;}
[data-nav="center"] .nav__links--end{display:flex;}
[data-nav="center"] .nav__cta{display:none;}

/* Nav variation: minimal centered links */
[data-nav="minimal"] .nav__links a{font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);}
[data-nav="minimal"] .nav__links{gap:clamp(16px,2vw,30px);}
[data-nav="minimal"] .nav__inner{justify-content:space-between;}

.nav__cta{
  font-size:12px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;
  color:var(--sage-deep);border:1px solid var(--line);border-radius:2px;
  padding:9px 16px;transition:.2s;white-space:nowrap;
}
.nav__cta:hover{border-color:var(--sage);color:var(--sage-deep);background:var(--sage-tint);}

/* Mobile drawer */
.nav__drawer{
  position:fixed;inset:var(--nav-h) 0 0;z-index:999;
  background:var(--bg);
  transform:translateY(-100%);opacity:0;pointer-events:none;
  transition:transform .4s cubic-bezier(.4,.7,.3,1),opacity .3s;
  padding:40px var(--gutter);
  display:flex;flex-direction:column;gap:6px;
}
.nav__drawer[data-open="1"]{transform:translateY(0);opacity:1;pointer-events:auto;}
.nav__drawer a{
  font-family:var(--display);font-size:30px;font-weight:500;
  padding:14px 0;border-bottom:1px solid var(--line-soft);color:var(--ink);
}
.nav__drawer a:last-child{border-bottom:0;}

@media(max-width:860px){
  .nav__links,.nav__cta{display:none !important;}
  .nav__burger{display:flex;}
  [data-nav="center"] .nav__inner{display:flex;}
  [data-nav="center"] .brand{text-align:left;}
}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;}
.hero__viewport{position:relative;overflow:hidden;}
.hero__track{display:flex;transition:transform .9s cubic-bezier(.5,.05,.2,1);}
.hero__slide{
  position:relative;flex:0 0 100%;
  height:clamp(440px,72vh,720px);
  display:flex;align-items:center;
}
.hero__scene{position:absolute;inset:0;}
/* placeholder "photo" scenes */
.scene-green{background:linear-gradient(160deg,var(--ph-green) 0%,var(--ph-green-d) 100%);}
.scene-terra{background:linear-gradient(160deg,var(--ph-terra) 0%,var(--ph-terra-d) 100%);}
.scene-sand{background:linear-gradient(160deg,var(--ph-clay) 0%,#7C5F49 100%);}
.hero__scene::before{
  content:"";position:absolute;inset:0;
  background-image:repeating-linear-gradient(135deg,rgba(255,255,255,.05) 0 2px,transparent 2px 22px);
  mix-blend-mode:soft-light;
}
.hero__scene::after{
  content:attr(data-ph);
  position:absolute;right:18px;bottom:14px;
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace;
  font-size:10px;letter-spacing:.12em;color:rgba(255,255,255,.55);
}
.hero__scrim{position:absolute;inset:0;background:linear-gradient(90deg,rgba(20,14,8,.5) 0%,rgba(20,14,8,.18) 48%,transparent 75%);}
.hero__content{position:relative;z-index:2;width:100%;}
.hero__inner{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter);}
.hero__eyebrow{
  font-size:11px;font-weight:500;letter-spacing:.3em;text-transform:uppercase;
  color:rgba(255,255,255,.8);margin-bottom:22px;
  display:flex;align-items:center;gap:14px;
}
.hero__eyebrow::before{content:"";width:34px;height:1px;background:rgba(255,255,255,.55);}
.hero__title{
  font-family:var(--display);
  font-weight:500;
  text-transform:uppercase;
  letter-spacing:.05em;
  line-height:1.04;
  font-size:clamp(2.4rem,6.2vw,5.4rem);
  color:#fff;
  max-width:16ch;
  margin:0 0 30px;
  text-wrap:balance;
}
.hero__cta{
  display:inline-flex;align-items:center;gap:12px;white-space:nowrap;
  font-size:13px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;
  color:#fff;padding-bottom:6px;border-bottom:1px solid rgba(255,255,255,.5);
  transition:.25s;
}
.hero__cta svg{transition:transform .25s;}
.hero__cta:hover{border-color:#fff;}
.hero__cta:hover svg{transform:translateX(6px);}

/* Hero controls */
.hero__dots{
  position:absolute;z-index:3;left:var(--gutter);bottom:34px;
  display:flex;gap:10px;
}
.hero__dot{
  width:34px;height:3px;border:0;padding:0;cursor:pointer;
  background:rgba(255,255,255,.35);transition:.3s;
}
.hero__dot[aria-selected="true"]{background:#fff;}
.hero__arrows{position:absolute;z-index:3;right:var(--gutter);bottom:28px;display:flex;gap:8px;}
.hero__arrow{
  width:44px;height:44px;border:1px solid rgba(255,255,255,.4);background:transparent;
  color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;
  border-radius:50%;transition:.2s;
}
.hero__arrow:hover{background:rgba(255,255,255,.14);border-color:#fff;}

/* Hero variation: SPLIT */
[data-hero="split"] .hero__slide{height:clamp(460px,70vh,640px);}
[data-hero="split"] .hero__scene{left:auto;right:0;width:46%;}
[data-hero="split"] .hero__scrim{display:none;}
[data-hero="split"] .hero__content{position:absolute;inset:0;display:flex;align-items:center;}
[data-hero="split"] .hero__eyebrow{color:var(--sage-deep);}
[data-hero="split"] .hero__eyebrow::before{background:var(--sage);}
[data-hero="split"] .hero__title{color:var(--ink);max-width:11ch;}
[data-hero="split"] .hero__cta{color:var(--ink);border-color:var(--ink-soft);}
[data-hero="split"] .hero__cta:hover{border-color:var(--ink);}
[data-hero="split"] .hero__inner{max-width:var(--maxw);width:100%;}
[data-hero="split"] .hero__copy{max-width:54%;}
[data-hero="split"] .hero__dots{filter:invert(0);}
[data-hero="split"] .hero__dot{background:var(--line);}
[data-hero="split"] .hero__dot[aria-selected="true"]{background:var(--sage-deep);}
[data-hero="split"] .hero__arrows{display:none;}

/* Hero variation: EDITORIAL */
[data-hero="editorial"] .hero__slide{height:clamp(500px,76vh,700px);justify-content:center;text-align:center;}
[data-hero="editorial"] .hero__scene{opacity:.92;}
[data-hero="editorial"] .hero__scene::before{opacity:.5;}
[data-hero="editorial"] .hero__scrim{background:rgba(20,14,8,.32);}
[data-hero="editorial"] .hero__copy{margin:0 auto;display:flex;flex-direction:column;align-items:center;}
[data-hero="editorial"] .hero__eyebrow::before{display:none;}
[data-hero="editorial"] .hero__eyebrow{justify-content:center;}
[data-hero="editorial"] .hero__title{max-width:18ch;font-size:clamp(2.6rem,6.5vw,5.8rem);}
[data-hero="editorial"] .hero__dots{left:50%;transform:translateX(-50%);}
[data-hero="editorial"] .hero__arrows{display:none;}

.hero__copy{opacity:0;transform:translateY(16px);transition:opacity .7s .15s,transform .7s .15s;}
.hero__slide[data-active="1"] .hero__copy{opacity:1;transform:none;}

@media(max-width:860px){
  [data-hero="split"] .hero__scene{position:relative;width:100%;height:200px;}
  [data-hero="split"] .hero__slide{flex-direction:column;height:auto;display:block;}
  [data-hero="split"] .hero__content{position:relative;padding-block:48px;}
  [data-hero="split"] .hero__copy{max-width:100%;}
}

/* ============================================================
   LÍNEAS (homepage 3-up)
   ============================================================ */
.section{padding-block:clamp(60px,9vw,120px);}
.section--tight{padding-block:clamp(44px,6vw,80px);}
.sec-intro{max-width:60ch;margin-bottom:clamp(40px,5vw,64px);}
.sec-intro .eyebrow{margin-bottom:18px;display:block;}
.sec-intro p{color:var(--ink-soft);font-size:18px;line-height:1.7;margin:18px 0 0;}

.lineas{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(28px,4vw,56px);
}
.linea{padding-top:28px;border-top:1px solid var(--line);}
.linea__icon{width:48px;height:48px;color:var(--sage-deep);margin-bottom:24px;}
.linea__icon svg{width:100%;height:100%;}
.linea h3{font-family:var(--display);font-weight:600;font-size:1.7rem;margin:0 0 10px;}
.linea p{color:var(--ink-soft);font-size:15px;margin:0 0 22px;min-height:3em;}
.linea__more{
  font-size:12px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;white-space:nowrap;
  color:var(--ink);display:inline-flex;align-items:center;gap:9px;transition:gap .25s,color .2s;
}
.linea__more svg{transition:transform .25s;}
.linea:hover .linea__more{color:var(--sage-deep);}
.linea:hover .linea__more svg{transform:translateX(5px);}

@media(max-width:860px){.lineas{grid-template-columns:1fr;gap:8px;}}

/* ============================================================
   PRODUCT GRID
   ============================================================ */
.cat-hero{padding-block:clamp(54px,7vw,96px) clamp(30px,4vw,48px);}
.cat-hero .eyebrow{display:block;margin-bottom:18px;}
.cat-hero h1{font-family:var(--display);font-weight:500;font-size:clamp(2.6rem,6vw,4.4rem);line-height:1.02;margin:0;}
.cat-hero p{max-width:54ch;color:var(--ink-soft);font-size:18px;margin:24px 0 0;}

.subcat{padding-block:clamp(34px,4vw,52px);}
.subcat__head{display:flex;align-items:baseline;justify-content:space-between;gap:20px;margin-bottom:32px;}
.subcat__head h2{font-family:var(--display);font-weight:500;font-size:clamp(1.6rem,3vw,2.2rem);margin:0;}
.subcat__count{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);white-space:nowrap;}

.grid{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:clamp(10px,1.4vw,20px);
}
.product{display:block;cursor:pointer;}
.product__media{
  position:relative;aspect-ratio:1;overflow:hidden;
  background:var(--bg-tile);
}
.product__media::before{
  content:"";position:absolute;inset:0;
  background-image:repeating-linear-gradient(135deg,rgba(28,20,16,.035) 0 1px,transparent 1px 12px);
}
.product__ph{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace;
  font-size:10px;letter-spacing:.08em;color:var(--ink-faint);
  text-align:center;padding:14px;
}
.product__glyph{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  color:color-mix(in srgb,var(--ph-green) 50%,var(--ink-faint));opacity:.5;
}
.product__glyph svg{width:42%;height:42%;}
.product__name{
  font-family:var(--display);font-weight:500;font-size:1.18rem;
  text-align:center;margin:14px 0 0;line-height:1.2;color:var(--ink);
  transition:color .2s;
}
.product:hover .product__media{background:var(--bg-tile-2);}
.product:hover .product__name{color:var(--sage-deep);}
.product__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}

/* tints to vary product placeholders */
.t-green .product__glyph{color:color-mix(in srgb,var(--ph-green) 60%,#000 6%);opacity:.42;}
.t-terra .product__glyph{color:color-mix(in srgb,var(--ph-terra) 60%,#000 6%);opacity:.45;}
.t-clay  .product__glyph{color:color-mix(in srgb,var(--ph-clay) 70%,#000 6%);opacity:.45;}

/* Grid variation: TILE (airy, cream tile bg, 4-col) */
[data-grid="tile"] .grid{grid-template-columns:repeat(4,1fr);gap:clamp(18px,2vw,30px);}
[data-grid="tile"] .product__media{background:var(--bg-tile-2);padding:0;}
[data-grid="tile"] .product{padding:0;}
[data-grid="tile"] .product__media{box-shadow:inset 0 0 0 1px var(--line-soft);}
[data-grid="tile"] .product__name{font-size:1.28rem;margin-top:18px;}

/* Grid variation: HAIRLINE (4-col, divider + category caption) */
[data-grid="hairline"] .grid{grid-template-columns:repeat(4,1fr);gap:clamp(16px,2vw,28px) clamp(14px,1.8vw,24px);}
[data-grid="hairline"] .product__name{padding-bottom:16px;border-bottom:1px solid var(--line);margin-top:16px;font-size:1.22rem;}
[data-grid="hairline"] .product__cap{
  display:block;font-family:var(--body);font-size:10.5px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink-faint);text-align:center;margin-top:8px;
}
.product__cap{display:none;}

@media(max-width:1100px){.grid{grid-template-columns:repeat(3,1fr);}[data-grid="tile"] .grid,[data-grid="hairline"] .grid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:680px){.grid,[data-grid="tile"] .grid,[data-grid="hairline"] .grid{grid-template-columns:repeat(2,1fr);}}

/* ============================================================
   PROPERTIES BAR
   ============================================================ */
.props{border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.props__row{
  display:grid;grid-template-columns:repeat(5,1fr);
}
.prop{
  display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;
  padding:clamp(34px,4vw,52px) 18px;
  border-left:1px solid var(--line-soft);
}
.prop:first-child{border-left:0;}
.prop__icon{width:34px;height:34px;color:var(--sage-deep);}
.prop__icon svg{width:100%;height:100%;}
.prop span{font-size:13.5px;font-weight:500;letter-spacing:.02em;line-height:1.4;color:var(--ink);max-width:16ch;}
@media(max-width:860px){
  .props__row{grid-template-columns:repeat(2,1fr);}
  .prop{border-left:0;border-top:1px solid var(--line-soft);}
  .prop:nth-child(odd){border-right:1px solid var(--line-soft);}
  .prop:nth-child(-n+2){border-top:0;}
}

/* ============================================================
   GENERIC CONTENT (nosotros / clientes)
   ============================================================ */
.page-hero{padding-block:clamp(64px,9vw,120px) clamp(30px,4vw,56px);}
.page-hero .eyebrow{display:block;margin-bottom:20px;}
.page-hero h1{font-family:var(--display);font-weight:500;font-size:clamp(2.8rem,7vw,5rem);line-height:1.0;margin:0;max-width:14ch;}
.lede{font-size:clamp(1.2rem,2vw,1.5rem);line-height:1.55;color:var(--ink-soft);max-width:46ch;font-family:var(--display);font-style:italic;}

.prose{max-width:62ch;}
.prose p{font-size:17px;line-height:1.8;color:var(--ink-soft);margin:0 0 1.4em;}
.prose p strong{color:var(--ink);font-weight:600;}

.split-feature{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px);align-items:center;}
.feature-media{aspect-ratio:4/5;background:var(--bg-tile);position:relative;overflow:hidden;}
.feature-media .product__ph{font-size:11px;}
.feature-media::before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(135deg,rgba(28,20,16,.035) 0 1px,transparent 1px 14px);}
@media(max-width:860px){.split-feature{grid-template-columns:1fr;}}

.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,4vw,60px);border-top:1px solid var(--line);padding-top:48px;}
.stat__num{font-family:var(--display);font-weight:500;font-size:clamp(2.6rem,5vw,3.8rem);line-height:1;color:var(--ink);}
.stat__lbl{font-size:14px;color:var(--ink-soft);margin-top:10px;max-width:22ch;}
@media(max-width:680px){.stat-row{grid-template-columns:1fr;gap:30px;}}

.timeline{display:flex;flex-direction:column;}
.tl-item{display:grid;grid-template-columns:140px 1fr;gap:clamp(20px,4vw,60px);padding:34px 0;border-top:1px solid var(--line);}
.tl-year{font-family:var(--display);font-size:1.8rem;font-weight:500;color:var(--sage-deep);}
.tl-body h4{font-family:var(--display);font-weight:600;font-size:1.35rem;margin:0 0 8px;}
.tl-body p{color:var(--ink-soft);margin:0;font-size:15.5px;line-height:1.7;}
@media(max-width:680px){.tl-item{grid-template-columns:1fr;gap:6px;}}

/* ============================================================
   FORMS (clientes + footer)
   ============================================================ */
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:22px;}
.field label{font-size:12px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);}
.field input,.field select,.field textarea{
  font-family:var(--body);font-size:15px;color:var(--ink);
  background:transparent;border:0;border-bottom:1px solid var(--line);
  padding:10px 2px;transition:border-color .2s;border-radius:0;
}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-faint);}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-bottom-color:var(--sage);}
.field textarea{resize:vertical;min-height:120px;}
.field select{appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%236A5E50' d='M0 0h12L6 8z'/></svg>");
  background-repeat:no-repeat;background-position:right 2px center;}
.field[data-error="1"] input,.field[data-error="1"] select,.field[data-error="1"] textarea{border-bottom-color:#B0573F;}
.field__err{font-size:12px;color:#B0573F;letter-spacing:.01em;text-transform:none;font-weight:400;min-height:0;display:none;}
.field[data-error="1"] .field__err{display:block;}

.field-row{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
@media(max-width:560px){.field-row{grid-template-columns:1fr;gap:0;}}

.radio-set{display:flex;flex-direction:column;gap:14px;margin-bottom:26px;}
.radio-set>span{font-size:12px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);}
.radio{display:flex;align-items:center;gap:12px;cursor:pointer;font-size:15px;color:var(--ink);}
.radio input{position:absolute;opacity:0;}
.radio i{width:17px;height:17px;border:1px solid var(--ink-soft);border-radius:50%;flex-shrink:0;display:grid;place-items:center;transition:.2s;}
.radio i::after{content:"";width:8px;height:8px;border-radius:50%;background:var(--sage-deep);transform:scale(0);transition:transform .2s;}
.radio input:checked+i{border-color:var(--sage-deep);}
.radio input:checked+i::after{transform:scale(1);}
.radio:hover i{border-color:var(--ink);}

.btn-submit{
  font-family:var(--body);font-size:13px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;
  color:var(--bg);background:var(--ink);border:0;padding:16px 34px;cursor:pointer;white-space:nowrap;
  transition:background .25s;border-radius:2px;
}
.btn-submit:hover{background:var(--sage-deep);}
.form-ok{
  display:none;padding:18px 0;border-top:1px solid var(--line);margin-top:8px;
  font-size:15px;color:var(--sage-deep);
}
.form-ok[data-show="1"]{display:block;}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--footer-bg);color:var(--footer-ink);margin-top:auto;}
.footer__inner{
  max-width:var(--maxw);margin:0 auto;padding:clamp(56px,7vw,90px) var(--gutter) 40px;
  display:grid;grid-template-columns:1fr 1.15fr;gap:clamp(40px,7vw,110px);
}
.footer__brand .brand{color:var(--footer-ink);}
.footer__brand .brand small{color:var(--footer-soft);}
.footer__addr{margin-top:30px;font-size:15px;line-height:1.9;color:var(--footer-soft);max-width:30ch;}
.footer__addr strong{color:var(--footer-ink);font-weight:500;}
.footer__links{margin-top:28px;display:flex;flex-direction:column;gap:10px;}
.footer__links a{
  font-size:14px;color:var(--footer-ink);display:inline-flex;align-items:center;gap:10px;width:max-content;
  border-bottom:1px solid transparent;padding-bottom:2px;transition:border-color .2s;
}
.footer__links a:hover{border-bottom-color:var(--footer-soft);}
.footer__links svg{width:16px;height:16px;color:var(--footer-soft);}

.footer__form h4{font-family:var(--display);font-weight:500;font-size:1.5rem;margin:0 0 24px;color:var(--footer-ink);}
.footer .field label{color:var(--footer-soft);}
.footer .field input,.footer .field select,.footer .field textarea{color:var(--footer-ink);border-bottom-color:var(--footer-line);}
.footer .field input::placeholder,.footer .field textarea::placeholder{color:#7C6E5C;}
.footer .field input:focus,.footer .field select:focus,.footer .field textarea:focus{border-bottom-color:var(--footer-soft);}
.footer .field select{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%23A99B89' d='M0 0h12L6 8z'/></svg>");}
/* el desplegable se dibuja sobre fondo blanco del SO: forzar texto oscuro legible */
.field select option{color:#2a201a;background:#fff;}
.footer .radio-set>span{color:var(--footer-soft);}
.footer .radio{color:var(--footer-ink);}
.footer .radio i{border-color:var(--footer-soft);}
.footer .radio input:checked+i{border-color:var(--footer-ink);}
.footer .radio input:checked+i::after{background:var(--footer-ink);}
.footer .btn-submit{background:var(--footer-ink);color:var(--footer-bg);}
.footer .btn-submit:hover{background:#fff;}
.footer__bar{
  max-width:var(--maxw);margin:0 auto;padding:24px var(--gutter);
  border-top:1px solid var(--footer-line);
  display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;
  font-size:12px;letter-spacing:.04em;color:var(--footer-soft);
}
@media(max-width:860px){.footer__inner{grid-template-columns:1fr;gap:48px;}}

/* ============================================================
   CLIENTES
   ============================================================ */
.cl-grid{display:grid;grid-template-columns:0.85fr 1.15fr;gap:clamp(40px,7vw,100px);align-items:start;}
.cl-intro .lede{font-family:var(--display);font-style:italic;}
.cl-benefits{display:flex;flex-direction:column;gap:30px;}
.cl-benefit{display:grid;grid-template-columns:30px 1fr;gap:18px;align-items:start;}
.cl-benefit .prop__icon{color:var(--sage-deep);margin-top:2px;}
.cl-benefit h4{font-family:var(--display);font-weight:600;font-size:1.3rem;margin:0 0 5px;}
.cl-benefit p{margin:0;color:var(--ink-soft);font-size:15px;line-height:1.65;}
.cl-form{background:var(--bg-tile);padding:clamp(28px,4vw,48px);}
.cl-form h3{font-family:var(--display);font-weight:500;font-size:1.9rem;margin:0 0 28px;}
@media(max-width:860px){.cl-grid{grid-template-columns:1fr;gap:48px;}}

/* ============================================================
   PORTAL DISTRIBUIDORES (clientes) — login + pedido
   ============================================================ */
/* Login card */
.login{background:var(--bg-tile);padding:clamp(28px,4vw,44px);}
.login h3{font-family:var(--display);font-weight:500;font-size:1.9rem;margin:0 0 6px;}
.login__sub{color:var(--ink-soft);font-size:15px;margin:0 0 28px;}
.login__hint{font-size:12.5px;color:var(--ink-faint);margin:14px 0 0;line-height:1.6;}
.login__note{margin-top:22px;padding-top:20px;border-top:1px solid var(--line);font-size:13px;color:var(--ink-soft);line-height:1.6;}
.login__note strong{color:var(--ink);font-weight:600;}
.login__error{display:none;font-size:13px;color:#B0573F;margin:0 0 18px;padding:11px 14px;background:rgba(176,87,63,.07);}
.login__error[data-show="1"]{display:block;}

/* Portal shell */
.portal{padding-block:clamp(40px,6vw,72px) clamp(60px,9vw,110px);}
.portal__head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;
  border-bottom:1px solid var(--line);padding-bottom:26px;}
.portal__hello{flex:1 1 auto;min-width:0;}
.portal__hello .eyebrow{display:block;margin-bottom:12px;}
.portal__hello h1{font-family:var(--display);font-weight:500;font-size:clamp(2rem,4vw,3rem);line-height:1.05;margin:0;}
.portal__session{display:flex;align-items:center;gap:18px;}
.chip{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:500;letter-spacing:.12em;
  text-transform:uppercase;color:var(--sage-deep);}
.chip::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--sage);}
.logout-btn{appearance:none;border:1px solid var(--line);background:transparent;cursor:pointer;
  font:inherit;font-size:12px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);
  padding:9px 16px;border-radius:2px;transition:.2s;}
.logout-btn:hover{border-color:var(--ink);color:var(--ink);}

.portal__tabs{display:flex;gap:30px;border-bottom:1px solid var(--line);margin:0 0 clamp(32px,4vw,48px);}
.ptab{appearance:none;border:0;background:transparent;cursor:pointer;font:inherit;white-space:nowrap;
  font-size:13px;font-weight:500;letter-spacing:.06em;color:var(--ink-faint);
  padding:18px 2px;margin-bottom:-1px;border-bottom:2px solid transparent;transition:.2s;
  display:inline-flex;align-items:center;gap:9px;}
.ptab:hover{color:var(--ink-soft);}
.ptab.is-active{color:var(--ink);border-bottom-color:var(--ink);}
.ptab .count{display:inline-grid;place-items:center;min-width:20px;height:20px;padding:0 6px;
  background:var(--sage-deep);color:#fff;border-radius:999px;font-size:11px;font-weight:600;letter-spacing:0;}
.ptab .count[data-n="0"]{display:none;}

/* Catalog within portal */
.pcat{margin-bottom:clamp(36px,5vw,60px);}
.pcat__title{font-family:var(--display);font-weight:500;font-size:1.5rem;margin:0 0 22px;
  display:flex;align-items:baseline;gap:14px;}
.pcat__title span{font-family:var(--body);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);white-space:nowrap;}
.pgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,2vw,26px);}
.pcard{display:flex;flex-direction:column;text-align:left;width:100%;border:0;background:transparent;font:inherit;color:inherit;cursor:pointer;padding:0;}
.pcard__media{position:relative;aspect-ratio:1;background:var(--bg-tile);box-shadow:inset 0 0 0 1px var(--line-soft);transition:background .25s,box-shadow .25s;overflow:hidden;}
.pcard__media::before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(135deg,rgba(28,20,16,.035) 0 1px,transparent 1px 12px);}
.pcard__glyph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:color-mix(in srgb,var(--ph-green) 55%,var(--ink-faint));opacity:.45;transition:transform .35s cubic-bezier(.4,.7,.3,1);}
.pcard__glyph svg{width:40%;height:40%;}
.pcard.t-terra .pcard__glyph{color:color-mix(in srgb,var(--ph-terra) 60%,#000 6%);}
.pcard.t-clay .pcard__glyph{color:color-mix(in srgb,var(--ph-clay) 70%,#000 6%);}
.pcard:hover .pcard__media{background:var(--bg-tile-2);box-shadow:inset 0 0 0 1px var(--line);}
.pcard:hover .pcard__glyph{transform:scale(1.06);}
.pcard:focus-visible{outline:2px solid var(--sage-deep);outline-offset:3px;}
.pcard__name{font-family:var(--display);font-weight:500;font-size:1.2rem;margin:14px 0 3px;line-height:1.2;transition:color .2s;}
.pcard:hover .pcard__name{color:var(--sage-deep);}
.pcard__line{font-family:var(--body);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);}
.pcard__cue{display:flex;align-items:center;gap:8px;margin-top:12px;font-size:10.5px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);transition:color .2s,gap .25s;}
.pcard:hover .pcard__cue{color:var(--sage-deep);gap:11px;}
.pcard__cue svg{flex-shrink:0;}

/* ---- ficha de producto (sub-catálogo) ---- */
.pdetail__back{margin-bottom:26px;}
.pdetail__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,72px);align-items:start;}
.pdetail__media{position:relative;aspect-ratio:1;background:var(--bg-tile);box-shadow:inset 0 0 0 1px var(--line-soft);overflow:hidden;}
.pdetail__media::before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(135deg,rgba(28,20,16,.04) 0 1px,transparent 1px 14px);}
.pdetail__media .pcard__glyph{opacity:.5;transition:color .3s;}
.pdetail__media .pcard__glyph svg{width:34%;height:34%;}
.pdetail__tag{position:absolute;left:16px;bottom:13px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:10px;letter-spacing:.06em;color:var(--ink-faint);}
.pdetail__cfg .eyebrow{display:block;margin-bottom:12px;}
.pdetail__name{font-family:var(--display);font-weight:500;font-size:clamp(1.9rem,3.4vw,2.6rem);line-height:1.04;margin:0 0 14px;}
.pdetail__desc{color:var(--ink-soft);font-size:15.5px;line-height:1.7;margin:0 0 28px;max-width:42ch;}
.pdetail__cfg hr.rule{margin:0 0 26px;}
.opt-group{margin-bottom:26px;}
.opt-group__head{display:flex;align-items:baseline;justify-content:space-between;gap:14px;margin-bottom:13px;}
.opt-group__label{font-size:11px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);white-space:nowrap;}
.opt-group__val{font-family:var(--display);font-style:italic;font-size:1.05rem;color:var(--ink);white-space:nowrap;}
.opt-row{display:flex;flex-wrap:wrap;gap:10px;}
.chip-opt{appearance:none;padding:9px 17px;border:1px solid var(--line);background:transparent;font:inherit;font-size:13px;color:var(--ink-soft);cursor:pointer;border-radius:2px;transition:.18s;}
.chip-opt:hover{border-color:var(--ink-soft);color:var(--ink);}
.chip-opt.is-active{border-color:var(--ink);background:var(--ink);color:var(--bg);}
.swatch-opt{appearance:none;width:36px;height:36px;border-radius:50%;border:1px solid var(--line);background:transparent;padding:0;cursor:pointer;display:grid;place-items:center;transition:.18s;}
.swatch-opt i{width:24px;height:24px;border-radius:50%;background:var(--sw);box-shadow:inset 0 0 0 1px rgba(28,20,16,.14);}
.swatch-opt:hover{border-color:var(--ink-soft);}
.swatch-opt.is-active{border-color:var(--ink);box-shadow:0 0 0 1px var(--ink);}
.pdetail__buy{display:flex;align-items:stretch;gap:14px;margin-top:32px;}
.pdetail__buy .qty{height:50px;}
.pdetail__buy .qty button{height:48px;width:42px;}
.pdetail__buy .qty input{height:48px;width:48px;font-size:15px;}
.add--wide{flex:1;height:50px;font-size:12.5px;letter-spacing:.12em;}
.pdetail__added{display:flex;align-items:center;gap:9px;color:var(--sage-deep);font-size:14px;margin:16px 0 0;opacity:0;transform:translateY(4px);transition:.25s;}
.pdetail__added[data-show="1"]{opacity:1;transform:none;}
@media(max-width:760px){.pdetail__grid{grid-template-columns:1fr;gap:26px;}.pdetail__media{max-width:320px;}}

.qty{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:2px;background:var(--bg);}
.qty button{appearance:none;border:0;background:transparent;cursor:pointer;width:34px;height:36px;
  font-size:16px;line-height:1;color:var(--ink-soft);transition:.15s;}
.qty button:hover{color:var(--ink);background:var(--bg-tile);}
.qty input{width:40px;height:36px;border:0;background:transparent;text-align:center;font:inherit;
  font-size:14px;font-variant-numeric:tabular-nums;color:var(--ink);-moz-appearance:textfield;}
.qty input::-webkit-inner-spin-button,.qty input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0;}
.add{flex:1;appearance:none;border:1px solid var(--ink);background:transparent;cursor:pointer;font:inherit;
  font-size:11.5px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);
  height:38px;border-radius:2px;transition:.2s;white-space:nowrap;}
.add:hover{background:var(--ink);color:var(--bg);}
.add.added{background:var(--sage-deep);border-color:var(--sage-deep);color:#fff;}

/* Review */
.review{max-width:780px;}
.review__lead{margin:0 0 30px;color:var(--ink-soft);font-size:16px;max-width:54ch;}
.review__item{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:clamp(14px,3vw,32px);
  padding:20px 0;border-bottom:1px solid var(--line-soft);}
.review__item:first-of-type{border-top:1px solid var(--line);}
.review__info h4{font-family:var(--display);font-weight:500;font-size:1.3rem;margin:0 0 2px;}
.review__info span{font-family:var(--body);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);}
.review__rm{appearance:none;border:0;background:transparent;cursor:pointer;color:var(--ink-faint);
  width:34px;height:34px;border-radius:50%;font-size:15px;transition:.2s;}
.review__rm:hover{background:rgba(176,87,63,.1);color:#B0573F;}
.review__empty{padding:60px 0;text-align:center;color:var(--ink-faint);}
.review__empty p{font-family:var(--display);font-style:italic;font-size:1.4rem;color:var(--ink-soft);margin:0 0 20px;}
.review__notes{margin:32px 0;}
.review__actions{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;}
.link-btn{appearance:none;border:0;background:transparent;cursor:pointer;font:inherit;
  font-size:12px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);
  display:inline-flex;align-items:center;gap:9px;padding:6px 0;transition:.2s;}
.link-btn:hover{color:var(--ink);}

/* Confirm */
.confirm{max-width:620px;}
.confirm__check{width:54px;height:54px;border-radius:50%;border:1.5px solid var(--sage);color:var(--sage-deep);
  display:grid;place-items:center;margin-bottom:28px;}
.confirm h2{font-family:var(--display);font-weight:500;font-size:clamp(2rem,4vw,2.8rem);margin:0 0 14px;line-height:1.05;}
.confirm__p{color:var(--ink-soft);font-size:16px;line-height:1.7;margin:0 0 28px;max-width:48ch;}
.confirm__num{background:var(--bg-tile);padding:22px 26px;margin-bottom:30px;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;}
.confirm__num .lbl{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);}
.confirm__num .val{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:1.4rem;letter-spacing:.04em;color:var(--ink);}
.confirm__list{margin:0 0 32px;padding:0;list-style:none;border-top:1px solid var(--line);}
.confirm__list li{display:flex;justify-content:space-between;gap:16px;padding:13px 0;border-bottom:1px solid var(--line-soft);font-size:15px;}
.confirm__list .q{font-variant-numeric:tabular-nums;color:var(--ink-soft);}

@media(max-width:1100px){.pgrid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:680px){.pgrid{grid-template-columns:repeat(2,1fr);}.pcard__foot{flex-wrap:wrap;}}

/* page shell to keep footer pinned */
.page{display:flex;flex-direction:column;min-height:100vh;}
main{flex:1;}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.4,.7,.3,1),transform .7s cubic-bezier(.4,.7,.3,1);}
.reveal.in{opacity:1;transform:none;}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1 !important;transform:none !important;}
  .hero__track{transition:none;}
  .hero__copy{opacity:1 !important;transform:none !important;}
}

/* ============================================================
   PANEL DE ADMINISTRACIÓN
   ============================================================ */
.chip--admin{color:var(--ph-terra-d);}
.chip--admin::before{background:var(--ph-terra);}

/* badges */
.badge{display:inline-flex;align-items:center;font-size:10.5px;font-weight:500;letter-spacing:.1em;
  text-transform:uppercase;padding:4px 10px;border-radius:2px;white-space:nowrap;line-height:1.4;}
.badge--ok{color:var(--sage-deep);background:var(--sage-tint);}
.badge--warn{color:#9A6233;background:#F4E9DC;}
.badge--mute{color:var(--ink-faint);background:var(--bg-tile);}
.badge--admin{color:var(--ph-terra-d);background:#F4E5DC;}
.badge--plain{color:var(--ink-soft);background:var(--bg-tile);}
.badge--new{color:#fff;background:var(--sage-deep);}

/* toolbar + filters */
.adm-toolbar{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-bottom:26px;}
.adm-filters{display:flex;flex-wrap:wrap;gap:8px;}
.fchip{appearance:none;border:1px solid var(--line);background:transparent;cursor:pointer;font:inherit;
  font-size:12.5px;color:var(--ink-soft);padding:8px 14px;border-radius:999px;transition:.18s;display:inline-flex;align-items:center;gap:7px;}
.fchip:hover{border-color:var(--ink-soft);color:var(--ink);}
.fchip.is-active{border-color:var(--ink);background:var(--ink);color:var(--bg);}
.fchip__n{font-size:11px;opacity:.7;font-variant-numeric:tabular-nums;}
.adm-add{appearance:none;border:0;background:var(--ink);color:var(--bg);cursor:pointer;font:inherit;
  font-size:12.5px;font-weight:500;letter-spacing:.08em;padding:11px 20px;border-radius:2px;transition:background .2s;white-space:nowrap;}
.adm-add:hover{background:var(--sage-deep);}
.adm-search{margin:0 0 18px;}
.adm-search input{width:100%;max-width:380px;padding:10px 14px;border:1px solid var(--line);border-radius:4px;
  font-family:var(--body);font-size:14px;color:var(--ink);background:var(--bg);}
.adm-search input:focus{outline:none;border-color:var(--ink);}
.adm-note{font-size:13.5px;color:var(--ink-soft);margin:0 0 22px;line-height:1.6;}
.adm-marcas{display:grid;gap:26px;margin-top:6px;}
.adm-marcas-group__t{font-family:var(--display);font-weight:500;font-size:1.25rem;margin:0 0 10px;}
.adm-act--disabled{opacity:.28;cursor:default;}
.adm-note--self{margin-top:18px;padding:12px 16px;background:var(--bg-tile);border-radius:3px;}
.adm-opt{color:var(--ink-faint);font-weight:400;text-transform:none;letter-spacing:0;font-size:12px;}

/* table */
.adm-tablewrap{overflow-x:auto;}
.adm-table{width:100%;border-collapse:collapse;font-size:14px;min-width:720px;}
.adm-table th:first-child,.adm-table td:first-child{min-width:240px;}
.adm-table thead th{text-align:left;font-size:10.5px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-faint);padding:0 16px 14px;border-bottom:1px solid var(--line);white-space:nowrap;}
.adm-table tbody td{padding:16px;border-bottom:1px solid var(--line-soft);vertical-align:middle;}
.adm-table tbody tr:hover{background:color-mix(in srgb,var(--bg-tile) 50%,transparent);}
.adm-item{display:flex;align-items:center;gap:14px;}
.adm-item__glyph{width:42px;height:42px;flex-shrink:0;background:var(--bg-tile);display:grid;place-items:center;
  color:color-mix(in srgb,var(--ph-green) 55%,var(--ink-faint));box-shadow:inset 0 0 0 1px var(--line-soft);}
.adm-item__glyph.t-terra{color:color-mix(in srgb,var(--ph-terra) 60%,#000 6%);}
.adm-item__glyph.t-clay{color:color-mix(in srgb,var(--ph-clay) 70%,#000 6%);}
.adm-item__glyph svg{width:24px;height:24px;}
.adm-item__glyph--img{background-size:cover;background-position:center;background-repeat:no-repeat;}
.adm-item__name{font-family:var(--display);font-weight:500;font-size:1.15rem;line-height:1.25;white-space:nowrap;}
.adm-item__sub{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);margin-top:2px;}
.adm-actions{text-align:right;white-space:nowrap;}
.adm-act{appearance:none;border:0;background:transparent;cursor:pointer;font:inherit;font-size:12.5px;font-weight:500;
  color:var(--ink-soft);padding:6px 9px;border-radius:3px;transition:.15s;}
.adm-act:hover{background:var(--bg-tile);color:var(--ink);}
.adm-act--danger:hover{background:rgba(176,87,63,.1);color:#B0573F;}
.adm-self{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);padding:6px 9px;}
.adm-empty{text-align:center;color:var(--ink-faint);padding:48px 0 !important;}
@media(max-width:720px){.adm-hide-sm{display:none;}.adm-actions{text-align:left;}}

/* solicitudes */
.adm-sollist{display:flex;flex-direction:column;gap:12px;}
.adm-sol{border:1px solid var(--line);border-radius:3px;overflow:hidden;background:var(--bg);}
.adm-sol__head{width:100%;appearance:none;border:0;background:transparent;cursor:pointer;font:inherit;text-align:left;
  display:flex;align-items:center;justify-content:space-between;gap:18px;padding:18px 22px;transition:background .15s;}
.adm-sol__head:hover{background:var(--bg-tile);}
.adm-sol__meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.adm-sol__num{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:14px;letter-spacing:.03em;color:var(--ink);}
.adm-sol__cli{flex-basis:100%;font-size:13px;color:var(--ink-soft);margin-top:2px;}
.adm-sol__count{font-size:13px;color:var(--ink-soft);white-space:nowrap;display:flex;align-items:center;gap:12px;}
.adm-sol__chev{transition:transform .2s;display:inline-block;}
.adm-sol__head.is-open .adm-sol__chev{transform:rotate(180deg);}
.adm-sol__body{display:none;padding:0 22px 22px;border-top:1px solid var(--line-soft);}
.adm-sol__body.is-open{display:block;}
.adm-sol__clifull{font-size:13px;color:var(--ink-soft);padding:16px 0 4px;}
.adm-sol__list{list-style:none;margin:8px 0 0;padding:0;}
.adm-sol__list li{display:flex;justify-content:space-between;gap:16px;padding:11px 0;border-bottom:1px solid var(--line-soft);font-size:14.5px;}
.adm-sol__var{color:var(--ink-faint);}
.adm-sol__list .q{font-variant-numeric:tabular-nums;color:var(--ink-soft);white-space:nowrap;}
.adm-sol__notes{margin-top:16px;padding:14px 16px;background:var(--bg-tile);border-radius:3px;font-size:14px;color:var(--ink-soft);line-height:1.6;}
.adm-sol__nl{display:block;font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:5px;}
.adm-sol__actions{display:flex;gap:10px;margin-top:20px;flex-wrap:wrap;}

/* modal */
.admin-modal{position:fixed;inset:0;z-index:2147483600;display:flex;align-items:center;justify-content:center;padding:24px;}
.admin-modal__backdrop{position:absolute;inset:0;background:rgba(28,20,16,.42);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);}
.admin-modal__panel{position:relative;background:var(--bg);width:min(620px,100%);max-height:90vh;overflow-y:auto;
  border-radius:5px;box-shadow:0 30px 80px rgba(28,20,16,.3);}
.admin-modal__head{display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:24px clamp(22px,4vw,34px) 18px;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--bg);z-index:1;}
.admin-modal__head h3{font-family:var(--display);font-weight:500;font-size:1.7rem;margin:0;white-space:nowrap;}
.admin-modal__x{appearance:none;border:0;background:transparent;cursor:pointer;color:var(--ink-faint);
  width:34px;height:34px;border-radius:50%;font-size:14px;transition:.2s;flex-shrink:0;}
.admin-modal__x:hover{background:var(--bg-tile);color:var(--ink);}
.admin-modal__form{padding:24px clamp(22px,4vw,34px) clamp(22px,4vw,30px);}
.admin-modal__foot{display:flex;justify-content:flex-end;gap:12px;margin-top:10px;padding-top:22px;border-top:1px solid var(--line);}
.adm-ghost{appearance:none;border:1px solid var(--line);background:transparent;cursor:pointer;font:inherit;
  font-size:13px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);padding:14px 22px;border-radius:2px;transition:.2s;}
.adm-ghost:hover{border-color:var(--ink);color:var(--ink);}

/* swatch checkboxes (form) */
.sw-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:8px;}
.sw-item{display:flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:6px;padding:7px 9px;}
.sw-item:hover{border-color:var(--ink-soft);}
.sw-item__x{border:0;background:transparent;cursor:pointer;color:var(--ink-faint);font-size:11px;line-height:1;padding:3px;flex-shrink:0;border-radius:3px;}
.sw-item__x:hover{color:#B0573F;background:rgba(176,87,63,.08);}
.sw-item .sw-check{flex:1;min-width:0;}
.sw-check{display:flex;align-items:center;gap:9px;cursor:pointer;font-size:13.5px;color:var(--ink-soft);}
.sw-check input{position:absolute;opacity:0;width:0;height:0;}
.sw-dot{width:20px;height:20px;border-radius:50%;background:var(--sw);box-shadow:inset 0 0 0 1px rgba(28,20,16,.16);position:relative;flex-shrink:0;transition:.15s;}
.sw-check input:checked+.sw-dot{box-shadow:inset 0 0 0 1px rgba(28,20,16,.16),0 0 0 2px var(--bg),0 0 0 3px var(--ink);}
.sw-check:hover{color:var(--ink);}
@media(max-width:520px){.sw-grid{grid-template-columns:repeat(2,1fr);}}

/* agregar color personalizado */
.sw-add{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:14px;padding-top:14px;border-top:1px dashed var(--line);}
.sw-add input[type="color"]{width:40px;height:36px;padding:2px;border:1px solid var(--line);border-radius:4px;background:var(--bg);cursor:pointer;flex-shrink:0;}
.sw-add input[type="text"]{padding:8px 10px;border:1px solid var(--line);border-radius:4px;font-family:var(--body);font-size:13px;color:var(--ink);background:var(--bg);}
.sw-add input[type="text"]:focus{outline:none;border-color:var(--ink);}
.sw-add__hex{width:88px;}
.sw-add__name{flex:1;min-width:130px;}

/* admin permission warning */
.admin-warn{border:1px solid #D9A88E;background:#F8EEE6;border-radius:4px;padding:18px 20px;margin:6px 0 22px;}
.admin-warn__check{display:flex;align-items:center;gap:12px;cursor:pointer;font-weight:600;font-size:15px;color:var(--ink);}
.admin-warn__check input{position:absolute;opacity:0;width:0;height:0;}
.admin-warn__box{width:22px;height:22px;border:1.5px solid var(--ph-terra-d);border-radius:4px;flex-shrink:0;
  display:grid;place-items:center;background:var(--bg);transition:.18s;}
.admin-warn__box::after{content:"";width:11px;height:6px;border-left:2px solid var(--bg);border-bottom:2px solid var(--bg);
  transform:rotate(-45deg) scale(0);transition:transform .18s;margin-top:-2px;}
.admin-warn__check input:checked+.admin-warn__box{background:var(--ph-terra-d);border-color:var(--ph-terra-d);}
.admin-warn__check input:checked+.admin-warn__box::after{transform:rotate(-45deg) scale(1);}
.admin-warn__check input:disabled~.admin-warn__label,.admin-warn__check input:disabled+.admin-warn__box{opacity:.5;cursor:not-allowed;}
.admin-warn__txt{display:flex;gap:11px;margin-top:14px;font-size:13px;line-height:1.6;color:#8A5A3D;}
.admin-warn__txt svg{flex-shrink:0;margin-top:1px;color:var(--ph-terra-d);}
.admin-warn__txt strong{color:var(--ph-terra-d);}

/* ── two-level catalog filter (public page + portal) ─────── */
/* barra de filtros fija al hacer scroll (pega debajo del nav) */
.cat-bar{position:sticky;top:var(--nav-h);z-index:900;background:var(--bg);
  padding-top:14px;padding-bottom:12px;margin-bottom:22px;border-bottom:1px solid var(--line);}
.cat-bar .cat-tabs{margin-bottom:10px;}
.cat-bar .brand-tabs{margin-bottom:0;}
.cat-tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:28px;}
.cat-tab{padding:9px 20px;border:1.5px solid var(--line);background:var(--bg);color:var(--ink-soft);
  font-family:var(--body);font-size:14px;font-weight:500;cursor:pointer;border-radius:4px;
  transition:background .15s,color .15s,border-color .15s;}
.cat-tab:hover{color:var(--ink);border-color:var(--ink);}
.cat-tab[aria-selected="true"]{background:var(--ink);color:var(--bg);border-color:var(--ink);}

.brand-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px;}
.brand-tab{padding:6px 16px;border:1.5px solid var(--line);background:var(--bg);color:var(--ink-soft);
  font-family:var(--body);font-size:13px;font-weight:500;cursor:pointer;border-radius:999px;
  transition:background .15s,color .15s,border-color .15s;}
.brand-tab:hover{color:var(--ink);border-color:var(--ink);}
.brand-tab[aria-selected="true"]{background:var(--ink);color:var(--bg);border-color:var(--ink);}

/* catalog section wrapper on public page */
.pub-catalog{padding:60px 0 80px;}
.pub-catalog__inner{max-width:1200px;margin:0 auto;padding:0 32px;}
.pub-catalog__heading{font-family:var(--display);font-size:clamp(22px,3vw,30px);font-weight:600;
  color:var(--ink);margin-bottom:36px;}

/* product card grid shared between public + portal — cards use the .pcard tile
   design defined above (.pcard / .pcard__media / __glyph / __name / __line / __cue) */
.pgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:24px 20px;}
.pcard--static{cursor:default;}

/* empty state */
.cat-empty{padding:48px 0;text-align:center;color:var(--ink-soft);font-size:15px;grid-column:1/-1;}

/* catalog search (public page) */
.cat-search{position:relative;max-width:420px;margin:0 0 26px;}
.cat-search input{width:100%;padding:11px 38px 11px 14px;border:1.5px solid var(--line);border-radius:6px;
  font-family:var(--body);font-size:14px;color:var(--ink);background:var(--bg);}
.cat-search input:focus{outline:none;border-color:var(--ink);}
.cat-search__clear{position:absolute;right:6px;top:50%;transform:translateY(-50%);border:0;background:transparent;
  color:var(--ink-soft);cursor:pointer;font-size:14px;padding:6px 9px;line-height:1;}
.cat-search__clear:hover{color:var(--ink);}
.cat-results__head{font-size:14px;color:var(--ink-soft);margin-bottom:20px;}

/* public product detail — variant display + note */
.pdetail__group{margin:16px 0;}
.pdetail__group h4{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);margin:0 0 9px;font-weight:600;}
.pd-chips{display:flex;flex-wrap:wrap;gap:8px;}
.pd-chip{padding:6px 13px;border:1px solid var(--line);border-radius:4px;font-size:13px;color:var(--ink-soft);}
.pd-sw{display:inline-flex;align-items:center;gap:7px;padding:5px 12px 5px 6px;border:1px solid var(--line);border-radius:999px;font-size:13px;color:var(--ink-soft);}
.pd-sw i{width:15px;height:15px;border-radius:50%;background:var(--sw);box-shadow:inset 0 0 0 1px rgba(28,20,16,.18);flex-shrink:0;}
.pdetail__note{font-size:13px;color:var(--ink-faint);margin-top:18px;line-height:1.6;}
.pdetail__note a{color:var(--sage-deep);text-decoration:underline;}

/* photo media (when a product has an uploaded image) */
.pcard__media--img::before,.pdetail__media--img::before{display:none;}
.pcard__photo,.pdetail__photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;}

/* ── admin image uploader (drop zone) ───────────────────── */
.img-drop{position:relative;border:1.5px dashed var(--line);border-radius:6px;background:var(--bg-tile,var(--bg));
  min-height:150px;display:grid;place-items:center;cursor:pointer;overflow:hidden;text-align:center;
  transition:border-color .15s,background .15s;outline:none;}
.img-drop:hover,.img-drop:focus-visible{border-color:var(--ink);}
.img-drop.is-drag{border-color:var(--ink);border-style:solid;background:var(--bg-tile-2,var(--bg-tile,var(--bg)));}
.img-drop__preview{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;display:none;}
.img-drop.has-img .img-drop__preview{display:block;}
.img-drop__cta{position:relative;display:flex;flex-direction:column;align-items:center;gap:8px;
  padding:24px;color:var(--ink-soft);pointer-events:none;}
.img-drop__cta svg{color:var(--ink-soft);}
.img-drop__cta span{font-size:14px;color:var(--ink);}
.img-drop__cta strong{font-weight:600;}
.img-drop__cta small{font-size:12px;color:var(--ink-faint);}
.img-drop.has-img .img-drop__cta{display:none;}
.img-drop__remove{position:absolute;top:10px;right:10px;z-index:2;display:none;border:none;cursor:pointer;
  background:rgba(20,16,12,.72);color:#fff;font-size:12px;padding:6px 11px;border-radius:999px;
  font-family:var(--body);transition:background .15s;}
.img-drop__remove:hover{background:rgba(20,16,12,.9);}
.img-drop.has-img .img-drop__remove{display:inline-block;}
.img-drop.is-uploading::after{content:"Subiendo…";position:absolute;inset:0;z-index:3;display:grid;place-items:center;
  background:rgba(245,242,235,.78);color:var(--ink);font-size:13px;font-family:var(--body);}
