/* =====================================================
   Entrevero do Elias — paleta inspirada no flyer
   rosa #E63946 / amarelo #F6C445 / azul #2E86C1
   ===================================================== */
:root {
    --ee-rosa:    #E63946;
    --ee-rosa-2:  #C92C3A;
    --ee-amarelo: #F6C445;
    --ee-azul:    #2E86C1;
    --ee-azul-2:  #1B5E8B;
    --ee-bege:    #FFF6E0;
    --ee-escuro:  #1F2A37;
    --ee-cinza:   #6c757d;
}

* { -webkit-font-smoothing: antialiased; }

body {
    font-family: 'Fredoka', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
    color: var(--ee-escuro);
    background: #fff;
}

.bg-pattern {
    background:
        radial-gradient(circle at 10% 0%, rgba(246,196,69,.25), transparent 40%),
        radial-gradient(circle at 90% 10%, rgba(46,134,193,.18), transparent 45%),
        #FFFDF6;
}

/* ---------- Navbar ---------- */
.ee-navbar {
    background: linear-gradient(90deg, var(--ee-rosa), var(--ee-rosa-2));
}
.ee-navbar .navbar-brand,
.ee-navbar a { color: #fff !important; }
.ee-navbar .navbar-brand { font-weight: 700; letter-spacing: .2px; }

/* ---------- Stepper ---------- */
.stepper {
    display: flex; align-items: center; justify-content: center;
    gap: 8px; flex-wrap: wrap; padding: 8px 0 4px;
}
.stepper .step { display: flex; align-items: center; gap: 10px; opacity: .55; }
.stepper .step.active { opacity: 1; }
.stepper .step.done .circle { background: var(--ee-azul); border-color: var(--ee-azul); color: #fff; }
.stepper .step.active .circle { background: var(--ee-azul); border-color: var(--ee-azul); color: #fff; }
.stepper .circle {
    width: 34px; height: 34px; border-radius: 50%;
    border: 2px solid var(--ee-cinza); color: var(--ee-cinza);
    display: flex; align-items: center; justify-content: center; font-weight: 700;
    background: #fff;
}
.stepper .label { font-weight: 600; color: var(--ee-escuro); }
.stepper .bar { width: 60px; height: 2px; background: #dee2e6; }
@media (max-width: 600px){
    .stepper .label { display:none; }
    .stepper .bar { width: 28px; }
}

/* ---------- Hero ---------- */
.hero {
    position: relative;
    background: linear-gradient(135deg, var(--ee-rosa) 0%, #D93A4C 55%, var(--ee-rosa-2) 100%);
    color: #fff;
    overflow: hidden;
    border-radius: 0 0 24px 24px;
    padding: 48px 0 72px;
}
.hero::before {
    content:''; position:absolute; inset:0;
    background-image:
        radial-gradient(circle at 15% 20%, rgba(246,196,69,.35), transparent 20%),
        radial-gradient(circle at 85% 10%, rgba(246,196,69,.25), transparent 25%),
        radial-gradient(circle at 5% 90%, rgba(246,196,69,.25), transparent 25%);
    pointer-events:none;
}
.hero .hero-inner { position: relative; z-index: 1; }
.hero .hero-title {
    font-family: 'Caveat', cursive;
    font-weight: 700;
    font-size: clamp(3rem, 9vw, 6.5rem);
    line-height: 1;
    text-shadow: 0 4px 0 rgba(0,0,0,.12);
}
.hero .hero-kicker { font-weight: 700; letter-spacing: 2px; text-transform: uppercase; opacity:.9;}
.hero .hero-date {
    display: inline-flex; align-items: center; gap: 10px;
    background: var(--ee-amarelo); color: var(--ee-escuro);
    padding: 8px 18px; border-radius: 999px; font-weight: 700;
    box-shadow: 0 6px 0 rgba(0,0,0,.08);
}
.hero .hero-meta { font-size: 1.1rem; }
.hero .hero-meta i { color: var(--ee-amarelo); }

.hero-img {
    max-width: 100%; height: auto;
    filter: drop-shadow(0 10px 15px rgba(0,0,0,.25));
}

/* ---------- Cards de ingresso ---------- */
.card-ingresso {
    border: 1px solid #eee;
    border-radius: 14px;
    transition: transform .15s ease, box-shadow .15s ease;
}
.card-ingresso:hover { transform: translateY(-2px); box-shadow: 0 8px 20px rgba(0,0,0,.06); }
.card-ingresso .preco { color: var(--ee-rosa); font-weight: 700; font-size: 1.35rem; }
.card-ingresso .preco .old { color: var(--ee-cinza); font-size: .85rem; font-weight: 400; }
.card-ingresso .badge-gratis {
    background: var(--ee-amarelo); color: var(--ee-escuro); font-weight: 700;
}

/* quantidade (- / +) */
.qty-group { display: flex; align-items: center; gap: 6px; }
.qty-group .btn-qty {
    width: 40px; height: 40px; border-radius: 50%;
    border: 2px solid var(--ee-rosa); color: var(--ee-rosa);
    background: #fff; font-weight: 700; font-size: 1.1rem;
    display:inline-flex; align-items:center; justify-content:center;
    transition: all .15s;
}
.qty-group .btn-qty:hover { background: var(--ee-rosa); color:#fff; }
.qty-group .qty-display {
    min-width: 42px; text-align: center; font-weight: 700; font-size: 1.1rem;
}

/* ---------- Caixa de total ---------- */
.total-box {
    background: #5d6a7a;
    color: #fff;
    padding: 22px 28px;
    border-radius: 0 0 14px 14px;
}
.total-box .valor { font-size: 1.8rem; font-weight: 700; }

.panel {
    background: #fff; border: 1px solid #eee; border-radius: 14px;
    padding: 20px; margin-bottom: 18px;
    box-shadow: 0 2px 0 rgba(0,0,0,.02);
}
.panel h5 { margin: 0 0 14px; font-weight: 700; }

.panel-head-item {
    background: var(--ee-azul); color: #fff;
    padding: 10px 16px; border-radius: 12px 12px 0 0; font-weight: 600;
}
.panel-body-item { background:#fff; border: 1px solid #e9ecef; border-top: 0; border-radius: 0 0 12px 12px; padding: 20px; margin-bottom: 16px; }

.timer-pill {
    display: inline-flex; align-items: center; gap: 6px;
    background: var(--ee-amarelo); color: var(--ee-escuro);
    padding: 6px 14px; border-radius: 999px; font-weight: 700;
}

.btn-primary-ee {
    background: #16a34a; border:0; color:#fff; font-weight: 700;
    padding: 12px 18px; border-radius: 10px; letter-spacing: .3px;
}
.btn-primary-ee:hover { background: #128a3b; color: #fff; }

.btn-rosa {
    background: var(--ee-rosa); color: #fff; border:0; font-weight: 700;
    padding: 10px 18px; border-radius: 10px;
}
.btn-rosa:hover { background: var(--ee-rosa-2); color:#fff; }

/* Forms */
.form-control:focus, .form-select:focus {
    border-color: var(--ee-rosa);
    box-shadow: 0 0 0 .2rem rgba(230,57,70,.18);
}
.form-label { font-weight: 600; }

/* Footer */
.ee-footer {
    background: linear-gradient(180deg, var(--ee-azul-2), #12415f);
    color: #fff;
}

/* Utilitários */
.text-rosa   { color: var(--ee-rosa) !important; }
.bg-rosa     { background: var(--ee-rosa) !important; color:#fff !important; }
.text-amarelo{ color: var(--ee-amarelo) !important; }

.beneficio-pill {
    display: inline-flex; align-items: center; gap: 8px;
    background: rgba(255,255,255,.15); color:#fff;
    padding: 6px 14px; border-radius: 999px; font-weight: 600;
    font-size:.95rem;
}

hr.dashed { border: 0; border-top: 1px dashed #dee2e6; }

/* Skeleton p/ feedback quando consulta CPF */
.cpf-loading { color: var(--ee-azul); font-weight: 600; }
