:root{--brown:#683015;--brown-d:#4a2110;--gold:#ffc54c;--gold-d:#e8a92f;--cream:#f6f7d4;--cream-2:#fcfcee;--wa:#25d366;--wa-d:#128c7e;--ig:#c13584;--green:#177e3e;--terra:#e0562b;--ink:#5a4632}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Montserrat',system-ui,sans-serif;color:var(--brown);line-height:1.65;background:linear-gradient(rgba(246,247,212,.93),rgba(246,247,212,.93)),url('assets/img/fondo.webp');background-size:cover;background-attachment:fixed;background-position:center}
h1,h2,h3,h4{font-family:'STIX Two Text',Georgia,serif;font-weight:600;color:var(--brown);line-height:1.15;margin:0}
a{text-decoration:none}
.script{font-family:'Great Vibes',cursive;font-weight:400;line-height:1.1;color:var(--gold)}
img{max-width:100%}
.container-x{max-width:1180px;margin:0 auto;padding:0 22px}
section{padding:84px 0}
.eyebrow{display:inline-block;font-weight:600;letter-spacing:.12em;text-transform:uppercase;font-size:.72rem;color:var(--terra);background:rgba(224,86,43,.08);padding:6px 14px;border-radius:999px}
.section-head{text-align:center;margin-bottom:48px}
.title{font-size:clamp(1.85rem,3.4vw,2.7rem);margin-top:.5rem}
.section-head p{max-width:640px;margin:14px auto 0;color:var(--ink);font-size:1.02rem}
.gold-bar{width:64px;height:4px;background:var(--gold);border-radius:2px;margin:16px auto 0}
.btn-x{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:.95rem;padding:13px 26px;border-radius:999px;border:2px solid transparent;transition:transform .25s,box-shadow .25s,background .25s,color .25s;cursor:pointer}
.btn-x:hover{transform:translateY(-2px)}
.btn-brown{background:var(--brown);color:var(--cream)}
.btn-brown:hover{background:var(--brown-d);color:#fff;box-shadow:0 10px 24px rgba(104,48,21,.28)}
.btn-gold{background:var(--gold);color:var(--brown)}
.btn-gold:hover{background:var(--gold-d)}
.btn-wa{background:var(--wa);color:#063}
.btn-wa:hover{background:var(--wa-d);color:#fff}
.btn-ghost{background:transparent;color:var(--cream);border-color:rgba(246,247,212,.6)}
.btn-ghost:hover{background:rgba(246,247,212,.14);color:#fff}
.nav-top{background:var(--brown-d);color:var(--cream);font-size:.83rem;text-align:center;padding:8px 14px}
.nav-top a{color:var(--gold);font-weight:600}
.navbar-x{position:sticky;top:0;z-index:1000;background:var(--brown-d);background-image:linear-gradient(rgba(58,26,12,.62),rgba(58,26,12,.62)),url('assets/img/fondo-navbar-footer.webp');background-size:cover;background-position:center;border-bottom:3px solid var(--gold);box-shadow:0 6px 18px rgba(0,0,0,.3);transition:box-shadow .3s}
.navbar-x.scrolled{box-shadow:0 8px 24px rgba(0,0,0,.4)}
.navbar-x .container-x{display:flex;align-items:center;justify-content:space-between;padding-top:14px;padding-bottom:14px}
.brand{display:flex;align-items:center;gap:11px;color:var(--cream);font-family:'STIX Two Text',serif;font-weight:600;font-size:1.18rem}
.brand img{height:42px;width:auto}
.nav-links{display:flex;align-items:center;gap:16px;list-style:none;margin:0;padding:0}
.nav-links a{color:var(--cream);font-weight:500;font-size:.92rem;transition:color .25s,background .25s}
.nav-links a:not(.btn-x){padding:8px 15px;border-radius:999px;background:rgba(246,247,212,.12);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}
.nav-links a:not(.btn-x):hover,.nav-links a.active{background:rgba(255,197,76,.92);color:var(--brown)}
.nav-toggle,.nav-close{display:none;background:none;border:0;color:var(--cream);font-size:1.7rem;cursor:pointer}
.hero{position:relative;min-height:92vh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.hero-sm{min-height:54vh}
.hero-bg{position:absolute;inset:0;background:url('assets/img/fondo-navbar-footer.webp') center/cover;animation:zoom 20s ease-in-out infinite alternate}
@keyframes zoom{from{transform:scale(1)}to{transform:scale(1.12)}}
.hero::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(74,33,16,.5),rgba(74,33,16,.82))}
.hero-inner{position:relative;z-index:2;color:var(--cream);padding:40px 22px;max-width:840px}
.hero-inner>.hlogo{max-width:200px;margin-bottom:20px;filter:drop-shadow(0 6px 18px rgba(0,0,0,.4))}
.hero h1{color:#fff;font-size:clamp(2.2rem,5vw,3.4rem);text-shadow:0 4px 24px rgba(0,0,0,.35)}
.hero .sub{font-size:clamp(1rem,2vw,1.2rem);color:#f6f7d4;max-width:620px;margin:18px auto 0}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:30px}
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:22px}
.svc{background:#fff;border:1px solid rgba(104,48,21,.1);border-radius:18px;padding:32px 26px;text-align:center;transition:transform .3s,box-shadow .3s}
.svc:hover{transform:translateY(-8px);box-shadow:0 18px 36px rgba(104,48,21,.16)}
.svc .ic{width:66px;height:66px;border-radius:16px;background:rgba(23,126,62,.1);display:flex;align-items:center;justify-content:center;margin:0 auto 18px;font-size:1.9rem;color:var(--green)}
.svc h3{font-size:1.2rem;margin-bottom:8px}
.svc p{font-size:.92rem;color:var(--ink);margin:0}
.feat{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:22px}
.feat-card{background:#fff;border:1px solid rgba(104,48,21,.1);border-radius:18px;padding:28px 28px}
.feat-card h3{font-size:1.2rem;margin-bottom:14px;display:flex;align-items:center;gap:10px;color:var(--brown)}
.feat-card h3 i{color:var(--terra)}
.feat-list{list-style:none;margin:0;padding:0}
.feat-list li{display:flex;align-items:center;gap:12px;padding:10px 0;font-size:.98rem;color:var(--ink);border-top:1px solid rgba(104,48,21,.08)}
.feat-list li:first-child{border-top:0}
.feat-list i{color:var(--green);font-size:1.2rem;flex:0 0 auto}
.note-band{background:var(--green);color:#eafaef;text-align:center;border-radius:20px;padding:36px 26px;margin-top:30px}
.note-band i{font-size:2rem;margin-bottom:10px;display:inline-block}
.note-band p{max-width:720px;margin:0 auto;font-size:1.05rem;color:#eafaef}
.collab{max-width:430px;margin:0 auto;background:#fff;border:1px solid rgba(104,48,21,.1);border-radius:18px;overflow:hidden}
.collab .vid{position:relative;width:100%;padding-top:56.25%}
.collab .vid iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.collab .bd{padding:22px;text-align:center}
.collab .bd img{max-width:120px;border-radius:50%;margin:0 auto 10px;display:block}
.collab .bd h3{font-size:1.3rem;margin-bottom:6px}
.collab .bd p{color:var(--ink);font-style:italic;margin:0}
.legal{max-width:820px;margin:0 auto;background:#fff;border:1px solid rgba(104,48,21,.1);border-radius:18px;padding:38px 40px}
.legal h2{font-size:1.4rem;margin:26px 0 10px}
.legal h2:first-child{margin-top:0}
.legal p,.legal li{color:var(--ink);font-size:.98rem;line-height:1.7}
.legal ul{padding-left:20px}
.legal .muted{font-size:.85rem;color:#8a7560}
.legal .todo{background:rgba(255,197,76,.2);border-radius:6px;padding:1px 6px;font-weight:600;color:var(--brown)}
.footer{background:var(--brown);background-image:url('assets/img/fondo-navbar-footer.webp');background-size:cover;background-position:center;color:var(--cream);padding:58px 0 30px}
.footer .cols{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:36px;margin-bottom:34px}
.footer .brand{margin-bottom:14px}
.footer h4{color:#fff;font-size:1.05rem;margin-bottom:14px}
.footer a{color:var(--cream);opacity:.85;display:block;padding:4px 0;font-size:.92rem}
.footer a:hover{color:var(--gold);opacity:1}
.footer .soc{display:flex;gap:12px;margin-top:14px}
.footer .soc a{width:42px;height:42px;border-radius:50%;border:1px solid rgba(246,247,212,.35);display:flex;align-items:center;justify-content:center;padding:0}
.footer .soc img{width:20px;height:20px}
.footer .copy{border-top:1px solid rgba(246,247,212,.18);padding-top:20px;text-align:center;font-size:.82rem;color:rgba(246,247,212,.75)}
.rgs-credit{display:inline-flex;align-items:center;gap:12px;margin-top:18px;padding:10px 16px;border-radius:14px;background:rgba(16,26,38,.92);color:#e8e4d8;text-decoration:none;transition:.25s;text-align:left}
.rgs-credit:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(16,26,38,.35);color:#e8e4d8}
.rgs-credit img{width:38px;height:38px;border-radius:8px;display:block}
.rgs-credit span{font-size:12px;line-height:1.4;color:#e8e4d8}
.rgs-credit b{color:#fff;font-weight:700}
.rgs-credit small{color:rgba(232,228,216,.6);font-size:10.5px}
.fab{position:fixed;right:22px;bottom:22px;z-index:1200;display:flex;flex-direction:column;align-items:flex-end;gap:12px}
.fab-menu{display:flex;flex-direction:column;gap:10px;opacity:0;transform:translateY(12px) scale(.96);pointer-events:none;transition:all .25s}
.fab.open .fab-menu{opacity:1;transform:none;pointer-events:auto}
.fab-menu a{display:flex;align-items:center;gap:10px;background:#fff;color:var(--wa-d);font-weight:600;font-size:.86rem;padding:10px 16px;border-radius:999px;box-shadow:0 6px 18px rgba(0,0,0,.18)}
.fab-menu a i{font-size:1.15rem}
.fab-row{display:flex;align-items:center;gap:10px}
.fab-tip{background:var(--brown);color:var(--cream);font-size:.78rem;padding:7px 13px;border-radius:999px;white-space:nowrap;box-shadow:0 4px 12px rgba(0,0,0,.2)}
.fab-main{width:62px;height:62px;border-radius:50%;background:var(--wa);color:#fff;border:0;display:flex;align-items:center;justify-content:center;font-size:2rem;box-shadow:0 8px 22px rgba(37,211,102,.5);cursor:pointer;animation:pulse 2.6s infinite}
@keyframes pulse{0%{box-shadow:0 8px 22px rgba(37,211,102,.5),0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 8px 22px rgba(37,211,102,.5),0 0 0 16px rgba(37,211,102,0)}100%{box-shadow:0 8px 22px rgba(37,211,102,.5),0 0 0 0 rgba(37,211,102,0)}}
.reveal{opacity:0;transform:translateY(34px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
.cookie-banner{position:fixed;left:16px;right:16px;bottom:16px;z-index:1500;max-width:760px;margin:0 auto;background:#fff;border:1px solid rgba(104,48,21,.2);box-shadow:0 16px 40px rgba(74,33,16,.25);border-radius:16px;padding:18px 20px;display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between}
.cookie-banner[hidden]{display:none}
.cookie-banner p{margin:0;flex:1 1 320px;font-size:13.5px;line-height:1.5;color:var(--ink)}
.cookie-banner a{color:var(--terra);font-weight:600;text-decoration:underline}
.cookie-actions{display:flex;gap:10px;flex:0 0 auto}
.cookie-btn{border:0;cursor:pointer;font-weight:600;font-size:14px;padding:10px 22px;border-radius:999px;background:var(--gold);color:var(--brown)}
.cookie-btn.ghost{background:transparent;color:var(--ink);border:1px solid rgba(104,48,21,.3)}
.nav-backdrop{display:none}
@media(max-width:860px){
  section{padding:64px 0}
  .footer .cols{grid-template-columns:1fr 1fr}
  .nav-toggle{display:block}
  .nav-close{display:block;position:absolute;top:18px;right:22px}
  .nav-links{position:fixed;inset:0 0 0 auto;width:80%;max-width:330px;flex-direction:column;align-items:flex-start;gap:8px;background:var(--brown-d);padding:84px 30px;transform:translateX(100%);transition:transform .3s;z-index:1100}
  .nav-links.open{transform:none}
  .nav-links a{font-size:1.05rem;width:100%}
  .nav-backdrop.show{display:block;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:1050}
  .legal{padding:28px 22px}
}
@media(max-width:520px){.footer .cols{grid-template-columns:1fr}}
@media(prefers-reduced-motion:reduce){*{animation:none!important}.reveal{transition:none;opacity:1;transform:none}}
/* catálogo de productos */
.filterbar{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:44px}
.filter-btn{border:1px solid rgba(104,48,21,.25);background:#fff;color:var(--brown);font-weight:600;font-size:.86rem;padding:9px 18px;border-radius:999px;cursor:pointer;transition:all .2s}
.filter-btn:hover{border-color:var(--gold)}
.filter-btn.active{background:var(--brown);color:var(--cream);border-color:var(--brown)}
.cat{margin-bottom:56px;scroll-margin-top:90px}
.cat[hidden]{display:none}
.cat-title{text-align:center;margin:8px 0 4px;font-size:1.5rem}
.cat-sub{text-align:center;color:var(--ink);margin:0 0 28px;font-size:.95rem}
.prod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:22px}
.prod{background:#fff;border:1px solid rgba(104,48,21,.1);border-radius:18px;overflow:hidden;height:100%;display:flex;flex-direction:column;transition:transform .3s,box-shadow .3s}
.prod:hover{transform:translateY(-6px);box-shadow:0 16px 30px rgba(104,48,21,.16)}
.prod .ph{height:180px;background:#fff;display:flex;align-items:center;justify-content:center;padding:18px;border-bottom:1px solid rgba(104,48,21,.07);position:relative}
.prod .ph img{max-height:140px;max-width:100%;width:auto;object-fit:contain}
.prod .bd{padding:18px 18px 22px;text-align:center}
.prod .bd h3{font-size:1.15rem;margin-bottom:6px}
.prod .bd p{font-size:.86rem;color:var(--ink);margin:0}
.badge-new{position:absolute;top:12px;left:12px;background:var(--gold);color:var(--brown);font-size:.7rem;font-weight:600;padding:3px 11px;border-radius:999px;z-index:1}
.prod .note{font-size:.78rem;color:var(--terra);font-weight:600;margin-top:10px}
/* formulario de contacto */
.form-wrap{max-width:680px;margin:0 auto;background:#fff;border:1px solid rgba(104,48,21,.1);border-radius:18px;padding:34px 32px}
.field{margin-bottom:16px}
.field label{display:block;font-weight:600;font-size:.9rem;margin-bottom:6px;color:var(--brown)}
.field input,.field textarea{width:100%;border:1px solid rgba(104,48,21,.25);border-radius:10px;padding:11px 14px;font-family:inherit;font-size:.95rem;color:var(--brown);background:#fffdf5;transition:border .2s,box-shadow .2s}
.field input:focus,.field textarea:focus{outline:0;border-color:var(--gold);box-shadow:0 0 0 3px rgba(255,197,76,.25)}
.form-ok{display:none;background:rgba(23,126,62,.1);border:1px solid rgba(23,126,62,.3);color:var(--green);border-radius:12px;padding:16px;text-align:center;margin-top:16px;font-weight:600}
.form-ok.show{display:block}
.contact-methods{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:8px}
@media(max-width:520px){
  .prod-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .prod .ph{height:130px;padding:12px}
  .prod .ph img{max-height:95px}
  .prod .bd{padding:12px 12px 16px}
  .prod .bd h3{font-size:1rem}
  .prod .bd p{font-size:.78rem}
  .filterbar{gap:7px}
  .filter-btn{font-size:.78rem;padding:7px 13px}
}
