/* ===========================================================
   TO.M.E — Distribuidora de café · Sistema visual
   Paleta de marca:  café #423330 · oro #eecd89 · crema #f7e9cc
   Tipografía: Hepta Slab (display) · Hanken Grotesk (texto) · Gwendolyn (script)
   Variables --font-display / --font-body / --display-weight (tweakables)
   =========================================================== */

:root{
  --cafe:#423330;
  --cafe-2:#5a4742;
  --oro:#eecd89;
  --oro-deep:#d9b265;
  --crema:#f7e9cc;
  --crema-soft:#fbf4e4;
  --paper:#ffffff;
  --paper-2:#fcfaf6;
  --ink:#423330;
  --ink-soft:#6b5b54;
  --line:rgba(66,51,48,.14);
  --line-soft:rgba(66,51,48,.08);

  /* tweakable accents (overwritten by Tweaks) */
  --accent:var(--oro);
  --accent-ink:var(--cafe);

  --shadow-sm:0 1px 2px rgba(66,51,48,.06), 0 4px 14px rgba(66,51,48,.05);
  --shadow-md:0 10px 30px rgba(66,51,48,.12), 0 2px 8px rgba(66,51,48,.06);
  --shadow-lg:0 30px 70px rgba(66,51,48,.20);

  --maxw:1240px;
  --r:14px;
  --r-lg:22px;
  --ease:cubic-bezier(.22,.61,.36,1);

  /* tweakable type system */
  --font-display:'Hepta Slab', Georgia, serif;
  --font-body:'Hanken Grotesk', system-ui, sans-serif;
  --display-weight:800;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  font-size:18px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;}

h1,h2,h3,.display{
  font-family:var(--font-display);
  font-weight:var(--display-weight);
  line-height:1.04;
  letter-spacing:.01em;
  margin:0;
}
.script{font-family:'Gwendolyn', cursive; font-weight:700;}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}
.eyebrow{
  font-family:var(--font-body);
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.32em;
  font-size:12.5px;
  color:var(--oro-deep);
  display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:26px;height:1.5px;background:var(--oro-deep);display:inline-block;}
.eyebrow.center::after{content:"";width:26px;height:1.5px;background:var(--oro-deep);display:inline-block;}

.bean{width:1em;height:1.32em;display:inline-block;vertical-align:middle;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--font-body);font-weight:700;
  font-size:15px;letter-spacing:.04em;
  padding:15px 30px;border-radius:999px;
  border:1.5px solid transparent;
  transition:transform .35s var(--ease), background .3s, color .3s, box-shadow .3s;
  text-transform:uppercase;
}
.btn-primary{background:var(--accent);color:var(--accent-ink);box-shadow:var(--shadow-sm);}
.btn-primary:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);}
.btn-ghost{background:transparent;color:var(--cafe);border-color:var(--line);}
.btn-ghost:hover{border-color:var(--cafe);transform:translateY(-3px);}
.btn-light{background:var(--crema);color:var(--cafe);}
.btn-light:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);}
.btn-lg{padding:18px 38px;font-size:16px;}

/* ---------- Nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 28px;
  transition:background .4s var(--ease), box-shadow .4s, padding .4s;
}
.nav.scrolled{
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(14px);
  box-shadow:0 1px 0 var(--line-soft);
  padding:12px 28px;
}
.nav-logo img{height:46px;width:auto;transition:height .4s var(--ease);}
.nav.scrolled .nav-logo img{height:38px;}
.nav-links{display:flex;align-items:center;gap:34px;}
.nav-links a{
  font-size:14.5px;font-weight:600;letter-spacing:.04em;
  color:var(--cafe);position:relative;padding:4px 0;opacity:.82;
  transition:opacity .25s;
}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;
  background:var(--oro-deep);transition:width .3s var(--ease);
}
.nav-links a:hover{opacity:1;}
.nav-links a:hover::after, .nav-links a.active::after{width:100%;}
.nav-cta{margin-left:8px;}
.nav-burger{display:none;background:none;border:none;padding:8px;color:var(--cafe);}
.nav-burger svg{width:28px;height:28px;}

/* mobile menu */
.mobile-menu{
  position:fixed;inset:0;z-index:300;background:var(--cafe);
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:6px;
  opacity:0;pointer-events:none;transform:scale(1.04);
  transition:opacity .4s var(--ease), transform .4s var(--ease);
}
.mobile-menu.open{opacity:1;pointer-events:auto;transform:scale(1);}
.mobile-menu a{font-family:var(--font-display);color:var(--crema);font-size:30px;padding:10px;letter-spacing:.02em;}
.mobile-menu a:hover{color:var(--oro);}
.mobile-close{position:absolute;top:24px;right:24px;background:none;border:none;color:var(--crema);}
.mobile-close svg{width:32px;height:32px;}

