/* ============================================================
   TUTSY PIZZA — Sistema visual  ·  vintage americana / kraft
   ============================================================ */

/* ---------- Fuentes ---------- */
@import url('https://fonts.googleapis.com/css2?family=Anton&family=Alfa+Slab+One&family=Bebas+Neue&family=Bowlby+One+SC&family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,500&display=swap');

/* ---------- Tokens base (tema KRAFT por defecto) ---------- */
:root{
  --red:#EE2A1F;        --red-deep:#C2211A;     --red-ink:#8E1812;
  --blue:#0D4581;       --blue-bright:#1A5BB0;  --blue-ink:#082E58;
  --kraft:#D9A468;      --kraft-2:#CF9551;      --kraft-3:#C2853F;
  --kraft-edge:#A66A2C;
  --paper:#F2E6CE;      --paper-2:#E9D8B7;
  --cream:#F7EEDC;
  --ink:#241A12;        --ink-soft:#5A452F;     --ink-mut:#80694E;
  --ink-fixed:#1B130C;  /* fondo oscuro que NO cambia con el tema */

  /* superficies semánticas (CLARO por defecto) */
  --bg:#FBF7F1;
  --surface:#FFFFFF;
  --surface-2:#F4EFE6;
  --text:#1E1813;
  --text-soft:#6E6356;
  --line:rgba(30,24,19,.12);
  --line-2:rgba(30,24,19,.20);

  /* acentos funcionales */
  --wa:#1FA855;         --wa-deep:#13853f;
  --py:#FF5A47;         /* PedidosYa-ish */

  /* tipografía */
  --f-display:'Anton',sans-serif;
  --f-slab:'Alfa Slab One',serif;
  --f-body:'DM Sans',sans-serif;

  /* motion */
  --rise:34px;
  --dur:.7s;
  --ease:cubic-bezier(.16,.84,.34,1);

  --maxw:1240px;
}

/* ----- Tema CLARO (default, no-op) ----- */
[data-theme="light"]{ }
/* ----- Tema KRAFT (marrón, opcional) ----- */
[data-theme="kraft"]{
  --bg:var(--kraft);
  --surface:var(--paper);
  --surface-2:var(--paper-2);
  --text:var(--ink);
  --text-soft:var(--ink-soft);
  --line:rgba(36,26,18,.16);
  --line-2:rgba(36,26,18,.28);
}
/* ----- Tema CREAM (claro cálido) ----- */
[data-theme="cream"]{
  --bg:#F3EAD7;
  --surface:#FBF5E9;
  --surface-2:#F2E7CF;
}
/* ----- Tema MIDNIGHT (oscuro) ----- */
[data-theme="midnight"]{
  --bg:#171310;
  --surface:#221C16;
  --surface-2:#2B231B;
  --cream:#F7EEDC;
  --text:#F4E8D2;
  --text-soft:#C9B698;
  --line:rgba(247,238,220,.12);
  --line-2:rgba(247,238,220,.22);
  --kraft:#2B231B;
  --kraft-2:#241D16;
  --paper:#221C16;
  --paper-2:#2B231B;
  --ink:#F4E8D2;
}

/* ---------- Fuentes intercambiables (Tweak) ---------- */
[data-font="bebas"]{ --f-display:'Bebas Neue',sans-serif; }
[data-font="bowlby"]{ --f-display:'Bowlby One SC',sans-serif; }

/* ---------- Reset ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:clip;max-width:100%}
body{
  font-family:var(--f-body);
  background:var(--bg);
  color:var(--text);
  line-height:1.5;
  overflow-x:clip;
  max-width:100%;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--red);color:var(--cream)}

/* ---------- Textura kraft (overlay global) ---------- */
.tex-layer{position:fixed;inset:0;pointer-events:none;z-index:1;mix-blend-mode:multiply;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.6'/%3E%3C/svg%3E");
}
.tex-layer.fibers{opacity:.35;mix-blend-mode:multiply;
  background-image:repeating-linear-gradient(0deg,rgba(120,80,40,.05) 0 1px,transparent 1px 3px),
                   repeating-linear-gradient(90deg,rgba(120,80,40,.04) 0 1px,transparent 1px 4px);
}
[data-texture="off"] .tex-layer{display:none}
[data-theme="midnight"] .tex-layer{opacity:.6;mix-blend-mode:overlay}

