/* ═══════════════════════════════════════════════════════════
   voTickets — CSS v4.0 — Mobile-first · 100% responsive
   #17334E navy + #FF933E orange
═══════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Syne:wght@600;700;800&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600&family=DM+Mono:wght@400;500&display=swap');

:root {
  --bg0:#0D1B2A; --bg1:#132234; --bg2:#1A2D42; --bg3:#213450;
  --bd:#2A3F58;  --bd2:#355070;
  --accent:#FF933E; --accent-d:#E07A28;
  --accent-bg:rgba(255,147,62,.08); --accent-bdr:rgba(255,147,62,.25);
  --navy:#17334E; --navy-d:#0F2338;
  --txt1:#F0EEF8; --txt2:#9BAFC4; --txt3:#5C7A96;
  --ok:#22C55E; --err:#EF4444; --wrn:#F59E0B; --inf:#3B82F6;
  --ff-d:'Syne',sans-serif; --ff-b:'DM Sans',sans-serif; --ff-m:'DM Mono',monospace;
  --r1:4px;--r2:10px;--r3:14px;--r4:20px;--r5:28px;--rF:9999px;
  --sh:0 4px 20px rgba(0,0,0,.5);
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}
body{font-family:var(--ff-b);background:var(--bg0);color:var(--txt1);line-height:1.65;min-height:100vh;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font-family:inherit;font-size:inherit;border:none;outline:none;background:none}
ul,ol{list-style:none}

/* ── Typo ── */
h1,h2,h3,h4{font-family:var(--ff-d);font-weight:700;line-height:1.15;color:var(--txt1)}
h1{font-size:clamp(1.5rem,5vw,2.8rem)}
h2{font-size:clamp(1.2rem,3.5vw,2rem)}
h3{font-size:clamp(.95rem,2.5vw,1.4rem)}
.display{font-size:clamp(1.8rem,7vw,4rem);font-family:var(--ff-d);font-weight:800;line-height:1.05}
.mono{font-family:var(--ff-m)}

/* ── Layout ── */
.wrap{max-width:1200px;margin:0 auto;padding:0 16px}
.wrap-sm{max-width:560px;margin:0 auto;padding:0 16px}
.wrap-md{max-width:860px;margin:0 auto;padding:0 16px}
.flex{display:flex}.col{flex-direction:column}
.ai-c{align-items:center}.jc-b{justify-content:space-between}.jc-c{justify-content:center}
.f1{flex:1}.shrink0{flex-shrink:0}
.g1{gap:4px}.g2{gap:8px}.g3{gap:12px}.g4{gap:16px}.g5{gap:20px}.g6{gap:24px}.g8{gap:32px}
.grid{display:grid}
.grid2{grid-template-columns:repeat(2,1fr)}
.grid3{grid-template-columns:repeat(3,1fr)}
.grid4{grid-template-columns:repeat(4,1fr)}
.auto-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}
.w100{width:100%}
.rel{position:relative}.abs{position:absolute}.fix{position:fixed}.sticky{position:sticky}
.z10{z-index:10}.z50{z-index:50}.z100{z-index:100}.ov-h{overflow:hidden}

/* ── Spacing ── */
.mt2{margin-top:8px}.mt3{margin-top:12px}.mt4{margin-top:16px}.mt5{margin-top:20px}.mt6{margin-top:24px}.mt8{margin-top:32px}.mt10{margin-top:40px}.mt12{margin-top:48px}.mt16{margin-top:64px}
.mb2{margin-bottom:8px}.mb3{margin-bottom:12px}.mb4{margin-bottom:16px}.mb5{margin-bottom:20px}.mb6{margin-bottom:24px}.mb8{margin-bottom:32px}.mb10{margin-bottom:40px}.mb12{margin-bottom:48px}.mb0{margin-bottom:0}
.mx-auto{margin-left:auto;margin-right:auto}
.p4{padding:16px}.p5{padding:20px}.p6{padding:24px}
.py4{padding-top:16px;padding-bottom:16px}.py6{padding-top:24px;padding-bottom:24px}.py8{padding-top:32px;padding-bottom:32px}.py10{padding-top:40px;padding-bottom:40px}.py12{padding-top:48px;padding-bottom:48px}.py16{padding-top:64px;padding-bottom:64px}.py20{padding-top:80px;padding-bottom:80px}