/* ---------- Hero ---------- */
.hero{position:relative;padding:150px 0 90px;overflow:hidden;}
.hero-bg-beans{position:absolute;inset:0;pointer-events:none;}
.hero-bg-beans .bean-float{position:absolute;color:var(--oro);opacity:.28;}

/* hero: SELLO (centered emblem) */
.hero-sello{text-align:center;}
.hero-sello .hero-badge{width:min(230px,46vw);margin:0 auto 26px;animation:floaty 7s ease-in-out infinite;}
.hero-sello h1{font-size:clamp(44px,8.2vw,108px);color:var(--cafe);margin:8px auto 0;max-width:14ch;}
.hero-sello .hero-script{font-family:var(--font-display);font-size:clamp(44px,8.2vw,108px);color:var(--oro-deep);line-height:1;display:block;}
.hero-sub{font-size:clamp(17px,2vw,21px);color:var(--ink-soft);max-width:48ch;margin:24px auto 0;}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:36px;}
.hero-meta{display:flex;gap:34px;justify-content:center;flex-wrap:wrap;margin-top:56px;}
.hero-meta .m{text-align:center;}
.hero-meta .m b{font-family:var(--font-display);font-size:34px;color:var(--cafe);display:block;line-height:1;}
.hero-meta .m span{font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);}
.hero-meta .div{width:1px;background:var(--line);align-self:stretch;}

/* hero: EDITORIAL (split) */
.hero-editorial .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center;}
.hero-editorial h1{font-size:clamp(40px,5.6vw,82px);color:var(--cafe);}
.hero-editorial .hero-script{font-family:var(--font-display);font-size:inherit;color:var(--oro-deep);display:inline;}
.hero-editorial .hero-art{position:relative;aspect-ratio:4/5;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lg);}
.hero-editorial .hero-badge-sm{position:absolute;right:-26px;bottom:-26px;width:150px;filter:drop-shadow(0 12px 22px rgba(66,51,48,.28));}

/* hero: PANORAMICO (full image) */
.hero-pano{padding:0;min-height:92vh;display:flex;align-items:flex-end;position:relative;color:var(--crema);}
.hero-pano .ph-img{position:absolute;inset:0;}
.hero-pano .scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(40,30,28,.25) 0%,rgba(40,30,28,.55) 55%,rgba(40,30,28,.86) 100%);}
.hero-pano .wrap{position:relative;padding-bottom:78px;}
.hero-pano h1{font-size:clamp(46px,8vw,118px);color:var(--crema);}
.hero-pano .hero-script{font-family:var(--font-display);font-size:inherit;color:var(--oro);display:inline;}
.hero-pano .hero-sub{color:rgba(247,233,204,.86);margin-left:0;}
.hero-pano .hero-cta{justify-content:flex-start;}

@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* ---------- Section scaffold ---------- */
section{position:relative;}
.section{padding:96px 0;}
.section-head{max-width:760px;margin-bottom:54px;}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center;}
.section-head h2{font-size:clamp(30px,4.4vw,54px);color:var(--cafe);margin:16px 0 0;}
.section-head p{font-size:18px;color:var(--ink-soft);margin:18px 0 0;}
.bg-crema{background:var(--crema-soft);}
.bg-cafe{background:var(--cafe);color:var(--crema);}
.bg-cafe .section-head h2{color:var(--crema);}
.bg-cafe .section-head p{color:rgba(247,233,204,.78);}
.bg-cafe .eyebrow{color:var(--oro);}
.bg-cafe .eyebrow::before,.bg-cafe .eyebrow.center::after{background:var(--oro);}

/* ---------- Marcas ---------- */
.marcas-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.marca-card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:38px 32px;transition:transform .4s var(--ease), box-shadow .4s, border-color .4s;
  position:relative;overflow:hidden;
}
.marca-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-md);border-color:transparent;}
.marca-logo{height:78px;display:flex;align-items:center;margin-bottom:22px;}
.marca-card h3{font-family:var(--font-body);font-weight:700;font-size:23px;color:var(--cafe);margin:0 0 8px;}
.marca-card p{font-size:15.5px;color:var(--ink-soft);margin:0 0 18px;line-height:1.6;}
.marca-tag{display:inline-block;font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--oro-deep);font-weight:700;border-top:1px solid var(--line);padding-top:14px;}

