:root{
  --cream:#fff4dc;
  --cream-2:#fffaf0;
  --paper:#fffdf7;
  --brown:#4a271a;
  --brown-2:#7b3f27;
  --terracotta:#a55335;
  --gold:#d9a12b;
  --muted:#765646;
  --line:rgba(74,39,26,.14);
  --shadow:0 24px 70px rgba(74,39,26,.14);
  --radius:28px;
  --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--brown);
  background:linear-gradient(180deg,var(--cream) 0%,#fff8ec 38%,#fff 100%);
  line-height:1.5;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button,input,textarea{font:inherit}
.container{width:min(var(--max),calc(100% - 36px));margin-inline:auto}
.section-anchor{position:relative;top:-90px;display:block}
.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,250,240,.88);
  backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(74,39,26,.10);
}
.nav-wrap{height:98px;display:flex;align-items:center;justify-content:space-between;gap:22px}
.brand{display:flex;align-items:center;gap:12px;min-width:0}
.brand-logo-wrap{width:122px;height:88px;border-radius:20px;background:#fff;display:grid;place-items:center;box-shadow:0 12px 26px rgba(74,39,26,.11);overflow:hidden;flex:0 0 auto}
.brand-logo{width:100%;height:100%;object-fit:contain;padding:4px}
.brand-tagline {
  font-weight: 400 !important;
  font-style: italic !important;
}
.desktop-nav{display:flex;align-items:center;gap:22px;font-size:.88rem;font-weight:850;color:rgba(74,39,26,.82)}
.desktop-nav a{transition:.2s ease}
.desktop-nav a:hover{color:var(--terracotta)}
.nav-cta{padding:11px 16px;border-radius:999px;background:var(--brown);color:#fff;box-shadow:0 14px 28px rgba(74,39,26,.16)}
.nav-cta:hover{background:var(--terracotta);color:#fff}
.menu-toggle{display:none;width:42px;height:42px;border:1px solid var(--line);border-radius:14px;background:#fff;align-items:center;justify-content:center;flex-direction:column;gap:5px;cursor:pointer}
.menu-toggle span{width:20px;height:2px;background:var(--brown);border-radius:10px;transition:.2s ease}
.menu-toggle.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle.active span:nth-child(2){opacity:0}
.menu-toggle.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-nav{display:none;border-top:1px solid var(--line);padding:12px 18px 18px;background:rgba(255,250,240,.96)}
.mobile-nav a{display:block;padding:12px 6px;border-bottom:1px solid rgba(74,39,26,.08);font-weight:850}
.hero{position:relative;min-height:calc(100vh - 98px);overflow:hidden;display:flex;align-items:center;background:var(--brown)}
.hero-slider,.hero-shade{position:absolute;inset:0}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity .7s ease}
.hero-slide.active{opacity:1}
.hero-slide img{width:100%;height:100%;object-fit:cover;filter:saturate(.96) contrast(1.04)}
.hero-shade{background:linear-gradient(90deg,rgba(32,14,9,.82) 0%,rgba(64,29,18,.64) 42%,rgba(64,29,18,.12) 100%),linear-gradient(180deg,rgba(0,0,0,.20),rgba(0,0,0,.30));z-index:1}
.hero-dots{position:absolute;z-index:3;right:26px;bottom:26px;display:flex;gap:8px}
.hero-dots button{width:10px;height:10px;border:0;border-radius:999px;background:rgba(255,255,255,.48);cursor:pointer}
.hero-dots button.active{width:28px;background:#fff}
.hero-inner{position:relative;z-index:2;padding:84px 0}
.hero-card{max-width:720px;padding:34px;border-radius:34px;background:rgba(255,250,240,.90);box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.34)}
.eyebrow{display:inline-flex;align-items:center;gap:8px;color:var(--terracotta);font-weight:950;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase}
.eyebrow::before{content:"";width:28px;height:2px;border-radius:99px;background:var(--gold)}
h1,h2,h3,p{margin-top:0}
h1{font-size:clamp(2.35rem,5vw,4.7rem);line-height:.96;letter-spacing:-.06em;margin:14px 0 18px;color:#3b1d13}
h2{font-size:clamp(1.9rem,3.2vw,3rem);line-height:1.02;letter-spacing:-.045em;margin:10px 0 14px}
h3{letter-spacing:-.025em}
.hero-card p{font-size:1.06rem;color:rgba(74,39,26,.80);max-width:620px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:13px 18px;border-radius:999px;font-weight:950;transition:.2s ease;border:1px solid transparent}
.btn-primary{background:var(--brown);color:#fff;box-shadow:0 16px 36px rgba(74,39,26,.20)}
.btn-primary:hover{background:var(--terracotta)}
.btn-secondary{background:#fff;color:var(--brown);border-color:var(--line)}
.btn-secondary:hover{border-color:rgba(74,39,26,.28);transform:translateY(-1px)}
.trust-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:22px}
.trust-row span{padding:8px 10px;border-radius:999px;background:rgba(217,161,43,.16);font-size:.78rem;font-weight:850;color:#6b3b29}
section{padding:88px 0}
.section-head{max-width:760px;margin:0 auto 34px;text-align:center}
.section-head p,.section-copy p{color:rgba(74,39,26,.70);font-size:1rem}
.specialty-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:38px;align-items:center}
.section-copy{max-width:560px}
.clean-list{list-style:none;padding:0;margin:26px 0 0;display:grid;gap:12px}
.clean-list li{position:relative;padding:14px 16px 14px 42px;border:1px solid var(--line);background:rgba(255,255,255,.62);border-radius:18px;font-weight:800;color:#5d3526}
.clean-list li::before{content:"✓";position:absolute;left:16px;top:14px;color:var(--terracotta);font-weight:950}
.poster-area{overflow:hidden;border-radius:34px;background:linear-gradient(135deg,#fffdf7,#f7dfad);border:1px solid var(--line);box-shadow:var(--shadow);padding:18px;position:relative}
.poster-track{display:flex;gap:16px;transition:transform .35s ease}
.poster-card{min-width:calc(50% - 8px);border-radius:24px;overflow:hidden;background:#fff;position:relative;box-shadow:0 18px 40px rgba(74,39,26,.13)}
.poster-card img{width:100%;aspect-ratio:3/4;object-fit:cover}
.poster-card span{position:absolute;left:12px;right:12px;bottom:12px;padding:10px 12px;border-radius:16px;background:rgba(255,250,240,.92);font-weight:950;text-align:center;box-shadow:0 12px 24px rgba(0,0,0,.10)}
.poster-controls{display:flex;gap:8px;justify-content:flex-end;margin-top:14px}
.poster-controls button{width:40px;height:40px;border-radius:50%;border:1px solid var(--line);background:#fff;color:var(--brown);font-size:1.4rem;font-weight:900;cursor:pointer}
.why{background:rgba(255,255,255,.45)}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.why-card{padding:24px;border-radius:24px;background:#fffdf7;border:1px solid var(--line);box-shadow:0 16px 42px rgba(74,39,26,.08)}
.why-card span{display:inline-grid;place-items:center;width:38px;height:38px;border-radius:14px;background:rgba(217,161,43,.18);color:var(--terracotta);font-weight:950;margin-bottom:18px}
.why-card h3{font-size:1.04rem;margin-bottom:8px}
.why-card p{font-size:.92rem;color:rgba(74,39,26,.68);margin-bottom:0}
.tabs{display:flex;justify-content:center;gap:10px;flex-wrap:wrap;margin-bottom:28px}
.tab{border:1px solid var(--line);background:#fff;border-radius:999px;padding:11px 18px;font-weight:950;color:#6a3f2f;cursor:pointer;transition:.2s ease}
.tab.active,.tab:hover{background:var(--brown);color:#fff;border-color:var(--brown)}
.product-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.product-card{background:#fffdf7;border:1px solid var(--line);border-radius:26px;overflow:hidden;box-shadow:0 16px 42px rgba(74,39,26,.09);display:flex;flex-direction:column;min-height:100%}
.product-photo{position:relative;background:#f7dfad;overflow:hidden}
.product-photo img{width:100%;aspect-ratio:1/1;object-fit:cover;transition:.25s ease}
.product-card:hover .product-photo img{transform:scale(1.035)}
.product-badge{position:absolute;left:12px;top:12px;padding:7px 10px;border-radius:999px;background:rgba(255,250,240,.92);font-size:.78rem;font-weight:950;color:var(--brown)}
.product-body{padding:18px;display:flex;flex-direction:column;flex:1}
.product-body h3{font-size:1.12rem;margin-bottom:4px}
.product-body .roman{font-size:.84rem;color:var(--terracotta);font-weight:950;margin-bottom:10px}
.product-body p{font-size:.9rem;color:rgba(74,39,26,.68);margin-bottom:16px;flex:1}
.add-btn{width:100%;border:0;border-radius:16px;background:rgba(74,39,26,.08);color:var(--brown);font-weight:950;padding:12px;cursor:pointer;transition:.2s ease}
.add-btn:hover,.add-btn.added{background:var(--brown);color:#fff}
.contact-order{background:linear-gradient(180deg,#fffaf0,#fff)}
.contact-layout{display:grid;grid-template-columns:minmax(300px,1fr) minmax(420px,.95fr);gap:26px;align-items:start}
.contact-card{position:sticky;top:104px;border-radius:30px;padding:28px;background:linear-gradient(135deg,var(--brown),var(--brown-2) 68%,var(--terracotta));color:var(--cream-2);box-shadow:var(--shadow)}
.contact-kicker{display:inline-flex;padding:8px 12px;border:1px solid rgba(255,244,220,.22);border-radius:999px;background:rgba(255,244,220,.12);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;font-weight:950;margin-bottom:16px}
.contact-item{padding:18px;border-radius:20px;background:rgba(255,244,220,.10);border:1px solid rgba(255,244,220,.13);margin-top:12px}
.contact-item b{display:block;color:#f8d47e;text-transform:uppercase;font-size:.74rem;letter-spacing:.11em;margin-bottom:8px}
.contact-item p{margin:0 0 8px;color:rgba(255,250,240,.88)}
.contact-item a{font-weight:950;text-decoration:underline;text-underline-offset:3px}
.text-link,.whatsapp-link{display:inline-flex;margin-top:5px;color:#fff}
.form-card{border-radius:30px;padding:24px;background:rgba(255,253,247,.96);border:1px solid var(--line);box-shadow:var(--shadow)}
.form-card h3{font-size:1.25rem;margin-bottom:16px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.form-group{display:flex;flex-direction:column;gap:5px}
.form-group.full{grid-column:1/-1}
label{font-size:.72rem;text-transform:uppercase;letter-spacing:.11em;font-weight:950;color:#6a3f2f}
input,textarea{width:100%;border:1px solid rgba(74,39,26,.18);background:#fff;border-radius:14px;padding:10px 12px;outline:none;color:var(--brown)}
textarea{min-height:76px;resize:vertical}
input:focus,textarea:focus{border-color:var(--terracotta);box-shadow:0 0 0 4px rgba(165,83,53,.10)}
input.error{border-color:#b3261e;background:#fff8f6}
.field-help{margin:-2px 0 6px;font-size:.78rem;color:rgba(74,39,26,.64)}
.product-quantity-grid{display:grid;grid-template-columns:1fr 1fr;gap:7px;max-height:330px;overflow:auto;padding-right:2px}
.product-qty-item{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center;border:1px solid rgba(74,39,26,.12);background:#fff;border-radius:14px;padding:8px}
.product-qty-item.selected{border-color:rgba(165,83,53,.55);background:#fff8ee}
.product-qty-info{display:flex;align-items:flex-start;gap:6px;min-width:0;cursor:pointer}
.product-qty-info input{width:14px;height:14px;margin-top:3px;accent-color:var(--terracotta)}
.product-qty-info b{display:block;font-size:.76rem;line-height:1.15}
.product-qty-info small{display:block;font-size:.68rem;color:rgba(74,39,26,.58);margin-top:2px}
.qty-control{display:flex;align-items:center;gap:3px;background:rgba(74,39,26,.06);border-radius:999px;padding:2px}
.qty-btn{width:22px;height:22px;border:0;border-radius:50%;background:#fff;color:var(--brown);font-weight:950;cursor:pointer}
.qty-input{width:34px;height:22px;min-height:22px;padding:0;border:0;background:transparent;text-align:center;font-weight:950;appearance:textfield}
.qty-input::-webkit-outer-spin-button,.qty-input::-webkit-inner-spin-button{appearance:none;margin:0}
.submit-btn{margin-top:12px;width:100%;border:0;border-radius:16px;background:var(--brown);color:#fff;font-weight:950;padding:13px 16px;cursor:pointer;box-shadow:0 16px 34px rgba(74,39,26,.18)}
.submit-btn:hover{background:var(--terracotta)}
.error-msg{display:none;color:#b3261e;font-size:.78rem;font-weight:800}
.error-msg.show{display:block}
.success-box{display:none;margin-top:12px;padding:14px;border-radius:16px;background:#f2fff5;border:1px solid rgba(38,116,55,.20);color:#246b35;font-weight:800}
.success-box.show{display:block}
.success-box a{text-decoration:underline;text-underline-offset:3px}
.site-footer{background:var(--brown);color:var(--cream-2);padding-top:48px}
.footer-grid{display:grid;grid-template-columns:1.1fr .65fr 1.45fr;gap:32px;align-items:start}
.footer-brand{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.footer-brand img{width:128px;height:94px;object-fit:contain;border-radius:20px;background:#fff;padding:4px}
.footer-logo-only{margin-bottom:16px}
.site-footer p,.site-footer span,.site-footer a{color:rgba(255,250,240,.78);font-size:.9rem}
.site-footer h4{color:#f8d47e;margin:0 0 12px}
.site-footer a,.site-footer span{display:block;margin-bottom:8px}
.map-embed{width:100%;height:240px;border-radius:18px;overflow:hidden;background:rgba(255,250,240,.08);border:1px solid rgba(255,250,240,.14);margin-top:12px}
.map-embed iframe{width:100%;height:100%;border:0;display:block}
.footer-contact-map{min-width:320px}
.footer-bottom{border-top:1px solid rgba(255,244,220,.12);margin-top:34px;padding:16px 0}
.footer-bottom-inner{display:flex;justify-content:center;text-align:center;gap:14px;flex-wrap:wrap}
.reveal{opacity:0;transform:translateY(18px);transition:opacity .55s ease,transform .55s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
@media(max-width:1080px){
  .desktop-nav{display:none}
  .menu-toggle{display:flex}
  .mobile-nav.open{display:block}
  .specialty-grid,.contact-layout{grid-template-columns:1fr}
  .contact-card{position:relative;top:auto}
  .why-grid,.product-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:720px){
  .container{width:min(100% - 28px,var(--max))}
  .nav-wrap{height:86px}
  .brand-logo-wrap{width:104px;height:76px}
  .brand-tagline{font-size:.82rem;white-space:normal;max-width:150px}
  .hero{min-height:680px}
  .hero-card{padding:24px;border-radius:26px}
  .hero-actions .btn{width:100%}
  section{padding:64px 0}
  .why-grid,.product-grid,.footer-grid{grid-template-columns:1fr}
  .poster-card{min-width:100%}
  .form-row,.product-quantity-grid{grid-template-columns:1fr}
  .footer-bottom-inner{display:block}
}
@media(max-width:420px){
  .hero-card{padding:20px}
  .contact-card,.form-card{padding:20px;border-radius:24px}
  .trust-row span{width:100%;text-align:center}
}