/* vignette muy sutil */
body::after{content:"";position:fixed;inset:0;pointer-events:none;z-index:2;
  box-shadow:inset 0 0 220px rgba(40,24,10,.20);}
[data-theme="cream"] body::after{box-shadow:inset 0 0 220px rgba(40,24,10,.10)}
[data-theme="midnight"] body::after{box-shadow:inset 0 0 240px rgba(0,0,0,.5)}

/* ---------- Layout helpers ---------- */
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px;position:relative;z-index:3}
.section{position:relative;z-index:3}
@media(max-width:640px){.wrap{padding:0 18px}}

/* ---------- Tipografía utilitaria ---------- */
.display{font-family:var(--f-display);text-transform:uppercase;line-height:.9;letter-spacing:.01em;font-weight:400}
.slab{font-family:var(--f-slab);text-transform:uppercase;line-height:1;letter-spacing:.005em}
.eyebrow{font-family:var(--f-slab);text-transform:uppercase;letter-spacing:.14em;font-size:13px;line-height:1}
.kicker{font-weight:700;text-transform:uppercase;letter-spacing:.18em;font-size:12px}

/* outline / stroke text */
.stroke{color:transparent;-webkit-text-stroke:2px currentColor;}
@media(max-width:640px){.stroke{-webkit-text-stroke:1.4px currentColor}}

/* ---------- Botones (elegantes) ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--f-body);font-weight:700;
  letter-spacing:.005em;font-size:15px;
  padding:14px 26px;border-radius:999px;
  border:1.5px solid transparent;
  background:var(--surface);color:var(--text);
  box-shadow:0 6px 18px rgba(20,14,10,.10);
  transition:transform .18s var(--ease), box-shadow .18s var(--ease), background .18s, color .18s;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(20,14,10,.16)}
.btn:active{transform:translateY(0)}
.btn .ic{width:20px;height:20px;flex:0 0 auto}
.btn-wa{background:var(--wa);color:#fff;box-shadow:0 8px 22px rgba(31,168,85,.32)}
.btn-wa:hover{box-shadow:0 14px 32px rgba(31,168,85,.42)}
.btn-red{background:var(--red);color:#fff;box-shadow:0 8px 22px rgba(232,54,42,.30)}
.btn-red:hover{box-shadow:0 14px 32px rgba(232,54,42,.40)}
.btn-blue{background:var(--blue);color:#fff;box-shadow:0 8px 22px rgba(13,69,129,.30)}
.btn-blue:hover{box-shadow:0 14px 32px rgba(13,69,129,.40)}
.btn-ghost{background:transparent;border-color:var(--line-2);box-shadow:none;color:var(--text)}
.btn-ghost:hover{background:var(--surface);border-color:var(--text);box-shadow:0 8px 18px rgba(20,14,10,.10)}
.btn-sm{font-size:13px;padding:10px 18px}
.btn-lg{font-size:17px;padding:17px 32px}
[data-theme="midnight"] .btn{background:var(--surface);color:var(--text)}
[data-theme="midnight"] .btn-ghost{border-color:var(--line-2);color:var(--text)}

/* ---------- Estrella (clip-path) ---------- */
.star{display:inline-block;background:currentColor;
  clip-path:polygon(50% 0,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%);
  width:1em;height:1em}

/* ---------- Rayo (clip-path) ---------- */
.bolt{display:inline-block;background:currentColor;
  clip-path:polygon(55% 0,15% 58%,45% 58%,30% 100%,85% 42%,52% 42%);
  width:.7em;height:1em}

/* ---------- Sello circular (stamp) ---------- */
.stamp{
  position:relative;width:118px;height:118px;border-radius:50%;
  border:3px solid currentColor;display:grid;place-items:center;text-align:center;
  font-family:var(--f-slab);text-transform:uppercase;line-height:.95;
}
.stamp::before{content:"";position:absolute;inset:7px;border-radius:50%;border:1.5px solid currentColor;opacity:.6}