/* ── Boutons ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:10px 18px;border-radius:var(--r2);font-weight:600;font-size:.88rem;cursor:pointer;transition:all .15s;white-space:nowrap;line-height:1;-webkit-tap-highlight-color:transparent;touch-action:manipulation;user-select:none}
.btn:active{transform:scale(.96)}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}
.btn-p{background:var(--accent);color:#fff;font-family:var(--ff-d);font-weight:700}
.btn-p:hover{background:var(--accent-d)}
.btn-navy{background:var(--navy);color:#fff}
.btn-s{background:var(--bg2);color:var(--txt2);border:1px solid var(--bd)}
.btn-s:hover{background:var(--bg3);color:var(--txt1)}
.btn-g{background:transparent;color:var(--txt2);border:1px solid var(--bd)}
.btn-g:hover{background:var(--bg2);color:var(--txt1)}
.btn-err{background:rgba(239,68,68,.1);color:var(--err);border:1px solid rgba(239,68,68,.25)}
.btn-wa{background:#25D366;color:#fff}
.btn-sm{padding:6px 11px;font-size:.78rem}
.btn-lg{padding:14px 28px;font-size:1rem}
.btn-w{width:100%}

/* ── Formulaires ── */
.fg{margin-bottom:14px}
.label{display:block;font-size:.8rem;font-weight:500;color:var(--txt2);margin-bottom:5px}
.req{color:var(--err);margin-left:2px}
.input{width:100%;padding:11px 13px;background:var(--bg2);border:1.5px solid var(--bd);border-radius:var(--r2);color:var(--txt1);font-size:.9rem;transition:border-color .15s;-webkit-appearance:none;appearance:none}
.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(255,147,62,.12)}
.input::placeholder{color:var(--txt3)}
textarea.input{resize:vertical;min-height:90px}
select.input{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%235C7A96' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}
.hint{font-size:.74rem;color:var(--txt3);margin-top:4px}

/* ── Alertes ── */
.alert{padding:11px 14px;border-radius:var(--r2);font-size:.84rem;border:1px solid transparent;margin-bottom:14px}
.alert-ok{background:rgba(34,197,94,.08);border-color:rgba(34,197,94,.25);color:var(--ok)}
.alert-err{background:rgba(239,68,68,.08);border-color:rgba(239,68,68,.25);color:var(--err)}
.alert-wrn{background:rgba(245,158,11,.08);border-color:rgba(245,158,11,.25);color:var(--wrn)}
.alert-inf{background:rgba(59,130,246,.08);border-color:rgba(59,130,246,.25);color:var(--inf)}

/* ── Badges ── */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:var(--rF);font-size:.7rem;font-weight:600}
.bdg-a{background:var(--accent);color:#fff}
.bdg-ok{background:rgba(34,197,94,.12);color:var(--ok)}
.bdg-err{background:rgba(239,68,68,.12);color:var(--err)}
.bdg-wrn{background:rgba(245,158,11,.12);color:var(--wrn)}
.bdg-inf{background:rgba(59,130,246,.12);color:var(--inf)}
.bdg-mut{background:var(--bg3);color:var(--txt2)}

/* ── Event cards ── */
.ev-card{background:var(--bg1);border:1px solid var(--bd);border-radius:var(--r4);overflow:hidden;transition:transform .2s,border-color .2s;display:block;color:inherit}
.ev-card:hover{transform:translateY(-3px);border-color:var(--bd2)}
.ev-card:active{transform:scale(.98)}
.ev-card__img{position:relative;height:160px;background:var(--bg2);overflow:hidden}
.ev-card__img img{width:100%;height:100%;object-fit:cover}
.ev-card__body{padding:13px}
.ev-card__cat{display:inline-block;font-size:.65rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--accent);background:var(--accent-bg);border:1px solid var(--accent-bdr);padding:3px 8px;border-radius:var(--rF);margin-bottom:7px}
.ev-card__title{font-family:var(--ff-d);font-size:.9rem;font-weight:700;line-height:1.3;margin-bottom:7px;color:var(--txt1)}
.ev-card__meta{display:flex;flex-direction:column;gap:3px;margin-bottom:9px}
.ev-card__meta-row{display:flex;align-items:center;gap:5px;font-size:.73rem;color:var(--txt2)}
.ev-card__footer{display:flex;align-items:center;justify-content:space-between;padding-top:9px;border-top:1px solid var(--bd)}
.ev-card__price{font-family:var(--ff-m);font-size:.85rem;font-weight:600;color:var(--txt1)}
.ev-card__price.free{color:var(--ok)}

