/* ============================================================
   Snowland — ingressos.css (página de compra de ingressos)
   Reusa style.css (reset/:root/.btn/.socials/.mobile-menu).
   Cores do calendário extraídas do app real (snowland.com.br/ingressos).
   ============================================================ */

:root{
  --ing-bg:#2a67cc;            /* azul de fundo da página */
  --cal-blue:#2B93D1;          /* texto/numero azul */
  --d-selecionado:#c0a86b;     /* dia selecionado (dourado) */
  --d-baixa:#2B93D1;           /* baixa temporada / disponível */
  --d-media:#1E5FAB;           /* média temporada */
  --d-super:#20356b;           /* super temporada */
  --d-alta:#d6177f;            /* alta temporada (magenta marca) */
  --d-fechado:#cbccce;         /* dia fechado */
  --d-esgotado:#f2e0b8;        /* dia esgotado */
}

/* ---------- Fundo da página ---------- */
.ing-page{
  background:var(--ing-bg) url('../images/snow-pattern.svg');
  background-size:260px 260px;
  min-height:100vh;
}

/* ============================================================
   HEADER simplificado (checkout)
   ============================================================ */
.ck-header{
  position:sticky;top:0;z-index:200;background:#fff;
  box-shadow:0 4px 18px rgba(20,20,60,.10);
}
.ck-inner{display:flex;align-items:center;gap:16px;padding:12px 24px;min-height:64px}
.ck-header .logo img{height:46px;width:auto;display:block}
.ck-orders{
  margin-left:auto;display:inline-flex;align-items:center;gap:7px;
  font-family:var(--font-display);font-weight:600;font-size:13px;letter-spacing:.03em;
  text-transform:uppercase;color:var(--accent-blue);transition:opacity .2s ease;
}
.ck-orders:hover{opacity:.75}

/* ============================================================
   CONTEÚDO
   ============================================================ */
.ing-main{padding:30px 0 50px}

.step-head{
  display:flex;align-items:center;gap:12px;
  font-family:var(--font-display);font-weight:600;font-style:italic;
  text-transform:uppercase;color:#fff;font-size:clamp(17px,2.4vw,24px);letter-spacing:.02em;
  margin-bottom:22px;text-shadow:0 2px 8px rgba(10,20,60,.25);
}
.step-num{
  flex-shrink:0;width:30px;height:30px;border-radius:50%;background:#fff;
  display:inline-flex;align-items:center;justify-content:center;
  font-style:normal;font-weight:700;color:var(--d-selecionado);font-size:16px;
}

/* ---------- Step 1: grid polaroid + calendário ---------- */
.step1-grid{display:grid;grid-template-columns:minmax(280px,1fr) 1.25fr;gap:40px;align-items:start}

.polaroid{
  background:#fff;padding:14px 14px 0;border-radius:4px;
  box-shadow:0 18px 40px rgba(10,20,60,.30);transform:rotate(-3deg);
  align-self:center;max-width:420px;justify-self:center;
}
.polaroid-photo{width:100%;display:block;border-radius:2px}
.polaroid-logo{display:block;height:54px;width:auto;margin:14px auto 18px}

.date-col{display:flex;flex-direction:column;gap:18px}

