/* styles.css — Comida Caseira Kosai */

:root {
  --bg: #faf3e3;
  --bg-tint: #f6ebd1;
  --paper: #fffaf0;
  --ink: #2a1a0f;
  --ink-soft: #5a4a3a;
  --muted: #8c7a64;
  --line: #d9c9a8;
  --line-soft: rgba(124,29,29,.12);

  --wine: #7c1d1d;
  --wine-deep: #5a1212;
  --orange: #b94a16;
  --orange-soft: #f1d9c4;
  --olive: #3f6b3a;
  --olive-soft: #d8e3cf;
  --gold: #c2922c;
  --gold-soft: #fbe7c4;

  --serif: "Instrument Serif", "DM Serif Display", Georgia, "Times New Roman", serif;
  --sans: "DM Sans", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;
  --hand: "Caveat", "Reenie Beanie", cursive;
  --mono: ui-monospace, "SF Mono", "Menlo", monospace;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 17px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* Paper grain overlay */
body::before {
  content:"";
  position: fixed; inset:0;
  pointer-events:none;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(124,29,29,.025) 0, transparent 50%),
    radial-gradient(circle at 80% 70%, rgba(185,74,22,.025) 0, transparent 50%);
  z-index: 1;
}

img { max-width:100%; display:block; }

/* ─── Typography utilities ─── */
.cck-h2 {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(34px, 4.6vw, 64px);
  line-height: 1.02;
  letter-spacing: -.015em;
  color: var(--ink);
  margin: 0 0 18px;
  text-wrap: balance;
}
.cck-h2 em {
  font-style: italic;
  color: var(--wine);
}
.cck-h2-sub {
  font-family: var(--sans);
  font-size: clamp(15px, 1.2vw, 18px);
  line-height: 1.55;
  color: var(--ink-soft);
  max-width: 56ch;
  margin: 0;
  text-wrap: pretty;
}
.cck-lede {
  font-family: var(--serif);
  font-size: clamp(20px, 1.7vw, 26px);
  line-height: 1.35;
  color: var(--ink);
  margin: 0 0 18px;
  text-wrap: pretty;
}
.cck-body-p {
  font-size: 16.5px;
  line-height: 1.65;
  color: var(--ink-soft);
  margin: 0 0 14px;
  max-width: 60ch;
  text-wrap: pretty;
}

/* ─── Buttons ─── */
.cck-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 14px 22px;
  font-family: var(--sans);
  font-weight: 600;
  font-size: 15px;
  letter-spacing: .005em;
  border: 1.5px solid transparent;
  border-radius: 999px;
  cursor: pointer;
  text-decoration: none;
  transition: transform .15s ease, background .2s, color .2s, box-shadow .2s;
}
.cck-btn-primary {
  background: var(--wine);
  color: #fff9ec;
  box-shadow: 0 4px 0 var(--wine-deep), 0 6px 16px rgba(124,29,29,.18);
}
.cck-btn-primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 5px 0 var(--wine-deep), 0 10px 20px rgba(124,29,29,.22);
}
.cck-btn-primary:active { transform: translateY(2px); box-shadow: 0 2px 0 var(--wine-deep); }
.cck-btn-ghost {
  background: transparent;
  color: var(--wine);
  border-color: rgba(124,29,29,.35);
}
.cck-btn-ghost:hover { background: rgba(124,29,29,.06); border-color: var(--wine); }
.cck-btn-lg { padding: 18px 30px; font-size: 17px; }

/* ─── Stamps, tickets, marks ─── */
.cck-stamp {
  display: inline-block;
  padding: 8px 14px;
  border: 2.5px solid;
  border-radius: 4px;
  font-family: var(--mono);
  text-transform: uppercase;
  text-align: center;
  letter-spacing: .08em;
  background: rgba(255,250,240,.7);
  position: relative;
}
.cck-stamp::before, .cck-stamp::after {
  content:""; position:absolute; inset:0;
  border-radius: 4px; pointer-events: none;
}
.cck-ticket {
  display: inline-block;
  padding: 4px 12px;
  border-radius: 3px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .15em;
  font-weight: 700;
  text-transform: uppercase;
  background: var(--orange-soft);
  color: var(--orange);
}
.cck-dot {
  display: inline-block;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #c8511c;
  box-shadow: 0 0 0 4px rgba(200,81,28,.18);
  animation: pulse 2s infinite ease-in-out;
}
@keyframes pulse {
  0%,100%{ box-shadow: 0 0 0 4px rgba(200,81,28,.18); }
  50%{ box-shadow: 0 0 0 7px rgba(200,81,28,.08); }
}

/* Section labels */
.cck-seclabel {
  display: flex; align-items: center; gap: 14px;
  font-family: var(--mono);
  font-size: 11.5px;
  text-transform: uppercase;
  letter-spacing: .22em;
  margin-bottom: 28px;
}
.cck-seclabel-num { font-weight: 700; }
.cck-seclabel-line {
  display: block; flex: 0 0 56px; height: 1.5px;
}
.cck-seclabel-text { color: var(--ink-soft); }

.cck-section-head { margin-bottom: 52px; }

