/* -------------------------------------------
   TOKENS & RESET
------------------------------------------- */
:root{
  --brand:#4F46E5;--brand-d:#3730A3;--brand-l:#EEF2FF;--brand-m:#C7D2FE;
  --ink:#0F172A;--ink2:#334155;--ink3:#64748B;--ink4:#94A3B8;
  --surface:#FFFFFF;--bg:#F8FAFC;--bg2:#F1F5F9;
  --border:#E2E8F0;--border2:#CBD5E1;
  --green:#10B981;--green-l:#D1FAE5;
  --red:#EF4444;--red-l:#FEE2E2;
  --amber:#F59E0B;--amber-l:#FEF3C7;
  --radius:12px;--radius-lg:18px;--radius-xl:24px;
  --shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.04);
  --shadow-md:0 4px 16px rgba(0,0,0,.08);
  --shadow-lg:0 12px 40px rgba(0,0,0,.12);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Plus Jakarta Sans',sans-serif;background:var(--bg);color:var(--ink);min-height:100vh;line-height:1.5}
button{cursor:pointer;font-family:inherit;border:none}
input,select,textarea{font-family:inherit}
a{text-decoration:none;color:inherit}
img{max-width:100%}

/* -------------------------------------------
   UTILS
------------------------------------------- */
.hidden{display:none!important}
.page{display:none}
.page.active{display:block}
.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}.w-full{width:100%}.text-center{text-align:center}

