*{box-sizing:border-box;margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}:root{--blue:#1B9BD1;--green:#8DC21F;--orange:#F37021;--red:#E01C24;--pink:#E0007A;--purple:#7B2D8B;--yellow:#D7DF23;--black:#1A1A1A;--bg:#F4F6F8;--white:#fff;--border:#E8E8E8;--muted:#999;--text:#333}html,body,#root{height:100%;background:var(--bg)}.app{display:grid;grid-template-columns:220px 1fr;height:100vh;overflow:hidden}.sidebar{background:var(--white);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.sidebar-top{border-bottom:1px solid var(--border)}.colour-bar{display:flex;height:5px}.colour-bar div{flex:1}.logo-wrap{padding:16px 18px;display:flex;align-items:center;gap:10px;cursor:pointer}.logo-word{font-size:22px;font-weight:900;color:var(--black);letter-spacing:-.5px}.nav-section{padding:8px 18px 4px;font-size:10px;font-weight:700;color:#bbb;text-transform:uppercase;letter-spacing:.08em;margin-top:8px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 18px;font-size:13px;font-weight:500;color:#666;cursor:pointer;transition:all .12s;border-left:3px solid transparent;background:none;border-top:none;border-right:none;border-bottom:none;width:100%;text-align:left}.nav-item:hover{background:#f5fafd;color:var(--black)}.nav-item.active{background:#ebf6fc;color:var(--blue);font-weight:700;border-left-color:var(--blue)}.nav-icon{width:16px;height:16px;flex-shrink:0;opacity:.6}.nav-item.active .nav-icon{opacity:1}.sidebar-bottom{margin-top:auto;padding:14px;border-top:1px solid var(--border)}.user-chip{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;cursor:pointer;transition:background .12s}.user-chip:hover{background:var(--bg)}.avatar{width:34px;height:34px;border-radius:50%;background:var(--blue);color:#fff;font-weight:700;font-size:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.user-info{flex:1;min-width:0}.user-name{font-size:12px;font-weight:700;color:var(--black);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:10px;color:var(--muted)}.main{display:flex;flex-direction:column;overflow:hidden}.topbar{background:var(--white);border-bottom:1px solid var(--border);padding:0 24px;height:52px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.topbar-title{font-size:15px;font-weight:700;color:var(--black)}.topbar-actions{display:flex;align-items:center;gap:8px}.content{flex:1;overflow-y:auto;padding:24px}.btn{padding:8px 18px;border-radius:6px;font-size:12px;font-weight:700;cursor:pointer;border:none;transition:all .12s;letter-spacing:.02em}.btn-blue{background:var(--blue);color:#fff}.btn-blue:hover{background:#1589ba}.btn-ghost{background:var(--white);color:#555;border:1px solid var(--border)}.btn-ghost:hover{background:var(--bg)}.btn-red{background:var(--white);color:var(--red);border:1px solid var(--red)}.btn-red:hover{background:#fff5f5}.btn-green{background:var(--green);color:#fff}.btn-green:hover{background:#7aaa18}.btn-sm{padding:6px 12px;font-size:11px}.card{background:var(--white);border:1px solid var(--border);border-radius:10px;padding:18px;margin-bottom:14px}.card-accent{border-top:3px solid var(--blue)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px}.stat-card{background:var(--white);border:1px solid var(--border);border-radius:10px;padding:16px;cursor:pointer;transition:all .12s;border-top:3px solid var(--blue)}.stat-card:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000000f}.stat-num{font-size:28px;font-weight:900;color:var(--blue);margin:4px 0 2px}.stat-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.stat-sub{font-size:11px;color:var(--muted);margin-top:2px}.table-wrap{background:var(--white);border:1px solid var(--border);border-radius:10px;overflow:hidden}.table-head{display:grid;gap:8px;padding:9px 16px;font-size:10px;font-weight:700;color:#aaa;text-transform:uppercase;letter-spacing:.06em;background:#fafafa;border-bottom:1px solid var(--border)}.table-row{display:grid;gap:8px;padding:12px 16px;font-size:13px;align-items:center;border-bottom:1px solid #f5f5f5;cursor:pointer;transition:background .1s}.table-row:last-child{border-bottom:none}.table-row:hover{background:#f9fafc}.badge{font-size:10px;font-weight:700;padding:3px 9px;border-radius:20px;display:inline-block;white-space:nowrap}.badge-blue{background:#ebf6fc;color:var(--blue)}.badge-orange{background:#fef3ec;color:var(--orange)}.badge-gray{background:#f2f2f2;color:#888}.badge-green{background:#f1f8e4;color:#4a7a0a}.badge-red{background:#fff0f0;color:var(--red)}.overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:100;align-items:center;justify-content:center}.overlay.open{display:flex}.tunnel{background:var(--white);border-radius:14px;padding:28px;width:380px;border-top:4px solid var(--blue);max-height:90vh;overflow-y:auto}.t-prog{display:flex;gap:3px;margin-bottom:20px}.t-dot{height:4px;border-radius:2px;background:#e0e0e0;flex:1;transition:background .2s}.t-dot.on{background:var(--blue)}.t-dot.done{background:var(--green)}.t-label{font-size:10px;font-weight:700;color:var(--blue);text-transform:uppercase;letter-spacing:.07em;margin-bottom:4px}.t-q{font-size:18px;font-weight:900;color:var(--black);line-height:1.3;margin-bottom:20px}.t-input{width:100%;border:1.5px solid #e0e0e0;border-radius:8px;padding:13px 14px;font-size:15px;color:var(--black);outline:none;transition:border-color .15s;margin-bottom:8px}.t-input:focus{border-color:var(--blue)}.t-opt{width:100%;padding:13px 16px;border-radius:8px;border:1.5px solid #e0e0e0;background:var(--white);font-size:14px;font-weight:500;color:var(--black);cursor:pointer;text-align:left;margin-bottom:9px;display:flex;justify-content:space-between;align-items:center;transition:all .15s}.t-opt:hover{border-color:var(--blue);background:#ebf6fc;color:var(--blue)}.t-opt.sel{border-color:var(--blue);background:#ebf6fc;color:var(--blue);font-weight:700}.t-back{padding:9px 16px;border-radius:8px;border:1.5px solid #e0e0e0;background:var(--white);color:#666;font-size:12px;font-weight:600;cursor:pointer}.t-next{padding:9px 22px;border-radius:8px;background:var(--blue);color:#fff;border:none;font-size:12px;font-weight:700;cursor:pointer}.t-next:disabled{opacity:.35;cursor:default}.t-option-btn{flex:1;padding:18px 12px;border-radius:12px;border:2px solid #e0e0e0;background:var(--white);cursor:pointer;text-align:center;transition:border-color .15s,background .15s;font-size:13px;color:var(--black)}.t-option-btn:hover{border-color:var(--blue);background:#f0f4ff}.t-option-btn.selected{border-color:var(--blue);background:#e8f0fe}.cal-wrap{background:#f9f9f9;border-radius:8px;padding:12px;margin-bottom:10px}.cal-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.cal-nav-btn{background:none;border:none;cursor:pointer;color:#888;font-size:18px;padding:2px 8px;border-radius:4px;line-height:1}.cal-nav-btn:hover{background:#eee}.cal-month-lbl{font-size:13px;font-weight:700;color:var(--black)}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.cal-dow{font-size:9px;font-weight:700;color:#bbb;text-align:center;padding:2px 0}.cal-day{font-size:11px;text-align:center;padding:6px 2px;border-radius:5px;cursor:pointer;color:var(--black);background:none;border:none;font-weight:500;width:100%}.cal-day:hover:not(:disabled){background:#ebf6fc;color:var(--blue)}.cal-day.sel{background:var(--blue);color:#fff;font-weight:700}.cal-day.today-mark{color:var(--blue);font-weight:900}.cal-day:disabled{color:#ccc;cursor:default}.time-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px}.time-box{background:var(--white);border:1px solid var(--border);border-radius:8px;padding:10px;text-align:center}.time-box-lbl{font-size:9px;font-weight:700;color:#aaa;text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}.time-val{font-size:20px;font-weight:900;color:var(--black);font-family:monospace;margin-bottom:6px}.adj-row{display:flex;justify-content:center;gap:6px}.adj-btn{width:26px;height:26px;border-radius:50%;border:1.5px solid #ddd;background:var(--white);font-size:14px;cursor:pointer;color:#555;display:flex;align-items:center;justify-content:center;font-weight:700}.adj-btn:hover{border-color:var(--blue);color:var(--blue)}.time-input{width:48px;text-align:center;font-size:20px;font-weight:900;font-family:monospace;color:var(--black);border:1.5px solid #e0e0e0;border-radius:6px;padding:4px 2px;outline:none;-moz-appearance:textfield}.time-input::-webkit-outer-spin-button,.time-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.time-input:focus{border-color:var(--blue)}.dur-input{width:60px;text-align:center;font-size:18px;font-weight:900;font-family:monospace;color:var(--black);border:1.5px solid #e0e0e0;border-radius:6px;padding:4px 2px;outline:none;-moz-appearance:textfield}.dur-input::-webkit-outer-spin-button,.dur-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.dur-input:focus{border-color:var(--blue)}.info-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #f5f5f5;font-size:13px}.info-row:last-child{border-bottom:none}.info-label{font-size:10px;font-weight:700;color:#aaa;text-transform:uppercase;letter-spacing:.05em}.info-val{font-size:13px;font-weight:500;color:var(--black)}.log-row{display:grid;grid-template-columns:130px 100px 70px 1fr;gap:8px;padding:8px 12px;font-size:12px;align-items:center;border-radius:6px}.empty-state{text-align:center;padding:40px 20px;color:var(--muted);font-size:13px}.confirm-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:200;align-items:center;justify-content:center}.confirm-overlay.open{display:flex}.confirm-box{background:var(--white);border-radius:14px;padding:24px;width:300px;border-top:4px solid var(--red)}.email-preview{background:#f9f9f9;border:1px solid var(--border);border-radius:8px;padding:14px;font-size:12px;line-height:1.8;color:var(--text);margin-top:10px}.email-preview b{color:var(--black)}.kiosk-wrap{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#1a1a1a;z-index:300;flex-direction:column;align-items:center;justify-content:center}.kiosk-wrap.open{display:flex}.kiosk-inner{width:480px;text-align:center}.kiosk-colour-bar{display:flex;height:6px;border-radius:3px;overflow:hidden;margin-bottom:32px}.kiosk-colour-bar div{flex:1}.kiosk-title{font-size:42px;font-weight:900;color:#fff;letter-spacing:-1px;margin-bottom:8px}.kiosk-sub{font-size:16px;color:#ffffff80;margin-bottom:40px}.kiosk-input{width:100%;background:#ffffff14;border:2px solid rgba(255,255,255,.15);border-radius:14px;padding:18px 22px;font-size:22px;color:#fff;outline:none;text-align:center;transition:border-color .2s;margin-bottom:16px}.kiosk-input:focus{border-color:var(--blue)}.kiosk-input::placeholder{color:#ffffff4d}.kiosk-btn{width:100%;padding:18px;border-radius:14px;background:var(--blue);color:#fff;border:none;font-size:18px;font-weight:700;cursor:pointer;transition:background .15s;margin-bottom:12px}.kiosk-btn:hover{background:#1589ba}.kiosk-btn:disabled{opacity:.3;cursor:default}.kiosk-notfound{background:#ff64641a;border:1px solid rgba(255,100,100,.3);border-radius:10px;padding:14px;color:#f99;font-size:13px;margin-top:10px}.kiosk-fun{font-size:14px;color:#ffffff59;margin-top:32px;font-style:italic}.kiosk-success-icon{width:80px;height:80px;border-radius:50%;background:var(--green);margin:0 auto 20px;display:flex;align-items:center;justify-content:center}.kiosk-success-name{font-size:32px;font-weight:900;color:#fff;margin-bottom:8px}.kiosk-success-msg{font-size:16px;color:#fff9;margin-bottom:8px}.kiosk-close{position:fixed;top:20px;right:20px;background:#ffffff1a;border:none;color:#ffffff80;font-size:12px;padding:8px 14px;border-radius:8px;cursor:pointer}.kiosk-close:hover{background:#fff3;color:#fff}.kiosk-privacy{display:flex;align-items:flex-start;gap:10px;padding:14px 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;font-size:12px;color:#ffffff80;cursor:pointer;text-align:left;margin-bottom:12px;line-height:1.5}.kiosk-privacy:hover{border-color:#fff3}.kiosk-match-btn{width:100%;padding:14px 18px;background:#ffffff0f;border:1.5px solid rgba(255,255,255,.12);border-radius:12px;color:#fff;text-align:left;cursor:pointer;margin-bottom:8px;transition:all .15s}.kiosk-match-btn:hover{background:#1b9bd133;border-color:var(--blue)}.kiosk-back-btn{background:none;border:none;color:#ffffff59;font-size:13px;cursor:pointer;margin-top:20px;padding:8px 16px;transition:color .15s}.kiosk-back-btn:hover{color:#fff9}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .35s ease forwards}@keyframes vivSlideIn{0%{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes stampIn{0%{opacity:0;transform:rotate(-12deg) scale(.7)}to{opacity:1;transform:rotate(-12deg) scale(1)}}.viv-card{position:relative;background:linear-gradient(145deg,#1c1c2e,#16213e,#0f3460);border:1px solid rgba(255,255,255,.12);border-radius:20px;overflow:hidden;padding:0 0 48px;text-align:center;animation:vivSlideIn .45s cubic-bezier(.22,1,.36,1) forwards;box-shadow:0 20px 60px #0009,0 0 0 1px #ffffff0f}.viv-card-bar{display:flex;height:7px}.viv-card-bar div{flex:1}.viv-card-top{padding:28px 24px 4px;display:flex;flex-direction:column;align-items:center;gap:6px}.viv-badge{display:inline-block;background:linear-gradient(135deg,#c9a227,#f0c040,#c9a227);color:#1a1000;font-size:13px;font-weight:900;letter-spacing:.25em;padding:5px 16px;border-radius:20px;text-transform:uppercase}.viv-subtitle{font-size:11px;font-weight:700;color:#ffffff59;text-transform:uppercase;letter-spacing:.15em}.viv-name{font-size:32px;font-weight:900;color:#fff;letter-spacing:-.5px;padding:20px 24px 6px;line-height:1.1}.viv-company{font-size:15px;color:#ffffff73;padding:0 24px 4px;font-weight:500}.viv-stamp{position:absolute;bottom:18px;right:18px;font-size:11px;font-weight:900;color:#8dc21fcc;letter-spacing:.12em;border:2px solid rgba(141,194,31,.4);border-radius:6px;padding:4px 10px;transform:rotate(-12deg);animation:stampIn .5s .35s cubic-bezier(.22,1,.36,1) both}