/* ─── Nav ─── */
.cck-nav {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 48px;
  background: rgba(250,243,227,.88);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--line-soft);
}
.cck-logo {
  display: flex; align-items: center; gap: 12px;
  text-decoration: none; color: var(--ink);
}
.cck-logo-text { display:flex; flex-direction:column; line-height:1.05; }
.cck-logo-name { font-family: var(--serif); font-size: 22px; font-style: italic; color: var(--wine); }
.cck-logo-place { font-family: var(--mono); font-size: 9px; letter-spacing: .25em; color: var(--ink-soft); margin-top: 2px; }
.cck-nav-links { display:flex; gap: 28px; }
.cck-nav-links a {
  text-decoration: none; color: var(--ink-soft); font-size: 14.5px; font-weight: 500;
  position: relative; padding: 4px 0;
}
.cck-nav-links a:hover { color: var(--wine); }
.cck-nav-links a::after {
  content:""; position:absolute; left:0; right:0; bottom:0; height: 1.5px;
  background: var(--wine); transform: scaleX(0); transform-origin: left;
  transition: transform .25s ease;
}
.cck-nav-links a:hover::after { transform: scaleX(1); }
.cck-nav-cta {
  text-decoration: none;
  background: var(--ink);
  color: #fff9ec;
  padding: 10px 18px;
  border-radius: 999px;
  font-size: 14px;
  font-weight: 600;
  transition: background .2s;
}
.cck-nav-cta:hover { background: var(--wine); }

/* ─── Hero ─── */
.cck-hero {
  position: relative;
  padding: 80px 48px 0;
  z-index: 2;
  overflow: hidden;
}
.cck-hero-grid {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 60px;
  align-items: center;
  max-width: 1320px;
  margin: 0 auto;
  padding-bottom: 80px;
}
.cck-hero-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--mono); font-size: 11.5px; letter-spacing: .15em;
  text-transform: uppercase; color: var(--ink-soft);
  margin-bottom: 28px;
}
.cck-hero-h1 {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(60px, 8.5vw, 138px);
  line-height: .9;
  letter-spacing: -.025em;
  margin: 0 0 28px;
  color: var(--ink);
}
.cck-hero-h1 em {
  font-style: italic;
  color: var(--wine);
}
.cck-hero-h1-line2 {
  display: block;
  font-style: italic;
  color: var(--wine);
}
.cck-hero-sub {
  font-size: 19px;
  line-height: 1.5;
  color: var(--ink-soft);
  max-width: 50ch;
  margin: 0 0 36px;
  text-wrap: pretty;
}
.cck-hero-sub strong { color: var(--ink); font-weight: 600; }
.cck-hero-cta { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 56px; }
.cck-hero-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  padding-top: 24px;
  border-top: 1px solid var(--line-soft);
}
.cck-stat-num {
  font-family: var(--serif);
  font-size: 34px;
  font-style: italic;
  color: var(--wine);
  line-height: 1;
  margin-bottom: 4px;
}
.cck-stat-lbl {
  font-size: 13px;
  color: var(--ink);
  font-weight: 600;
  line-height: 1.3;
}
.cck-stat-lbl span {
  display: block;
  font-weight: 400;
  color: var(--muted);
  font-size: 12px;
}

/* Hero art stack */
.cck-hero-art {
  position: relative;
  height: 540px;
  display: flex; align-items: center; justify-content: center;
}
.cck-hero-stack { position: relative; width: 100%; height: 100%; }
.cck-hero-tilt { position: absolute; filter: drop-shadow(0 18px 30px rgba(40,20,10,.18)); }
.cck-hero-tilt-1 { top: 6%; left: 20%; transform: rotate(-7deg); z-index: 3; }
.cck-hero-tilt-2 { top: 30%; left: -2%; transform: rotate(-3deg); z-index: 2; }
.cck-hero-tilt-3 { top: 45%; right: 0%; transform: rotate(8deg); z-index: 1; }
.cck-hero-stack .cck-stamp {
  position: absolute;
  top: 4%; right: 6%;
  z-index: 5;
  background: rgba(255,250,240,.95);
}
.cck-hero-handwritten {
  position: absolute;
  bottom: 8%; left: 0;
  font-family: var(--hand);
  font-size: 28px;
  color: var(--orange);
  transform: rotate(-3deg);
}

/* Ticker */
.cck-ticker {
  border-top: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
  background: var(--bg-tint);
  overflow: hidden;
  margin-top: 24px;
}
.cck-ticker-track {
  display: flex;
  gap: 0;
  animation: ticker 60s linear infinite;
  white-space: nowrap;
  padding: 18px 0;
}
.cck-ticker-row {
  display: flex; gap: 26px; padding-right: 26px;
  font-family: var(--serif);
  font-style: italic;
  font-size: 26px;
  color: var(--wine);
}
@keyframes ticker {
  from { transform: translateX(0); }
  to { transform: translateX(-33.333%); }
}

/* ─── Promises ─── */
.cck-promises {
  padding: 110px 48px;
  max-width: 1320px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}
.cck-promises-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 36px;
}
@media (max-width: 1024px) {
  .cck-promises-grid { grid-template-columns: repeat(2, 1fr); gap: 32px; }
}
@media (max-width: 560px) {
  .cck-promises-grid { grid-template-columns: 1fr; gap: 28px; }
}
.cck-promise { padding-top: 16px; border-top: 2px solid var(--wine); }
.cck-promise h3 em { font-style: italic; color: var(--wine); }
.cck-promise-num {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .25em;
  color: var(--orange);
  margin-bottom: 24px;
}
.cck-promise h3 {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 38px;
  line-height: 1.02;
  letter-spacing: -.01em;
  margin: 0 0 18px;
  color: var(--ink);
}
.cck-promise p {
  font-size: 16px;
  line-height: 1.55;
  color: var(--ink-soft);
  margin: 0;
  max-width: 32ch;
}
.cck-promise p em { font-style: italic; color: var(--wine); font-weight: 500; }