/* ---------- Banner ribbon ---------- */
.ribbon{
  position:relative;display:inline-block;
  background:var(--blue);color:var(--cream);
  font-family:var(--f-slab);text-transform:uppercase;letter-spacing:.05em;
  padding:10px 26px;
  clip-path:polygon(0 0,100% 0,calc(100% - 14px) 50%,100% 100%,0 100%,14px 50%);
}

/* ---------- Placeholder de imagen ---------- */
.ph{
  position:relative;overflow:hidden;background:var(--surface-2);
  border:2px dashed var(--line-2);border-radius:14px;
  display:grid;place-items:center;color:var(--text-soft);
}
.ph::before{content:"";position:absolute;inset:0;opacity:.5;
  background:repeating-linear-gradient(45deg,transparent 0 14px,rgba(36,26,18,.05) 14px 28px)}
.ph .ph-label{position:relative;font-family:'DM Sans',monospace;font-size:12px;font-weight:600;
  letter-spacing:.06em;text-transform:uppercase;padding:6px 12px;border:1.5px solid var(--line-2);
  border-radius:999px;background:var(--surface);white-space:nowrap}
[data-theme="midnight"] .ph::before{background:repeating-linear-gradient(45deg,transparent 0 14px,rgba(255,255,255,.04) 14px 28px)}

/* ---------- Reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(var(--rise));transition:opacity var(--dur) var(--ease),transform var(--dur) 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}.reveal.d5{transition-delay:.40s}.reveal.d6{transition-delay:.48s}
[data-motion="subtle"] .reveal{transform:translateY(16px);transition-duration:.45s}
[data-motion="subtle"] .reveal[class*="d"]{transition-delay:0s}

/* respeta usuarios con motion reducido */
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}

