/* BoraCompetir.com.br — Design System v3 (Mobile First) */
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Inter:wght@300;400;500;600;700&display=swap');

/* =============================================
   VARIÁVEIS
   ============================================= */
:root {
    --primary:#E63946;--primary-dark:#C1121F;--primary-light:#FF6B6B;
    --dark:#0D1117;--dark2:#161B22;--dark3:#21262D;
    --accent:#3A86FF;--green:#2DC653;--yellow:#F4A261;
    --text:#E6EDF3;--text-muted:#8B949E;--border:#30363D;
    --bg:#0D1117;--bg2:#161B22;--bg3:#21262D;--white:#FFFFFF;
    --success:#2DC653;--danger:#F85149;--warning:#E3B341;--info:#3A86FF;
    --radius:10px;--radius-sm:6px;
    --shadow:0 4px 24px rgba(0,0,0,0.4);--shadow-lg:0 12px 48px rgba(0,0,0,0.6);
    --sidebar-w:250px;
    --topbar-h:60px;
}

/* =============================================
   RESET & BASE
   ============================================= */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh;overflow-x:hidden}
h1,h2,h3,h4{font-family:'Bebas Neue',sans-serif;letter-spacing:1px;line-height:1.1}
a{color:var(--primary);text-decoration:none;transition:all .2s}
a:hover{color:var(--primary-light)}
img{max-width:100%;height:auto;display:block}
input,select,textarea,button{font-family:inherit}

/* =============================================
   NAVBAR
   ============================================= */
.navbar{
    background:rgba(13,17,23,.97);
    backdrop-filter:blur(12px);
    border-bottom:1px solid var(--border);
    padding:0 1.25rem;
    position:sticky;top:0;z-index:1000;
}
.navbar-inner{
    max-width:1280px;margin:0 auto;
    display:flex;align-items:center;justify-content:space-between;
    height:60px;
}
.navbar-brand{
    font-family:'Bebas Neue',sans-serif;font-size:1.75rem;
    color:var(--white)!important;letter-spacing:2px;
    display:flex;align-items:center;gap:4px;
    flex-shrink:0;
}
.navbar-brand .dot{color:var(--primary)}
.navbar-nav{display:flex;align-items:center;gap:1.25rem;list-style:none}
.navbar-nav a{color:var(--text-muted);font-size:.88rem;font-weight:500;transition:color .2s;padding:.25rem 0}
.navbar-nav a:hover,.navbar-nav a.active{color:var(--white)}
.btn-nav{background:var(--primary);color:var(--white)!important;padding:6px 16px;border-radius:6px;font-weight:600;font-size:.82rem}
.btn-nav:hover{background:var(--primary-dark)!important}

/* Hamburguer */
.nav-hamburger{
    display:none;flex-direction:column;gap:5px;cursor:pointer;
    background:none;border:none;padding:.4rem;color:var(--text);
}
.nav-hamburger span{
    display:block;width:22px;height:2px;background:currentColor;
    border-radius:2px;transition:all .3s;
}
.nav-hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.nav-hamburger.open span:nth-child(2){opacity:0}
.nav-hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Mobile nav drawer */
.mobile-nav-overlay{
    display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);
    z-index:1100;opacity:0;transition:opacity .3s;
}
.mobile-nav-overlay.open{display:block;opacity:1}
.mobile-nav-drawer{
    position:fixed;top:0;right:-280px;width:280px;height:100%;
    background:var(--dark2);border-left:1px solid var(--border);
    z-index:1200;transition:right .3s;
    display:flex;flex-direction:column;overflow-y:auto;
    padding:1.25rem;
}
.mobile-nav-drawer.open{right:0}
.mobile-nav-close{align-self:flex-end;background:none;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;padding:.25rem}
.mobile-nav-drawer ul{list-style:none;margin-top:1rem;display:flex;flex-direction:column;gap:.25rem}
.mobile-nav-drawer ul a{display:block;padding:.75rem 1rem;color:var(--text);font-weight:500;border-radius:var(--radius-sm);font-size:.95rem}
.mobile-nav-drawer ul a:hover{background:rgba(255,255,255,.06);color:var(--white)}
.mobile-nav-drawer .btn-nav{margin-top:1rem;display:block;text-align:center;padding:.75rem}