/* ─── Pacotes ─── */
.cck-pacotes {
  padding: 80px 48px 120px;
  max-width: 1320px;
  margin: 0 auto;
  position: relative; z-index: 2;
}
.cck-pacotes-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  margin-top: 32px;
}
.cck-pacote {
  position: relative;
  background: var(--paper);
  border: 1.5px solid var(--pc);
  border-radius: 14px;
  padding: 32px 28px 28px;
  display: flex; flex-direction: column;
  transition: transform .25s ease, box-shadow .25s;
}
.cck-pacote:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 28px rgba(40,20,10,.1);
}
.cck-pacote-destaque {
  background: linear-gradient(180deg, var(--pcl) 0%, var(--paper) 30%);
  border-width: 2.5px;
  transform: scale(1.03);
}
.cck-pacote-destaque:hover { transform: scale(1.03) translateY(-4px); }
.cck-pacote-badge {
  position: absolute;
  top: -12px; left: 50%; transform: translateX(-50%);
  background: var(--pc);
  color: #fff9ec;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .2em;
  text-transform: uppercase;
  padding: 6px 14px;
  border-radius: 999px;
}
.cck-pacote-head {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 12px;
  margin-bottom: 18px;
}
.cck-pacote-nome {
  font-family: var(--serif);
  font-style: italic;
  font-size: 28px;
  color: var(--pc);
  letter-spacing: -.01em;
}
.cck-pacote-range {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .2em;
  color: var(--muted);
  text-transform: uppercase;
}
.cck-pacote-stats {
  display: flex; align-items: baseline; gap: 12px;
  padding: 14px 0;
  border-top: 1px dashed var(--line);
  border-bottom: 1px dashed var(--line);
  color: var(--ink-soft);
  font-size: 14px;
  font-family: var(--mono);
}
.cck-pacote-stat-big {
  font-family: var(--serif);
  font-style: normal;
  font-size: 28px;
  color: var(--ink);
  font-weight: 400;
  margin-right: 4px;
}
.cck-pacote-x {
  font-family: var(--serif);
  font-size: 18px;
  color: var(--muted);
  font-style: italic;
}
.cck-pacote-preco {
  display: flex; align-items: baseline; gap: 4px;
  margin-top: 22px;
  color: var(--ink);
}
.cck-pacote-y {
  font-family: var(--serif);
  font-style: italic;
  font-size: 36px;
  color: var(--pc);
}
.cck-pacote-valor {
  font-family: var(--serif);
  font-size: 64px;
  line-height: 1;
  font-weight: 400;
  letter-spacing: -.02em;
}
.cck-pacote-por {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .1em;
  color: var(--muted);
  margin-bottom: 18px;
}
.cck-pacote-desc {
  font-size: 15px;
  line-height: 1.5;
  color: var(--ink);
  margin: 0 0 18px;
}
.cck-pacote-trocas {
  font-size: 12.5px;
  color: var(--ink-soft);
  background: rgba(0,0,0,.025);
  border-left: 2px solid var(--pc);
  padding: 8px 12px;
  margin-bottom: 24px;
  border-radius: 0 4px 4px 0;
}
.cck-pacote-cta {
  margin-top: auto;
  display: inline-flex; align-items: center; justify-content: space-between;
  gap: 10px;
  padding: 14px 18px;
  background: var(--pc);
  color: #fff9ec;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 600;
  font-size: 14.5px;
  transition: opacity .2s;
}
.cck-pacote-cta:hover { opacity: .88; }
.cck-pacotes-foot {
  margin-top: 56px;
  display: flex; justify-content: center; align-items: center; gap: 18px;
  font-family: var(--mono); font-size: 11.5px;
  letter-spacing: .15em; text-transform: uppercase;
  color: var(--muted);
}

/* ─── Builder ─── */
.cck-builder {
  padding: 80px 48px 120px;
  max-width: 1320px;
  margin: 0 auto;
  position: relative; z-index: 2;
}
.cck-builder-shell {
  background: var(--paper);
  border: 1.5px solid var(--line);
  border-radius: 18px;
  padding: 40px;
  display: grid;
  gap: 36px;
  position: relative;
  box-shadow: 0 2px 0 rgba(124,29,29,.06);
}
.cck-builder-shell::before {
  content:"";
  position: absolute; inset: 6px; border-radius: 14px;
  border: 1px dashed var(--line);
  pointer-events: none;
}
.cck-builder-step {}
.cck-step-label {
  display: flex; align-items: baseline; gap: 14px;
  font-family: var(--serif);
  font-style: italic;
  font-size: 26px;
  color: var(--ink);
  margin-bottom: 18px;
  flex-wrap: wrap;
}
.cck-step-label span:first-child {
  font-family: var(--mono);
  font-style: normal;
  font-size: 10px;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--orange);
  background: var(--orange-soft);
  padding: 4px 10px;
  border-radius: 3px;
}
.cck-step-counter {
  margin-left: auto;
  font-family: var(--mono);
  font-style: normal;
  font-size: 13px;
  letter-spacing: .05em;
}
.cck-step-counter em { font-style: normal; opacity: .6; }

