:root{--bg: #0D0D1A;--accent: #C9A84C;--text: #FFFFFF;--text-sec: #A0A0B0;--card: #1A1A2E;--border: #2A2A3E;--success: #22C55E;--warning: #C9A84C;--danger: #EF4444;--vip: #C9A84C;--pmi: #3B82F6;--esmt: #22C55E;--bfp: #8B5CF6;--proches: #EC4899;--nav-h: 52px;--header-h: 52px}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}html,body{height:100%;width:100%;overflow:hidden;background:var(--bg);font-family:system-ui,-apple-system,sans-serif;color:var(--text)}#auth-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:var(--bg);display:flex;align-items:center;justify-content:center;padding:24px}.auth-box{width:100%;max-width:400px;background:var(--card);border:1px solid var(--border);border-radius:20px;padding:40px 32px;text-align:center}.auth-logo{width:72px;height:72px;background:linear-gradient(135deg,var(--accent) 0%,#A07830 100%);border-radius:18px;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;font-size:32px;font-weight:700;color:#0d0d1a}.auth-title{font-size:22px;font-weight:700;margin-bottom:6px}.auth-sub{font-size:13px;color:var(--text-sec);margin-bottom:32px;line-height:1.5}.auth-field{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:16px;padding:14px 16px;outline:none;margin-bottom:16px;transition:border-color .2s}.auth-field:focus{border-color:var(--accent)}.auth-btn{width:100%;background:var(--accent);color:#0d0d1a;font-size:16px;font-weight:700;border:none;border-radius:10px;padding:15px;cursor:pointer;transition:opacity .2s,transform .1s}.auth-btn:active{transform:scale(.98);opacity:.9}.auth-loading{font-size:13px;color:var(--text-sec);margin-top:12px}.auth-error{color:var(--danger);font-size:13px;margin-top:12px;min-height:20px;display:none}.auth-box.shake{animation:shake .4s ease}@keyframes shake{0%,to{transform:translate(0)}15%{transform:translate(-8px)}30%{transform:translate(8px)}45%{transform:translate(-6px)}60%{transform:translate(6px)}75%{transform:translate(-3px)}90%{transform:translate(3px)}}#app{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column}#app.hidden{display:none}#app-header{height:var(--header-h);background:var(--card);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 16px;flex-shrink:0;z-index:100}.header-event{font-size:11px;color:var(--text-sec);line-height:1.4}.header-event span{color:var(--accent);font-weight:600}.header-counter{background:var(--bg);border:1px solid var(--border);border-radius:20px;padding:6px 12px;font-size:13px;font-weight:700;color:var(--success);white-space:nowrap}#main-content{flex:1;overflow:hidden;position:relative}.tab-pane{position:absolute;top:0;right:0;bottom:0;left:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:16px;opacity:0;pointer-events:none;transform:translateY(8px);transition:opacity .2s,transform .2s}.tab-pane.active{opacity:1;pointer-events:all;transform:translateY(0)}#app-nav{height:var(--nav-h);background:var(--card);border-bottom:1px solid var(--border);display:flex;flex-shrink:0;z-index:100;overflow-x:auto;scrollbar-width:none}#app-nav::-webkit-scrollbar{display:none}.nav-btn{flex:1;min-width:80px;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:7px;border:none;background:transparent;color:var(--text-sec);font-size:13px;font-weight:500;cursor:pointer;padding:0 12px;white-space:nowrap;border-bottom:2px solid transparent;transition:color .2s,border-color .2s}.nav-btn.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:700}.nav-btn svg{width:18px;height:18px;flex-shrink:0}.scanner-counter{display:flex;gap:12px;margin-bottom:16px}.counter-pill{flex:1;background:var(--card);border:1px solid var(--border);border-radius:12px;padding:12px;text-align:center}.counter-pill .num{font-size:28px;font-weight:800;color:var(--success)}.counter-pill .num.warning{color:var(--warning)}.counter-pill .num.accent{color:var(--accent)}.counter-pill .lbl{font-size:11px;color:var(--text-sec);margin-top:2px}.camera-box{background:#000;border-radius:16px;overflow:hidden;position:relative;width:100%;aspect-ratio:1;margin-bottom:16px;border:1px solid var(--border)}#video-el{width:100%;height:100%;object-fit:cover;display:block}.camera-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0d0d1ad9;flex-direction:column;gap:12px}.camera-overlay.hidden{display:none}.scan-frame{position:absolute;width:60%;aspect-ratio:1;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}.scan-frame:before,.scan-frame:after,.scan-frame span:before,.scan-frame span:after{content:"";position:absolute;width:28px;height:28px;border-color:var(--accent);border-style:solid}.scan-frame:before{top:0;left:0;border-width:3px 0 0 3px;border-radius:4px 0 0}.scan-frame:after{top:0;right:0;border-width:3px 3px 0 0;border-radius:0 4px 0 0}.scan-frame span:before{bottom:0;left:0;border-width:0 0 3px 3px;border-radius:0 0 0 4px}.scan-frame span:after{bottom:0;right:0;border-width:0 3px 3px 0;border-radius:0 0 4px}.scan-line{position:absolute;width:60%;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent);top:50%;left:50%;transform:translate(-50%);animation:scanAnim 2s linear infinite}@keyframes scanAnim{0%{top:20%}50%{top:80%}to{top:20%}}#canvas-el{display:none}.camera-btn{background:var(--accent);color:#0d0d1a;border:none;border-radius:12px;padding:14px 28px;font-size:15px;font-weight:700;cursor:pointer}.scan-alert{border-radius:12px;padding:14px 16px;margin-bottom:12px;font-size:14px;font-weight:600;display:none}.scan-alert.success{background:#22c55e26;border:1px solid var(--success);color:var(--success)}.scan-alert.warning{background:#c9a84c26;border:1px solid var(--warning);color:var(--warning)}.scan-alert.danger{background:#ef444426;border:1px solid var(--danger);color:var(--danger)}.scan-alert.visible{display:block}.confirm-card{background:var(--card);border:2px solid var(--success);border-radius:16px;padding:20px;margin-bottom:12px;display:none}.confirm-card.visible{display:block}.confirm-name{font-size:24px;font-weight:800;margin-bottom:8px}.confirm-meta{display:flex;gap:8px;align-items:center;margin-bottom:16px;flex-wrap:wrap}.confirm-time{font-size:13px;color:var(--text-sec)}.confirm-btns{display:flex;gap:10px}.btn-validate{flex:1;background:var(--success);color:#fff;border:none;border-radius:12px;padding:16px;font-size:16px;font-weight:700;cursor:pointer}.btn-cancel-scan{background:var(--card);border:1px solid var(--border);color:var(--text-sec);border-radius:12px;padding:16px 20px;font-size:15px;cursor:pointer}.manual-section{margin-top:8px}.section-title{font-size:13px;font-weight:600;color:var(--text-sec);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.input-field{width:100%;background:var(--card);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:15px;padding:12px 14px;outline:none;margin-bottom:10px;transition:border-color .2s}.input-field:focus{border-color:var(--accent)}.input-field::placeholder{color:var(--text-sec)}select.input-field{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.guest-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px;margin-bottom:8px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:border-color .2s}.guest-card:active{border-color:var(--accent)}.guest-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;flex-shrink:0}.guest-info{flex:1;min-width:0}.guest-name{font-size:15px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.guest-meta{display:flex;gap:6px;align-items:center;margin-top:3px;flex-wrap:wrap}.badge{display:inline-block;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600}.badge-vip{background:#c9a84c33;color:var(--vip)}.badge-pmi{background:#3b82f633;color:var(--pmi)}.badge-esmt{background:#22c55e33;color:var(--esmt)}.badge-bfp{background:#8b5cf633;color:var(--bfp)}.badge-proches{background:#ec489933;color:var(--proches)}.status-present{font-size:11px;color:var(--success);font-weight:500}.status-waiting{font-size:11px;color:var(--text-sec)}.guest-actions{display:flex;gap:6px;flex-shrink:0}.btn-sm{padding:6px 12px;border-radius:8px;font-size:12px;font-weight:600;border:none;cursor:pointer;transition:opacity .2s}.btn-sm:active{opacity:.7}.btn-enter{background:#22c55e26;color:var(--success);border:1px solid var(--success)}.btn-cancel-entry{background:#ef44441a;color:var(--danger);border:1px solid rgba(239,68,68,.3)}.filter-bar{display:flex;gap:6px;margin-bottom:12px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:2px;scrollbar-width:none}.filter-bar::-webkit-scrollbar{display:none}.filter-chip{flex-shrink:0;padding:6px 12px;border-radius:20px;border:1px solid var(--border);background:transparent;color:var(--text-sec);font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .2s}.filter-chip.active{background:var(--accent);border-color:var(--accent);color:#0d0d1a;font-weight:700}.fab{position:fixed;bottom:24px;right:16px;width:52px;height:52px;border-radius:50%;background:var(--accent);border:none;color:#0d0d1a;font-size:26px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #c9a84c66;z-index:200;transition:transform .1s,opacity .2s}.fab:active{transform:scale(.92)}.fab.hidden-fab{opacity:0;pointer-events:none}.topbar{display:flex;gap:8px;margin-bottom:12px;align-items:center}.export-btn{flex-shrink:0;background:var(--card);border:1px solid var(--border);color:var(--text-sec);border-radius:10px;padding:10px 14px;font-size:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:6px}.budget-section{margin-bottom:24px}.budget-section-title{font-size:15px;font-weight:700;color:var(--accent);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border)}.budget-table{width:100%;border-collapse:collapse}.budget-table th{font-size:11px;color:var(--text-sec);text-align:left;padding:6px 8px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.budget-table td{padding:8px;border-top:1px solid var(--border);font-size:13px;vertical-align:middle}.budget-table tr.totals-row td{font-weight:700;color:var(--accent);border-top:2px solid var(--border)}.budget-input{background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:13px;padding:6px 8px;width:90px;outline:none}.budget-input:focus{border-color:var(--accent)}.ecart-pos{color:var(--success)}.ecart-neg{color:var(--danger)}.status-badge-paid{background:#22c55e26;color:var(--success);padding:2px 7px;border-radius:6px;font-size:11px;cursor:pointer}.status-badge-pending{background:#c9a84c26;color:var(--warning);padding:2px 7px;border-radius:6px;font-size:11px;cursor:pointer}.vente-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:16px;margin-bottom:12px}.vente-row{display:flex;gap:10px;align-items:center;margin-bottom:10px}.vente-row label{font-size:13px;color:var(--text-sec);flex:0 0 auto}.btn-plus-vente{background:var(--success);color:#fff;border:none;border-radius:12px;padding:14px 24px;font-size:16px;font-weight:700;cursor:pointer;width:100%}.progress-bar-wrap{background:var(--bg);border-radius:8px;height:10px;overflow:hidden;margin-top:8px}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--success));border-radius:8px;transition:width .4s ease}.synthese-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.synthese-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px;text-align:center}.synthese-card .s-label{font-size:11px;color:var(--text-sec);margin-bottom:4px}.synthese-card .s-val{font-size:18px;font-weight:800}.synthese-card .s-eur{font-size:11px;color:var(--text-sec);margin-top:2px}.synthese-card.full{grid-column:1/-1}.result-positive{color:var(--success)}.result-negative{color:var(--danger)}.add-poste-btn{background:transparent;border:1px dashed var(--border);color:var(--text-sec);border-radius:10px;padding:10px;width:100%;font-size:13px;cursor:pointer;margin-top:8px}.presence-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:20px;margin-bottom:16px;display:flex;align-items:center;gap:20px}.circle-wrap{position:relative;width:90px;height:90px;flex-shrink:0}.circle-wrap svg{width:90px;height:90px;transform:rotate(-90deg)}.circle-bg{fill:none;stroke:var(--border);stroke-width:8}.circle-fill{fill:none;stroke:var(--accent);stroke-width:8;stroke-linecap:round;transition:stroke-dashoffset 1s ease}.circle-text{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.circle-pct{font-size:20px;font-weight:800;color:var(--accent)}.circle-sub{font-size:10px;color:var(--text-sec)}.presence-info{flex:1}.presence-big{font-size:32px;font-weight:800;line-height:1}.presence-total{font-size:16px;color:var(--text-sec)}.presence-lastci{font-size:12px;color:var(--text-sec);margin-top:6px}.cercle-bars{margin-bottom:16px}.cercle-bar-item{margin-bottom:10px}.cercle-bar-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.cercle-bar-name{font-size:13px;font-weight:600}.cercle-bar-val{font-size:12px;color:var(--text-sec)}.cercle-bar-bg{background:var(--border);border-radius:4px;height:8px;overflow:hidden}.cercle-bar-fill{height:100%;border-radius:4px;transition:width .6s ease}.timeline-item{display:flex;gap:12px;align-items:center;padding:10px 0;border-bottom:1px solid var(--border)}.timeline-item:last-child{border-bottom:none}.tl-time{font-size:12px;color:var(--text-sec);flex-shrink:0;width:42px}.tl-name{font-size:14px;font-weight:500;flex:1}.tl-dot{width:8px;height:8px;border-radius:50%;background:var(--success);flex-shrink:0}.reset-btn{width:100%;background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--danger);border-radius:12px;padding:14px;font-size:14px;font-weight:600;cursor:pointer}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;background:#000000b3;display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s}.modal-backdrop.open{opacity:1;pointer-events:all}.modal-sheet{background:var(--card);border-radius:20px 20px 0 0;padding:20px 20px calc(20px + env(safe-area-inset-bottom));width:100%;max-width:520px;max-height:90vh;overflow-y:auto;transform:translateY(100%);transition:transform .3s cubic-bezier(.32,.72,0,1)}.modal-backdrop.open .modal-sheet{transform:translateY(0)}.modal-handle{width:36px;height:4px;background:var(--border);border-radius:2px;margin:0 auto 20px}.modal-title{font-size:18px;font-weight:700;margin-bottom:20px}.modal-form-row{margin-bottom:14px}.modal-form-row label{display:block;font-size:12px;color:var(--text-sec);margin-bottom:6px;font-weight:500}.modal-btns{display:flex;gap:10px;margin-top:20px}.btn-primary{flex:1;background:var(--accent);color:#0d0d1a;border:none;border-radius:10px;padding:14px;font-size:15px;font-weight:700;cursor:pointer}.btn-secondary{background:var(--bg);border:1px solid var(--border);color:var(--text-sec);border-radius:10px;padding:14px 20px;font-size:15px;cursor:pointer}#toast-container{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:900;display:flex;flex-direction:column;gap:8px;align-items:center;pointer-events:none}.toast{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:12px 20px;font-size:14px;font-weight:500;color:var(--text);box-shadow:0 8px 24px #0006;animation:toastIn .3s ease forwards;max-width:300px;text-align:center}.toast.success{border-color:var(--success);color:var(--success)}.toast.warning{border-color:var(--warning);color:var(--warning)}.toast.danger{border-color:var(--danger);color:var(--danger)}@keyframes toastIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes toastOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-8px)}}#success-flash{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;background:#22c55e40;pointer-events:none;opacity:0}#success-flash.flash{animation:flashAnim .8s ease forwards}@keyframes flashAnim{0%{opacity:0}20%{opacity:1}to{opacity:0}}.skeleton{background:linear-gradient(90deg,var(--card) 25%,var(--border) 50%,var(--card) 75%);background-size:200% 100%;animation:skeletonAnim 1.2s infinite;border-radius:8px;height:64px;margin-bottom:8px}@keyframes skeletonAnim{to{background-position:-200% 0}}.empty-state{text-align:center;padding:40px 20px;color:var(--text-sec);font-size:14px}