/* ── KPIs ── */
.kpi{background:var(--bg1);border:1px solid var(--bd);border-radius:var(--r3);padding:14px}
.kpi__label{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--txt3);margin-bottom:4px}
.kpi__val{font-family:var(--ff-m);font-size:clamp(1.1rem,2.5vw,1.6rem);font-weight:700;color:var(--txt1);line-height:1}
.kpi__val.accent,.kpi__val.ca{color:var(--accent)}
.kpi__val.ok,.kpi__val.cok{color:var(--ok)}
.kpi__sub{font-size:.7rem;color:var(--txt3);margin-top:4px}

/* ── Tables ── */
.tbl-wrap{overflow-x:auto;border:1px solid var(--bd);border-radius:var(--r3);-webkit-overflow-scrolling:touch}
.tbl{width:100%;border-collapse:collapse;font-size:.82rem;min-width:480px}
.tbl th{padding:9px 11px;text-align:left;font-size:.67rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--txt3);background:var(--bg2);border-bottom:1px solid var(--bd);white-space:nowrap}
.tbl td{padding:9px 11px;border-bottom:1px solid var(--bd);color:var(--txt2);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:hover td{background:rgba(255,255,255,.02)}
.td-b{color:var(--txt1);font-weight:500}
.td-m{font-family:var(--ff-m);font-size:.76rem}

/* ══ NAVBAR PUBLIC ══════════════════════════════════════════ */
.nav{position:sticky;top:0;z-index:100;background:rgba(13,27,42,.96);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--bd)}
.nav__in{display:flex;align-items:center;height:56px;gap:12px;padding:0 16px;max-width:1200px;margin:0 auto}
.nav__logo{font-family:var(--ff-d);font-size:1.25rem;font-weight:800;flex-shrink:0;color:var(--txt1)}
.nav__logo span{color:var(--accent)}
.nav__links{display:flex;align-items:center;gap:2px;flex:1}
.nav__link{padding:6px 11px;border-radius:var(--r2);font-size:.85rem;font-weight:500;color:var(--txt2);transition:all .15s;white-space:nowrap}
.nav__link:hover,.nav__link.on{color:var(--txt1);background:var(--bg2)}
.nav__actions{display:flex;align-items:center;gap:7px;flex-shrink:0}
.nav__burger{display:none;width:38px;height:38px;background:var(--bg2);border:1px solid var(--bd);border-radius:var(--r2);cursor:pointer;align-items:center;justify-content:center;color:var(--txt2);flex-shrink:0;touch-action:manipulation}
.nav__burger:active{background:var(--bg3)}