.cck-builder-pacotes {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.cck-builder-pac {
  background: var(--paper);
  border: 1.5px solid var(--line);
  border-radius: 10px;
  padding: 18px 20px;
  text-align: left;
  cursor: pointer;
  display: flex; flex-direction: column; gap: 4px;
  transition: all .2s;
  font-family: inherit;
  color: inherit;
}
.cck-builder-pac:hover { border-color: var(--pc); }
.cck-builder-pac.is-on {
  background: var(--pcl);
  border-color: var(--pc);
  border-width: 2px;
  padding: 17px 19px;
}
.cck-builder-pac-nome {
  font-family: var(--serif);
  font-style: italic;
  font-size: 22px;
  color: var(--pc);
}
.cck-builder-pac-info {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .05em;
  color: var(--ink-soft);
}

/* Mixed (misturas) grid */
.cck-builder-misturas {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 14px;
}
.cck-bm {
  display: flex;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 10px;
  overflow: hidden;
  transition: border-color .2s, transform .15s;
}
.cck-bm.is-on { border-color: var(--wine); border-width: 2px; }
.cck-bm-tile {
  flex: 0 0 60px;
  position: relative;
  display: flex; flex-direction: column; justify-content: space-between;
  padding: 8px 6px;
  color: rgba(255,255,255,.95);
}
.cck-bm-n {
  font-family: var(--serif);
  font-style: italic;
  font-size: 22px;
  line-height: 1;
}
.cck-bm-tag {
  align-self: flex-start;
  font-family: var(--mono);
  font-size: 8px;
  letter-spacing: .15em;
  text-transform: uppercase;
  background: rgba(255,255,255,.22);
  padding: 2px 5px;
  border-radius: 2px;
}
.cck-bm-tag-carne { color: #fff9ec; }
.cck-bm-tag-frango { color: #2a1a0f; background: #fbe7c4; }
.cck-bm-tag-porco { color: #fff9ec; }
.cck-bm-tag-peixe { color: #fff9ec; background: rgba(255,255,255,.22); }

.cck-bm-info {
  flex: 1; padding: 10px 12px;
  display: flex; flex-direction: column;
  gap: 6px; justify-content: space-between;
}
.cck-bm-nome {
  font-family: var(--serif);
  font-size: 16px;
  line-height: 1.15;
  color: var(--ink);
}
.cck-bm-stepper {
  display: flex; align-items: center; gap: 4px;
}
.cck-bm-stepper button {
  width: 26px; height: 26px;
  border-radius: 50%;
  border: 1.2px solid var(--line);
  background: var(--paper);
  cursor: pointer;
  font-size: 16px;
  line-height: 1;
  color: var(--ink);
  transition: all .15s;
  font-family: inherit;
}
.cck-bm-stepper button:hover:not(:disabled) {
  border-color: var(--wine); color: var(--wine); background: var(--bg-tint);
}
.cck-bm-stepper button:disabled { opacity: .3; cursor: not-allowed; }
.cck-bm-qtd {
  min-width: 22px; text-align: center;
  font-family: var(--mono); font-size: 14px;
  font-weight: 600;
}

/* Checkout */
.cck-builder-checkout {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 28px;
  padding-top: 28px;
  border-top: 1px dashed var(--line);
}
.cck-checkout-info {
  font-size: 13px; color: var(--ink-soft); margin: 0 0 14px;
}
.cck-trocas-row {
  display: inline-flex; align-items: center; gap: 12px;
  background: var(--bg-tint);
  padding: 8px 14px;
  border-radius: 999px;
}
.cck-trocas-row button {
  width: 32px; height: 32px; border-radius: 50%;
  border: 1.5px solid var(--orange);
  color: var(--orange);
  background: var(--paper);
  cursor: pointer;
  font-size: 18px;
  font-family: inherit;
}
.cck-trocas-row button:disabled { opacity: .3; cursor: not-allowed; }
.cck-trocas-val {
  font-family: var(--mono); font-size: 14px; font-weight: 600;
  min-width: 100px; text-align: center;
}

.cck-checkout-total {
  background: var(--bg-tint);
  border-radius: 14px;
  padding: 24px 28px;
}
.cck-total-rows {
  display: flex; flex-direction: column; gap: 8px;
  padding-bottom: 16px;
  border-bottom: 1px dashed var(--line);
}
.cck-total-row {
  display: flex; justify-content: space-between;
  font-size: 14.5px;
  color: var(--ink-soft);
}
.cck-incluso {
  font-family: var(--mono); font-size: 11px; letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--olive);
  background: var(--olive-soft);
  padding: 2px 8px; border-radius: 3px;
}
.cck-total-grand {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-top: 16px;
  margin-bottom: 18px;
}
.cck-total-grand-lbl {
  font-family: var(--mono); font-size: 11px;
  letter-spacing: .2em; text-transform: uppercase;
  color: var(--muted);
}
.cck-total-grand-val {
  font-family: var(--serif);
  font-size: 46px;
  line-height: 1;
  letter-spacing: -.02em;
  color: var(--wine);
}
.cck-checkout-cta {
  display: block; width: 100%;
  padding: 16px;
  border-radius: 999px;
  border: 0;
  font-family: inherit;
  font-size: 16px;
  font-weight: 600;
  background: rgba(124,29,29,.18);
  color: var(--wine);
  cursor: not-allowed;
  text-align: center;
  text-decoration: none;
  transition: all .2s;
}
.cck-checkout-cta-on {
  background: var(--wine);
  color: #fff9ec;
  cursor: pointer;
  box-shadow: 0 4px 0 var(--wine-deep);
}
.cck-checkout-cta-on:hover { transform: translateY(-1px); box-shadow: 0 5px 0 var(--wine-deep), 0 8px 18px rgba(124,29,29,.2); }
.cck-checkout-footnote {
  font-size: 12px;
  color: var(--muted);
  margin: 14px 0 0;
  text-align: center;
  line-height: 1.45;
}

/* ─── Builder helper text ─── */
.cck-builder-helper {
  font-size: 14.5px;
  color: var(--ink-soft);
  margin: -8px 0 22px;
  line-height: 1.55;
}
.cck-builder-helper em { color: var(--wine); font-style: italic; }
.cck-builder-helper strong { color: var(--ink); }

/* ─── Misturas fixas (read-only) ─── */
.cck-fixas-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 12px;
}
.cck-fixa {
  display: flex; align-items: center; gap: 12px;
  background: var(--paper);
  border: 1.5px solid var(--line);
  border-radius: 10px;
  padding: 10px 12px;
  transition: opacity .2s, background .2s;
}
.cck-fixa.is-trocada {
  opacity: .82;
  background: var(--bg-tint);
  border-style: dashed;
}
.cck-fixa-tile {
  width: 52px; height: 52px;
  border-radius: 8px;
  flex-shrink: 0;
  position: relative;
  display: flex; align-items: flex-start; justify-content: flex-start;
  padding: 6px;
  color: #fff9ec;
}
.cck-fixa-n {
  font-family: var(--serif);
  font-style: italic;
  font-size: 18px;
  line-height: 1;
}
.cck-fixa-info { flex: 1; min-width: 0; }
.cck-fixa-nome {
  font-size: 14px;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.3;
}
.cck-fixa-nome s {
  color: var(--muted);
  text-decoration: line-through;
  font-weight: 400;
  font-size: 13px;
}
.cck-fixa-trocou {
  display: block;
  font-family: var(--serif);
  font-style: italic;
  font-size: 14px;
  color: var(--orange);
  margin-top: 2px;
}

/* ─── Trocas (Step 3) ─── */
.cck-trocas-empty {
  display: flex; align-items: center; justify-content: space-between;
  gap: 14px;
  background: rgba(124,29,29,.04);
  border: 1.5px dashed var(--line);
  border-radius: 10px;
  padding: 18px 22px;
  font-size: 14.5px;
  color: var(--ink-soft);
  flex-wrap: wrap;
}
.cck-troca-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 14px;
  align-items: center;
  background: var(--paper);
  border: 1.5px solid var(--line);
  border-radius: 12px;
  padding: 14px 16px;
  margin-bottom: 10px;
  transition: border-color .2s;
}
.cck-troca-row.is-err { border-color: #c8511c; background: rgba(200,81,28,.05); }
.cck-troca-num {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: .1em;
  color: var(--wine);
  font-weight: 700;
  padding: 6px 10px;
  background: rgba(124,29,29,.08);
  border-radius: 6px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
}
.cck-troca-num-tag {
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 3px 7px;
  border-radius: 4px;
  background: var(--orange-soft);
  color: var(--orange);
  font-weight: 700;
}
.cck-troca-num-tag.is-free {
  background: var(--olive-soft);
  color: var(--olive);
}
.cck-troca-fields {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 12px;
  align-items: end;
}
.cck-troca-field { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.cck-troca-field label {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--muted);
}
.cck-troca-field select {
  font-family: var(--sans);
  font-size: 14px;
  padding: 8px 28px 8px 12px;
  border: 1.5px solid var(--line);
  border-radius: 8px;
  background: var(--bg);
  color: var(--ink);
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  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='none' stroke='%237c1d1d' stroke-width='1.5' d='M1 1l5 5 5-5'/></svg>");
  background-repeat: no-repeat;
  background-position: right 10px center;
  background-size: 10px;
  width: 100%;
  text-overflow: ellipsis;
}
.cck-troca-field select:focus {
  outline: none;
  border-color: var(--wine);
  box-shadow: 0 0 0 3px rgba(124,29,29,.12);
}
.cck-troca-arrow {
  font-family: var(--serif);
  font-style: italic;
  font-size: 22px;
  color: var(--orange);
  align-self: center;
  padding-top: 14px;
}
.cck-troca-meta {
  display: flex; align-items: center; gap: 10px;
}
.cck-troca-custo {
  font-family: var(--mono);
  font-size: 12px;
  font-weight: 700;
  padding: 6px 10px;
  background: var(--orange-soft);
  color: var(--orange);
  border-radius: 6px;
  letter-spacing: .05em;
}
.cck-troca-custo.is-free {
  background: var(--olive-soft);
  color: var(--olive);
}
.cck-troca-remove {
  background: transparent;
  border: 1.5px solid var(--line);
  width: 32px; height: 32px;
  border-radius: 50%;
  font-size: 20px;
  line-height: 1;
  color: var(--muted);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: border-color .2s, color .2s, background .2s;
}
.cck-troca-remove:hover {
  border-color: var(--wine);
  color: var(--wine);
  background: rgba(124,29,29,.06);
}
.cck-troca-err {
  grid-column: 1 / -1;
  font-size: 12.5px;
  color: #c8511c;
  margin-top: 4px;
  font-family: var(--mono);
}
.cck-btn-sm { padding: 10px 18px; font-size: 13.5px; }
.cck-trocas-add {
  margin-top: 4px;
}
.cck-trocas-max {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--muted);
  margin: 14px 0 0;
  text-align: center;
}

@media (max-width: 720px) {
  .cck-troca-row { grid-template-columns: 1fr; }
  .cck-troca-fields { grid-template-columns: 1fr; gap: 8px; }
  .cck-troca-arrow { padding-top: 0; text-align: center; }
  .cck-troca-meta { justify-content: space-between; }
  .cck-trocas-empty { flex-direction: column; align-items: stretch; text-align: center; }
}

/* ─── Cardápio ─── */
.cck-cardapio {
  padding: 80px 48px 120px;
  max-width: 1320px;
  margin: 0 auto;
  position: relative; z-index: 2;
}
.cck-menu-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 24px;
}
.cck-dish {
  position: relative;
  background: var(--paper);
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--line);
  transition: transform .2s, box-shadow .2s;
}
.cck-dish:hover {
  transform: translateY(-3px);
  box-shadow: 0 10px 24px rgba(40,20,10,.1);
}
.cck-dish-destaque { border-color: var(--orange); border-width: 1.5px; }
.cck-dish-img {
  position: relative;
  height: 160px;
  display: flex;
  align-items: flex-end;
  padding: 14px 16px;
  color: #fff9ec;
  overflow: hidden;
}
.cck-dish-n {
  font-family: var(--serif);
  font-style: italic;
  font-size: 56px;
  line-height: .9;
  letter-spacing: -.04em;
}
.cck-dish-tag {
  position: absolute;
  top: 12px; right: 12px;
}
.cck-dish-star {
  position: absolute;
  bottom: 14px; right: 16px;
  font-family: var(--mono); font-size: 10px;
  letter-spacing: .15em; text-transform: uppercase;
  background: rgba(255,255,255,.95);
  color: var(--orange);
  padding: 4px 8px;
  border-radius: 3px;
  font-weight: 700;
}
.cck-dish-deco {
  position: absolute;
  top: -30%; right: -20%;
  width: 200px; height: 200px;
  opacity: .5;
}
.cck-dish-body { padding: 18px 18px 20px; }
.cck-dish-name {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 22px;
  line-height: 1.15;
  margin: 0 0 6px;
  color: var(--ink);
}
.cck-dish-desc {
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--ink-soft);
  margin: 0;
}