/* =============================================
   HERO CAROUSEL
   ============================================= */
.hero{position:relative;overflow:hidden;height:520px;background:var(--dark)}
.carousel-track{display:flex;height:100%;transition:transform .6s cubic-bezier(.25,.46,.45,.94)}
.carousel-slide{min-width:100%;height:100%;position:relative;display:flex;align-items:center}
.slide-bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:brightness(.3)}
.slide-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 0%,rgba(13,17,23,.6) 50%,rgba(13,17,23,.95) 100%)}
.slide-content{position:relative;z-index:2;max-width:1280px;margin:0 auto;padding:0 1.25rem;width:100%}
.slide-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(230,57,70,.15);border:1px solid rgba(230,57,70,.4);color:var(--primary-light);padding:4px 12px;border-radius:100px;font-size:.75rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;margin-bottom:.75rem}
.slide-content h2{font-size:3rem;color:var(--white);margin-bottom:.6rem;line-height:1}
.slide-meta{display:flex;gap:1rem;margin-bottom:1.25rem;flex-wrap:wrap}
.slide-meta span{color:rgba(255,255,255,.7);font-size:.85rem;display:flex;align-items:center;gap:5px}
.slide-content p{color:rgba(255,255,255,.65);max-width:500px;margin-bottom:1.5rem;font-size:.9rem}
.slide-btns{display:flex;gap:.75rem;flex-wrap:wrap}
.carousel-dots{position:absolute;bottom:1.25rem;left:50%;transform:translateX(-50%);display:flex;gap:.4rem;z-index:10}
.dot{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.3);cursor:pointer;border:none;transition:all .3s}
.dot.active{background:var(--primary);width:20px;border-radius:4px}
.c-arrow{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);color:white;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;z-index:10;font-size:1rem}
.c-arrow:hover{background:var(--primary);border-color:var(--primary)}
.c-prev{left:1rem}.c-next{right:1rem}

/* =============================================
   BUTTONS
   ============================================= */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:10px 22px;border-radius:8px;font-family:'Inter',sans-serif;font-weight:600;font-size:.88rem;cursor:pointer;transition:all .2s;border:2px solid transparent;white-space:nowrap;-webkit-tap-highlight-color:transparent}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-dark);color:#fff;transform:translateY(-1px);box-shadow:0 6px 20px rgba(230,57,70,.35)}