/* ---------- Marquee ---------- */
.marquee{display:flex;overflow:hidden;white-space:nowrap;user-select:none}
.marquee__track{display:flex;flex:0 0 auto;animation:marq var(--mq,28s) linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
[data-motion="subtle"] .marquee__track{animation-duration:calc(var(--mq,28s) * 1.8)}
@keyframes marq{to{transform:translateX(-50%)}}
.marquee__item{font-family:var(--f-display);text-transform:uppercase;display:inline-flex;align-items:center;gap:26px;padding-right:26px}

/* ---------- Card genérica (elegante) ---------- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:22px;
  box-shadow:0 12px 34px rgba(20,14,10,.07);position:relative}
[data-theme="midnight"] .card{box-shadow:0 12px 34px rgba(0,0,0,.4);border-color:var(--line-2)}

/* float anim */
@keyframes floaty{0%,100%{transform:translateY(0) rotate(var(--rot,0deg))}50%{transform:translateY(-10px) rotate(var(--rot,0deg))}}
.floaty{animation:floaty 5s ease-in-out infinite}
[data-motion="subtle"] .floaty{animation:none}
@keyframes spin-slow{to{transform:rotate(360deg)}}
.spin{animation:spin-slow 26s linear infinite}
[data-motion="subtle"] .spin{animation-duration:60s}

/* utilidades */
.u-red{color:var(--red)}.u-blue{color:var(--blue)}.u-cream{color:var(--cream)}
.center{text-align:center}
.hide-sc{scrollbar-width:none}.hide-sc::-webkit-scrollbar{display:none}

/* botón flotante WhatsApp + pulso */
.wa-fab::before{content:"";position:absolute;inset:0;border-radius:50%;background:var(--wa);z-index:-1;animation:wa-pulse 2.4s ease-out infinite;opacity:.5}
@keyframes wa-pulse{0%{transform:scale(1);opacity:.55}70%{transform:scale(1.9);opacity:0}100%{opacity:0}}
.wa-fab:hover{filter:brightness(1.05)}
[data-motion="subtle"] .wa-fab::before{animation:none}
@media(prefers-reduced-motion:reduce){.wa-fab::before{animation:none}}

/* parallax: imagen con sangrado para que el desplazamiento no muestre bordes */
.parallax-frame{position:relative;overflow:hidden}
.parallax-frame img{position:absolute;left:0;top:-12%;width:100%;height:124%;object-fit:cover;display:block;will-change:transform}

/* blindaje anti-overflow horizontal (mobile) */
.section{overflow-x:clip}
.wrap{max-width:min(var(--maxw),100%)}

/* instagram feed */
.insta-card{transition:transform .2s var(--ease),box-shadow .2s var(--ease)}
.insta-card:hover{transform:translateY(-4px);box-shadow:0 22px 46px rgba(20,14,10,.16)}
.insta-card img{transition:transform .5s var(--ease)}
.insta-card:hover img{transform:scale(1.06)}
.insta-badge{transition:transform .2s var(--ease)}
.insta-card:hover .insta-badge{transform:rotate(-8deg) scale(1.08)}
@media(max-width:760px){
  .insta-grid{grid-template-columns:1fr 1fr !important}
  .insta-head-cta{display:none !important}
  .insta-foot-cta{display:block !important}
}
@media(max-width:430px){
  .insta-grid{grid-template-columns:1fr !important}
}

/* ============================================================
   CARTA ONLINE (página dedicada)
   ============================================================ */
.cm-catnav{position:sticky;top:0;z-index:40;background:color-mix(in srgb,var(--surface) 92%,transparent);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.cm-catnav-inner{display:flex;gap:8px;overflow-x:auto;padding:12px 0;scrollbar-width:none}
.cm-catnav-inner::-webkit-scrollbar{display:none}
.cm-cat{flex:0 0 auto;font-family:var(--f-display);font-size:17px;text-transform:uppercase;letter-spacing:.03em;padding:8px 18px;border-radius:999px;border:1.5px solid var(--line-2);color:var(--text);background:var(--surface);cursor:pointer;transition:all .15s var(--ease);white-space:nowrap}
.cm-cat:hover{border-color:var(--text)}
.cm-cat.active{background:var(--red);color:#fff;border-color:var(--red)}

.cm-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.cm-card{background:var(--surface);border:1px solid var(--line);border-radius:20px;box-shadow:0 12px 34px rgba(20,14,10,.06);padding:22px 24px;display:flex;flex-direction:column;transition:transform .2s var(--ease),box-shadow .2s var(--ease)}
.cm-card:hover{transform:translateY(-3px);box-shadow:0 20px 44px rgba(20,14,10,.12)}
/* tarjeta con foto */
.cm-card-photo{padding:0;overflow:hidden}
.cm-photo{aspect-ratio:16/10;overflow:hidden;background:var(--surface-2)}
.cm-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s var(--ease)}
.cm-card-photo:hover .cm-photo img{transform:scale(1.05)}
.cm-body{padding:20px 22px;display:flex;flex-direction:column;flex:1}
/* thumbnail en items simples */
.cm-thumb{width:74px;height:74px;border-radius:13px;object-fit:cover;flex:0 0 auto;border:1px solid var(--line)}
.cm-sizes{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:16px}
.cm-size{text-align:center;padding:10px 6px;border-radius:12px;background:var(--surface-2);border:1px solid var(--line);font:inherit;color:inherit;cursor:pointer;-webkit-appearance:none;appearance:none;-webkit-tap-highlight-color:transparent;transition:border-color .15s,background .15s,box-shadow .15s,transform .08s}
.cm-size:hover{border-color:var(--red)}
.cm-size:active{transform:scale(.97)}
.cm-size.selected{background:var(--red);border-color:var(--red);box-shadow:0 8px 20px rgba(238,42,30,.28)}
.cm-size.selected .lbl,.cm-size.selected .sub,.cm-size.selected .pr{color:#fff}
.cm-size .lbl{display:block;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-soft)}
.cm-size .sub{display:block;font-size:9.5px;color:var(--text-soft);opacity:.75;margin-top:1px}
.cm-size .pr{display:block;font-family:var(--f-display);font-size:19px;color:var(--text);margin-top:5px}
.cm-size.top .pr{color:var(--red)}

.cm-simple{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cm-item{display:flex;align-items:flex-start;gap:14px;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:18px 20px;box-shadow:0 10px 28px rgba(20,14,10,.05)}
.cm-item .pr{font-family:var(--f-display);font-size:24px;color:var(--blue);white-space:nowrap}

@media(max-width:820px){
  .cm-grid{grid-template-columns:1fr}
  .cm-simple{grid-template-columns:1fr}
}
@media(max-width:460px){
  .cm-sizes{grid-template-columns:repeat(2,1fr)}
}

/* ============================================================
   ESTADOS + RESPONSIVE
   ============================================================ */
/* nav */
.nav-link{position:relative}
.nav-link::after{content:"";position:absolute;left:0;right:100%;bottom:-3px;height:2.5px;background:var(--red);transition:right .25s var(--ease)}
.nav-link:hover::after{right:0}
.nav-points{transition:transform .15s var(--ease)}
.nav-points:hover{transform:translateY(-1px)}

/* hover cards (lift elegante) */
.ch-card,.combo-card,.var-card{transition:transform .2s var(--ease),box-shadow .2s var(--ease)}
.ch-card:hover,.combo-card:hover,.var-card:hover{transform:translateY(-4px);box-shadow:0 22px 46px rgba(20,14,10,.13)}

/* carta */
.pz-price-lbl{display:none}
.pz-price-lbl + *{display:inline}

/* footer */
.foot-h{font-family:var(--f-display);font-size:16px;text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px;opacity:.6}
.foot-link{display:block;font-size:14.5px;font-weight:500;opacity:.78;padding:6px 0;transition:color .15s,opacity .15s,transform .15s}
.foot-link:hover{opacity:1;color:var(--red);transform:translateX(3px)}

/* ---------- Breakpoints ---------- */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr !important;gap:30px !important}
  .hero-art{max-width:560px}
  .combos-grid{grid-template-columns:1fr 1fr !important}
  .steps-grid,.dif-grid{grid-template-columns:1fr 1fr !important}
  .about-grid{grid-template-columns:1fr !important;gap:30px !important}
  .foot-grid{grid-template-columns:1fr 1fr !important}
}
@media(max-width:860px){
  .nav-desk{display:none !important}
  .nav-burger{display:grid !important}
  .nav-points{display:none !important}
}
@media(max-width:820px){
  .carta-cta{min-height:540px}
  .carta-cta-video{object-position:center center !important}
  .carta-cta-grad{background:linear-gradient(180deg, rgba(15,10,7,.92) 0%, rgba(15,10,7,.6) 36%, rgba(15,10,7,.2) 64%, rgba(15,10,7,0) 100%) !important}
}
@media(max-width:760px){
  .ch-grid{grid-template-columns:1fr !important}
  .combos-grid{grid-template-columns:1fr !important}
  .combo-feat{grid-column:span 1 !important}
  .combo-feat .combo-card{grid-template-columns:1fr !important;display:flex !important;flex-direction:column !important}
  .combo-feat .combo-card > div:last-child{border-left:none !important;border-top:3px solid var(--ink) !important;min-height:180px !important}
  .simple-grid{grid-template-columns:1fr !important}
  .loc-grid{grid-template-columns:1fr !important}
  /* tabla pizzas → tarjeta */
  .pz-head{display:none !important}
  .pz-row{grid-template-columns:1fr 1fr !important;gap:9px !important;padding:16px !important}
  .pz-name{grid-column:1 / -1}
  .pz-price{display:flex !important;justify-content:space-between;align-items:center;
    padding:9px 12px;border:2px solid var(--ink);border-radius:10px;background:var(--surface) !important}
  .pz-price-lbl{display:inline !important;font-weight:700;text-transform:uppercase;font-size:11px;letter-spacing:.04em;color:var(--text-soft)}
  .pz-btn{grid-column:1 / -1}
  .pts-banner{flex-direction:column !important;align-items:flex-start !important}
}
@media(max-width:560px){
  .steps-grid,.dif-grid,.foot-grid{grid-template-columns:1fr !important}
  .loc-grid .ph{display:none !important}
}

/* grillas nuevas (home v2) */
@media(max-width:780px){
  .video-grid{grid-template-columns:1fr !important;gap:28px !important;text-align:center}
  .video-copy{display:flex;flex-direction:column;align-items:center}
}
@media(max-width:980px){
  .var-grid{grid-template-columns:1fr 1fr !important}
  .combos-grid{grid-template-columns:1fr 1fr !important}
  .agente-grid{grid-template-columns:1fr !important}
  .combo-hero{grid-template-columns:1fr !important}
}
@media(max-width:640px){
  .var-grid{grid-template-columns:1fr !important}
  .combos-grid{grid-template-columns:1fr !important}
  .combo-feat-body{padding:26px !important}
}