/* Opcionais */
.cck-opcionais {
  margin-top: 52px;
  background: var(--bg-tint);
  border-radius: 14px;
  padding: 32px;
}
.cck-opcionais-head {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  align-items: end;
  margin-bottom: 24px;
}
.cck-opcionais-head h3 {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 28px;
  line-height: 1.1;
  margin: 12px 0 0;
  color: var(--ink);
}
.cck-opcionais-head p { margin: 0; color: var(--ink-soft); font-size: 14.5px; }
.cck-opcionais-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
}
.cck-opcional {
  display: flex; align-items: center; gap: 10px;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px 14px;
  font-family: var(--serif);
  font-size: 17px;
  color: var(--ink);
}
.cck-opcional-bullet {
  font-family: var(--mono); color: var(--orange); font-size: 18px;
}
.cck-opcional .cck-bm-tag { margin-left: auto; }

/* Feijão */
.cck-feijao {
  margin-top: 32px;
  display: grid;
  grid-template-columns: 100px 1fr auto;
  gap: 28px;
  align-items: center;
  background: var(--paper);
  border: 1.5px solid var(--line);
  border-radius: 14px;
  padding: 28px 32px;
}
.cck-feijao-text h3 {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 28px;
  margin: 0 0 4px;
}
.cck-feijao-text h3 em { font-style: italic; color: var(--wine); }
.cck-feijao-text p { margin: 0; color: var(--ink-soft); font-size: 15px; }
.cck-feijao-precos { display: flex; gap: 24px; }
.cck-feijao-preco {
  text-align: center;
  padding: 10px 18px;
  border-left: 2px solid var(--orange);
}
.cck-feijao-y {
  display: block;
  font-family: var(--serif);
  font-size: 28px;
  color: var(--wine);
  font-style: italic;
}
.cck-feijao-lbl {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--muted);
}