.btn-accent{background:var(--accent);color:#fff}
.btn-accent:hover{background:#2563EB;color:#fff}
.btn-success{background:var(--success);color:#fff}
.btn-success:hover{background:#22A846;color:#fff}
.btn-outline{background:transparent;border-color:var(--border);color:var(--text)}
.btn-outline:hover{border-color:var(--primary);color:var(--primary)}
.btn-ghost{background:rgba(255,255,255,.06);color:var(--text);border-color:transparent}
.btn-ghost:hover{background:rgba(255,255,255,.1);color:var(--white)}
.btn-danger{background:var(--danger);color:#fff}
.btn-danger:hover{background:#D94242;color:#fff}
.btn-lg{padding:13px 28px;font-size:.95rem}
.btn-sm{padding:6px 13px;font-size:.78rem}
.btn-xs{padding:4px 9px;font-size:.73rem}
.btn-block{width:100%;justify-content:center}
.btn:disabled,.btn[disabled]{opacity:.5;cursor:not-allowed;transform:none!important}

/* =============================================
   LAYOUT / SECTION
   ============================================= */
.section{padding:3.5rem 1.25rem}
.section-sm{padding:2.5rem 1.25rem}
.container{max-width:1280px;margin:0 auto}
.section-header{margin-bottom:2rem}
.eyebrow{font-family:'Inter',sans-serif;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:2px;font-size:.75rem;margin-bottom:.4rem}
.section-header h2{font-size:2.2rem;color:var(--white)}
.section-header p{color:var(--text-muted);margin-top:.4rem;max-width:600px}

/* =============================================
   CARDS EVENTO
   ============================================= */
.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:all .3s}
.card:hover{border-color:rgba(230,57,70,.3);transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.card-img{height:190px;background:var(--bg3);position:relative;overflow:hidden}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.card:hover .card-img img{transform:scale(1.05)}
.card-tipo{position:absolute;top:.6rem;left:.6rem;background:var(--primary);color:#fff;padding:2px 9px;border-radius:100px;font-size:.7rem;font-weight:700;text-transform:uppercase}
.card-body{padding:1.1rem}
.card-body h3{font-size:1.2rem;color:var(--white);margin-bottom:.4rem}
.card-meta{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.9rem}
.card-meta span{font-size:.82rem;color:var(--text-muted);display:flex;align-items:center;gap:5px}
.card-footer{padding:.9rem 1.1rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--bg3);gap:.75rem}
.card-price{font-family:'Bebas Neue',sans-serif;font-size:1.5rem;color:var(--primary)}
.card-price small{display:block;font-family:'Inter',sans-serif;font-size:.68rem;color:var(--text-muted);font-weight:400}
.eventos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem}

/* =============================================
   EVENTO DETALHE HERO
   ============================================= */
.evento-hero{background:var(--dark2);border-bottom:1px solid var(--border);padding:2.5rem 1.25rem}
.evento-hero-inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1fr auto;gap:2.5rem;align-items:center}
.evento-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(230,57,70,.15);border:1px solid rgba(230,57,70,.3);color:var(--primary-light);padding:3px 12px;border-radius:100px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;margin-bottom:.75rem}
.evento-hero h1{font-size:2.5rem;color:var(--white);margin-bottom:.9rem}
.evento-info-row{display:flex;gap:1.5rem;flex-wrap:wrap;margin-bottom:1.25rem}
.evento-info-item{display:flex;align-items:flex-start;gap:7px;color:var(--text-muted);font-size:.85rem}
.evento-info-item strong{color:var(--text)}

/* =============================================
   MODALIDADES
   ============================================= */
.modalidades-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}
.modalidade-card{background:var(--bg2);border:2px solid var(--border);border-radius:var(--radius);padding:1.25rem;cursor:pointer;transition:all .25s;position:relative}
.modalidade-card:hover,.modalidade-card.selected{border-color:var(--primary);box-shadow:0 0 0 3px rgba(230,57,70,.15)}
.modalidade-card.selected::after{content:'✓';position:absolute;top:.7rem;right:.7rem;background:var(--primary);color:#fff;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem}
.mod-lote{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--primary);background:rgba(230,57,70,.1);padding:2px 7px;border-radius:100px;display:inline-block;margin-bottom:.4rem}
.modalidade-card h3{font-size:1rem;color:var(--white);margin-bottom:.2rem}
.mod-dist{font-size:.82rem;color:var(--text-muted);margin-bottom:.6rem}
.mod-preco{font-family:'Bebas Neue',sans-serif;font-size:1.9rem;color:var(--primary);line-height:1}
.mod-vagas{font-size:.72rem;color:var(--text-muted);margin-top:.3rem}

/* =============================================
   FORMS
   ============================================= */
.form-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1.4rem;margin-bottom:1rem}
.form-card-title{font-size:1rem;color:var(--white);margin-bottom:1.1rem;padding-bottom:.7rem;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:.5rem}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
.form-grid-3{grid-template-columns:1fr 1fr 1fr}
.col-2{grid-column:span 2}
.col-3{grid-column:span 3}
.form-group{display:flex;flex-direction:column;gap:4px}
.form-group label{font-weight:600;font-size:.78rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}
.form-group label .req{color:var(--danger);margin-left:2px}
.form-control{
    border:1.5px solid var(--border);border-radius:8px;
    padding:9px 12px;font-family:'Inter',sans-serif;font-size:.88rem;
    color:var(--text);background:var(--bg3);width:100%;
    transition:border-color .2s,box-shadow .2s;
    -webkit-appearance:none;appearance:none;
}
.form-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(230,57,70,.12);background:var(--bg2)}
.form-control.error{border-color:var(--danger)}
.form-control::placeholder{color:var(--text-muted)}
select.form-control{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%238B949E' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}
textarea.form-control{min-height:80px;resize:vertical}
.form-hint{font-size:.72rem;color:var(--text-muted)}
.form-error{font-size:.72rem;color:var(--danger)}
.form-check{display:flex;align-items:flex-start;gap:10px;padding:.4rem 0}
.form-check input[type=checkbox]{width:17px;height:17px;min-width:17px;accent-color:var(--primary);cursor:pointer;margin-top:2px}
.form-check label{font-size:.85rem;cursor:pointer;line-height:1.5;color:var(--text-muted)}
.form-check label a{color:var(--accent)}

/* =============================================
   PAGAMENTO
   ============================================= */
.pay-tabs{display:flex;gap:.75rem;margin-bottom:1.5rem}
.pay-tab{flex:1;padding:.8rem;border:2px solid var(--border);border-radius:var(--radius);background:var(--bg2);cursor:pointer;text-align:center;transition:all .2s;-webkit-tap-highlight-color:transparent}
.pay-tab:hover,.pay-tab.active{border-color:var(--primary);background:rgba(230,57,70,.06)}
.pay-tab-icon{font-size:1.5rem;margin-bottom:.3rem}
.pay-tab-label{font-weight:700;font-size:.85rem;color:var(--text)}
.pay-tab.active .pay-tab-label{color:var(--primary)}
.pix-box{background:rgba(45,198,83,.08);border:2px solid rgba(45,198,83,.25);border-radius:var(--radius);padding:1.5rem;text-align:center}
.pix-qr{max-width:180px;margin:1rem auto;border:3px solid var(--white);border-radius:8px}
.pix-code{background:var(--bg3);border:1px solid rgba(45,198,83,.2);border-radius:8px;padding:.8rem;font-family:monospace;font-size:.68rem;word-break:break-all;color:var(--text-muted);margin:1rem 0;text-align:left}
.parcelas-row{display:flex;align-items:center;justify-content:space-between;padding:.55rem 0;border-bottom:1px solid var(--border);font-size:.85rem}
.parcelas-row:last-child{border:none}
.parcelas-row.sem-juros .valor{color:var(--success)}
.parcelas-row.com-juros .valor{color:var(--warning)}

/* =============================================
   RESUMO / SIDEBAR
   ============================================= */
.resumo-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.resumo-header{background:var(--bg3);border-bottom:1px solid var(--border);padding:1rem 1.25rem;font-family:'Bebas Neue',sans-serif;font-size:1.05rem;color:var(--white);letter-spacing:.5px}
.resumo-body{padding:1.1rem}
.resumo-row{display:flex;justify-content:space-between;align-items:center;padding:.38rem 0;font-size:.83rem;border-bottom:1px solid rgba(48,54,61,.5)}
.resumo-row:last-child{border:none}
.resumo-total{border-top:2px solid var(--border)!important;padding-top:.8rem!important;margin-top:.4rem}
.resumo-total span{font-family:'Bebas Neue',sans-serif;font-size:1.5rem;color:var(--primary)}

/* =============================================
   STEPS
   ============================================= */
.steps{display:flex;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:1.5rem}
.step{flex:1;padding:.75rem 1rem;display:flex;align-items:center;gap:.5rem;color:var(--text-muted);position:relative}
.step+.step::before{content:'';position:absolute;left:0;top:20%;height:60%;width:1px;background:var(--border)}
.step.active{color:var(--primary)}
.step.done{color:var(--success)}
.step-num{width:26px;height:26px;border-radius:50%;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.78rem;flex-shrink:0;border:1px solid var(--border)}
.step.active .step-num{background:var(--primary);color:#fff;border-color:var(--primary)}
.step.done .step-num{background:var(--success);color:#fff;border-color:var(--success)}
.step-label{font-weight:600;font-size:.82rem}

/* =============================================
   BADGES & ALERTS
   ============================================= */
.badge{display:inline-block;padding:2px 9px;border-radius:100px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.badge-success{background:rgba(45,198,83,.15);color:#2DC653;border:1px solid rgba(45,198,83,.3)}
.badge-warning{background:rgba(227,179,65,.15);color:#E3B341;border:1px solid rgba(227,179,65,.3)}
.badge-danger{background:rgba(248,81,73,.15);color:#F85149;border:1px solid rgba(248,81,73,.3)}
.badge-info{background:rgba(58,134,255,.15);color:#3A86FF;border:1px solid rgba(58,134,255,.3)}
.badge-primary{background:rgba(230,57,70,.15);color:var(--primary);border:1px solid rgba(230,57,70,.3)}
.badge-secondary{background:rgba(139,148,158,.15);color:var(--text-muted);border:1px solid var(--border)}

.alert{padding:.85rem 1rem;border-radius:8px;margin-bottom:1rem;display:flex;align-items:flex-start;gap:.6rem;font-size:.88rem;line-height:1.5}
.alert-success{background:rgba(45,198,83,.1);border:1px solid rgba(45,198,83,.3);color:#2DC653}
.alert-danger{background:rgba(248,81,73,.1);border:1px solid rgba(248,81,73,.3);color:#F85149}
.alert-warning{background:rgba(227,179,65,.1);border:1px solid rgba(227,179,65,.3);color:#E3B341}
.alert-info{background:rgba(58,134,255,.1);border:1px solid rgba(58,134,255,.3);color:#3A86FF}

/* =============================================
   REGULAMENTO BOX
   ============================================= */
.reg-box{background:linear-gradient(135deg,var(--bg2),var(--bg3));border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;display:flex;align-items:center;gap:1.25rem;margin:1.5rem 0}
.reg-icon{font-size:2.2rem;flex-shrink:0}
.reg-box h3{color:var(--white);font-size:1.15rem;margin-bottom:.2rem}
.reg-box p{color:var(--text-muted);font-size:.85rem}

/* =============================================
   SPINNER / LOADING
   ============================================= */
.spinner{display:inline-block;width:18px;height:18px;border:2px solid rgba(255,255,255,.25);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-overlay{position:fixed;inset:0;background:rgba(13,17,23,.85);backdrop-filter:blur(4px);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9999;gap:1rem;color:#fff}
.loading-overlay .spinner{width:36px;height:36px;border-width:3px}

/* =============================================
   TABLES
   ============================================= */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius);border:1px solid var(--border)}
table{width:100%;border-collapse:collapse;min-width:600px}
th,td{padding:.65rem .9rem;text-align:left;border-bottom:1px solid var(--border);font-size:.83rem}
th{font-weight:700;text-transform:uppercase;font-size:.7rem;letter-spacing:.5px;color:var(--text-muted);background:var(--bg3);white-space:nowrap}
tr:last-child td{border:none}
tr:hover td{background:rgba(255,255,255,.02)}
.table-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:1.25rem}
.table-card-header{padding:.9rem 1.1rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border);flex-wrap:wrap;gap:.5rem}
.table-card-header h3{font-size:.95rem;color:var(--white);font-weight:700}

/* =============================================
   INSCRIÇÃO CARD (confirmação)
   ============================================= */
.insc-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:1.25rem}
.insc-card-header{background:var(--bg3);padding:.9rem 1.1rem;display:flex;justify-content:space-between;align-items:flex-start;border-bottom:1px solid var(--border);flex-wrap:wrap;gap:.5rem}
.insc-card-header h3{font-size:1.1rem;color:var(--white)}
.insc-card-body{padding:1.1rem}
.insc-info-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.75rem;margin-bottom:1rem}
.insc-info-item label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);display:block;margin-bottom:2px}
.insc-info-item span{font-weight:600;color:var(--text);font-size:.88rem}

/* =============================================
   ADMIN / PANEL LAYOUT
   ============================================= */
.panel-layout{display:flex;min-height:100vh}

/* Sidebar desktop */
.panel-sidebar{
    width:var(--sidebar-w);flex-shrink:0;
    background:var(--dark2);border-right:1px solid var(--border);
    display:flex;flex-direction:column;
    position:sticky;top:0;height:100vh;overflow-y:auto;
}
.panel-brand{padding:1.1rem 1.25rem;border-bottom:1px solid var(--border);font-family:'Bebas Neue',sans-serif;font-size:1.4rem;color:var(--white);letter-spacing:1px;display:flex;align-items:center;justify-content:space-between}
.panel-brand span{color:var(--primary)}
.panel-nav{padding:.5rem 0;flex:1}
.panel-nav a{display:flex;align-items:center;gap:9px;padding:.6rem 1.25rem;color:var(--text-muted);font-weight:500;font-size:.85rem;transition:all .2s;border-left:3px solid transparent}
.panel-nav a:hover,.panel-nav a.active{color:var(--white);background:rgba(255,255,255,.04);border-left-color:var(--primary)}
.panel-nav .nav-section{padding:.45rem 1.25rem;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-top:.4rem}
.panel-nav .saldo-nav{padding:.75rem 1.25rem;margin-top:auto;border-top:1px solid var(--border)}

.panel-main{flex:1;display:flex;flex-direction:column;min-width:0}
.panel-topbar{
    background:var(--dark2);border-bottom:1px solid var(--border);
    padding:.8rem 1.5rem;display:flex;align-items:center;
    justify-content:space-between;gap:.75rem;flex-wrap:wrap;
    position:sticky;top:0;z-index:100;
}
.panel-topbar h1{font-size:1.35rem;color:var(--white)}
.panel-content{flex:1;padding:1.5rem;overflow-y:auto;background:var(--bg)}

/* Botão menu mobile para painel */
.panel-menu-btn{
    display:none;background:none;border:none;color:var(--text);
    font-size:1.4rem;cursor:pointer;padding:.2rem .4rem;flex-shrink:0;
}

/* Overlay sidebar mobile */
.sidebar-overlay{
    display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);
    z-index:200;
}
.sidebar-overlay.open{display:block}
body.sidebar-open .panel-sidebar{position:fixed;top:0;left:0;height:100%;z-index:300;box-shadow:4px 0 24px rgba(0,0,0,.5)}

/* =============================================
   STATS CARDS
   ============================================= */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}
.stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem}
.stat-card .s-icon{font-size:1.4rem;margin-bottom:.4rem}
.stat-card .s-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}
.stat-card .s-value{font-family:'Bebas Neue',sans-serif;font-size:1.8rem;color:var(--white);margin-top:.1rem}
.stat-card .s-sub{font-size:.72rem;color:var(--text-muted);margin-top:.2rem}

/* =============================================
   SALDO BOX
   ============================================= */
.saldo-box{background:linear-gradient(135deg,rgba(230,57,70,.1),rgba(58,134,255,.08));border:1px solid rgba(230,57,70,.25);border-radius:var(--radius);padding:1.5rem;margin-bottom:1.25rem}
.saldo-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.9rem;margin-top:.9rem}
.saldo-item{text-align:center}
.saldo-item .label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}
.saldo-item .valor{font-family:'Bebas Neue',sans-serif;font-size:1.45rem;color:var(--white);margin-top:.1rem}
.saldo-item .valor.disponivel{color:var(--success)}
.saldo-item .valor.retido{color:var(--warning)}