/* ── Drawer mobile ── */
.nav__overlay{display:none;position:fixed;inset:0;z-index:198;background:rgba(0,0,0,.6)}
.nav__overlay.open{display:block}
.nav__drawer{position:fixed;top:0;left:0;bottom:0;width:min(280px,85vw);z-index:199;background:var(--navy);transform:translateX(-100%);transition:transform .25s ease;overflow-y:auto;padding:20px 16px;display:flex;flex-direction:column}
.nav__drawer.open{transform:translateX(0)}
.nav__drawer-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}
.nav__drawer-logo{font-family:var(--ff-d);font-size:1.3rem;font-weight:800;color:#fff}
.nav__drawer-logo span{color:var(--accent)}
.nav__drawer-close{width:34px;height:34px;background:rgba(255,255,255,.1);border-radius:var(--r1);display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;font-size:1.1rem;touch-action:manipulation}
.nav__drawer-close:active{background:rgba(255,255,255,.2)}
.nav__drawer-link{display:flex;align-items:center;gap:10px;padding:12px;border-radius:var(--r2);font-size:.92rem;font-weight:500;color:rgba(255,255,255,.75);margin-bottom:3px;transition:all .15s}
.nav__drawer-link:hover,.nav__drawer-link:active{color:#fff;background:rgba(255,255,255,.1)}
.nav__drawer-sep{height:1px;background:rgba(255,255,255,.1);margin:12px 0}
.nav__drawer-actions{margin-top:auto;padding-top:16px;display:flex;flex-direction:column;gap:8px}

/* ══ DASHBOARD ══════════════════════════════════════════════ */
.dash-layout{display:flex;min-height:100vh}
.dash-main{flex:1;min-width:0;overflow-x:hidden}
.dash-header{padding:10px 16px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;background:var(--bg1);position:sticky;top:0;z-index:10;gap:10px;min-height:52px}
.dash-content{padding:16px;max-width:1100px}

/* Sidebar */
.sidebar{width:220px;min-height:100vh;background:var(--navy);border-right:1px solid var(--bd);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto;flex-shrink:0;transition:transform .25s ease}
.sidebar__logo{padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.1);font-family:var(--ff-d);font-size:1.15rem;font-weight:800;color:#fff;display:flex;align-items:center;justify-content:space-between}
.sidebar__logo span{color:var(--accent)}
.sidebar__close{display:none;width:28px;height:28px;background:rgba(255,255,255,.1);border-radius:4px;align-items:center;justify-content:center;cursor:pointer;color:#fff;font-size:1rem;flex-shrink:0}
.sidebar__sec{padding:8px 6px}
.sidebar__lbl{font-size:.64rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:rgba(255,255,255,.3);padding:0 8px;margin-bottom:3px}
.sidebar__link{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--r2);font-size:.83rem;font-weight:500;color:rgba(255,255,255,.6);transition:all .15s;margin-bottom:1px}
.sidebar__link:hover{color:#fff;background:rgba(255,255,255,.08)}
.sidebar__link.on{color:#fff;background:var(--accent);font-weight:600}
.sidebar__foot{margin-top:auto;padding:10px 6px;border-top:1px solid rgba(255,255,255,.08)}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:199}
.sidebar-overlay.open{display:block}

/* ── Scanner ── */
.scan-box{position:relative;width:100%;max-width:280px;margin:0 auto;background:#000;border-radius:var(--r3);overflow:hidden;aspect-ratio:1}
.scan-frame{position:absolute;inset:12px;border:2px solid var(--accent);border-radius:var(--r2);pointer-events:none}
.scan-line{position:absolute;left:14px;right:14px;height:2px;background:var(--accent);animation:scanAnim 2s ease-in-out infinite}
@keyframes scanAnim{0%,100%{top:14px}50%{top:calc(100% - 14px)}}
.scan-result{padding:12px 14px;border-radius:var(--r2);text-align:center}
.scan-ok{background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.3)}
.scan-dup{background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.3)}
.scan-bad{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3)}

/* ── Misc ── */
.bar{height:5px;background:var(--bg3);border-radius:var(--rF);overflow:hidden}
.bar__fill{height:100%;background:var(--accent);border-radius:var(--rF);transition:width .4s}
.bar__fill.danger{background:var(--err)}
.pager{display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.pager__btn{padding:6px 11px;border-radius:var(--r1);font-size:.78rem;font-weight:500;background:var(--bg2);color:var(--txt2);border:1px solid var(--bd);cursor:pointer}
.pager__btn.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.empty{text-align:center;padding:48px 20px}
.empty__ico{font-size:2.5rem;margin-bottom:12px}
.empty__title{font-family:var(--ff-d);font-size:1rem;font-weight:700;margin-bottom:6px}
.empty__desc{font-size:.83rem;color:var(--txt3);max-width:260px;margin:0 auto 18px}
.avatar{width:34px;height:34px;border-radius:var(--rF);background:var(--bg3);display:flex;align-items:center;justify-content:center;font-family:var(--ff-d);font-weight:700;color:var(--accent);font-size:.78rem;flex-shrink:0}
.dot{width:7px;height:7px;border-radius:50%;display:inline-block}
.dot-ok{background:var(--ok)}.dot-err{background:var(--err)}.dot-wrn{background:var(--wrn)}.dot-mut{background:var(--txt3)}
.divider{height:1px;background:var(--bd);margin:16px 0}

/* ── Text utils ── */
.c1{color:var(--txt1)}.c2{color:var(--txt2)}.c3{color:var(--txt3)}.ca{color:var(--accent)}.cok{color:var(--ok)}.cerr{color:var(--err)}
.fw5{font-weight:500}.fw6{font-weight:600}.fw7{font-weight:700}.fw8{font-weight:800}
.fs-sm{font-size:.83rem}.fs-xs{font-size:.75rem}.fs-2xs{font-size:.68rem}
.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.line-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.txt-c{text-align:center}.txt-r{text-align:right}
.hidden{display:none}.pointer{cursor:pointer}

/* ── Footer ── */
.footer{background:var(--navy);border-top:1px solid var(--bd);padding:36px 0 20px}
.footer__grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:24px}
.footer__logo{font-family:var(--ff-d);font-size:1.25rem;font-weight:800;margin-bottom:8px;color:#fff}
.footer__logo span{color:var(--accent)}
.footer__desc{font-size:.78rem;color:rgba(255,255,255,.4);line-height:1.7;max-width:220px}
.footer__ht{font-weight:700;font-size:.75rem;color:rgba(255,255,255,.7);margin-bottom:10px;text-transform:uppercase;letter-spacing:.04em}
.footer__link{display:block;font-size:.78rem;color:rgba(255,255,255,.4);margin-bottom:6px;transition:color .15s}
.footer__link:hover{color:#fff}
.footer__bottom{margin-top:28px;padding-top:16px;border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:space-between;font-size:.73rem;color:rgba(255,255,255,.3);flex-wrap:wrap;gap:8px}

/* ── Animations ── */
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.fade-in{animation:fadeIn .3s ease both}
.slide-up{animation:slideUp .3s ease both}
.stagger>*:nth-child(1){animation-delay:.04s}
.stagger>*:nth-child(2){animation-delay:.08s}
.stagger>*:nth-child(3){animation-delay:.12s}
.stagger>*:nth-child(4){animation-delay:.16s}
.stagger>*:nth-child(5){animation-delay:.2s}
.stagger>*:nth-child(6){animation-delay:.24s}

/* ══ RESPONSIVE ══════════════════════════════════════════════ */

/* Tablette ≤1024px */
@media(max-width:1024px){
  .grid4{grid-template-columns:repeat(2,1fr)}
  .footer__grid{grid-template-columns:1fr 1fr;gap:20px}
  .dash-content{padding:14px}
  .sidebar{width:200px}
}

/* Mobile ≤768px */
@media(max-width:768px){
  /* Grilles */
  .grid2{grid-template-columns:1fr}
  .grid3{grid-template-columns:1fr}
  .auto-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}

  /* Navbar — hamburger visible */
  .nav__links{display:none}
  .nav__burger{display:flex}
  .nav__actions .btn-s,.nav__actions .btn-g{display:none}

  /* Dashboard — sidebar off-canvas */
  .sidebar{
    position:fixed;left:0;top:0;bottom:0;
    transform:translateX(-100%);
    z-index:200;width:260px;
    box-shadow:0 0 40px rgba(0,0,0,.6);
  }
  .sidebar.open{transform:translateX(0)}
  .sidebar__close{display:flex}
  .sidebar-overlay.open{display:block;z-index:199}
  .dash-content{padding:12px}
  .dash-header{padding:8px 12px}
  .dash-header h1{font-size:.9rem}
  .dash-main{width:100%}

  /* KPIs en 2 colonnes */
  .grid4{grid-template-columns:1fr 1fr}

  /* Footer */
  .footer__grid{grid-template-columns:1fr}
  .footer__bottom{flex-direction:column;text-align:center}

  /* Tables */
  .tbl-wrap{border-radius:var(--r2)}

  /* Wrappers */
  .wrap,.wrap-sm,.wrap-md{padding:0 12px}
}

/* Petit mobile ≤480px */
@media(max-width:480px){
  .grid4{grid-template-columns:1fr 1fr}
  .nav__in{height:50px;padding:0 12px}
  .nav__logo{font-size:1.1rem}
  .display{font-size:clamp(1.5rem,9vw,2.5rem)}
  .btn-lg{padding:12px 18px;font-size:.92rem}
  /* Checkout billets — boutons + grands pour mobile */
  .tt-item .btn{min-width:38px;min-height:38px}
  /* KPIs 2 colonnes même sur petit écran */
  .grid4{grid-template-columns:1fr 1fr}
  .kpi__val{font-size:1.2rem}
}