/* ─── Cozinheira ─── */
.cck-cozinheira {
  padding: 80px 48px 120px;
  max-width: 1320px;
  margin: 0 auto;
  position: relative; z-index: 2;
}
.cck-coz-grid {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 60px;
  align-items: center;
}
.cck-coz-photo {
  position: relative;
}
.cck-coz-photo-frame {
  position: relative;
  border-radius: 4px;
  overflow: hidden;
  aspect-ratio: 5/6;
  background: #f4e3c4;
  box-shadow: 0 18px 40px rgba(40,20,10,.16);
  transform: rotate(-2deg);
}
.cck-coz-photo-img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.cck-coz-photo-fallback {
  position: absolute; inset: 0;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 12px;
  background: linear-gradient(180deg, #f4e3c4 0%, #e6c79b 100%);
  color: var(--ink);
  text-align: center;
  padding: 24px;
  font-family: var(--mono);
  font-size: 12px;
  line-height: 1.5;
}
.cck-coz-photo-fallback span { font-size: 48px; opacity: .5; }
.cck-coz-photo-fallback code {
  background: rgba(42,26,15,.08);
  padding: 4px 10px;
  border-radius: 3px;
  font-size: 11px;
}
.cck-coz-photo .cck-stamp {
  position: absolute;
  bottom: -20px; right: -20px;
  background: rgba(255,250,240,.95);
}
.cck-coz-kicker {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--orange);
  margin-bottom: 14px;
}
.cck-coz-quotes blockquote {
  margin: 24px 0 0;
  padding: 18px 0 18px 24px;
  border-left: 3px solid var(--wine);
  font-family: var(--serif);
  font-style: italic;
  font-size: 22px;
  line-height: 1.35;
  color: var(--wine);
  max-width: 50ch;
}