/* ---------- Historia ---------- */
.historia{display:grid;grid-template-columns:.92fr 1.08fr;gap:64px;align-items:center;}
.historia-art{position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:5/6;box-shadow:var(--shadow-lg);}
.historia-badge{position:absolute;left:-30px;top:30px;width:128px;filter:drop-shadow(0 14px 24px rgba(0,0,0,.3));}
.historia h2{font-size:clamp(30px,4.2vw,52px);color:var(--crema);margin-bottom:8px;}
.historia .lead{font-size:20px;color:var(--crema);opacity:.95;}
.historia p{color:rgba(247,233,204,.8);}
.valores{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:36px;}
.valor{border-top:2px solid var(--oro);padding-top:16px;}
.valor h4{font-family:var(--font-display);font-weight:700;font-size:17px;color:var(--oro);margin:0 0 6px;letter-spacing:.04em;}
.valor p{font-size:14.5px;color:rgba(247,233,204,.78);margin:0;line-height:1.55;}

/* ---------- Timeline ---------- */
.timeline{display:flex;gap:0;margin-top:42px;flex-wrap:wrap;}
.tl-item{flex:1;min-width:150px;padding:0 22px;border-left:1px solid rgba(247,233,204,.22);}
.tl-item:first-child{padding-left:0;border-left:none;}
.tl-item b{font-family:var(--font-display);font-size:30px;color:var(--oro);display:block;}
.tl-item span{font-size:14px;color:rgba(247,233,204,.8);}

/* ---------- Catálogo ---------- */
.cat-filter{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:44px;}
.cat-chip{
  font-family:var(--font-body);font-weight:600;font-size:14px;letter-spacing:.02em;
  padding:10px 22px;border-radius:999px;border:1.5px solid var(--line);
  background:transparent;color:var(--cafe);transition:all .3s var(--ease);
}
.cat-chip:hover{border-color:var(--cafe);}
.cat-chip.active{background:var(--cafe);color:var(--crema);border-color:var(--cafe);}
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
.prod-card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r);
  overflow:hidden;transition:transform .45s var(--ease), box-shadow .45s, opacity .4s;
  display:flex;flex-direction:column;
}
.prod-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-md);}
.prod-media{aspect-ratio:4/5;position:relative;overflow:hidden;background:var(--crema-soft);}
.prod-media .ribbon{position:absolute;top:14px;left:14px;background:var(--accent);color:var(--accent-ink);
  font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:5px 12px;border-radius:999px;z-index:2;}
.prod-body{padding:20px 20px 24px;flex:1;display:flex;flex-direction:column;}
.prod-brand{font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--oro-deep);font-weight:700;margin-bottom:6px;}
.prod-card h3{font-family:var(--font-body);font-weight:700;font-size:19px;color:var(--cafe);margin:0 0 6px;}
.prod-card .desc{font-size:14px;color:var(--ink-soft);margin:0 0 16px;flex:1;}
.prod-meta{display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--line-soft);padding-top:14px;}
.prod-meta .fmt{font-size:13px;color:var(--ink-soft);}
.prod-meta .roast{display:flex;gap:4px;align-items:center;}
.roast .dot{width:9px;height:9px;border-radius:50%;background:var(--line);}
.roast .dot.on{background:var(--cafe);}
.prod-card.hide{display:none;}

/* ---------- Local ---------- */
.local{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center;}
.local-map{position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:1/1;box-shadow:var(--shadow-md);border:1px solid var(--line);}
.local-info .info-row{display:flex;gap:16px;padding:22px 0;border-bottom:1px solid var(--line);}
.local-info .info-row:last-child{border-bottom:none;}
.info-ico{width:42px;height:42px;border-radius:50%;background:var(--crema);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--cafe);}
.info-ico svg{width:20px;height:20px;}
.info-row h4{font-family:var(--font-body);font-weight:700;font-size:16px;color:var(--cafe);margin:0 0 3px;}
.info-row p{font-size:15px;color:var(--ink-soft);margin:0;}
.cobertura{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px;}
.cob-chip{font-size:13px;padding:6px 14px;border-radius:999px;background:var(--crema);color:var(--cafe);font-weight:600;}