/* -------------------------------------------
   NAVBAR � estilo Sympla com top-bar + main-nav
------------------------------------------- */
#topbar{background:var(--brand-d);padding:.35rem 0;text-align:center;font-size:.78rem;color:var(--brand-m);letter-spacing:.3px}
#topbar b{color:#fff}
#navbar{background:#fff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;box-shadow:var(--shadow)}
.nav-inner{max-width:1200px;margin:0 auto;padding:0 1.5rem;height:64px;display:flex;align-items:center;gap:1.5rem}
.nav-logo{font-family:'Syne',sans-serif;font-size:1.5rem;font-weight:800;color:var(--brand);cursor:pointer;flex-shrink:0;letter-spacing:-1px}
.nav-logo span{color:var(--ink)}
.nav-search{flex:1;max-width:440px;position:relative}
.nav-search input{width:100%;border:1.5px solid var(--border);border-radius:30px;padding:.55rem 1rem .55rem 2.8rem;font-size:.9rem;color:var(--ink);outline:none;background:var(--bg);transition:border-color .2s}
.nav-search input:focus{border-color:var(--brand);background:#fff}
.nav-search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--ink4);font-size:1rem;pointer-events:none}
.nav-links{display:flex;align-items:center;gap:.25rem;margin-left:auto}
.nav-link{padding:.5rem .9rem;border-radius:8px;font-size:.875rem;font-weight:600;color:var(--ink2);transition:all .15s;white-space:nowrap;background:none}
.nav-link:hover{background:var(--bg2);color:var(--ink)}
.nav-link.active{color:var(--brand)}
.nav-sep{width:1px;height:24px;background:var(--border);flex-shrink:0}
.btn-login{border:1.5px solid var(--border2);color:var(--ink2);background:#fff;padding:.5rem 1.1rem;border-radius:8px;font-size:.875rem;font-weight:600;transition:all .15s}
.btn-login:hover{border-color:var(--brand);color:var(--brand)}
.btn-signup{background:var(--brand);color:#fff;padding:.5rem 1.2rem;border-radius:8px;font-size:.875rem;font-weight:700;transition:background .15s}
.btn-signup:hover{background:var(--brand-d)}
.nav-user-area{display:flex;align-items:center;gap:.75rem}
.nav-avatar{width:36px;height:36px;border-radius:50%;background:var(--brand);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.9rem;cursor:pointer;flex-shrink:0}
.nav-dropdown{position:relative}
.nav-dropdown-menu{position:absolute;right:0;top:calc(100% + 8px);background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:220px;padding:.5rem;z-index:200}
.nav-dropdown-menu a,.nav-dropdown-menu button{display:flex;align-items:center;gap:.6rem;padding:.65rem .9rem;border-radius:8px;font-size:.875rem;font-weight:500;color:var(--ink2);width:100%;background:none;text-align:left;transition:background .15s}
.nav-dropdown-menu a:hover,.nav-dropdown-menu button:hover{background:var(--bg2);color:var(--ink)}
.nav-dropdown-menu hr{border:none;border-top:1px solid var(--border);margin:.35rem 0}
.nav-dropdown-menu .danger{color:var(--red)}
.nav-dropdown-menu .danger:hover{background:var(--red-l)}

/* -------------------------------------------
   SUBNAVBAR (comprador logado) � igual ao Sympla
------------------------------------------- */
#subnav{background:#fff;border-bottom:1px solid var(--border)}
.subnav-inner{max-width:1200px;margin:0 auto;padding:0 1.5rem;display:flex;gap:0}
.subnav-link{padding:.75rem 1.1rem;font-size:.875rem;font-weight:600;color:var(--ink3);border-bottom:2.5px solid transparent;transition:all .15s;cursor:pointer;white-space:nowrap;background:none}
.subnav-link:hover{color:var(--ink)}
.subnav-link.active{color:var(--brand);border-bottom-color:var(--brand)}

/* -------------------------------------------
   BOT�ES GERAIS
------------------------------------------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border-radius:10px;font-weight:700;font-size:.9rem;transition:all .18s;cursor:pointer;border:none;padding:.7rem 1.4rem}
.btn-primary{background:var(--brand);color:#fff}.btn-primary:hover{background:var(--brand-d)}
.btn-secondary{background:var(--brand-l);color:var(--brand)}.btn-secondary:hover{background:var(--brand-m)}
.btn-outline{background:#fff;border:1.5px solid var(--border2);color:var(--ink2)}.btn-outline:hover{border-color:var(--brand);color:var(--brand)}
.btn-success{background:var(--green);color:#fff}.btn-success:hover{opacity:.9}
.btn-ghost{background:transparent;color:var(--ink3);border:1.5px solid var(--border)}.btn-ghost:hover{background:var(--bg2)}
.btn-danger{background:var(--red);color:#fff}.btn-danger:hover{opacity:.9}
.btn-lg{padding:.875rem 2rem;font-size:1rem;border-radius:12px}
.btn-sm{padding:.4rem .9rem;font-size:.8rem;border-radius:8px}
.btn-icon{width:36px;height:36px;padding:0;border-radius:8px}

/* -------------------------------------------
   FORMS
------------------------------------------- */
.form-group{margin-bottom:1rem}
.form-label{display:block;font-size:.82rem;font-weight:700;color:var(--ink2);margin-bottom:.4rem;letter-spacing:.2px}
.form-label span{color:var(--red);margin-left:2px}
.form-control{width:100%;border:1.5px solid var(--border);border-radius:10px;padding:.7rem 1rem;font-size:.9rem;color:var(--ink);outline:none;transition:border-color .2s;background:#fff}
.form-control:focus{border-color:var(--brand)}
.form-control.error{border-color:var(--red)}
.form-hint{font-size:.76rem;color:var(--ink4);margin-top:.3rem}
.form-error{font-size:.76rem;color:var(--red);margin-top:.3rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
textarea.form-control{resize:vertical;min-height:100px}

/* -------------------------------------------
   ALERTS
------------------------------------------- */
.alert{border-radius:10px;padding:.85rem 1.1rem;font-size:.875rem;font-weight:500;display:flex;align-items:flex-start;gap:.6rem;margin-bottom:1rem}
.alert-success{background:var(--green-l);color:#065F46}
.alert-error{background:var(--red-l);color:#991B1B}
.alert-info{background:var(--brand-l);color:var(--brand-d)}
.alert-warning{background:var(--amber-l);color:#92400E}

/* -------------------------------------------
   MODAL
------------------------------------------- */
.overlay{position:fixed;inset:0;background:rgba(15,23,42,.5);z-index:300;display:flex;align-items:center;justify-content:center;padding:1rem;backdrop-filter:blur(2px)}
.modal{background:#fff;border-radius:var(--radius-xl);width:100%;max-width:480px;max-height:92vh;overflow-y:auto;position:relative;box-shadow:var(--shadow-lg)}
.modal-header{padding:1.5rem 1.5rem 0;display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}
.modal-title{font-size:1.2rem;font-weight:800;color:var(--ink)}
.modal-body{padding:0 1.5rem 1.5rem}
.modal-close{width:32px;height:32px;border-radius:50%;background:var(--bg2);border:none;display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--ink3);cursor:pointer;flex-shrink:0}
.modal-close:hover{background:var(--border)}

/* TABS */
.tabs-pill{display:flex;background:var(--bg2);border-radius:10px;padding:4px;margin-bottom:1.25rem}
.tab-pill{flex:1;padding:.55rem;border-radius:7px;border:none;background:transparent;font-weight:700;font-size:.875rem;color:var(--ink3);cursor:pointer;transition:all .18s}
.tab-pill.active{background:#fff;color:var(--brand);box-shadow:var(--shadow)}

/* -------------------------------------------
   HOME PAGE � HERO
------------------------------------------- */
.hero{background:linear-gradient(135deg,#1e1b4b 0%,#312e81 50%,#4338ca 100%);padding:5rem 1.5rem 4rem;text-align:center;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}
.hero-inner{max-width:700px;margin:0 auto;position:relative}
.hero-badge{display:inline-flex;align-items:center;gap:.4rem;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:30px;padding:.35rem 1rem;font-size:.8rem;font-weight:600;color:rgba(255,255,255,.9);margin-bottom:1.5rem}
.hero h1{font-family:'Syne',sans-serif;font-size:clamp(2.2rem,5vw,3.5rem);font-weight:800;color:#fff;line-height:1.1;margin-bottom:1rem;letter-spacing:-1px}
.hero h1 em{font-style:normal;color:#A5B4FC}
.hero p{font-size:1.1rem;color:rgba(255,255,255,.75);max-width:500px;margin:0 auto 2rem}
.hero-search-bar{background:#fff;border-radius:var(--radius-xl);display:flex;overflow:hidden;max-width:600px;margin:0 auto;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.hero-search-bar input{flex:1;border:none;outline:none;padding:1rem 1.25rem;font-size:.95rem;color:var(--ink)}
.hero-search-bar select{border:none;border-left:1px solid var(--border);outline:none;padding:.75rem 1rem;font-size:.875rem;color:var(--ink2);background:#fff;min-width:120px}
.hero-search-bar button{background:var(--brand);color:#fff;border:none;padding:0 1.5rem;font-weight:700;font-size:.9rem;cursor:pointer;transition:background .15s;white-space:nowrap}
.hero-search-bar button:hover{background:var(--brand-d)}
.hero-stats{display:flex;justify-content:center;gap:2.5rem;margin-top:2.5rem}
.hero-stat{text-align:center}
.hero-stat-num{font-family:'Syne',sans-serif;font-size:1.6rem;font-weight:800;color:#fff}
.hero-stat-label{font-size:.78rem;color:rgba(255,255,255,.6)}

/* CATEGORIES */
.categories{background:#fff;border-bottom:1px solid var(--border);padding:.5rem 0;overflow-x:auto}
.categories-inner{max-width:1200px;margin:0 auto;padding:0 1.5rem;display:flex;gap:.5rem;min-width:max-content}
.cat-chip{display:flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border-radius:30px;border:1.5px solid var(--border);font-size:.82rem;font-weight:600;color:var(--ink2);cursor:pointer;transition:all .15s;white-space:nowrap;background:#fff}
.cat-chip:hover,.cat-chip.active{border-color:var(--brand);color:var(--brand);background:var(--brand-l)}

/* EVENTS SECTION */
.events-section{max-width:1200px;margin:0 auto;padding:2.5rem 1.5rem}
.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}
.section-title{font-family:'Syne',sans-serif;font-size:1.4rem;font-weight:800;color:var(--ink)}
.section-link{font-size:.875rem;font-weight:600;color:var(--brand)}

/* EVENT CARDS � estilo Sympla */
.events-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:1.25rem}
.ev-card{background:#fff;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);transition:transform .2s,box-shadow .2s;cursor:pointer}
.ev-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.ev-card-img{height:170px;position:relative;overflow:hidden}
.ev-card-img-bg{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:4rem}
.ev-card-img-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.4) 0%,transparent 60%)}
.ev-card-date-badge{position:absolute;top:.75rem;left:.75rem;background:rgba(0,0,0,.6);backdrop-filter:blur(8px);color:#fff;border-radius:8px;padding:.3rem .65rem;font-size:.75rem;font-weight:700}
.ev-card-status{position:absolute;top:.75rem;right:.75rem;border-radius:20px;padding:.25rem .65rem;font-size:.72rem;font-weight:700}
.ev-card-status.sold-out{background:var(--red);color:#fff}
.ev-card-status.few-left{background:var(--amber);color:#fff}
.ev-card-status.free{background:var(--green);color:#fff}
.ev-card-body{padding:1.1rem}
.ev-card-title{font-weight:800;font-size:.95rem;color:var(--ink);margin-bottom:.4rem;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ev-card-meta{font-size:.8rem;color:var(--ink3);margin-bottom:.25rem;display:flex;align-items:center;gap:.35rem}
.ev-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:.9rem;padding-top:.9rem;border-top:1px solid var(--border)}
.ev-card-price{font-size:1rem;font-weight:800;color:var(--ink)}
.ev-card-price.free{color:var(--green)}
.ev-card-org{font-size:.75rem;color:var(--ink4)}

/* -------------------------------------------
   DETALHE DO EVENTO
------------------------------------------- */
.ev-detail-hero{position:relative;background:#1e1b4b;height:300px;display:flex;align-items:flex-end}
.ev-detail-hero-bg{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:8rem;opacity:.15}
.ev-detail-hero-gradient{position:absolute;inset:0;background:linear-gradient(to top,rgba(15,23,42,.95) 0%,rgba(15,23,42,.4) 100%)}
.ev-detail-hero-content{position:relative;max-width:1200px;margin:0 auto;padding:0 1.5rem 2rem;width:100%}
.ev-detail-hero-tag{background:rgba(255,255,255,.15);border-radius:20px;padding:.25rem .75rem;font-size:.75rem;font-weight:700;color:rgba(255,255,255,.9);display:inline-block;margin-bottom:.75rem}
.ev-detail-hero-title{font-family:'Syne',sans-serif;font-size:clamp(1.5rem,4vw,2.5rem);font-weight:800;color:#fff;line-height:1.1}
.ev-detail-body{max-width:1200px;margin:0 auto;padding:2rem 1.5rem;display:grid;grid-template-columns:1fr 360px;gap:2rem;align-items:start}
@media(max-width:900px){.ev-detail-body{grid-template-columns:1fr}}
.ev-detail-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border);padding:1.5rem;margin-bottom:1.25rem}
.ev-detail-card h3{font-size:1rem;font-weight:800;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}
.ev-detail-meta-item{display:flex;gap:.75rem;margin-bottom:.9rem;align-items:flex-start}
.ev-detail-meta-icon{width:38px;height:38px;background:var(--brand-l);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.ev-detail-meta-label{font-size:.75rem;color:var(--ink4);margin-bottom:.1rem}
.ev-detail-meta-value{font-size:.9rem;font-weight:600;color:var(--ink)}

/* TICKET TYPES */
.ticket-type-item{border:1.5px solid var(--border);border-radius:12px;padding:1rem;margin-bottom:.75rem;transition:border-color .18s}
.ticket-type-item:hover{border-color:var(--brand-m)}
.ticket-type-name{font-weight:700;font-size:.95rem}
.ticket-type-desc{font-size:.8rem;color:var(--ink3);margin-top:.15rem}
.ticket-type-price{font-size:1.15rem;font-weight:800;color:var(--brand)}
.ticket-type-price.free{color:var(--green)}
.qty-control{display:flex;align-items:center;gap:.5rem}
.qty-btn{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--brand);background:#fff;color:var(--brand);font-size:1.1rem;font-weight:700;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}
.qty-btn:hover{background:var(--brand);color:#fff}
.qty-num{font-weight:800;font-size:1rem;min-width:24px;text-align:center}
.ticket-box-total{background:var(--bg2);border-radius:10px;padding:1rem;margin-top:1rem}
.total-line{display:flex;justify-content:space-between;font-size:.875rem;margin-bottom:.35rem;color:var(--ink2)}
.total-line.big{font-size:1.1rem;font-weight:800;color:var(--ink);margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--border)}

/* -------------------------------------------
   CHECKOUT � estilo Sympla 3 passos
------------------------------------------- */
.checkout-wrap{max-width:820px;margin:0 auto;padding:2rem 1.5rem}
.checkout-progress{display:flex;align-items:center;margin-bottom:2rem}
.cp-step{display:flex;align-items:center;gap:.5rem;flex:1}
.cp-circle{width:32px;height:32px;border-radius:50%;border:2px solid var(--border);background:#fff;display:flex;align-items:center;justify-content:center;font-size:.82rem;font-weight:800;color:var(--ink4);flex-shrink:0}
.cp-step.done .cp-circle{background:var(--green);border-color:var(--green);color:#fff}
.cp-step.active .cp-circle{background:var(--brand);border-color:var(--brand);color:#fff}
.cp-label{font-size:.82rem;font-weight:600;color:var(--ink4)}
.cp-step.active .cp-label,.cp-step.done .cp-label{color:var(--ink2)}
.cp-line{flex:1;height:2px;background:var(--border);margin:0 .5rem}
.cp-step.done+.cp-step .cp-line,.cp-step.done .cp-line{background:var(--green)}
.checkout-grid{display:grid;grid-template-columns:1fr 320px;gap:1.5rem;align-items:start}
@media(max-width:720px){.checkout-grid{grid-template-columns:1fr}}
.checkout-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border);padding:1.5rem;margin-bottom:1.25rem}
.checkout-card-title{font-size:1rem;font-weight:800;margin-bottom:1.25rem;display:flex;align-items:center;gap:.5rem}
.order-mini-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border);padding:1.25rem;position:sticky;top:80px}
.order-mini-title{font-weight:800;font-size:.9rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}
.order-mini-item{display:flex;justify-content:space-between;font-size:.85rem;margin-bottom:.4rem;color:var(--ink2)}
.order-mini-total{display:flex;justify-content:space-between;font-size:1rem;font-weight:800;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border)}

/* M�TODOS DE PAGAMENTO */
.pay-methods{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1.25rem}
.pay-method{border:2px solid var(--border);border-radius:12px;padding:1rem .75rem;text-align:center;cursor:pointer;transition:all .18s}
.pay-method:hover{border-color:var(--brand-m)}
.pay-method.selected{border-color:var(--brand);background:var(--brand-l)}
.pay-method-icon{font-size:1.6rem;margin-bottom:.4rem}
.pay-method-name{font-size:.78rem;font-weight:700;color:var(--ink3)}
.pay-method.selected .pay-method-name{color:var(--brand)}

/* PIX */
.pix-box{background:linear-gradient(135deg,#ECFDF5,#D1FAE5);border:1.5px solid var(--green);border-radius:14px;padding:1.5rem;text-align:center}
.pix-qr-area{width:180px;height:180px;background:#fff;border-radius:10px;margin:.75rem auto;display:flex;align-items:center;justify-content:center;border:2px solid var(--border);font-size:4rem}
.pix-code-area{background:#fff;border:1px solid var(--border);border-radius:8px;padding:.7rem 1rem;font-family:monospace;font-size:.8rem;word-break:break-all;color:var(--ink);text-align:left;margin:.75rem 0}

/* BOLETO */
.boleto-box{background:var(--amber-l);border:1.5px solid var(--amber);border-radius:14px;padding:1.5rem}

/* CART�O */
.card-brands{display:flex;gap:.4rem;margin-bottom:.75rem}
.card-brand{background:var(--bg2);border-radius:6px;padding:.25rem .6rem;font-size:.72rem;font-weight:700;color:var(--ink3)}

/* -------------------------------------------
   INGRESSO / QR CODE � estilo Sympla
------------------------------------------- */
.ticket-page-wrap{max-width:500px;margin:0 auto;padding:2rem 1.5rem}
.ticket-success-banner{background:linear-gradient(135deg,var(--green),#059669);border-radius:var(--radius-lg);padding:1.5rem;text-align:center;color:#fff;margin-bottom:1.5rem}
.ticket-success-banner h2{font-size:1.3rem;font-weight:800;margin:.5rem 0 .25rem}
.ticket-success-banner p{font-size:.875rem;opacity:.9}
.ticket-card{background:#fff;border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-lg);border:1px solid var(--border)}
.ticket-card-top{background:linear-gradient(135deg,#312e81,var(--brand));padding:1.5rem;text-align:center;color:#fff}
.ticket-card-top .emoji{font-size:2.5rem;margin-bottom:.5rem;display:block}
.ticket-card-top h2{font-size:1.1rem;font-weight:800;margin-bottom:.2rem}
.ticket-card-top p{font-size:.82rem;opacity:.8}
.ticket-perforation{display:flex;align-items:center;padding:0 0}
.ticket-circle{width:22px;height:22px;border-radius:50%;background:var(--bg);flex-shrink:0}
.ticket-dashes{flex:1;border-top:2px dashed var(--border)}
.ticket-card-body{padding:1.5rem;text-align:center}
#tk-qr{display:flex;justify-content:center;margin:1rem 0}
#tk-qr canvas,#tk-qr img{border-radius:10px!important;box-shadow:var(--shadow-md)}
.ticket-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-top:1rem;text-align:left}
.ticket-info-item label{font-size:.7rem;font-weight:700;color:var(--ink4);text-transform:uppercase;letter-spacing:.5px}
.ticket-info-item p{font-size:.875rem;font-weight:700;color:var(--ink);margin-top:.15rem}
.ticket-id-code{font-size:.72rem;color:var(--ink4);font-family:monospace;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border)}

/* -------------------------------------------
   MEUS PEDIDOS � estilo Sympla
------------------------------------------- */
.user-area-wrap{max-width:1000px;margin:0 auto;padding:2rem 1.5rem}
.user-area-title{font-family:'Syne',sans-serif;font-size:1.6rem;font-weight:800;margin-bottom:.35rem}
.user-area-sub{color:var(--ink3);font-size:.9rem;margin-bottom:2rem}
.orders-list{display:flex;flex-direction:column;gap:1rem}
.order-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border);padding:1.25rem;display:grid;grid-template-columns:auto 1fr auto;gap:1rem;align-items:center;transition:box-shadow .2s;cursor:pointer}
.order-card:hover{box-shadow:var(--shadow-md)}
.order-card-emoji{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:2rem;flex-shrink:0}
.order-card-info h3{font-weight:800;font-size:.95rem;margin-bottom:.2rem}
.order-card-info p{font-size:.82rem;color:var(--ink3)}
.order-card-right{text-align:right;flex-shrink:0}
.order-card-status{display:inline-flex;align-items:center;gap:.3rem;padding:.3rem .75rem;border-radius:20px;font-size:.75rem;font-weight:700;margin-bottom:.4rem}
.status-confirmed{background:var(--green-l);color:#065F46}
.status-pending{background:var(--amber-l);color:#92400E}
.status-cancelled{background:var(--red-l);color:#991B1B}
.order-card-value{font-size:.9rem;font-weight:700;color:var(--ink)}

/* -------------------------------------------
   PAINEL ORGANIZADOR � estilo Sympla
------------------------------------------- */
#page-org{background:var(--bg)}
.org-layout{display:flex;min-height:calc(100vh - 64px)}
.org-sidebar{width:240px;background:#fff;border-right:1px solid var(--border);padding:1.5rem 0;flex-shrink:0;position:sticky;top:64px;height:calc(100vh - 64px);overflow-y:auto}
.org-sidebar-section{margin-bottom:1.5rem}
.org-sidebar-label{font-size:.7rem;font-weight:800;color:var(--ink4);text-transform:uppercase;letter-spacing:1px;padding:0 1.25rem;margin-bottom:.4rem}
.org-sidebar-item{display:flex;align-items:center;gap:.6rem;padding:.6rem 1.25rem;font-size:.875rem;font-weight:600;color:var(--ink2);cursor:pointer;transition:all .15s;border-left:3px solid transparent}
.org-sidebar-item:hover{background:var(--bg2);color:var(--ink)}
.org-sidebar-item.active{background:var(--brand-l);color:var(--brand);border-left-color:var(--brand)}
.org-sidebar-icon{width:18px;text-align:center;font-size:1rem}
.org-main{flex:1;padding:2rem;overflow-y:auto}
.org-page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.75rem}
.org-page-title{font-family:'Syne',sans-serif;font-size:1.4rem;font-weight:800}

/* STATS */
.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(175px,1fr));gap:1rem;margin-bottom:1.75rem}
.stat-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border);padding:1.25rem}
.stat-card-label{font-size:.78rem;font-weight:600;color:var(--ink3);margin-bottom:.4rem}
.stat-card-value{font-size:1.75rem;font-weight:800;color:var(--ink)}
.stat-card-trend{font-size:.75rem;color:var(--green);margin-top:.2rem;font-weight:600}
.stat-card.indigo .stat-card-value{color:var(--brand)}
.stat-card.green .stat-card-value{color:var(--green)}
.stat-card.amber .stat-card-value{color:var(--amber)}

/* TABLE */
.table-wrap{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border);overflow:auto}
.table-header{padding:1.1rem 1.5rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;gap:1rem}
.table-title{font-size:.95rem;font-weight:800}
table{width:100%;min-width:760px;border-collapse:collapse}
thead th{padding:.75rem 1.25rem;text-align:left;font-size:.75rem;font-weight:800;color:var(--ink3);text-transform:uppercase;letter-spacing:.5px;background:var(--bg);border-bottom:1px solid var(--border)}
tbody td{padding:.9rem 1.25rem;border-bottom:1px solid var(--border);font-size:.875rem;color:var(--ink)}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover td{background:var(--bg2)}
.badge{display:inline-flex;align-items:center;padding:.25rem .65rem;border-radius:20px;font-size:.72rem;font-weight:700}
.badge-green{background:var(--green-l);color:#065F46}
.badge-red{background:var(--red-l);color:#991B1B}
.badge-amber{background:var(--amber-l);color:#92400E}
.badge-indigo{background:var(--brand-l);color:var(--brand-d)}
.badge-gray{background:var(--bg2);color:var(--ink2)}

/* CRIAR EVENTO */
.create-event-wrap{max-width:800px}
.section-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border);padding:1.5rem;margin-bottom:1.25rem}
.section-card-title{font-size:.95rem;font-weight:800;color:var(--ink);margin-bottom:1.25rem;display:flex;align-items:center;gap:.5rem}
.emoji-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:.4rem;margin-top:.5rem}
.emoji-opt{font-size:1.4rem;padding:.45rem;border-radius:8px;border:2px solid transparent;cursor:pointer;text-align:center;transition:all .15s;background:transparent}
.emoji-opt:hover{background:var(--bg2)}
.emoji-opt.selected{border-color:var(--brand);background:var(--brand-l)}
.ticket-type-row{border:1.5px solid var(--border);border-radius:12px;padding:1rem;margin-bottom:.75rem;position:relative}
.add-tt-btn{border:2px dashed var(--border);border-radius:10px;padding:.75rem;text-align:center;cursor:pointer;color:var(--ink3);font-size:.875rem;font-weight:600;transition:all .18s;background:transparent}
.add-tt-btn:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-l)}

/* SCANNER */
.scanner-wrap{max-width:500px;margin:0 auto}
.scanner-cam-area{background:#0f172a;border-radius:var(--radius-lg);aspect-ratio:1;max-width:320px;margin:0 auto;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.scanner-frame-box{width:220px;height:220px;border:3px solid var(--brand);border-radius:10px;position:relative}
.scanner-frame-box::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--brand),transparent);animation:scan 1.5s linear infinite}
@keyframes scan{0%{top:0}100%{top:100%}}
.scanner-result-success{background:var(--green-l);border:2px solid var(--green);border-radius:12px;padding:1.25rem}
.scanner-result-error{background:var(--red-l);border:2px solid var(--red);border-radius:12px;padding:1.25rem}

/* FINANCEIRO */
.finance-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-bottom:1.75rem}
.finance-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border);padding:1.5rem}
.finance-card-label{font-size:.8rem;font-weight:600;color:var(--ink3);margin-bottom:.3rem}
.finance-card-value{font-size:2rem;font-weight:800;color:var(--ink)}
.finance-card-sub{font-size:.78rem;color:var(--ink4);margin-top:.2rem}
.finance-card.highlight{background:linear-gradient(135deg,var(--brand),#4338ca);border:none}
.finance-card.highlight .finance-card-label,.finance-card.highlight .finance-card-value,.finance-card.highlight .finance-card-sub{color:#fff}
.finance-card.highlight .finance-card-label,.finance-card.highlight .finance-card-sub{opacity:.8}

/* PAINEL INTERNO DO SAAS */
.platform-action-row{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}
.platform-permission-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-top:1rem}
.platform-permission-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem}
.platform-permission-title{font-weight:800;font-size:.9rem;margin-bottom:.5rem;color:var(--ink)}
.platform-permission-card ul{list-style:none}
.platform-permission-card li{font-size:.82rem;color:var(--ink3);padding:.25rem 0}
.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:.35rem;background:var(--green)}
.status-dot.paused{background:var(--amber)}
.status-dot.cancelled{background:var(--red)}

/* ORGANIZERS */
.org-members-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}
.org-member-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border);padding:1.25rem;display:flex;align-items:center;gap:.75rem}
.org-member-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--brand),#4338ca);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1rem;flex-shrink:0}
.org-member-info{flex:1}
.org-member-name{font-weight:700;font-size:.9rem}
.org-member-email{font-size:.78rem;color:var(--ink3)}
.org-member-role{margin-top:.3rem}

/* P�GINA DO ORGANIZADOR */
.org-profile-header{background:linear-gradient(135deg,#1e1b4b,var(--brand));border-radius:var(--radius-xl);padding:2rem;color:#fff;display:flex;align-items:center;gap:1.5rem;margin-bottom:1.5rem}
.org-profile-avatar-big{width:80px;height:80px;border-radius:50%;background:rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:800;color:#fff;border:3px solid rgba(255,255,255,.3);flex-shrink:0}
.org-profile-name{font-family:'Syne',sans-serif;font-size:1.5rem;font-weight:800;margin-bottom:.25rem}
.org-profile-desc{font-size:.875rem;opacity:.8}

/* WAITING LIST */
.waitlist-item{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border);padding:1.1rem;margin-bottom:.75rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}

/* EMPTY STATE */
.empty-state{text-align:center;padding:4rem 2rem}
.empty-icon{font-size:3.5rem;margin-bottom:1rem;display:block}
.empty-title{font-size:1.1rem;font-weight:800;margin-bottom:.4rem}
.empty-desc{font-size:.875rem;color:var(--ink3);margin-bottom:1.5rem}

/* DIVIDER */
.divider{display:flex;align-items:center;gap:.75rem;font-size:.8rem;color:var(--ink4);margin:.9rem 0}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--border)}

/* FOOTER */
footer{background:var(--ink);margin-top:4rem;padding:3rem 1.5rem 1.5rem}
.footer-inner{max-width:1200px;margin:0 auto}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2.5rem;margin-bottom:2.5rem}
@media(max-width:768px){.footer-grid{grid-template-columns:1fr 1fr}}
.footer-logo{font-family:'Syne',sans-serif;font-size:1.4rem;font-weight:800;color:#fff;margin-bottom:.75rem}
.footer-logo span{color:#A5B4FC}
.footer-desc{font-size:.875rem;color:#64748B;line-height:1.7}
.footer-col-title{font-size:.75rem;font-weight:800;color:#64748B;text-transform:uppercase;letter-spacing:1px;margin-bottom:.9rem}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:.5rem}
.footer-col ul li a{font-size:.875rem;color:#94A3B8;transition:color .15s}
.footer-col ul li a:hover{color:#fff}
.footer-bottom{border-top:1px solid #1e293b;padding-top:1.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}
.footer-bottom p{font-size:.8rem;color:#475569}

/* WA FLOAT */
.wa-float{position:fixed;bottom:1.5rem;right:1.5rem;z-index:199;width:54px;height:54px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,.4);transition:transform .2s}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:26px;height:26px;fill:#fff}

@media(max-width:768px){
  .nav-search,.nav-links .nav-link:not(.mobile-show){display:none}
  .form-row{grid-template-columns:1fr}
  .pay-methods{grid-template-columns:1fr 1fr 1fr}
  .org-sidebar{display:none}
  .footer-grid{grid-template-columns:1fr}
  .order-card{grid-template-columns:auto 1fr}
  .order-card-right{grid-column:2}
}