/* ─── Como funciona ─── */
.cck-comofunciona {
  padding: 80px 48px 120px;
  max-width: 1320px;
  margin: 0 auto;
  background: linear-gradient(180deg, transparent, var(--bg-tint) 40%, transparent);
  position: relative; z-index: 2;
}
.cck-cf-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}
.cck-cf-step {
  position: relative;
  text-align: left;
  padding: 8px 0;
}
.cck-cf-num {
  display: flex; align-items: center; gap: 14px;
  margin-bottom: 18px;
}
.cck-cf-num span {
  font-family: var(--serif);
  font-style: italic;
  font-size: 64px;
  line-height: 1;
  color: var(--orange);
  letter-spacing: -.04em;
}
.cck-cf-arrow {
  flex-shrink: 0;
  margin-top: 12px;
}
.cck-cf-step h3 {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 30px;
  line-height: 1.1;
  margin: 0 0 12px;
  color: var(--ink);
}
.cck-cf-step p { color: var(--ink-soft); font-size: 15.5px; line-height: 1.55; margin: 0 0 14px; max-width: 36ch; }
.cck-cf-step p em { font-style: italic; color: var(--wine); }
.cck-cf-detail {
  font-family: var(--mono);
  font-size: 11.5px;
  letter-spacing: .1em;
  color: var(--wine);
  padding-top: 12px;
  border-top: 1px dashed var(--line);
}

/* ─── Depoimentos ─── */
.cck-depoimentos {
  padding: 80px 48px 120px;
  max-width: 1320px;
  margin: 0 auto;
  position: relative; z-index: 2;
}
.cck-dep-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.cck-dep {
  position: relative;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 36px 28px 28px;
  margin: 0;
}
.cck-dep-quote-mark {
  position: absolute;
  top: -10px; left: 20px;
  font-family: var(--serif);
  font-size: 100px;
  line-height: 1;
  color: var(--orange);
  font-style: italic;
}
.cck-dep blockquote {
  margin: 0 0 24px;
  font-family: var(--serif);
  font-size: 20px;
  line-height: 1.35;
  color: var(--ink);
  font-style: italic;
}
.cck-dep figcaption {
  display: flex; flex-direction: column; gap: 2px;
  padding-top: 18px;
  border-top: 1px dashed var(--line);
  font-size: 14px;
}
.cck-dep figcaption strong { font-family: var(--sans); color: var(--ink); }
.cck-dep figcaption span { color: var(--ink-soft); font-size: 13px; }
.cck-dep-pkg {
  font-family: var(--mono);
  font-size: 10.5px !important;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--orange) !important;
  margin-top: 4px;
}

/* ─── Entrega ─── */
.cck-entrega {
  padding: 80px 48px 120px;
  max-width: 1320px;
  margin: 0 auto;
  position: relative; z-index: 2;
}
.cck-ent-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 48px;
  align-items: start;
}
.cck-ent-mapa, .cck-ent-pgto {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 32px;
}
.cck-ent-mapa h3, .cck-ent-pgto h3 {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 28px;
  margin: 0 0 18px;
  color: var(--ink);
}
.cck-ent-mapa-art {
  background: var(--bg);
  border: 1px dashed var(--line);
  border-radius: 8px;
  padding: 16px;
  margin-bottom: 20px;
}
.cck-ent-zonas { display: flex; flex-direction: column; gap: 14px; }
.cck-zona {
  display: grid;
  grid-template-columns: 14px auto 1fr;
  gap: 10px;
  align-items: baseline;
  font-size: 14px;
}
.cck-zona-dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  margin-top: 4px;
}
.cck-zona strong { color: var(--ink); }
.cck-zona span:last-child { color: var(--ink-soft); font-size: 13px; }
.cck-ent-p { color: var(--ink-soft); margin: 0 0 18px; font-size: 15px; }
.cck-pgto-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  margin-bottom: 20px;
}
.cck-pgto {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 12px;
  border: 1.5px solid;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
}
.cck-pgto-dot {
  width: 8px; height: 8px; border-radius: 50%;
}
.cck-ent-aviso {
  font-size: 13.5px;
  color: var(--ink-soft);
  background: var(--bg-tint);
  border-radius: 8px;
  padding: 14px 16px;
  line-height: 1.5;
}
.cck-ent-aviso strong { color: var(--wine); }

/* ─── FAQ ─── */
.cck-faq {
  padding: 80px 48px 120px;
  max-width: 980px;
  margin: 0 auto;
  position: relative; z-index: 2;
}
.cck-faq-list { display: flex; flex-direction: column; }
.cck-faq-item {
  border-bottom: 1px solid var(--line);
}
.cck-faq-item:first-child { border-top: 1px solid var(--line); }
.cck-faq-q {
  display: flex; align-items: center; gap: 18px;
  width: 100%;
  padding: 22px 4px;
  background: transparent;
  border: 0;
  cursor: pointer;
  text-align: left;
  font-family: inherit;
}
.cck-faq-num {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .2em;
  color: var(--orange);
}
.cck-faq-text {
  flex: 1;
  font-family: var(--serif);
  font-size: 22px;
  color: var(--ink);
  line-height: 1.2;
}
.cck-faq-toggle {
  font-family: var(--serif);
  font-size: 32px;
  color: var(--wine);
  line-height: 1;
  width: 32px;
  text-align: center;
  transition: transform .25s;
}
.cck-faq-item.is-open .cck-faq-toggle { transform: rotate(180deg); }
.cck-faq-a {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows .3s ease;
}
.cck-faq-item.is-open .cck-faq-a { grid-template-rows: 1fr; }
.cck-faq-a > p {
  overflow: hidden;
  margin: 0;
  padding-left: 60px;
  padding-right: 60px;
  color: var(--ink-soft);
  font-size: 16px;
  line-height: 1.6;
}
.cck-faq-item.is-open .cck-faq-a > p { padding-bottom: 22px; }