/* ---------- Contacto ---------- */
.contacto{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start;}
.form-field{margin-bottom:20px;}
.form-field label{display:block;font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--cafe);margin-bottom:8px;}
.form-field input,.form-field textarea,.form-field select{
  width:100%;font-family:var(--font-body);font-size:16px;color:var(--cafe);
  padding:14px 16px;border:1.5px solid var(--line);border-radius:10px;background:var(--paper);
  transition:border-color .25s;
}
.form-field input:focus,.form-field textarea:focus,.form-field select:focus{outline:none;border-color:var(--oro-deep);}
.form-field.err input,.form-field.err textarea{border-color:#c0563f;}
.form-field .msg{font-size:12.5px;color:#c0563f;margin-top:6px;display:none;}
.form-field.err .msg{display:block;}
.form-ok{background:var(--cafe);color:var(--crema);padding:18px 22px;border-radius:12px;display:none;align-items:center;gap:12px;}
.form-ok.show{display:flex;}
.contact-aside{background:var(--cafe);color:var(--crema);border-radius:var(--r-lg);padding:40px;}
.contact-aside h3{font-family:var(--font-display);font-weight:700;font-size:26px;color:var(--crema);margin:0 0 8px;}
.contact-aside p{color:rgba(247,233,204,.82);font-size:15.5px;}
.contact-aside .ca-row{display:flex;gap:14px;align-items:center;padding:16px 0;border-bottom:1px solid rgba(247,233,204,.16);}
.contact-aside .ca-row:last-child{border-bottom:none;}
.contact-aside .ca-row svg{width:20px;height:20px;color:var(--oro);flex-shrink:0;}
.contact-aside a:hover{color:var(--oro);}
.wa-btn{display:inline-flex;gap:10px;align-items:center;background:var(--oro);color:var(--cafe);
  font-weight:700;padding:14px 26px;border-radius:999px;margin-top:24px;transition:transform .3s var(--ease);}
.wa-btn:hover{transform:translateY(-3px);}

/* ---------- Footer ---------- */
.footer{background:var(--cafe);color:var(--crema);padding:70px 0 32px;}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-bottom:48px;border-bottom:1px solid rgba(247,233,204,.16);}
.footer img.fm{height:60px;width:auto;margin-bottom:18px;}
.footer p{color:rgba(247,233,204,.72);font-size:15px;}
.footer h5{font-family:var(--font-body);font-weight:700;text-transform:uppercase;letter-spacing:.14em;font-size:12.5px;color:var(--oro);margin:0 0 18px;}
.footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:11px;}
.footer ul a{color:rgba(247,233,204,.8);font-size:15px;transition:color .25s;}
.footer ul a:hover{color:var(--oro);}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;padding-top:26px;}
.footer-bottom span{font-size:13px;color:rgba(247,233,204,.55);}
.socials{display:flex;gap:12px;}
.socials a{width:38px;height:38px;border-radius:50%;border:1px solid rgba(247,233,204,.24);display:flex;align-items:center;justify-content:center;transition:all .3s;}
.socials a:hover{background:var(--oro);color:var(--cafe);border-color:var(--oro);}
.socials svg{width:18px;height:18px;}

/* ---------- Placeholder media ---------- */
.ph{position:absolute;inset:0;background:
  repeating-linear-gradient(135deg,var(--crema) 0 14px,var(--crema-soft) 14px 28px);
  display:flex;align-items:center;justify-content:center;}
.ph span{font-family:'Courier New',monospace;font-size:11px;letter-spacing:.08em;color:var(--cafe);
  opacity:.62;background:rgba(255,255,255,.7);padding:5px 12px;border-radius:6px;text-align:center;}
.ph.dark{background:repeating-linear-gradient(135deg,#4d3c38 0 14px,#43332f 14px 28px);}
.ph.dark span{color:var(--crema);background:rgba(40,30,28,.5);}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease), transform .8s var(--ease);}
.reveal.in{opacity:1;transform:none;}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

/* ---------- Responsive ---------- */
@media(max-width:1080px){
  .cat-grid{grid-template-columns:repeat(2,1fr);}
  .footer-top{grid-template-columns:1fr 1fr;}
}
@media(max-width:900px){
  .nav-links{display:none;}
  .nav-burger{display:block;}
  .hero-editorial .wrap{grid-template-columns:1fr;gap:40px;}
  .hero-editorial .hero-art{max-width:460px;}
  .marcas-grid{grid-template-columns:1fr;}
  .historia,.local,.contacto{grid-template-columns:1fr;gap:40px;}
  .historia-art{order:-1;max-width:440px;}
  .valores{grid-template-columns:1fr;}
}
@media(max-width:560px){
  body{font-size:17px;}
  .section{padding:72px 0;}
  .wrap{padding:0 20px;}
  .cat-grid{grid-template-columns:1fr;}
  .footer-top{grid-template-columns:1fr;}
  .hero-meta{gap:22px;}
  .hero-meta .div{display:none;}
}