/* ---------- Calendário ---------- */
.cal-card{background:#fff;border-radius:16px;padding:22px 24px;box-shadow:0 16px 36px rgba(10,20,60,.18)}
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.cal-title{font-family:var(--font-display);font-weight:700;color:var(--cal-blue);font-size:20px}
.cal-nav{
  width:40px;height:40px;border-radius:50%;color:var(--cal-blue);font-size:24px;line-height:1;
  display:flex;align-items:center;justify-content:center;transition:background .15s ease;
}
.cal-nav:hover{background:#eaf3fb}
.cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-bottom:8px}
.cal-weekdays span{text-align:center;font-size:12px;color:#9bb4cf;text-transform:lowercase;font-weight:600}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}
.cal-day{
  aspect-ratio:1/1;border-radius:10px;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-weight:600;font-size:15px;
  background:#e9eef5;color:var(--cal-blue);transition:transform .12s ease,box-shadow .15s ease;
}
.cal-day.is-clickable{cursor:pointer}
.cal-day.is-clickable:hover{transform:translateY(-2px);box-shadow:0 6px 14px rgba(20,40,90,.18)}
.cal-empty{background:transparent}
.cal-day.t-baixa{background:#e9eef5;color:var(--cal-blue)}
.cal-day.t-media{background:var(--d-media);color:#fff}
.cal-day.t-super{background:var(--d-super);color:#fff}
.cal-day.t-alta{background:var(--d-alta);color:#fff}
.cal-day.t-fechado{background:var(--d-fechado);color:#fff;cursor:not-allowed}
.cal-day.t-esgotado{background:var(--d-esgotado);color:var(--cal-blue);cursor:not-allowed;position:relative}
.cal-day.t-esgotado::after{content:'';position:absolute;inset:18% 16%;border-top:2px solid var(--cal-blue);transform:rotate(-45deg);opacity:.6}
.cal-day.is-selected{background:var(--d-selecionado)!important;color:#fff!important;box-shadow:0 6px 16px rgba(192,168,107,.5)}
.cal-card.cal-shake{animation:calShake .45s ease}
@keyframes calShake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-7px)}40%,80%{transform:translateX(7px)}}

/* ---------- Botão Procurar Ingresso ---------- */
.ing-search{
  display:flex;align-items:center;justify-content:center;gap:10px;width:100%;
  background:linear-gradient(90deg,#2f6fd6,#1e4fb0);color:#fff;border-radius:14px;
  font-family:var(--font-display);font-weight:600;font-size:16px;padding:16px;
  box-shadow:0 10px 24px rgba(20,50,120,.30);transition:transform .15s ease,box-shadow .2s ease;
}
.ing-search:hover{transform:translateY(-2px);box-shadow:0 14px 28px rgba(20,50,120,.4)}

/* ---------- Telefones (mobile) ---------- */
.ing-phones{display:none;text-align:center;background:#fff;border-radius:14px;padding:16px;box-shadow:0 10px 24px rgba(10,20,60,.12)}
.ing-phones p{display:flex;align-items:center;justify-content:center;gap:8px;color:var(--ink);font-size:14px;font-weight:600;margin:6px 0}
.ing-phones svg{color:var(--cal-blue)}

/* ---------- Legenda ---------- */
.legend{
  background:rgba(255,255,255,.16);border-radius:16px;padding:18px;
  display:grid;grid-template-columns:repeat(3,1fr);gap:12px;
}
.leg{
  display:flex;align-items:center;justify-content:center;text-align:center;
  font-family:var(--font-display);font-weight:600;font-size:12.5px;color:#fff;line-height:1.15;
  padding:10px 12px;border-radius:999px;min-height:44px;
}
.leg--selecionado{background:var(--d-selecionado)}
.leg--alta{background:var(--d-alta)}
.leg--baixa{background:var(--d-baixa)}
.leg--fechado{background:var(--d-fechado);color:var(--cal-blue)}
.leg--media{background:var(--d-media)}
.leg--super{background:var(--d-super)}
.leg--esgotado{background:var(--d-esgotado);color:var(--cal-blue)}

/* ============================================================
   FOOTER da página
   ============================================================ */
.ing-footer{background:#fff;margin-top:30px}
.ing-foot-top{display:grid;grid-template-columns:.85fr 1.15fr;gap:48px;padding:44px 24px 36px}
.foot-pay h3{font-family:var(--font-display);font-weight:700;color:var(--accent-blue);font-size:17px;margin-bottom:4px}
.foot-pay-sub{color:var(--accent-blue);font-size:14px;margin-bottom:14px}
.foot-pay-icons{height:30px;width:auto;margin-bottom:26px}
.foot-rel{margin-top:8px}
.foot-phone{display:inline-flex;align-items:center;gap:8px;margin-top:10px;color:var(--accent-blue);font-family:var(--font-display);font-weight:700;font-size:16px;border:1.5px solid #cfe0f1;border-radius:999px;padding:10px 20px}
.foot-help h4{font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:16px;margin-bottom:10px}
.foot-help p{color:var(--ink-soft);font-size:13.5px;line-height:1.6;margin-bottom:14px}
.foot-help a{color:var(--cal-blue);font-weight:600}
.foot-rules{display:flex;flex-direction:column;gap:6px}
.foot-rules li{position:relative;padding-left:16px;color:var(--ink-soft);font-size:13px;line-height:1.5;list-style:none}
.foot-rules li::before{content:'*';position:absolute;left:0;color:var(--cal-blue);font-weight:700}

.ing-foot-bottom{background:#eef1f6;padding:34px 0}
.foot-bottom-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:36px;align-items:start}
.foot-logo{height:50px;width:auto;margin-bottom:14px}
.foot-bottom-grid p{color:var(--ink-soft);font-size:13.5px;line-height:1.6}
.foot-bottom-grid strong{color:var(--ink);font-family:var(--font-display);font-weight:600}
.foot-bottom-grid a{color:var(--cal-blue)}

/* ============================================================
   RESPONSIVO
   ============================================================ */
.burger{display:none}

@media (max-width:900px){
  .step1-grid{grid-template-columns:1fr;gap:22px}
  .polaroid{display:none}
  .ing-phones{display:block}
  .ing-foot-top{grid-template-columns:1fr;gap:30px;padding:34px 20px 28px}
  .foot-bottom-grid{grid-template-columns:1fr;gap:24px;text-align:center}
  .foot-bottom-grid .foot-logo{margin-left:auto;margin-right:auto}
}

@media (max-width:768px){
  .burger{display:flex}
  .ck-orders{display:none}              /* mobile usa o burger (overlay) */
  .legend{grid-template-columns:repeat(2,1fr)}
}

@media (max-width:480px){
  .ck-inner{padding:10px 16px}
  .ing-main .container{padding:0 16px}
  .cal-card{padding:18px 16px}
  .cal-weekdays{gap:5px}
  .cal-grid{gap:5px}
}

/* ============================================================
   STEP 2 — SHOP (3 colunas: data + ingressos + carrinho)
   ============================================================ */
.shop[hidden]{display:none}
.shop-grid{display:grid;grid-template-columns:300px 1fr 320px;gap:26px;align-items:start}
.shop-col{min-width:0}
.step-head--sm{font-size:15px;margin-bottom:14px}
.step-head--sm .step-num{width:26px;height:26px;font-size:14px}

/* coluna data */
.shop-cal .cal-card{padding:16px}
.shop-cal .cal-title{font-size:17px}
.shop-back{margin:14px 0;color:#fff;font-family:var(--font-display);font-weight:600;font-size:13px;opacity:.9}
.shop-back:hover{opacity:1;text-decoration:underline}
.legend--side{grid-template-columns:1fr;gap:8px;background:rgba(255,255,255,.14)}
.legend--side .leg{justify-content:flex-start;min-height:36px;font-size:12px}

/* coluna ingressos */
.prod-day{display:flex;align-items:center;gap:8px;background:#fff;border-radius:12px;padding:12px 16px;margin-bottom:16px;color:var(--ink);font-weight:600;font-size:14px;box-shadow:0 8px 18px rgba(10,20,60,.12)}
.prod-day svg{color:var(--cal-blue);flex-shrink:0}
.prod-day strong{color:var(--cal-blue)}

.tabs{display:flex;gap:10px;margin-bottom:18px}
.tab{
  flex:1;background:rgba(255,255,255,.55);color:var(--ink-soft);
  font-family:var(--font-display);font-weight:600;font-size:14px;padding:14px 8px;border-radius:12px;
  transition:background .15s ease,color .15s ease;
}
.tab.is-active{background:#fff;color:var(--cal-blue);box-shadow:0 8px 18px rgba(10,20,60,.14)}
.cat-label{text-align:center;color:#fff;font-family:var(--font-display);font-weight:600;font-size:15px;margin-bottom:18px}
.cat-label span{color:#ffd76a;text-transform:uppercase}

.ticket-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:18px}
.ticket-card{background:#eef2f7;border-radius:16px;padding:12px;display:flex;flex-direction:column;box-shadow:0 8px 20px rgba(10,20,60,.12)}
.tk-banner{
  position:relative;border-radius:12px;overflow:hidden;aspect-ratio:16/10;margin-bottom:12px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  background-size:cover;background-position:center;color:#fff;padding:14px 10px;
}
.tk-banner::after{content:'';position:absolute;inset:0;background:linear-gradient(rgba(8,12,40,.05),rgba(8,12,40,.30))}
.tk-detalhes{position:absolute;top:8px;left:8px;z-index:2;background:rgba(10,20,60,.55);color:#fff;font-size:10.5px;font-weight:600;padding:3px 9px;border-radius:999px}
.tk-bn-label{position:relative;z-index:1;font-family:var(--font-display);font-weight:700;text-transform:uppercase;line-height:1;font-size:clamp(18px,3vw,26px);text-shadow:0 2px 6px rgba(0,0,0,.3)}
.tk-bn-sub{position:relative;z-index:1;font-size:11px;font-weight:600;margin-top:6px;opacity:.95}
.tk-type{position:absolute;bottom:8px;left:0;right:0;z-index:1;font-size:11px;font-weight:600;letter-spacing:.02em}
.b-combo{background:linear-gradient(135deg,#2a5cc0,#16307e)}
.b-morador{background:linear-gradient(140deg,#7a3bc4,#2c6fd4)}
.b-estudante,.b-gestante,.b-pcd{background:linear-gradient(140deg,#2f6fd6,#16307e)}
.b-foto::after{background:linear-gradient(rgba(8,12,40,.12),rgba(8,12,40,.55))}

.tk-title{font-family:var(--font-display);font-weight:700;color:var(--cal-blue);font-size:14.5px;line-height:1.2;text-align:center;margin-bottom:8px;min-height:35px}
.tk-price{text-align:center;margin-bottom:10px}
.tk-old{display:block;color:#9aa6bd;font-size:12.5px;text-decoration:line-through}
.tk-now{display:block;color:var(--cal-blue);font-family:var(--font-display);font-weight:700;font-size:19px}
.tk-stepper{display:flex;align-items:center;justify-content:center;gap:0;margin:0 auto 10px;border:1px solid #d7deea;border-radius:10px;overflow:hidden;width:max-content;background:#fff}
.tk-stepper button{width:38px;height:38px;font-size:20px;color:var(--cal-blue);line-height:1;display:flex;align-items:center;justify-content:center}
.tk-stepper button:hover{background:#eaf3fb}
.tk-stepper .tk-qty{width:46px;text-align:center;font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:16px}
.tk-action{width:100%;border:1px solid #d7deea;background:#fff;color:var(--ink-soft);border-radius:999px;padding:10px;font-size:13px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:7px}
.tk-action.is-add{background:linear-gradient(90deg,#2f6fd6,#1e4fb0);color:#fff;border-color:transparent;cursor:pointer;box-shadow:0 6px 14px rgba(20,50,120,.28)}
.tk-action.is-add:hover{transform:translateY(-1px)}

/* coluna carrinho */
.shop-cart .cart-box{background:#fff;border-radius:16px;padding:18px;box-shadow:0 12px 28px rgba(10,20,60,.16);min-height:160px}
.cart-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:24px 8px;color:#9aa6bd}
.cart-empty svg{color:#c7d2e2;margin-bottom:10px}
.cart-empty-title{font-family:var(--font-display);font-weight:700;color:var(--ink-soft);font-size:15px}
.cart-empty-sub{font-size:12.5px;margin-top:2px}
.cart-items{display:flex;flex-direction:column;gap:12px}
.cart-item{display:flex;gap:10px;align-items:flex-start;border-bottom:1px solid #eef2f7;padding-bottom:12px}
.cart-item-main{flex:1;min-width:0}
.cart-item-title{font-family:var(--font-display);font-weight:700;color:var(--cal-blue);font-size:13px;line-height:1.25}
.cart-item-meta{font-size:11.5px;color:var(--muted);margin-top:2px}
.cart-item-price{font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:13px;white-space:nowrap}
.cart-item-rm{color:#c75; font-size:18px;line-height:1;flex-shrink:0}
.cart-foot[hidden]{display:none}
.cart-count{font-size:12.5px;color:var(--muted);margin-top:12px}
.cart-total{display:flex;align-items:center;justify-content:space-between;margin:8px 0 14px;font-family:var(--font-display);font-weight:700;color:var(--ink)}
.cart-total strong{color:var(--cal-blue);font-size:20px}
.cart-proceed{font-size:15px;padding:13px}

@media (max-width:1024px){
  .shop-grid{grid-template-columns:240px 1fr;gap:18px}
  .shop-cart{grid-column:1 / -1}
}
@media (max-width:768px){
  .shop-grid{grid-template-columns:1fr;gap:18px}
  .shop-cart{grid-column:auto}
  .ticket-grid{grid-template-columns:1fr}
  .legend--side{grid-template-columns:repeat(2,1fr)}
  .shop-back{order:-1}
  .tabs{flex-direction:column}
  .tab{padding:15px}
}

/* ============================================================
   MODAIS (Selecione as datas / Selecione a Data)
   ============================================================ */
.ing-modal{position:fixed;inset:0;z-index:400;background:rgba(10,16,40,.55);display:flex;align-items:center;justify-content:center;padding:20px}
.ing-modal[hidden]{display:none}
.ing-modal--top{z-index:410}
.ing-modal-card{background:#fff;border-radius:14px;width:100%;max-width:470px;max-height:90vh;overflow:auto;padding:22px 24px;box-shadow:0 30px 70px rgba(8,12,40,.4)}
.im-title{font-family:var(--font-display);font-weight:600;color:var(--ink);font-size:20px;padding-bottom:14px;border-bottom:1px solid #eef2f7;margin-bottom:16px}
.im-field{margin-bottom:6px}
.im-field label{display:block;font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:15px;margin-bottom:6px}
.im-field input{width:100%;border:0;border-bottom:1px solid #d7deea;padding:8px 2px;font-size:15px;color:var(--ink-soft);background:transparent}

.im-comp{padding:16px 0;border-top:1px solid #eef2f7}
.im-comp:first-child{border-top:0}
.im-comp-name{font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:15px;margin-bottom:8px}
.im-date-btn{display:flex;align-items:center;justify-content:center;gap:8px;margin:0 auto;color:var(--ink-soft);font-size:14px;font-weight:600}
.im-date-btn .im-date-val{color:var(--ink)}
.im-date-btn svg{color:var(--ink)}
.im-date-btn.has-date .im-date-val{color:var(--cal-blue)}
.im-slots{display:grid;grid-template-columns:repeat(3,1fr);gap:10px 8px;margin-top:14px}
.im-slots[hidden]{display:none}
.tslot{color:var(--cal-blue);font-family:var(--font-display);font-weight:600;font-size:15px;padding:8px 4px;border-radius:8px;text-align:center}
.tslot:hover{background:#eaf3fb}
.tslot.is-picked{background:var(--cal-blue);color:#fff}

.im-error{background:#d1503f;color:#fff;text-align:center;font-weight:600;font-size:13px;line-height:1.3;border-radius:8px;padding:10px 12px;margin-top:16px}
.im-error[hidden]{display:none}

.im-foot{display:flex;justify-content:flex-end;gap:12px;margin-top:18px}
.im-btn{border-radius:999px;font-family:var(--font-display);font-weight:600;font-size:14px;padding:10px 22px;cursor:pointer}
.im-cancel{background:#d1503f;color:#fff}
.im-ok{background:#5a8fd0;color:#fff}
.im-btn:hover{filter:brightness(1.05)}

.cal-card--pick{box-shadow:none;padding:6px 0 0}
.im-pick{max-width:420px}

@media (max-width:480px){
  .ing-modal{padding:12px}
  .ing-modal-card{padding:18px 16px}
}

/* ============================================================
   CARRINHO preenchido (stepper + limpar) + ETAPA EXTRAS
   ============================================================ */
.cart-box{position:relative}
.cart-clear{position:absolute;top:14px;right:16px;z-index:2;color:#c75;font-size:12.5px;font-weight:700;font-family:var(--font-display)}
.cart-clear[hidden]{display:none}
.cart-clear:hover{text-decoration:underline}

.cart-item{align-items:flex-start}
.cart-qty{display:inline-flex;align-items:center;gap:0;border:1px solid #d7deea;border-radius:8px;overflow:hidden;margin-top:8px;background:#fff}
.cart-qty button{width:28px;height:28px;font-size:16px;color:var(--cal-blue);line-height:1;display:flex;align-items:center;justify-content:center}
.cart-qty button:hover{background:#eaf3fb}
.cart-qty span{min-width:30px;text-align:center;font-family:var(--font-display);font-weight:700;font-size:13px;color:var(--ink)}
.cart-item-right{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0}

/* etapa extras */
.extras[hidden]{display:none}
.extras-bar{background:var(--d-super);padding:14px 0;position:sticky;top:64px;z-index:50}
.extras-bar-inner{display:flex;align-items:center;justify-content:space-between;gap:14px}
.extras-title{color:#fff;font-family:var(--font-display);font-weight:600;font-size:16px;text-align:center;flex:1}
.extras-title .flake{opacity:.8}
.extras-back,.extras-finish{flex-shrink:0;border-radius:999px;font-family:var(--font-display);font-weight:600;font-size:13px;padding:10px 18px}
.extras-back{background:rgba(255,255,255,.16);color:#fff}
.extras-back:hover{background:rgba(255,255,255,.26)}
.extras-finish{background:var(--grad-pink);color:#fff;box-shadow:0 8px 18px rgba(216,27,134,.35)}
.extras-finish:hover{transform:translateY(-1px)}

.extras-grid{display:grid;grid-template-columns:1fr 320px;gap:26px;align-items:start;padding-top:26px}
.extras-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px}
.extra-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 10px 24px rgba(10,20,60,.14);display:flex;flex-direction:column}
.extra-banner{position:relative;aspect-ratio:16/10;background-size:cover;background-position:center}
.extra-banner::after{content:'';position:absolute;inset:0;background:linear-gradient(rgba(8,12,40,.05),rgba(8,12,40,.4))}
.extra-price{position:absolute;top:10px;right:10px;z-index:1;background:rgba(10,20,60,.6);color:#fff;font-family:var(--font-display);font-weight:700;font-size:15px;padding:5px 12px;border-radius:999px}
.extra-body{padding:14px 16px 16px;display:flex;flex-direction:column;gap:12px;flex:1}
.extra-title{font-family:var(--font-display);font-weight:700;color:var(--cal-blue);font-size:14.5px;line-height:1.25;flex:1}
.extra-add{display:flex;align-items:center;justify-content:center;gap:7px;background:linear-gradient(90deg,#2f6fd6,#1e4fb0);color:#fff;border-radius:999px;padding:11px;font-family:var(--font-display);font-weight:600;font-size:13.5px;box-shadow:0 6px 14px rgba(20,50,120,.26)}
.extra-add:hover{transform:translateY(-1px)}
.extra-add.is-added{background:#3bb54a;box-shadow:none}

.extras-cart .step-head--sm{color:#fff}
.extras-nowant{display:none;margin-top:14px;width:100%;text-align:center;color:#fff;font-family:var(--font-display);font-weight:600;font-size:14px;opacity:.85}

/* modal de termos */
.terms-text{max-height:230px;overflow:auto;background:#f7f9fc;border:1px solid #e7edf5;border-radius:10px;padding:14px 16px;margin-bottom:14px}
.terms-text p{font-size:13.5px;color:var(--ink-soft);line-height:1.5;margin-bottom:10px}
.terms-text p:last-child{margin-bottom:0}
.terms-text strong{color:var(--ink)}
.terms-list{padding-left:6px}
.terms-check{display:flex;align-items:flex-start;gap:10px;font-size:13.5px;color:var(--ink);cursor:pointer;font-weight:600}
.terms-check input{margin-top:2px;width:17px;height:17px;flex-shrink:0;accent-color:var(--cal-blue)}

/* barra sticky (mobile) */
.sticky-bar{position:fixed;left:0;right:0;bottom:0;z-index:300;background:var(--d-super);display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 18px;box-shadow:0 -6px 20px rgba(10,20,60,.25)}
.sticky-bar[hidden]{display:none}
.sticky-info{display:flex;flex-direction:column;line-height:1.15;color:#fff}
.sticky-info strong{font-family:var(--font-display);font-weight:700;font-size:18px}
.sticky-info span{font-size:12px;opacity:.85}
.sticky-cart{display:inline-flex;align-items:center;gap:8px;background:var(--grad-pink);color:#fff;font-family:var(--font-display);font-weight:600;font-size:14px;padding:12px 22px;border-radius:999px}

@media (min-width:769px){
  .sticky-bar{display:none!important}
}
@media (max-width:1024px){
  .extras-grid{grid-template-columns:1fr}
}
@media (max-width:768px){
  .extras-bar{top:0}
  .extras-bar-inner{flex-wrap:wrap;gap:10px}
  .extras-title{order:-1;flex-basis:100%;font-size:15px}
  .extras-finish{flex:1}
  .extras-back{flex:1}
  .extras-list{grid-template-columns:1fr}
  .extras-nowant{display:block}
  .ing-foot-bottom{padding-bottom:96px}
}

/* ============================================================
   ETAPA 4 — CHECKOUT (carrinho + comprador + pagamento)
   ============================================================ */
.checkout[hidden],.pixwait[hidden]{display:none}
.checkout-grid{display:grid;grid-template-columns:330px 1fr 360px;gap:24px;align-items:start}
.ck-col{min-width:0}
.ck-card{background:#fff;border-radius:16px;padding:20px;box-shadow:0 12px 28px rgba(10,20,60,.16);position:relative}
.ck-card + .ck-card{margin-top:18px}
.ck-col-title{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:700;color:var(--cal-blue);font-size:18px;padding-bottom:14px;border-bottom:1px solid #eef2f7;margin-bottom:16px}
.ck-col-ic{flex-shrink:0;display:inline-flex;width:32px;height:32px;border-radius:50%;background:var(--d-media);color:#fff;align-items:center;justify-content:center}
.req{color:var(--d-alta)}

/* progresso (mobile) */
.ck-steps{display:none}

/* coluna carrinho */
.ck-back{color:var(--cal-blue);font-family:var(--font-display);font-weight:600;font-size:13px;margin-bottom:8px;display:inline-block}
.ck-back:hover{text-decoration:underline}
.ck-cart-items{display:flex;flex-direction:column;gap:12px}
.ck-coupon{margin-top:16px}
.ck-coupon > label{display:block;font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:13px;margin-bottom:6px}
.ck-coupon-row{display:flex;gap:8px}
.ck-coupon-row input{flex:1;min-width:0;border:1px solid #d7deea;border-radius:10px;padding:11px 12px;font-size:14px;background:#eef2f7;color:var(--ink)}
.ck-coupon-row input:focus{outline:none;border-color:var(--cal-blue);background:#fff}
.ck-coupon-btn{flex-shrink:0;background:linear-gradient(90deg,#2f6fd6,#1e4fb0);color:#fff;border-radius:10px;padding:0 16px;display:inline-flex;align-items:center;gap:6px;font-weight:700}
.ck-cart-foot{margin-top:16px;border-top:1px solid #eef2f7;padding-top:12px}
.ck-cart-count{font-size:12.5px;color:var(--muted);margin-bottom:10px}
.ck-cart-total{display:flex;justify-content:space-between;align-items:center;background:#eef2f7;border-radius:12px;padding:12px 16px;font-family:var(--font-display);font-weight:700;color:var(--cal-blue)}
.ck-cart-total strong{font-size:21px}
.ck-cart-mactions{display:none}

/* coluna comprador */
.ck-form{display:grid;grid-template-columns:1fr 1fr;gap:14px 16px}
.ck-field{display:flex;flex-direction:column;min-width:0}
.ck-field--full{grid-column:1 / -1}
.ck-field label{font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:12.5px;margin-bottom:5px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.ck-field label small{font-weight:600;color:var(--muted);font-size:11px}
.ck-field input,.ck-field select{border:1px solid #d7deea;border-radius:8px;padding:10px 12px;font-size:14px;font-family:var(--font-body);color:var(--ink);background:#f3f6fa;width:100%}
.ck-field input:focus,.ck-field select:focus{outline:none;border-color:var(--cal-blue);background:#fff}
.ck-field input.is-ok{border-color:var(--green);background:#f1fbf3}
.ck-field input.is-bad{border-color:var(--d-alta);background:#fdf1f6}
.ck-err{color:var(--d-alta);font-weight:700;font-size:11px;font-style:italic}
.ck-err[hidden]{display:none}
.ck-promo{flex-direction:row;align-items:center;gap:14px;flex-wrap:wrap}
.ck-promo-label{color:var(--cal-blue);font-family:var(--font-display);font-weight:700;font-size:13px}
.ck-radio{display:inline-flex;align-items:center;gap:5px;font-size:13px;color:var(--ink);cursor:pointer}
.ck-radio input{accent-color:var(--cal-blue)}
.ck-promoter{grid-column:1 / -1;color:var(--cal-blue);font-size:12.5px;font-weight:600;text-decoration:underline}
.ck-form-status{grid-column:1 / -1;font-family:var(--font-display);font-weight:700;font-size:13px;text-align:center;margin:2px 0}
.ck-form-status--bad{color:var(--d-alta)}
.ck-form-status--ok{color:var(--green)}
.ck-confirm{grid-column:1 / -1;display:flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(90deg,#2f6fd6,#1e4fb0);color:#fff;border-radius:12px;padding:14px;font-family:var(--font-display);font-weight:600;font-size:15px;transition:transform .15s ease}
.ck-confirm:disabled{background:#9db8dd;cursor:not-allowed}
.ck-confirm:not(:disabled):hover{transform:translateY(-1px)}
.ck-buyer-note{margin-top:16px;border:1px solid #eef2f7;border-radius:10px;padding:14px}
.ck-buyer-note p{color:var(--ink-soft);font-size:13px;text-align:center;margin:3px 0}
.ck-buyer-note strong{color:var(--ink)}

/* coluna pagamento */
.ck-pay-card.is-locked{min-height:210px}
.ck-pay-body[hidden]{display:none}
.ck-pay-head{font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:14px;margin:2px 0 12px}
.ck-pay-subhead{font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:14px;margin:18px 0 8px}
.ck-method{display:flex;align-items:center;justify-content:center;width:100%;border:2px solid #e1e7f0;border-radius:12px;padding:18px;background:#fff;transition:border-color .15s ease,box-shadow .15s ease}
.ck-method.is-selected{border-color:var(--green);box-shadow:0 0 0 3px rgba(59,181,74,.13)}
.ck-parcelado{display:inline-flex;align-items:center;gap:7px;font-size:13.5px;color:var(--ink);font-weight:600;margin-bottom:12px;cursor:pointer}
.ck-parcelado input{accent-color:var(--cal-blue);width:16px;height:16px}
.ck-brands{display:grid;grid-template-columns:repeat(3,1fr);gap:9px}
.ck-brands.is-disabled{opacity:.4;pointer-events:none;filter:grayscale(.4)}
.ck-brand{border:1.5px solid #e1e7f0;border-radius:10px;padding:11px 4px;background:#fff;display:flex;align-items:center;justify-content:center;overflow:hidden;transition:border-color .15s ease,box-shadow .15s ease}
.ck-brand.is-selected{border-color:var(--green);box-shadow:0 0 0 2px rgba(59,181,74,.16)}

/* sprite de pagamento (recorte de ico-payments.png 600x33, 6 celulas de 100px) */
.pay-sprite{display:block;background-image:url('../images/ico-payments.png');background-repeat:no-repeat;background-size:600px 33px;width:100px;height:33px}
.pay-pix{background-position:0 0}
.pay-visa{background-position:-100px 0}
.pay-master{background-position:-200px 0}
.pay-elo{background-position:-300px 0}
.pay-amex{background-position:-400px 0}
.pay-hipercard{background-position:-500px 0}
.ck-method .pay-pix{width:128px;height:42px;background-size:768px 42px}

.ck-pix-info{margin-top:16px;text-align:center}
.ck-pix-val{font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:14px}
.ck-pix-sub{color:var(--ink-soft);font-size:12.5px;margin-top:3px}
.ck-card-form{background:linear-gradient(160deg,#2a5cc0,#1c3f86);border-radius:12px;padding:16px;margin-top:14px;display:flex;flex-direction:column;gap:12px}
.ck-card-form[hidden]{display:none}
.ck-cf-field label{display:block;color:#fff;font-family:var(--font-display);font-weight:700;font-size:12.5px;margin-bottom:5px}
.ck-cf-field input,.ck-cf-field select{width:100%;border:0;border-radius:8px;padding:11px 12px;font-size:13.5px;background:#eef2f7;color:var(--ink)}
.ck-card-total{color:#fff;font-family:var(--font-display);font-weight:700;font-size:18px;text-align:center;margin-top:2px}

/* compra segura */
.ck-secure{text-align:center}
.ck-secure-title{font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:18px;margin-bottom:14px}
.ck-terms{display:inline-flex;align-items:center;gap:8px;font-size:13.5px;color:var(--ink);font-weight:600;margin-bottom:16px;cursor:pointer}
.ck-terms input{accent-color:var(--cal-blue);width:16px;height:16px;flex-shrink:0}
.ck-secure-btns{display:flex;gap:12px;justify-content:center;margin-bottom:20px}
.ck-secure-btn{border:1.5px solid var(--cal-blue);color:var(--cal-blue);border-radius:999px;padding:9px 18px;font-family:var(--font-display);font-weight:600;font-size:12.5px;transition:background .15s ease}
.ck-secure-btn:hover{background:#eaf3fb}
.ck-rel-title{font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:14.5px;margin-bottom:10px}
.ck-rel{display:flex;align-items:center;justify-content:center;gap:7px;color:var(--cal-blue);font-size:13px;font-weight:600;margin:5px 0}
.ck-pay-warn{color:var(--d-alta);font-weight:700;font-size:12px;margin:16px 0 8px}
.ck-pay-warn[hidden]{display:none}
.ck-finish{width:100%;background:linear-gradient(90deg,#2f6fd6,#1e4fb0);color:#fff;border-radius:12px;padding:15px;font-family:var(--font-display);font-weight:600;font-size:15px;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:8px;transition:transform .15s ease}
.ck-finish:disabled{background:#9db8dd;cursor:not-allowed}
.ck-finish:not(:disabled):hover{transform:translateY(-1px)}

/* ============================================================
   ETAPA 5 — RESULTADO PIX
   ============================================================ */
.pixwait{padding:30px 0 60px}
.pixwait-panel{background:#fff;max-width:760px;margin:0 auto;border-radius:14px;padding:32px 30px 40px;box-shadow:0 18px 50px rgba(8,12,40,.2);text-align:center}
.pw-title{font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:clamp(22px,3vw,30px);line-height:1.15;margin-bottom:6px}
.pw-sub{color:var(--ink-soft);font-size:14px;padding-bottom:16px;border-bottom:1px solid #eef2f7;margin-bottom:14px}
.pw-meta{display:flex;justify-content:center;gap:46px;flex-wrap:wrap;padding-bottom:14px;border-bottom:1px solid #eef2f7;margin-bottom:14px;font-size:14px;color:var(--ink)}
.pw-meta strong{font-family:var(--font-display)}
.pw-items{font-family:var(--font-display);font-weight:600;color:var(--ink);font-size:14px;line-height:1.4;padding-bottom:18px;border-bottom:1px solid #eef2f7;margin-bottom:18px}
.pw-instr{color:var(--ink-soft);font-size:12px;margin-bottom:18px}
.pw-qr{display:flex;justify-content:center;margin-bottom:22px}
.pw-qr img{width:280px;height:280px;max-width:78%;background:#f3f6fa}
.pw-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;max-width:430px;margin:11px auto 0;background:var(--d-media);color:#fff;border-radius:999px;padding:14px;font-family:var(--font-display);font-weight:600;font-size:15px;transition:filter .15s ease}
.pw-btn:hover{filter:brightness(1.08)}

/* ============================================================
   MODAIS adicionais (alert / wait)
   ============================================================ */
.im-alert{max-width:430px;padding:0;overflow:hidden}
.im-alert-title{font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:19px;padding:20px 22px;border-bottom:1px solid #eef2f7;margin:0}
.im-alert-title--red{color:var(--d-alta)}
.im-alert-body{padding:18px 22px;color:var(--ink-soft);font-size:14.5px;line-height:1.5}
.im-alert-body strong{color:var(--ink)}
.im-alert-scroll{max-height:300px;overflow:auto}
.im-alert-scroll p{margin-bottom:12px}
.im-alert-scroll p:last-child{margin-bottom:0}
.im-alert .im-foot{margin-top:0;padding:6px 22px 20px}
.im-foot--split{justify-content:space-between}
.im-btn--grey{background:#e9edf3;color:var(--ink)}
.im-btn--green{background:var(--green);color:#fff}
.im-ok-outline{background:#fff;border:1.5px solid var(--d-alta);color:var(--d-alta)}
.im-wait{display:flex;flex-direction:column;align-items:center;gap:16px;padding:34px;max-width:300px;text-align:center}
.im-spinner{width:46px;height:46px;border-radius:50%;border:4px solid #d7e3f3;border-top-color:var(--cal-blue);animation:imspin .8s linear infinite}
@keyframes imspin{to{transform:rotate(360deg)}}
.im-wait-text{font-family:var(--font-display);font-weight:600;color:var(--ink);font-size:16px}

/* ============================================================
   RESPONSIVO CHECKOUT
   ============================================================ */
@media (max-width:1024px){
  .checkout-grid{grid-template-columns:1fr 1fr;gap:18px}
  .ck-pay-col{grid-column:1 / -1}
}
@media (max-width:768px){
  .checkout-grid{grid-template-columns:1fr;gap:16px}
  .ck-pay-col{grid-column:auto}
  .ck-back{display:none}
  .ck-cart-mactions{display:flex;flex-direction:column;gap:10px;margin-top:16px}
  .ck-cart-more{color:var(--cal-blue);font-family:var(--font-display);font-weight:600;font-size:13.5px;border:1.5px solid #d7deea;border-radius:12px;padding:13px;background:#fff}
  .ck-cart-go{font-size:15px;padding:14px}

  .ck-steps{display:flex;justify-content:space-between;align-items:flex-start;position:relative;margin-bottom:20px;padding:4px 6px 0}
  .ck-steps::before{content:'';position:absolute;top:24px;left:46px;right:46px;height:3px;background:rgba(255,255,255,.4)}
  .ck-step{display:flex;flex-direction:column;align-items:center;gap:8px;width:33%;position:relative;z-index:1}
  .ck-step-ic{width:44px;height:44px;border-radius:50%;background:#0f3f96;color:#fff;display:flex;align-items:center;justify-content:center;border:3px solid rgba(255,255,255,.5)}
  .ck-step.is-active .ck-step-ic{background:#fff;color:var(--cal-blue);border-color:var(--d-selecionado)}
  .ck-step-lb{font-family:var(--font-display);font-weight:600;font-size:10.5px;color:#fff;text-align:center;line-height:1.15}
}
@media (max-width:480px){
  .pixwait-panel{padding:24px 18px 32px}
  .pw-meta{gap:18px}
}