/* ─── Final CTA ─── */
.cck-finalcta {
  position: relative;
  padding: 120px 48px;
  background: var(--wine);
  color: #fff9ec;
  overflow: hidden;
  z-index: 2;
}
.cck-finalcta::before {
  content:"";
  position: absolute; inset: 0;
  background:
    radial-gradient(circle at 10% 20%, rgba(255,180,100,.18) 0, transparent 40%),
    radial-gradient(circle at 90% 80%, rgba(255,120,50,.15) 0, transparent 40%);
}
.cck-finalcta-inner {
  position: relative;
  max-width: 920px;
  margin: 0 auto;
  text-align: center;
}
.cck-finalcta-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--mono);
  font-size: 11.5px; letter-spacing: .2em; text-transform: uppercase;
  color: rgba(255,249,236,.7);
  margin-bottom: 28px;
}
.cck-finalcta-eyebrow .cck-dot { background: #ffc77a; box-shadow: 0 0 0 4px rgba(255,199,122,.2); }
.cck-finalcta-h {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(48px, 6vw, 88px);
  line-height: 1;
  letter-spacing: -.02em;
  margin: 0 0 24px;
  text-wrap: balance;
}
.cck-finalcta-h em { font-style: italic; color: #ffc77a; }
.cck-finalcta-sub {
  font-size: 19px;
  color: rgba(255,249,236,.8);
  max-width: 52ch;
  margin: 0 auto 40px;
  line-height: 1.5;
  text-wrap: pretty;
}
.cck-finalcta-row {
  display: flex; gap: 14px; justify-content: center; flex-wrap: wrap;
  margin-bottom: 30px;
}
.cck-finalcta-row .cck-btn-primary {
  background: #ffc77a;
  color: var(--wine);
  box-shadow: 0 4px 0 #d99a3e;
}
.cck-finalcta-row .cck-btn-primary:hover { background: #ffd28e; }
.cck-finalcta-row .cck-btn-ghost { color: #fff9ec; border-color: rgba(255,249,236,.4); }
.cck-finalcta-row .cck-btn-ghost:hover { background: rgba(255,249,236,.08); border-color: #fff9ec; }
.cck-finalcta-foot {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,249,236,.6);
}
.cck-finalcta-foot strong { color: #fff9ec; }

/* ─── Footer ─── */
.cck-footer {
  background: var(--ink);
  color: rgba(255,249,236,.7);
  padding: 60px 48px 32px;
  position: relative; z-index: 2;
}
.cck-footer-grid {
  max-width: 1320px;
  margin: 0 auto 32px;
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: 40px;
}
.cck-footer-logo {
  font-family: var(--serif);
  font-style: italic;
  font-size: 32px;
  color: #fff9ec;
}
.cck-footer-logo span { color: #ffc77a; }
.cck-footer-kanji {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .25em;
  color: rgba(255,249,236,.5);
  margin: 6px 0 14px;
}
.cck-footer-brand p { font-size: 13.5px; line-height: 1.55; max-width: 38ch; }
.cck-footer-col { display: flex; flex-direction: column; gap: 6px; }
.cck-footer-col h4 {
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: #fff9ec;
  margin: 0 0 8px;
}
.cck-footer-col a, .cck-footer-col span {
  color: rgba(255,249,236,.7);
  text-decoration: none;
  font-size: 14px;
}
.cck-footer-col a:hover { color: #ffc77a; }
.cck-footer-bottom {
  max-width: 1320px;
  margin: 0 auto;
  padding-top: 24px;
  border-top: 1px solid rgba(255,249,236,.12);
  display: flex; justify-content: space-between;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .12em;
  color: rgba(255,249,236,.4);
}

/* ─── Floating WhatsApp ─── */
.cck-wa-float {
  position: fixed;
  bottom: 24px; left: 24px;
  z-index: 100;
  display: flex; align-items: center; gap: 8px;
  padding: 12px 18px;
  background: #25D366;
  color: #fff;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 600;
  font-size: 14.5px;
  box-shadow: 0 8px 24px rgba(37,211,102,.4);
  transition: transform .2s, opacity .25s ease;
}
.cck-wa-float:hover { transform: scale(1.04); }
.cck-wa-float.is-hidden { opacity: 0; pointer-events: none; transform: translateY(20px); }
/* Em mobile, aumenta padding bottom do body pra FAB não cobrir conteúdo final */
@media (max-width: 720px) {
  .cck-wa-float {
    bottom: 16px; left: 16px;
    padding: 10px 16px;
    font-size: 13.5px;
  }
  body { padding-bottom: 70px; }
}

/* ─── Marmita illustration ─── */
.cck-marmita { display: block; }

/* ─── Responsive ─── */
@media (max-width: 980px) {
  .cck-nav { padding: 14px 24px; }
  .cck-nav-links { display: none; }
  .cck-hero { padding: 48px 24px 0; }
  .cck-hero-grid { grid-template-columns: 1fr; gap: 40px; padding-bottom: 60px; }
  .cck-hero-art { height: 420px; }
  .cck-promises, .cck-pacotes, .cck-builder, .cck-cardapio, .cck-cozinheira,
  .cck-comofunciona, .cck-depoimentos, .cck-entrega, .cck-faq, .cck-finalcta, .cck-footer { padding-left: 24px; padding-right: 24px; }
  .cck-promises-grid, .cck-pacotes-grid, .cck-cf-grid, .cck-dep-grid, .cck-builder-pacotes,
  .cck-footer-grid { grid-template-columns: 1fr; gap: 24px; }
  .cck-builder-checkout { grid-template-columns: 1fr; }
  .cck-ent-grid, .cck-coz-grid, .cck-opcionais-head { grid-template-columns: 1fr; }
  .cck-pacote-destaque { transform: none; }
  .cck-pacote-destaque:hover { transform: translateY(-4px); }
  .cck-feijao { grid-template-columns: 1fr; text-align: center; }
  .cck-feijao-precos { justify-content: center; }
  .cck-builder-shell { padding: 24px; }
}