/* =============================================
   FOOTER
   ============================================= */
.footer{background:var(--dark2);border-top:1px solid var(--border);padding:2.5rem 1.25rem 1.25rem;color:var(--text-muted)}
.footer-inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr;gap:2.5rem;margin-bottom:1.75rem}
.footer-brand{font-family:'Bebas Neue',sans-serif;font-size:1.4rem;color:var(--white);letter-spacing:1px;margin-bottom:.6rem}
.footer-brand span{color:var(--primary)}
.footer h4{font-size:.73rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text);margin-bottom:.75rem}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:.35rem}
.footer ul a{color:var(--text-muted);font-size:.85rem}
.footer ul a:hover{color:var(--primary)}
.footer-bottom{border-top:1px solid var(--border);padding-top:1.1rem;text-align:center;font-size:.78rem;max-width:1280px;margin:0 auto}

/* =============================================
   TEMA CLARO
   ============================================= */
body.light-mode{
    --dark:#F0F4F8;--dark2:#FFFFFF;--dark3:#EDF2F7;
    --bg:#F0F4F8;--bg2:#FFFFFF;--bg3:#EDF2F7;
    --text:#1A202C;--text-muted:#718096;--border:#D1D9E0;--white:#1A202C;
    --shadow:0 2px 12px rgba(0,0,0,0.08);--shadow-lg:0 8px 32px rgba(0,0,0,0.12);
}
body.light-mode .navbar{background:rgba(255,255,255,.97);border-color:#D1D9E0}
body.light-mode .navbar-brand{color:#1A202C!important}
body.light-mode .navbar-nav a{color:#718096}
body.light-mode .navbar-nav a:hover{color:#1A202C}
body.light-mode .slide-bg{filter:brightness(.45)}
body.light-mode .panel-sidebar{background:#1E2A3A;border-color:#2D3748}
body.light-mode .panel-sidebar .panel-brand{color:#fff}
body.light-mode .panel-sidebar .panel-nav a{color:rgba(255,255,255,.65)}
body.light-mode .panel-sidebar .panel-nav a:hover,
body.light-mode .panel-sidebar .panel-nav a.active{color:#fff;background:rgba(255,255,255,.1)}
body.light-mode .panel-sidebar .panel-nav .nav-section{color:rgba(255,255,255,.4)}
body.light-mode .panel-topbar{background:#fff;border-color:#D1D9E0}
body.light-mode .panel-topbar h1{color:#1A202C}
body.light-mode th{background:#EDF2F7;color:#718096}
body.light-mode .footer{background:#1E2A3A;color:#aaa}
body.light-mode .footer-brand,body.light-mode .footer h4{color:#fff}
body.light-mode .mobile-nav-drawer{background:#fff;border-color:#D1D9E0}
body.light-mode select.form-control{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23718096' d='M1 1l5 5 5-5'/%3E%3C/svg%3E")}

/* =============================================
   BOTÃO TEMA (floating)
   ============================================= */
.theme-toggle-btn{
    position:fixed;bottom:1.25rem;right:1.25rem;
    width:46px;height:46px;border-radius:50%;
    background:var(--bg2);border:1.5px solid var(--border);
    color:var(--text);cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    font-size:1.2rem;z-index:9000;
    box-shadow:var(--shadow);transition:all .25s;
}
.theme-toggle-btn:hover{transform:scale(1.1);background:var(--primary);border-color:var(--primary);color:#fff}

/* =============================================
   TABLET  (max 1024px)
   ============================================= */
@media(max-width:1024px){
    .stats-grid{grid-template-columns:repeat(3,1fr)}
    .footer-inner{grid-template-columns:1fr 1fr;gap:2rem}
    .footer-inner > div:first-child{grid-column:span 2}
    .eventos-grid{grid-template-columns:repeat(auto-fill,minmax(270px,1fr))}
}

/* =============================================
   MOBILE  (max 768px)
   ============================================= */
@media(max-width:768px){
    /* NAVBAR */
    .navbar{padding:0 1rem}
    .navbar-nav{display:none}
    .nav-hamburger{display:flex}

    /* HERO */
    .hero{height:380px}
    .slide-overlay{background:linear-gradient(180deg,transparent 0%,rgba(13,17,23,.5) 40%,rgba(13,17,23,.97) 100%)}
    .slide-content{padding:0 1rem}
    .slide-content h2{font-size:1.9rem}
    .slide-meta{gap:.6rem}
    .slide-meta span{font-size:.78rem}
    .slide-content p{display:none}
    .slide-btns .btn:not(.btn-primary){display:none}
    .c-arrow{display:none}

    /* SECTION */
    .section{padding:2.5rem 1rem}
    .section-sm{padding:1.75rem 1rem}
    .section-header h2{font-size:1.8rem}

    /* EVENTS GRID */
    .eventos-grid{grid-template-columns:1fr}

    /* EVENTO DETAIL */
    .evento-hero{padding:1.75rem 1rem}
    .evento-hero-inner{grid-template-columns:1fr;gap:1rem}
    .evento-hero-inner > div:last-child{display:none} /* esconde imagem */
    .evento-hero h1{font-size:1.9rem}
    .evento-info-row{gap:.75rem}
    .evento-info-item{font-size:.8rem}
    .modalidades-grid{grid-template-columns:1fr}

    /* STEPS — compact on mobile */
    .step-label{display:none}
    .step{justify-content:center;padding:.65rem .5rem}

    /* FORMS */
    .form-grid,.form-grid-3{grid-template-columns:1fr}
    .col-2,.col-3{grid-column:span 1}
    .form-card{padding:1.1rem}

    /* PAGAMENTO */
    .pay-tabs{flex-direction:row}
    .pay-tab{padding:.65rem .5rem}
    .pay-tab-icon{font-size:1.2rem}

    /* Resumo sticky off on mobile — fica embaixo */
    .resumo-card{position:static!important}

    /* FOOTER */
    .footer-inner{grid-template-columns:1fr;gap:1.5rem}
    .footer-inner > div:first-child{grid-column:span 1}

    /* STATS */
    .stats-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}
    .stat-card{padding:.9rem}
    .stat-card .s-value{font-size:1.5rem}

    /* SALDO */
    .saldo-box{padding:1.1rem}
    .saldo-grid{grid-template-columns:repeat(2,1fr);gap:.6rem}
    .saldo-item .valor{font-size:1.2rem}

    /* PANEL LAYOUT */
    .panel-sidebar{
        position:fixed;top:0;left:0;height:100%;
        transform:translateX(-100%);
        transition:transform .3s cubic-bezier(.4,0,.2,1);
        z-index:300;width:270px;
    }
    body.sidebar-open .panel-sidebar{transform:translateX(0)}
    .sidebar-overlay{display:none}
    body.sidebar-open .sidebar-overlay{display:block}
    .panel-menu-btn{display:flex;align-items:center}
    .panel-content{padding:1rem}
    .panel-topbar{padding:.75rem 1rem}
    .panel-topbar h1{font-size:1.1rem}

    /* INSC CARD */
    .insc-info-grid{grid-template-columns:1fr 1fr}

    /* THEME BTN — acima do rodapé */
    .theme-toggle-btn{bottom:1rem;right:1rem;width:42px;height:42px;font-size:1.1rem}

    /* TABLES — scroll horizontal */
    table{min-width:500px}
    th,td{padding:.55rem .75rem;font-size:.78rem}

    /* TABLE CARD HEADER */
    .table-card-header{padding:.75rem 1rem}
}

/* =============================================
   SMALL PHONE  (max 480px)
   ============================================= */
@media(max-width:480px){
    .hero{height:320px}
    .slide-content h2{font-size:1.6rem}
    .slide-badge{font-size:.68rem;padding:3px 10px}
    .btn-lg{padding:11px 20px;font-size:.88rem}
    .stats-grid{grid-template-columns:repeat(2,1fr);gap:.5rem}
    .stat-card .s-value{font-size:1.3rem}
    .saldo-grid{grid-template-columns:repeat(2,1fr)}
    .insc-info-grid{grid-template-columns:1fr}
    .pay-tabs{flex-direction:column}
    .form-grid{grid-template-columns:1fr}
    .navbar-brand{font-size:1.5rem}
    .panel-topbar h1{font-size:1rem}
    .card-footer{flex-wrap:wrap}
}

/* =============================================
   TWO-COLUMN LAYOUT (form + sidebar)
   ============================================= */
.layout-form-sidebar{
    display:grid;
    grid-template-columns:1fr 300px;
    gap:1.5rem;
    align-items:start;
}
.layout-form-sidebar-wide{
    display:grid;
    grid-template-columns:1fr 320px;
    gap:1.5rem;
    align-items:start;
}
@media(max-width:900px){
    .layout-form-sidebar,
    .layout-form-sidebar-wide{
        grid-template-columns:1fr;
    }
    /* No mobile, resumo/sidebar vira bloco acima do botão submit */
    .layout-form-sidebar > div:last-child,
    .layout-form-sidebar-wide > div:last-child {
        order:-1; /* Sobe o resumo para antes do form */
    }
}
/* Evento detail — form + resumo lateral */
.layout-evento-form{
    display:grid;
    grid-template-columns:1fr 300px;
    gap:1.5rem;
    align-items:start;
}
@media(max-width:900px){
    .layout-evento-form{grid-template-columns:1fr}
}
