@import "https://fonts.googleapis.com/css2?family=Chakra+Petch:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&family=Outfit:wght@300;400;500;600;700&display=swap";:root{--bg-base:#070c17;--bg-surface:#0d1626;--bg-card:#111e35;--bg-elevated:#172440;--bg-hover:#ffffff0a;--accent:#b8ff3c;--accent-dim:#b8ff3c1f;--accent-glow:#b8ff3c4d;--accent-dark:#94cc30;--success:#22d3a5;--success-dim:#22d3a51f;--danger:#ff4d6d;--danger-dim:#ff4d6d1f;--warning:#fbbf24;--warning-dim:#fbbf241f;--info:#38bdf8;--info-dim:#38bdf81f;--text-bright:#f0f6ff;--text-primary:#d4e4f7;--text-secondary:#8aafd4;--text-muted:#4d6a8a;--border:#ffffff0f;--border-card:#ffffff17;--border-accent:#b8ff3c59;--font-display:"Chakra Petch", sans-serif;--font-body:"Outfit", sans-serif;--sidebar-width:248px;--topbar-height:62px;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;color:var(--text-primary);font-family:var(--font-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f7f9fc}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff26}.btn{border-radius:var(--radius-sm);font-family:var(--font-body);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:6px;padding:9px 18px;font-size:13.5px;font-weight:600;text-decoration:none;transition:all .18s;display:inline-flex}.btn-primary{background:var(--accent);color:#070c17}.btn-primary:hover{box-shadow:0 0 24px var(--accent-glow);background:#cf5;transform:translateY(-1px)}.btn-ghost{color:var(--text-secondary);border:1px solid var(--border-card);background:0 0}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary);border-color:#ffffff26}.btn-danger{background:var(--danger-dim);color:var(--danger);border:1px solid #ff4d6d33}.btn-danger:hover{background:var(--danger);color:#fff}.btn-sm{padding:6px 12px;font-size:12.5px}.badge{font-size:11px;font-weight:700;font-family:var(--font-display);letter-spacing:.04em;text-transform:uppercase;border-radius:20px;align-items:center;padding:3px 9px;display:inline-flex}.badge-success{background:var(--success-dim);color:var(--success)}.badge-danger{background:var(--danger-dim);color:var(--danger)}.badge-warning{background:var(--warning-dim);color:var(--warning)}.badge-info{background:var(--info-dim);color:var(--info)}.badge-accent{background:var(--accent-dim);color:var(--accent)}.badge-muted{color:var(--text-secondary);background:#ffffff0d}.page-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:28px;display:flex}.page-title{font-family:var(--font-display);color:var(--text-bright);letter-spacing:-.01em;font-size:20px;font-weight:700}.page-subtitle{color:var(--text-secondary);margin-top:4px;font-size:13px;font-weight:400}.page-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);padding:22px}.card-header{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.card-title{font-family:var(--font-display);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.1em;font-size:11px;font-weight:600}input,select,textarea{font-family:var(--font-body)}.input-field{background:var(--bg-surface);border:1px solid var(--border-card);border-radius:var(--radius-sm);color:var(--text-primary);outline:none;width:100%;padding:10px 14px;font-size:14px;transition:border-color .18s,box-shadow .18s}.avatar{width:36px;height:36px;font-family:var(--font-display);color:#070c17;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.avatar-lg{width:52px;height:52px;font-size:18px}.avatar-sm{width:28px;height:28px;font-size:11px}.divider{background:var(--border);height:1px;margin:16px 0}.data-table{border-collapse:collapse;width:100%}.data-table th{font-family:var(--font-display);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;text-align:left;border-bottom:1px solid var(--border);padding:10px 14px;font-size:10.5px;font-weight:600}.data-table td{color:var(--text-primary);border-bottom:1px solid var(--border);padding:12px 14px;font-size:13.5px}.data-table tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:var(--bg-hover)}.data-table tbody tr{cursor:pointer;transition:background .15s}.tabs{background:var(--bg-surface);border-radius:var(--radius-sm);gap:4px;padding:4px;display:flex}.tab-item{cursor:pointer;color:var(--text-secondary);font-size:13px;font-weight:500;font-family:var(--font-body);background:0 0;border:none;border-radius:4px;padding:7px 14px;transition:all .15s}.tab-item:hover{color:var(--text-primary)}.tab-item.active{background:var(--bg-card);color:var(--text-bright);font-weight:600}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#000000b3;justify-content:center;align-items:center;padding:20px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-xl);width:100%;max-width:500px;max-height:90vh;padding:28px;animation:.2s slideUp;overflow-y:auto}.modal-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.modal-title{font-family:var(--font-display);color:var(--text-bright);font-size:16px;font-weight:700}.modal-close{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;border-radius:4px;align-items:center;padding:4px;transition:color .15s;display:flex}.modal-close:hover{color:var(--text-primary)}.form-group{margin-bottom:16px}.form-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-size:12.5px;font-weight:600;display:block}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-footer{justify-content:flex-end;gap:8px;margin-top:24px;display:flex}.search-wrap{align-items:center;display:flex;position:relative}.search-wrap svg{color:var(--text-secondary);pointer-events:none;position:absolute;left:12px}.search-wrap .input-field{padding-left:38px}.settings-nav{flex-direction:column;flex-shrink:0;gap:2px;width:200px;padding:12px;display:flex}.settings-nav-item{border-radius:var(--radius-sm);color:var(--text-secondary);font-family:var(--font-body);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:9px;width:100%;padding:9px 12px;font-size:13.5px;font-weight:500;transition:all .15s;display:flex}.settings-nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.settings-nav-item.active{background:var(--accent-dim);color:var(--accent)}.settings-content{flex:1;min-width:0}.settings-section-title{font-family:var(--font-display);color:var(--text-primary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:20px;font-size:13px;font-weight:700}.settings-help-text{color:var(--text-secondary);margin:-8px 0 16px;font-size:12.5px;line-height:1.5}.class-type-list{flex-direction:column;gap:6px;margin-bottom:16px;display:flex}.class-type-row{background:var(--bg-surface);border-radius:var(--radius-sm);align-items:center;gap:12px;padding:10px 14px;display:flex}.class-type-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.class-type-name{color:var(--text-primary);flex:1;font-size:13.5px;font-weight:500}.toggle-wrap{align-items:center;display:flex}.toggle{background:var(--text-muted);cursor:pointer;border-radius:10px;width:38px;height:20px;transition:background .2s;position:relative}.toggle:after{content:"";background:#fff;border-radius:50%;width:14px;height:14px;transition:transform .2s;position:absolute;top:3px;left:3px}.toggle.on{background:var(--accent)}.toggle.on:after{background:#070c17;transform:translate(18px)}.add-class-row{align-items:center;gap:8px;display:flex}.notif-settings-list{flex-direction:column;gap:0;display:flex}.notif-setting-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:16px;padding:14px 0;display:flex}.notif-setting-row:last-child{border-bottom:none}.notif-setting-label{color:var(--text-primary);font-size:13.5px;font-weight:600}.notif-setting-desc{color:var(--text-secondary);margin-top:3px;font-size:12px}.staff-row{background:var(--bg-surface);border-radius:var(--radius-sm);align-items:center;gap:12px;padding:12px 14px;display:flex}.settings-staff-form{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-bottom:16px;display:grid}@media (width<=900px){.settings-staff-form{grid-template-columns:1fr}}.table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.table-wrap .data-table{min-width:600px}@media (width<=768px){.data-table{-webkit-overflow-scrolling:touch;min-width:unset;width:100%;display:block;overflow-x:auto}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@media (width<=768px){.page-header{flex-direction:column;gap:12px;margin-bottom:20px}.page-actions{flex-wrap:wrap;width:100%}.form-row{grid-template-columns:1fr}.modal{border-radius:var(--radius-lg);max-height:95vh;padding:20px 16px}.card{padding:16px}.tabs{flex-wrap:nowrap;overflow-x:auto}.settings-nav{border-bottom:1px solid var(--border);flex-flow:row;width:100%;padding:8px;overflow-x:auto}.settings-nav-item{white-space:nowrap;flex-shrink:0}}@media (width<=480px){.page-title{font-size:17px}.btn{padding:8px 14px;font-size:13px}.modal{padding:16px 14px}.modal-overlay{padding:12px}}.sidebar{height:100vh;width:var(--sidebar-width);background:var(--bg-surface);border-right:1px solid var(--border);z-index:100;flex-direction:column;transition:width .28s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;left:0;overflow:hidden}.sidebar.closed{width:68px}.sidebar-logo{border-bottom:1px solid var(--border);min-height:var(--topbar-height);align-items:center;gap:10px;padding:18px 16px;display:flex;position:relative}.logo-icon{background:var(--accent);color:#070c17;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.logo-text{font-family:var(--font-display);color:var(--text-bright);letter-spacing:.02em;white-space:nowrap;font-size:17px;font-weight:700}.sidebar-toggle{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;flex-shrink:0;align-items:center;margin-left:auto;padding:4px;transition:color .15s,transform .28s;display:flex}.sidebar-toggle:hover{color:var(--text-primary)}.sidebar-toggle svg.rotated{transform:rotate(180deg)}.sidebar-nav{flex-direction:column;gap:2px;padding:12px 10px 4px;display:flex}.nav-group-label{font-family:var(--font-display);color:var(--text-muted);letter-spacing:.14em;white-space:nowrap;padding:6px 8px 4px;font-size:9.5px;font-weight:600}.nav-item{border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;white-space:nowrap;align-items:center;gap:10px;min-height:38px;padding:9px 10px;text-decoration:none;transition:all .15s;display:flex}.nav-item:hover{background:var(--bg-hover);color:var(--text-bright)}.nav-item.active{background:var(--accent-dim);color:var(--accent)}.nav-item.active .nav-icon{color:var(--accent)}.nav-icon{flex-shrink:0;justify-content:center;align-items:center;width:20px;display:flex}.nav-label{font-size:13.5px;font-weight:500}.sidebar-spacer{flex:1}.sidebar-bottom-nav{border-top:1px solid var(--border);padding-top:12px;padding-bottom:12px}.sidebar-user{border-radius:var(--radius-sm);align-items:center;gap:10px;margin-top:2px;padding:8px 10px;display:flex}.user-avatar{background:var(--accent-dim);width:30px;height:30px;color:var(--accent);font-family:var(--font-display);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex}.user-info{flex:1;overflow:hidden}.user-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.user-role{color:var(--text-secondary);white-space:nowrap;font-size:11px}.logout-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;flex-shrink:0;align-items:center;padding:4px;transition:color .15s;display:flex}.logout-btn:hover{color:var(--danger)}@media (width<=768px){.sidebar{z-index:200;transition:transform .28s cubic-bezier(.4,0,.2,1);transform:translate(-100%);width:var(--sidebar-width)!important}.sidebar.open{transform:translate(0)}}.admin-sidebar{height:100vh;width:var(--sidebar-width);background:var(--bg-surface);border-right:1px solid var(--border);z-index:100;flex-direction:column;transition:width .28s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;left:0;overflow:hidden}.admin-sidebar.closed{width:68px}.admin-sidebar-logo{border-bottom:1px solid var(--border);min-height:var(--topbar-height);align-items:center;gap:10px;padding:18px 16px;display:flex}.admin-logo-icon{background:var(--accent);color:#070c17;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.admin-logo-text-wrap{white-space:nowrap;align-items:center;gap:8px;display:flex;overflow:hidden}.admin-sidebar.closed .admin-logo-text-wrap,.admin-sidebar.closed .admin-nav-group-label,.admin-sidebar.closed .admin-nav-label,.admin-sidebar.closed .admin-user-info,.admin-sidebar.closed .admin-user-role{display:none}.admin-logo-text{font-family:var(--font-display);color:var(--text-bright);letter-spacing:.02em;white-space:nowrap;font-size:17px;font-weight:700}.admin-badge{font-family:var(--font-display);letter-spacing:.12em;color:#070c17;background:var(--accent);border-radius:4px;padding:2px 6px;font-size:9px;font-weight:700}.admin-sidebar-nav{flex-direction:column;gap:2px;padding:12px 10px 4px;display:flex}.admin-nav-group-label{font-family:var(--font-display);color:var(--text-muted);letter-spacing:.14em;white-space:nowrap;padding:6px 8px 4px;font-size:9.5px;font-weight:600}.admin-nav-item{border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;white-space:nowrap;align-items:center;gap:10px;min-height:38px;padding:9px 10px;text-decoration:none;transition:all .15s;display:flex}.admin-nav-item:hover{background:var(--bg-hover);color:var(--text-bright)}.admin-nav-item.active{background:var(--accent-dim);color:var(--accent)}.admin-nav-item.active .admin-nav-icon{color:var(--accent)}.admin-nav-icon{flex-shrink:0;justify-content:center;align-items:center;width:20px;display:flex}.admin-nav-label{font-size:13.5px;font-weight:500}.admin-sidebar-spacer{flex:1}.admin-sidebar-bottom-nav{border-top:1px solid var(--border);padding-top:12px;padding-bottom:12px}.admin-sidebar-user{border-radius:var(--radius-sm);align-items:center;gap:10px;margin-top:2px;padding:8px 10px;display:flex}.admin-user-avatar{background:var(--accent-dim);width:30px;height:30px;color:var(--accent);font-family:var(--font-display);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex}.admin-user-info{flex:1;overflow:hidden}.admin-user-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.admin-user-role{color:var(--text-secondary);white-space:nowrap;font-size:11px}@media (width<=768px){.admin-sidebar{z-index:200;transition:transform .28s cubic-bezier(.4,0,.2,1);transform:translate(-100%);width:var(--sidebar-width)!important}.admin-sidebar.open{transform:translate(0)}.admin-sidebar-logo{position:relative}}.theme-overlay{z-index:1200;position:fixed;inset:0}.theme-panel{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);z-index:1300;width:340px;max-height:calc(100vh - 80px);animation:.18s slideDown;position:fixed;top:62px;right:16px;overflow-y:auto;box-shadow:0 20px 60px #0009}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.theme-panel-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;padding:20px 20px 16px;display:flex}.theme-panel-title{font-family:var(--font-display);color:var(--text-bright);letter-spacing:.02em;font-size:14px;font-weight:700}.theme-panel-sub{color:var(--text-secondary);margin-top:3px;font-size:12px}.theme-close{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;border-radius:4px;flex-shrink:0;align-items:center;padding:2px;transition:color .15s;display:flex}.theme-close:hover{color:var(--text-bright)}.theme-section{padding:0 16px 4px}.theme-section:first-of-type{padding-top:14px}.theme-section-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;font-size:11px;font-weight:700;font-family:var(--font-display);margin-bottom:10px}.theme-grid{grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:12px;display:grid}.theme-card{border:1.5px solid var(--border-card);border-radius:var(--radius-md);cursor:pointer;background:0 0;padding:0;transition:border-color .18s,transform .15s,box-shadow .18s;overflow:hidden}.theme-card.is-light{border-color:#0000001f}.theme-card:hover{border-color:var(--card-accent,var(--accent));transform:translateY(-1px)}.theme-card.active{border-color:var(--card-accent,var(--accent));box-shadow:0 0 0 2px var(--card-accent,var(--accent))}.theme-preview{border-radius:var(--radius-sm) var(--radius-sm) 0 0;height:72px;display:flex;overflow:hidden}.preview-sidebar{flex-direction:column;flex-shrink:0;align-items:center;gap:4px;width:30px;padding:6px 4px;display:flex}.preview-logo{border-radius:3px;flex-shrink:0;width:14px;height:14px;margin-bottom:2px}.preview-nav-item{border-radius:2px;width:100%;height:6px}.preview-content{flex-direction:column;flex:1;gap:4px;min-width:0;padding:6px;display:flex}.preview-topbar{border-radius:2px;flex-shrink:0;height:10px}.preview-cards{flex:1;gap:4px;display:flex}.preview-card{border-radius:3px;flex:1;align-items:flex-start;padding:3px;display:flex}.preview-card-dot{border-radius:50%;width:6px;height:6px}.preview-bar{border-radius:3px;flex-shrink:0;height:8px;overflow:hidden}.preview-bar-fill{border-radius:3px;height:100%}.theme-card-footer{align-items:center;gap:7px;padding:8px 10px;display:flex}.theme-color-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.theme-name{color:var(--text-primary);font-size:11.5px;font-weight:600;font-family:var(--font-display);flex:1}.theme-check{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;display:flex}.theme-panel-footer{border-top:1px solid var(--border);color:var(--text-secondary);align-items:center;gap:10px;padding:12px 16px;font-size:12.5px;display:flex}.theme-panel-footer strong{color:var(--text-primary)}.accent-preview{border-radius:50%;flex-shrink:0;width:18px;height:18px}.theme-mode-badge{font-size:10.5px;font-weight:700;font-family:var(--font-display);background:var(--accent-dim);color:var(--accent);text-transform:uppercase;letter-spacing:.05em;border-radius:20px;margin-left:auto;padding:2px 8px}.topbar{height:var(--topbar-height);background:var(--bg-surface);border-bottom:1px solid var(--border);z-index:50;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:0 20px 0 24px;display:flex;position:sticky;top:0}.topbar-left{align-items:center;gap:10px;display:flex}.topbar-right{align-items:center;gap:6px;display:flex}.topbar-icon-btn{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;align-items:center;padding:7px;transition:all .15s;display:flex;position:relative}.topbar-icon-btn:hover,.topbar-icon-btn.active{background:var(--bg-hover);color:var(--text-primary)}.topbar-breadcrumb{align-items:center;gap:7px;font-size:13px;display:flex}.breadcrumb-brand{font-family:var(--font-display);color:var(--text-secondary);font-size:12.5px;font-weight:600}.breadcrumb-sep{color:var(--text-muted)}.breadcrumb-page{color:var(--text-primary);font-weight:600}.topbar-search-expand{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-sm);color:var(--text-secondary);align-items:center;gap:8px;padding:6px 10px;display:flex}.topbar-search-input{color:var(--text-primary);font-family:var(--font-body);background:0 0;border:none;outline:none;width:200px;font-size:13.5px}.topbar-search-input::placeholder{color:var(--text-secondary)}.notif-dot{background:var(--danger);border:1.5px solid var(--bg-surface);border-radius:50%;width:7px;height:7px;position:absolute;top:5px;right:5px}.notif-wrap{position:relative}.notif-overlay{z-index:200;position:fixed;inset:0}.notif-panel{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);z-index:300;width:320px;animation:.18s slideUp;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 20px 60px #00000080}.notif-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.notif-title{font-family:var(--font-display);color:var(--text-bright);letter-spacing:.04em;font-size:13px;font-weight:700}.notif-list{padding:8px 0}.notif-item{cursor:pointer;align-items:flex-start;gap:10px;padding:10px 16px;transition:background .15s;display:flex}.notif-item:hover{background:var(--bg-hover)}.notif-dot-side{border-radius:50%;flex-shrink:0;width:7px;height:7px;margin-top:5px}.notif-warning .notif-dot-side{background:var(--warning)}.notif-info .notif-dot-side{background:var(--info)}.notif-danger .notif-dot-side{background:var(--danger)}.notif-success .notif-dot-side{background:var(--success)}.notif-msg{color:var(--text-primary);font-size:13px;line-height:1.4}.notif-time{color:var(--text-secondary);margin-top:3px;font-size:11px}.topbar-user{border:1px solid var(--border-card);cursor:pointer;border-radius:24px;align-items:center;gap:8px;padding:4px 10px 4px 4px;transition:border-color .15s;display:flex}.topbar-user:hover{border-color:#ffffff26}.topbar-avatar{background:var(--accent-dim);width:28px;height:28px;color:var(--accent);font-family:var(--font-display);border-radius:50%;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex}.topbar-username{color:var(--text-primary);font-size:13px;font-weight:600}@media (width<=768px){.topbar{padding:0 12px 0 14px}.topbar-username{display:none}.topbar-search-input{width:120px}.notif-panel{width:calc(100vw - 24px);right:-12px}.breadcrumb-brand,.breadcrumb-sep{display:none}}@media (width<=480px){.topbar-search-expand{height:var(--topbar-height);border:none;border-bottom:1px solid var(--border);background:var(--bg-surface);z-index:10;border-radius:0;padding:0 14px;position:absolute;top:0;left:0;right:0}.topbar-search-input{width:100%}}.dashboard{animation:.3s fadeIn}.live-badge{background:var(--danger-dim);color:var(--danger);font-family:var(--font-display);letter-spacing:.1em;border:1px solid #ff4d6d33;border-radius:20px;align-items:center;gap:7px;padding:6px 14px;font-size:11px;font-weight:700;display:flex}.live-dot{background:var(--danger);border-radius:50%;width:7px;height:7px;animation:1.4s ease-in-out infinite pulse}.stat-grid{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);align-items:flex-start;gap:16px;padding:20px;transition:border-color .2s,transform .2s;display:flex}.stat-card:hover{transform:translateY(-2px)}.stat-icon-wrap{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;display:flex}.stat-accent .stat-icon-wrap{background:var(--accent-dim);color:var(--accent)}.stat-info .stat-icon-wrap{background:var(--info-dim);color:var(--info)}.stat-success .stat-icon-wrap{background:var(--success-dim);color:var(--success)}.stat-warning .stat-icon-wrap{background:var(--warning-dim);color:var(--warning)}.stat-accent{border-top:2px solid var(--accent)}.stat-info{border-top:2px solid var(--info)}.stat-success{border-top:2px solid var(--success)}.stat-warning{border-top:2px solid var(--warning)}.stat-body{flex:1;min-width:0}.stat-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-size:11.5px;font-weight:500}.stat-value{font-family:var(--font-display);color:var(--text-bright);align-items:baseline;gap:4px;font-size:26px;font-weight:700;line-height:1;display:flex}.stat-unit{color:var(--text-secondary);font-size:14px;font-weight:500}.stat-change{align-items:center;gap:3px;margin-top:6px;font-size:11.5px;font-weight:600;display:flex}.stat-change.up{color:var(--success)}.stat-change.down{color:var(--danger)}.stat-sub{color:var(--text-secondary);margin-top:6px;font-size:11.5px}.dash-charts{grid-template-columns:1fr 1fr;gap:14px;margin-bottom:20px;display:grid}.dash-chart-card{overflow:hidden}.chart-tooltip{background:var(--bg-elevated);border:1px solid var(--border-card);border-radius:var(--radius-sm);padding:8px 12px}.ct-label{font-family:var(--font-display);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:3px;font-size:11px}.ct-value{font-family:var(--font-display);color:var(--text-bright);font-size:14px;font-weight:700}.dash-bottom{grid-template-columns:1fr 360px;gap:14px;display:grid}.dash-right-col{flex-direction:column;gap:14px;display:flex}.class-list{flex-direction:column;gap:6px;display:flex}.class-row{border-radius:var(--radius-sm);background:var(--bg-surface);align-items:center;gap:12px;padding:10px 12px;transition:background .15s;display:flex}.class-row:hover{background:var(--bg-elevated)}.class-time-dot{flex-direction:column;flex-shrink:0;align-items:center;gap:4px;width:44px;display:flex}.class-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.class-time{font-family:var(--font-display);color:var(--text-secondary);white-space:nowrap;align-items:center;gap:3px;font-size:10.5px;display:flex}.class-info{flex:1;min-width:0}.class-name{color:var(--text-primary);font-size:13.5px;font-weight:600}.class-instructor{color:var(--text-secondary);margin-top:2px;font-size:11.5px}.class-capacity{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:4px;width:60px;display:flex}.cap-bar{background:#ffffff0f;border-radius:2px;width:100%;height:4px;overflow:hidden}.cap-fill{border-radius:2px;height:100%;transition:width .6s}.cap-text{font-family:var(--font-display);font-size:11px;font-weight:600}.expire-list{flex-direction:column;gap:10px;display:flex}.expire-row{align-items:center;gap:10px;display:flex}.expire-info{flex:1;min-width:0}.expire-name{color:var(--text-primary);font-size:13.5px;font-weight:600}.expire-plan{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:11.5px;overflow:hidden}.expire-days{font-family:var(--font-display);color:var(--warning);flex-shrink:0;font-size:13px;font-weight:700}.expire-days.urgent{color:var(--danger)}.recent-list{flex-direction:column;gap:10px;display:flex}.recent-row{align-items:center;gap:10px;display:flex}.recent-info{flex:1;min-width:0}.recent-name{color:var(--text-primary);font-size:13.5px;font-weight:600}.recent-plan{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:11.5px;overflow:hidden}.recent-date{font-family:var(--font-display);color:var(--text-secondary);flex-shrink:0;font-size:11.5px}@media (width<=1100px){.stat-grid{grid-template-columns:repeat(2,1fr)}.dash-charts,.dash-bottom{grid-template-columns:1fr}}@media (width<=480px){.stat-grid{grid-template-columns:1fr}.stat-card{gap:12px;padding:14px}.stat-value{font-size:22px}}.members-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px;display:flex}.tab-count{color:var(--text-secondary);font-size:11px;font-family:var(--font-display);background:#ffffff12;border-radius:10px;margin-left:4px;padding:1px 7px;font-weight:600}.tab-item.active .tab-count{background:var(--accent-dim);color:var(--accent)}.member-cell{align-items:center;gap:10px;display:flex}.member-name{color:var(--text-bright);font-size:13.5px;font-weight:600}.member-meta{color:var(--text-secondary);margin-top:2px;font-size:11.5px}.member-segment-row{flex-wrap:wrap;gap:6px;margin-top:6px;display:flex}.phone-cell{color:var(--text-secondary);align-items:center;gap:5px;font-size:13px;display:flex}.plan-tag{background:var(--bg-surface);color:var(--text-primary);white-space:nowrap;border-radius:6px;padding:4px 10px;font-size:12.5px;display:inline-flex}.expiry-cell{font-size:13px;font-family:var(--font-display);color:var(--text-secondary);align-items:center;gap:5px;display:flex}.attendance-cell{color:var(--text-secondary);font-size:12.5px;font-family:var(--font-display);align-items:center;gap:8px;display:flex}.att-bar-bg{background:#ffffff0f;border-radius:3px;width:60px;height:5px;overflow:hidden}.att-bar-fill{background:var(--accent);border-radius:3px;height:100%;transition:width .5s}.members-feedback{min-height:180px;color:var(--text-secondary);justify-content:center;align-items:center;gap:10px;font-size:14px;display:flex}.members-feedback-error{color:var(--danger)}.form-help{color:var(--text-secondary);margin-top:12px;font-size:12px;line-height:1.5}.form-error{color:var(--danger);margin-top:12px;font-size:12.5px}.spin{animation:.9s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.back-btn{color:var(--text-secondary);font-family:var(--font-body);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;margin-bottom:18px;padding:6px 0;font-size:13px;transition:color .15s;display:inline-flex}.back-btn:hover{color:var(--text-primary)}.member-profile-card{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px;display:flex}.profile-left{align-items:center;gap:16px;display:flex}.profile-info{flex-direction:column;gap:6px;display:flex}.profile-name{font-family:var(--font-display);color:var(--text-bright);font-size:20px;font-weight:700}.profile-meta{color:var(--text-secondary);flex-wrap:wrap;align-items:center;gap:8px;font-size:13px;display:flex}.profile-sep{color:var(--text-muted)}.profile-actions{gap:8px;display:flex}.member-stats-grid{grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:20px;display:grid}.mstat-card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);align-items:flex-start;gap:14px;padding:18px;display:flex}.mstat-icon{background:var(--accent-dim);width:40px;height:40px;color:var(--accent);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.mstat-body{flex:1;min-width:0}.mstat-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:5px;font-size:11px;font-weight:600}.mstat-value{font-family:var(--font-display);color:var(--text-bright);font-size:14px;font-weight:700;line-height:1.2}.mstat-big{font-size:22px}.mstat-sub{color:var(--text-secondary);margin-top:4px;font-size:11.5px}.member-tabs{border-bottom:1px solid var(--border);padding:0 4px;display:flex}.member-tab-btn{color:var(--text-secondary);font-family:var(--font-body);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:14px 18px;font-size:13.5px;font-weight:500;transition:all .15s}.member-tab-btn:hover{color:var(--text-primary)}.member-tab-btn.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.plan-tag{background:var(--bg-surface);color:var(--text-primary);border-radius:6px;padding:4px 10px;font-size:12.5px;display:inline-flex}.member-empty{text-align:center;color:var(--text-secondary);padding:32px 24px;font-size:13.5px}.member-save-success,.member-save-error{margin-top:12px;font-size:12.5px}.member-row-sub{color:var(--text-secondary);margin-top:4px;font-size:12px}.member-inline-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.member-save-success{color:var(--success)}.member-save-error{color:var(--danger)}.member-detail-help{color:var(--text-secondary);margin-top:10px;font-size:12.5px;line-height:1.55}.member-rewards-wrap{gap:16px;padding:18px;display:grid}.member-reward-panel{border:1px solid var(--border);background:var(--bg-card);border-radius:14px;overflow:hidden}.member-reward-title{border-bottom:1px solid var(--border);font-family:var(--font-display);color:var(--text-bright);padding:14px 16px;font-size:14px;font-weight:700}@media (width<=900px){.member-stats-grid{grid-template-columns:1fr 1fr}}@media (width<=640px){.member-stats-grid{grid-template-columns:1fr}}.membership-summary{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);align-items:center;gap:0;margin-bottom:24px;padding:20px 28px;display:flex}.ms-stat{flex-direction:column;gap:4px;display:flex}.ms-num{font-family:var(--font-display);color:var(--accent);font-size:26px;font-weight:700}.ms-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;font-size:12px}.ms-divider{background:var(--border);width:1px;height:40px;margin:0 32px}.plan-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;display:grid}.plan-card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);flex-direction:column;transition:border-color .2s,transform .2s;display:flex;overflow:hidden}.plan-card:hover{border-color:#ffffff26;transform:translateY(-2px)}.plan-card-top{padding:20px 20px 16px}.plan-cat-badge{font-family:var(--font-display);letter-spacing:.05em;text-transform:uppercase;border-radius:20px;margin-bottom:12px;padding:3px 10px;font-size:10.5px;font-weight:700;display:inline-flex}.plan-name{font-family:var(--font-display);color:var(--text-bright);margin-bottom:10px;font-size:16px;font-weight:700}.plan-price{font-family:var(--font-display);color:var(--text-bright);align-items:baseline;gap:4px;font-size:24px;font-weight:700;display:flex}.plan-price-unit{color:var(--text-secondary);font-size:13px;font-weight:400}.plan-per{color:var(--text-secondary);margin-top:4px;font-size:12px}.plan-desc{color:var(--text-secondary);flex:1;padding:14px 20px;font-size:13px;line-height:1.5}.plan-card-footer{flex-wrap:wrap;gap:16px;padding:0 20px 16px;display:flex}.plan-meta-item{color:var(--text-secondary);align-items:center;gap:5px;font-size:12.5px;display:flex}.plan-card-actions{border-top:1px solid var(--border);gap:8px;padding:14px 20px;display:flex}.plan-card-actions .btn{flex:1;justify-content:center}.schedule-legend{flex-wrap:wrap;gap:16px;margin-bottom:16px;display:flex}.schedule-status-tabs{margin-bottom:16px;display:inline-flex}.legend-item{color:var(--text-secondary);align-items:center;gap:6px;font-size:12.5px;display:flex}.legend-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.schedule-grid-wrap{overflow-x:auto}.schedule-grid{grid-template-columns:52px repeat(7,1fr);min-width:700px;display:grid}.sched-corner{background:var(--bg-surface);border-bottom:1px solid var(--border);border-right:1px solid var(--border);z-index:2;padding:10px;position:sticky;left:0}.sched-day-header{background:var(--bg-surface);border-bottom:1px solid var(--border);border-right:1px solid var(--border);text-align:center;flex-direction:column;gap:2px;padding:10px 8px;display:flex}.sched-day-header.today{background:var(--accent-dim)}.sched-day{font-family:var(--font-display);color:var(--text-primary);font-size:13px;font-weight:700}.sched-day-header.today .sched-day{color:var(--accent)}.sched-date{color:var(--text-secondary);font-size:11px;font-family:var(--font-display)}.sched-time{background:var(--bg-surface);border-bottom:1px solid var(--border);border-right:1px solid var(--border);text-align:right;font-family:var(--font-display);color:var(--text-muted);z-index:1;justify-content:flex-end;align-items:flex-start;padding:8px 6px;font-size:11px;display:flex;position:sticky;left:0}.sched-cell{border-bottom:1px solid var(--border);border-right:1px solid var(--border);min-height:52px;padding:3px;position:relative}.class-block{cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;width:100%;min-height:46px;padding:6px 8px;transition:filter .15s}.class-block:hover{filter:brightness(1.15)}.class-block.inactive{opacity:.52}.cb-name{font-family:var(--font-display);white-space:nowrap;text-overflow:ellipsis;font-size:11px;font-weight:700;line-height:1.2;overflow:hidden}.cb-instructor{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:10.5px;overflow:hidden}.cb-cap{align-items:center;gap:4px;margin-top:4px;display:flex}.cb-cap-track{background:#ffffff14;border-radius:2px;flex:1;height:3px;overflow:hidden}.cb-cap-bar{background:#ffffff14;border-radius:2px;height:100%;transition:width .2s}.cb-cap-num{font-size:9.5px;font-family:var(--font-display);color:var(--text-secondary);white-space:nowrap}.class-detail-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 0;display:flex}.class-detail-row:last-child{border-bottom:none}.cd-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;font-size:12px;font-weight:500}.cd-value{font-family:var(--font-display);color:var(--text-primary);font-size:13.5px;font-weight:600}.att-hourly-card{margin-bottom:24px}.hourly-bars{align-items:flex-end;gap:6px;height:80px;padding-top:8px;display:flex}.hour-bar-wrap{flex-direction:column;flex:1;align-items:center;gap:4px;height:100%;display:flex}.hour-bar-container{flex:1;align-items:flex-end;width:100%;display:flex}.hour-bar-fill{background:var(--accent);border-radius:3px 3px 0 0;justify-content:center;align-items:flex-start;width:100%;min-height:4px;transition:height .5s;display:flex;position:relative}.hour-bar-count{font-family:var(--font-display);color:#070c17;margin-top:2px;font-size:9px;font-weight:700}.hour-label{font-family:var(--font-display);color:var(--text-muted);font-size:10px}.att-header-row{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.section-title{font-family:var(--font-display);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;font-size:14px;font-weight:700}.checkin-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px;display:grid}.checkin-card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);align-items:center;gap:12px;padding:14px 16px;transition:border-color .15s;display:flex;position:relative}.checkin-card:hover{border-color:#ffffff26}.checkin-avatar{width:38px;height:38px;font-family:var(--font-display);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:15px;font-weight:700;display:flex}.checkin-info{flex:1;min-width:0}.checkin-name{color:var(--text-bright);font-size:13.5px;font-weight:700}.checkin-plan{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;margin-top:1px;font-size:11px;overflow:hidden}.checkin-class{color:var(--accent);margin-top:1px;font-size:11px}.checkin-time-wrap{flex-direction:column;flex-shrink:0;align-items:center;gap:3px;display:flex}.checkin-time{font-family:var(--font-display);color:var(--success);font-size:13px;font-weight:700}.checkin-delete-btn{width:30px;height:30px;color:var(--danger);cursor:pointer;background:#f871711a;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.checkin-delete-btn:disabled{opacity:.6;cursor:default}.manual-results{flex-direction:column;gap:6px;max-height:240px;display:flex;overflow-y:auto}.manual-result-row{border-radius:var(--radius-sm);background:var(--bg-surface);cursor:pointer;align-items:center;gap:10px;padding:10px;transition:background .15s;display:flex}.manual-result-row:hover{background:var(--bg-elevated)}.empty-state{text-align:center;color:var(--text-secondary);padding:40px;font-size:14px}.instructor-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;display:grid}.instructor-status-tabs{margin-bottom:16px;display:inline-flex}.instructor-card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);cursor:pointer;flex-direction:column;gap:10px;padding:20px;transition:border-color .2s,transform .2s;display:flex}.instructor-card:hover{border-color:#ffffff2e;transform:translateY(-2px)}.instructor-card.inactive{opacity:.58}.inst-card-top{justify-content:space-between;align-items:center;display:flex}.inst-avatar{width:52px;height:52px;font-family:var(--font-display);border:2px solid #0000;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:20px;font-weight:700;display:flex}.inst-rating{font-family:var(--font-display);color:var(--warning);align-items:center;gap:4px;font-size:13.5px;font-weight:700;display:flex}.inst-name{font-family:var(--font-display);color:var(--text-bright);font-size:17px;font-weight:700}.inst-specialty{flex-wrap:wrap;gap:6px;display:flex}.spec-tag{background:var(--bg-surface);color:var(--text-secondary);border-radius:20px;padding:3px 9px;font-size:11.5px;display:inline-flex}.inst-bio{color:var(--text-secondary);font-size:12.5px;line-height:1.5}.inst-stats{border-top:1px solid var(--border);border-bottom:1px solid var(--border);gap:20px;padding:12px 0;display:flex}.istat{flex-direction:column;gap:2px;display:flex}.istat-num{font-family:var(--font-display);color:var(--text-bright);font-size:18px;font-weight:700}.istat-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:11px}.inst-contact{color:var(--text-secondary);align-items:center;gap:6px;font-size:12.5px;display:flex}.detail-schedule{margin-bottom:12px}.inst-detail-meta{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.inst-detail-line{color:var(--text-secondary);align-items:center;gap:8px;font-size:12.5px;display:flex}.sched-row{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:8px 0;display:flex}.sched-row:last-child{border-bottom:none}.sched-day-badge{font-family:var(--font-display);color:var(--accent);flex-shrink:0;width:24px;font-size:12px;font-weight:700}.sched-classes{flex-wrap:wrap;gap:6px;display:flex}.sched-class-tag{background:var(--bg-surface);color:var(--text-primary);border-radius:5px;padding:3px 9px;font-size:12px;display:inline-flex}.payment-kpis{grid-template-columns:1.5fr 1fr 1fr 1fr;gap:14px;margin-bottom:20px;display:grid}.kpi-card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);flex-direction:column;gap:6px;padding:20px;display:flex}.kpi-main{border-top:2px solid var(--accent)}.kpi-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;font-size:11.5px;font-weight:600}.kpi-amount{font-family:var(--font-display);color:var(--text-bright);margin-top:4px;font-size:28px;font-weight:700;line-height:1}.kpi-change{align-items:center;gap:4px;margin-top:2px;font-size:12px;font-weight:600;display:flex}.kpi-change.up{color:var(--success)}.kpi-change.down{color:var(--danger)}.kpi-icon{background:var(--accent-dim);width:36px;height:36px;color:var(--accent);border-radius:9px;justify-content:center;align-items:center;display:flex}.kpi-stat-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-top:4px;font-size:11.5px;font-weight:600}.kpi-stat-value{font-family:var(--font-display);color:var(--text-bright);font-size:20px;font-weight:700}.payment-charts{flex-wrap:wrap;gap:14px;margin-bottom:20px;display:flex}.pie-wrap{align-items:center;gap:16px;display:flex}.pie-legend{flex-direction:column;flex:1;gap:8px;display:flex}.pie-legend-row{align-items:center;gap:8px;display:flex}.pie-legend-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.pie-legend-label{color:var(--text-secondary);flex:1;font-size:12.5px}.pie-legend-val{font-family:var(--font-display);color:var(--text-primary);font-size:12.5px;font-weight:700}.empty-inline{color:var(--text-secondary);font-size:12.5px}@media (width<=1000px){.payment-kpis{grid-template-columns:1fr 1fr}}.marketing-kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:18px;display:grid}.marketing-kpi-card,.marketing-segment-card,.marketing-log-card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);padding:18px}.marketing-kpi-label,.marketing-segment-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;font-size:12px}.marketing-kpi-value,.marketing-segment-count{font-family:var(--font-display);color:var(--text-bright);margin-top:8px;font-size:28px}.marketing-kpi-sub,.marketing-segment-desc,.marketing-list-meta,.marketing-help{color:var(--text-secondary);margin-top:6px;font-size:12.5px;line-height:1.5}.marketing-layout{grid-template-columns:minmax(0,1.5fr) minmax(320px,.9fr);align-items:start;gap:18px;display:grid}.marketing-main,.marketing-side,.marketing-list{flex-direction:column;gap:14px;display:flex}.marketing-segment-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;display:grid}.marketing-form-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.marketing-form-grid-campaign{grid-template-columns:repeat(3,minmax(0,1fr))}.marketing-side-form{flex-direction:column;gap:10px;display:flex}.marketing-list-row{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;display:flex}.marketing-list-row-wide{align-items:flex-start}.marketing-list-title,.marketing-provider-title{color:var(--text-bright);font-size:13.5px;font-weight:600}.marketing-inline-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.marketing-log-top,.marketing-provider-row{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.marketing-log-body{background:var(--bg-surface);border-radius:var(--radius-sm);color:var(--text-primary);white-space:pre-wrap;margin:10px 0 8px;padding:12px;font-size:13px;line-height:1.55}.marketing-provider-card{background:radial-gradient(circle at top right, #b8ff3c14, transparent 34%), var(--bg-card)}@media (width<=1200px){.marketing-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.marketing-layout{grid-template-columns:1fr}}@media (width<=860px){.marketing-form-grid,.marketing-form-grid-campaign,.marketing-kpi-grid{grid-template-columns:1fr}}.crm-analytics-kpis{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:18px;display:grid}.crm-analytics-kpi-card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);padding:18px}.crm-analytics-kpi-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;font-size:12px}.crm-analytics-kpi-value{font-family:var(--font-display);color:var(--text-bright);margin-top:8px;font-size:28px}.crm-analytics-kpi-sub{color:var(--text-secondary);margin-top:6px;font-size:12px}.crm-analytics-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;display:grid}.crm-analytics-pie-wrap{grid-template-columns:220px 1fr;align-items:center;gap:18px;display:grid}.crm-analytics-mini-title{color:var(--text-secondary);margin-bottom:8px;font-size:12px}.crm-analytics-demo-list{flex-direction:column;gap:10px;display:flex}.crm-analytics-demo-row{background:var(--bg-surface);border-radius:var(--radius-sm);color:var(--text-primary);justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;display:flex}@media (width<=1100px){.crm-analytics-kpis,.crm-analytics-grid{grid-template-columns:1fr 1fr}}@media (width<=820px){.crm-analytics-kpis,.crm-analytics-grid,.crm-analytics-pie-wrap{grid-template-columns:1fr}}.report-filter{width:100px}.report-kpi-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-bottom:18px;display:grid}.report-kpi-card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);flex-direction:column;gap:8px;padding:18px;display:flex}.report-kpi-card span{color:var(--text-secondary);font-size:12px}.report-kpi-card strong{font-family:var(--font-display);color:var(--text-bright);font-size:24px}.report-insight-grid,.report-bottom-grid{grid-template-columns:1fr 1.2fr;gap:18px;margin-bottom:18px;display:grid}.report-insight-card{background:radial-gradient(circle at top right, #b8ff3c14, transparent 36%), var(--bg-card)}.report-insight-list{flex-direction:column;gap:10px;margin-top:12px;display:flex}.report-insight-list div{background:var(--bg-surface);border-radius:var(--radius-sm);color:var(--text-primary);justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;display:flex}.report-insight-list span{color:var(--text-secondary);font-size:13px}.report-insight-list strong{color:var(--text-bright)}@media (width<=980px){.report-kpi-grid{grid-template-columns:1fr 1fr}.report-insight-grid,.report-bottom-grid{grid-template-columns:1fr}}@media (width<=680px){.report-kpi-grid{grid-template-columns:1fr}}.rewards-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;margin-bottom:18px;display:flex}.qr-page{animation:.3s fadeIn}.qr-clock{font-family:var(--font-display);color:var(--text-secondary);align-items:center;gap:6px;font-size:13px;font-weight:600;display:flex}.qr-layout{grid-template-columns:340px 1fr;align-items:start;gap:16px;display:grid}.qr-card{padding:22px}.qr-card-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.qr-wrap{flex-direction:column;align-items:center;gap:16px;display:flex}.qr-wrap>svg{border-radius:var(--radius-md);border:1px solid var(--border-card);background:#ffffff0a;padding:12px}.qr-placeholder{justify-content:center;padding:20px 0;display:flex}.qr-skeleton{border-radius:var(--radius-md);background:var(--bg-elevated);width:220px;height:220px;animation:1.2s ease-in-out infinite pulse}.qr-timer{background:var(--bg-surface);border:1px solid var(--border-card);border-radius:999px;align-items:center;gap:8px;padding:6px 16px;display:flex}.qr-timer.urgent{background:var(--danger-dim);border-color:#ff4d6d66}.qr-timer-label{color:var(--text-secondary);font-size:11px;font-weight:600}.qr-timer-value{font-family:var(--font-display);color:var(--text-bright);letter-spacing:.05em;font-size:18px;font-weight:700}.qr-timer.urgent .qr-timer-value{color:var(--danger)}.qr-hint{color:var(--text-muted);text-align:center;font-size:12px}.qr-error{text-align:center;color:var(--danger);padding:40px 0;font-size:13px}.qr-manual-card{padding:22px}.qr-member-list{flex-direction:column;gap:6px;max-height:400px;margin-top:4px;display:flex;overflow-y:auto}.qr-member-row{border-radius:var(--radius-sm);background:var(--bg-surface);justify-content:space-between;align-items:center;padding:12px 14px;transition:background .15s;display:flex}.qr-member-row:hover{background:var(--bg-elevated)}.qr-member-name{color:var(--text-primary);font-size:14px;font-weight:600}.qr-member-phone{color:var(--text-secondary);margin-top:2px;font-size:12px}.qr-search-hint{text-align:center;color:var(--text-secondary);padding:20px 0;font-size:13px}.qr-manual-success{border-radius:var(--radius-sm);background:var(--success-dim);color:var(--success);border:1px solid #22d3a540;align-items:center;gap:8px;margin-bottom:10px;padding:10px 14px;font-size:13px;font-weight:600;display:flex}.qr-manual-error{border-radius:var(--radius-sm);background:var(--danger-dim);color:var(--danger);border:1px solid #ff4d6d33;margin-bottom:10px;padding:10px 14px;font-size:13px}@media (width<=900px){.qr-layout{grid-template-columns:1fr}}@media (width<=600px){.qr-wrap>svg{width:180px!important;height:180px!important}}.login-page{background:var(--bg-base);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";pointer-events:none;background:radial-gradient(circle,#b8ff3c0f 0%,#0000 70%);border-radius:50%;width:600px;height:600px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.login-page:after{content:"";pointer-events:none;background-image:linear-gradient(#ffffff04 1px,#0000 1px),linear-gradient(90deg,#ffffff04 1px,#0000 1px);background-size:48px 48px;position:absolute;inset:0}.login-card{z-index:1;background:var(--bg-surface);border:1px solid var(--border-card);border-radius:var(--radius-xl);width:100%;max-width:400px;padding:44px 40px 40px;animation:.4s cubic-bezier(.22,1,.36,1) both cardIn;position:relative;box-shadow:0 0 0 1px #b8ff3c0a,0 24px 64px #00000080,0 4px 16px #0000004d}@keyframes cardIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.login-logo{align-items:center;gap:10px;margin-bottom:36px;display:flex}.login-logo-icon{background:var(--accent);color:#070c17;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.login-logo-text{font-family:var(--font-display);color:var(--text-bright);letter-spacing:-.01em;font-size:19px;font-weight:700}.login-heading{margin-bottom:28px}.login-title{font-family:var(--font-display);color:var(--text-bright);letter-spacing:-.02em;margin-bottom:5px;font-size:22px;font-weight:700}.login-sub{color:var(--text-secondary);font-size:13.5px;line-height:1.5}.login-form{flex-direction:column;gap:16px;display:flex}.form-group{flex-direction:column;gap:7px;display:flex}.form-label{color:var(--text-secondary);letter-spacing:.06em;text-transform:uppercase;font-size:12px;font-weight:600;font-family:var(--font-display)}.input-field{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-md);width:100%;color:var(--text-bright);font-family:var(--font-body);outline:none;padding:11px 14px;font-size:14px;transition:border-color .15s,box-shadow .15s}.input-field::placeholder{color:var(--text-muted)}.input-field:focus{border-color:#b8ff3c66;box-shadow:0 0 0 3px #b8ff3c14}.pw-wrap{position:relative}.pw-wrap .input-field{padding-right:42px}.pw-toggle{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;padding:4px;transition:color .12s;display:flex;position:absolute;top:50%;right:11px;transform:translateY(-50%)}.pw-toggle:hover{color:var(--text-primary)}.login-error{background:var(--danger-dim);color:var(--danger);border-radius:var(--radius-sm);border:1px solid #ff4d6d38;padding:10px 13px;font-size:13px;line-height:1.45;animation:.2s both errorIn}@keyframes errorIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.login-submit{width:100%;font-size:14px;font-family:var(--font-display);letter-spacing:.08em;border-radius:var(--radius-md);justify-content:center;margin-top:6px;padding:13px;font-weight:600;transition:opacity .15s,transform .15s}.login-submit:not(:disabled):hover{transform:translateY(-1px)}.login-submit:disabled{opacity:.6;cursor:not-allowed}.login-spinner{border:2px solid #070c1740;border-top-color:#070c17;border-radius:50%;width:17px;height:17px;animation:.65s linear infinite spin;display:inline-block}.login-hint{text-align:center;color:var(--text-muted);margin-top:20px;font-size:11.5px}@media (width<=480px){.login-card{padding:30px 20px 28px}.login-title{font-size:19px}.login-page{padding:16px}}.admin-dashboard{padding:0}.admin-stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.admin-stat-card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);align-items:center;gap:16px;padding:20px;display:flex}.admin-stat-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.admin-stat-accent .admin-stat-icon{background:var(--accent-dim);color:var(--accent)}.admin-stat-success .admin-stat-icon{background:var(--success-dim);color:var(--success)}.admin-stat-info .admin-stat-icon{background:var(--info-dim);color:var(--info)}.admin-stat-warning .admin-stat-icon{background:var(--warning-dim);color:var(--warning)}.admin-stat-value{font-family:var(--font-display);color:var(--text-bright);margin-bottom:4px;font-size:26px;font-weight:700;line-height:1}.admin-stat-label,.admin-store-count{color:var(--text-secondary);font-size:12px}.admin-store-name{color:var(--text-bright);font-size:13.5px;font-weight:600}.admin-store-addr{color:var(--text-secondary);margin-top:2px;font-size:11.5px}.admin-view-btn{align-items:center;gap:4px;display:inline-flex}@media (width<=1024px){.admin-stats-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.admin-stats-grid{grid-template-columns:1fr}}.admin-stores{padding:0}.stores-search{max-width:400px;margin-bottom:20px}.stores-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;display:grid}.store-card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);flex-direction:column;gap:8px;padding:20px;transition:border-color .15s;display:flex}.store-card:hover{border-color:var(--border-accent)}.store-card-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.store-card-name{font-family:var(--font-display);color:var(--text-bright);font-size:15px;font-weight:700}.store-card-info{color:var(--text-primary);gap:8px;font-size:13px;display:flex}.store-info-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;flex-shrink:0;min-width:40px;font-size:11px;font-weight:600}.store-card-member{align-items:center;gap:8px;font-size:13px;display:flex}.store-member-count{color:var(--text-secondary)}.store-card-actions{border-top:1px solid var(--border);gap:8px;margin-top:8px;padding-top:12px;display:flex}.admin-users{padding:0}.user-name-cell{color:var(--text-bright);font-size:13.5px;font-weight:600}.user-email-cell{color:var(--text-secondary);margin-top:2px;font-size:12px}.user-username{font-family:var(--font-display);color:var(--text-primary);font-size:13px}.perm-all{color:var(--accent);font-size:12px;font-weight:600}.perm-count{color:var(--info);font-size:12px;font-weight:600}.perm-none{color:var(--text-muted);font-size:12px}.admin-users-modal{max-width:560px}.perm-grid{grid-template-columns:repeat(2,1fr);gap:8px;margin-top:4px;display:grid}.perm-checkbox{border-radius:var(--radius-sm);background:var(--bg-surface);border:1px solid var(--border-card);color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;padding:8px 12px;font-size:13px;transition:all .15s;display:flex}.perm-checkbox input{accent-color:var(--accent);cursor:pointer;width:14px;height:14px}.perm-checkbox.checked{border-color:var(--border-accent);background:var(--accent-dim);color:var(--text-bright)}.admin-loading,.admin-empty{text-align:center;color:var(--text-secondary);padding:40px 0;font-size:14px}.mobile-app{color:#1d2735;max-width:430px;min-height:100vh;padding:calc(env(safe-area-inset-top) + 18px) 16px calc(env(safe-area-inset-bottom) + 92px);background:radial-gradient(circle at 0 0,#0891b21f,#0000 30%),linear-gradient(#f0fdfa 0%,#f7fffd 42%,#f4f9f8 100%);margin:0 auto}.mobile-topbar{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:18px;display:flex}.mobile-topbar-eyebrow{color:#6c7c92;font-size:12px;font-weight:700}.mobile-topbar-title{color:#162030;letter-spacing:-.04em;margin:6px 0 0;font-size:24px;font-weight:800}.mobile-topbar-member{color:#6c7c92;margin-top:6px;font-size:13px;font-weight:700}.mobile-icon-button{color:#23314c;background:#fffc;border:1px solid #91a6c838;border-radius:999px;width:40px;height:40px;position:relative}.mobile-dot{background:#ff6d6d;border-radius:999px;width:7px;height:7px;position:absolute;top:10px;right:10px}.mobile-content{gap:14px;display:grid}.login-screen{min-height:100dvh;padding:calc(env(safe-area-inset-top) + 24px) 24px calc(env(safe-area-inset-bottom) + 24px);background:linear-gradient(155deg,#0f1f3d 0%,#0a1628 50%,#071020 100%);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.login-bg-circle{pointer-events:none;border-radius:50%;position:absolute}.login-bg-circle-1{background:radial-gradient(circle,#64b4ff1a 0%,#0000 70%);width:420px;height:420px;top:-120px;right:-100px}.login-bg-circle-2{background:radial-gradient(circle,#50dca014 0%,#0000 70%);width:320px;height:320px;bottom:-80px;left:-60px}.login-inner{z-index:1;text-align:center;flex-direction:column;align-items:center;gap:0;width:100%;max-width:360px;display:flex;position:relative}.login-brand{align-items:center;gap:10px;margin-bottom:36px;display:flex}.login-brand-icon{color:#071020;background:linear-gradient(135deg,#4ade80,#22d3ee);border-radius:14px;justify-content:center;align-items:center;width:44px;height:44px;display:flex;box-shadow:0 8px 24px #4ade8059}.login-brand-name{color:#f0f9ff;letter-spacing:-.04em;font-size:26px;font-weight:900}.login-headline{color:#f0f9ff;letter-spacing:-.04em;margin-bottom:12px;font-size:30px;font-weight:800;line-height:1.25}.login-subtext{color:#b4d2ffa6;letter-spacing:.01em;margin-bottom:40px;font-size:14px}.login-card-box{-webkit-backdrop-filter:blur(20px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:24px;width:100%;padding:28px 24px 24px}.login-card-label{color:#b4d2ffb3;letter-spacing:.02em;margin-bottom:16px;font-size:13px;font-weight:600}.login-google-slot{justify-content:center;min-height:44px;display:flex}.login-loading-row{justify-content:center;gap:6px;padding:14px 0;display:flex}.login-spinner-dot{background:#b4d2ff80;border-radius:50%;width:7px;height:7px;animation:1.2s ease-in-out infinite dotPulse}.login-spinner-dot:nth-child(2){animation-delay:.2s}.login-spinner-dot:nth-child(3){animation-delay:.4s}@keyframes dotPulse{0%,80%,to{opacity:.3;transform:scale(.85)}40%{opacity:1;transform:scale(1)}}.login-error-msg{color:#ff8fa3;text-align:left;background:#ff4d6d1f;border:1px solid #ff4d6d40;border-radius:10px;margin-top:12px;padding:10px 14px;font-size:13px;line-height:1.5}.login-terms{color:#b4d2ff66;margin-top:20px;font-size:11px;line-height:1.6}.login-terms a{color:#b4d2ffa6;text-decoration:underline}.login-webview-notice{text-align:center;flex-direction:column;align-items:center;gap:0;display:flex}.login-webview-icon{margin-bottom:14px;font-size:36px}.login-webview-title{color:#f0f9ff;margin-bottom:12px;font-size:17px;font-weight:800;line-height:1.4}.login-webview-desc{color:#b4d2ffa6;margin-bottom:22px;font-size:13px;line-height:1.65}.login-open-btn{color:#071020;cursor:pointer;letter-spacing:-.01em;background:linear-gradient(135deg,#4ade80,#22d3ee);border:none;border-radius:14px;width:100%;padding:14px;font-size:15px;font-weight:800;transition:opacity .15s,transform .15s}.login-open-btn:active{opacity:.85;transform:scale(.98)}.login-webview-hint{color:#b4d2ff73;margin-top:10px;font-size:12px}.mobile-card{background:#fffffff0;border:1px solid #e5ebf4;border-radius:24px;box-shadow:0 18px 38px -28px #1e293b47}.mobile-card.padded{padding:18px}.mobile-hero{color:#fff;background:linear-gradient(135deg,#0d9488 0%,#2dd4bf 100%);min-height:196px;padding:22px 20px;position:relative;overflow:hidden}.mobile-hero-badge{background:#fff3;border-radius:999px;align-items:center;height:28px;padding:0 12px;font-size:12px;font-weight:800;display:inline-flex}.mobile-hero-title{letter-spacing:-.04em;margin:16px 0 10px;font-size:28px;font-weight:800;line-height:1.2}.mobile-hero-copy{color:#ffffffe0;max-width:230px;font-size:14px;line-height:1.6}.mobile-hero-metrics{background:#ffffff38;border-radius:16px;grid-template-columns:repeat(3,1fr);gap:1px;margin-top:18px;display:grid;overflow:hidden}.mobile-hero-metric{text-align:center;background:#ffffff14;padding:12px 10px}.mobile-hero-metric strong{font-size:17px;font-weight:800;display:block}.mobile-hero-metric span{color:#ffffffd1;margin-top:4px;font-size:11px;display:block}.mobile-section-header{justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px;display:flex}.mobile-section-header h2{color:#1e293b;letter-spacing:-.03em;font-size:18px;font-weight:800}.mobile-link-button{color:#0891b2;background:0 0;border:0;font-size:13px;font-weight:800}.mobile-list{gap:10px;display:grid}.mobile-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.mobile-row-title{color:#1f2937;font-size:15px;font-weight:700}.mobile-row-subtitle{color:#738298;margin-top:4px;font-size:13px;line-height:1.5}.mobile-chip{border-radius:999px;align-items:center;height:28px;padding:0 12px;font-size:12px;font-weight:800;display:inline-flex}.mobile-chip.blue{color:#0891b2;background:#e0f7fa}.mobile-chip.green{color:#4a9428;background:#edf9e6}.mobile-chip.gray{color:#67768c;background:#f1f4f8}.mobile-progress{background:#edf2f7;border-radius:999px;height:10px;margin-top:12px;overflow:hidden}.mobile-progress>span{border-radius:inherit;background:linear-gradient(90deg,#0891b2 0%,#38bdf8 100%);height:100%;display:block}.mobile-grid-2{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.mobile-kpi{padding:16px}.mobile-kpi strong{color:#1e293b;font-size:24px;font-weight:800;display:block}.mobile-kpi span{color:#738298;margin-top:6px;font-size:13px;display:block}.mobile-cta{bottom:calc(env(safe-area-inset-bottom) + 76px);color:#fff;background:linear-gradient(#0891b2 0%,#0e7490 100%);border:0;border-radius:18px;width:100%;height:56px;font-size:16px;font-weight:800;position:sticky;box-shadow:0 18px 32px -22px #0891b2b3}.mobile-tabbar{z-index:20;width:min(100vw,430px);padding:10px 12px calc(env(safe-area-inset-bottom) + 12px);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#fffffff0;border-top:1px solid #e7edf5;grid-template-columns:repeat(5,1fr);gap:2px;display:grid;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.mobile-tab{color:#9aa8bc;justify-items:center;gap:5px;font-size:11px;font-weight:800;text-decoration:none;display:grid}.mobile-tab.active{color:#0891b2}.mobile-divider{background:#edf1f6;height:1px;margin:14px 0}.mobile-history-graph{grid-template-columns:repeat(6,1fr);align-items:end;gap:8px;min-height:130px;margin-top:18px;display:grid}.mobile-history-bar{background:linear-gradient(#7dd3fc 0%,#0891b2 100%);border-radius:12px 12px 6px 6px}.mobile-profile{grid-template-columns:60px 1fr;align-items:center;gap:14px;display:grid}.mobile-avatar{color:#0891b2;background:linear-gradient(135deg,#e0f7fa 0%,#b2ebf2 100%);border-radius:20px;place-items:center;width:60px;height:60px;font-size:22px;font-weight:800;display:grid}.mobile-menu-list{gap:10px;display:grid}.mobile-form-grid{gap:12px;display:grid}.mobile-field{gap:8px;display:grid}.mobile-field span{color:#6c7c92;font-size:13px;font-weight:700}.mobile-field input{color:#1d2735;background:#fbfdff;border:1px solid #dce4ef;border-radius:16px;width:100%;height:48px;padding:0 14px;font-size:14px}.mobile-form-error{color:#d14343;margin-top:12px;font-size:13px;font-weight:700}.mobile-menu-item{color:#1f2937;background:#fff;border:1px solid #e8edf5;border-radius:18px;justify-content:space-between;align-items:center;gap:12px;padding:16px 18px;font-size:15px;font-weight:700;display:flex}.mobile-cal-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.mobile-cal-month{color:#1e293b;letter-spacing:-.02em;font-size:16px;font-weight:800}.mobile-cal-nav{color:#475569;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:10px;justify-content:center;align-items:center;width:34px;height:34px;transition:background .15s,border-color .15s;display:flex}.mobile-cal-nav:hover{background:#f1f5f9;border-color:#cbd5e1}.mobile-cal-grid{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.mobile-cal-dow{text-align:center;color:#94a3b8;padding:4px 0 8px;font-size:11px;font-weight:700}.mobile-cal-day{color:#1e293b;cursor:pointer;background:0 0;border:none;border-radius:10px;justify-content:center;align-items:center;height:38px;font-size:14px;font-weight:600;transition:background .15s,color .15s;display:flex}.mobile-cal-day:hover:not(:disabled):not(.selected){color:#0891b2;background:#f0fdfa}.mobile-cal-day.today{color:#0891b2;font-weight:900}.mobile-cal-day.selected{color:#fff;background:#0891b2;font-weight:800}.mobile-cal-day.today.selected{color:#fff;background:#0891b2}.mobile-cal-day.past{color:#cbd5e1;cursor:default}.mobile-week-strip{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.mobile-week-day{cursor:pointer;background:0 0;border:1px solid #0000;border-radius:14px;flex-direction:column;align-items:center;gap:4px;padding:8px 2px;display:flex}.mobile-week-day.today .mobile-week-num{color:#0891b2;font-weight:900}.mobile-week-day.active{background:#0891b2;border-color:#0891b2}.mobile-week-day.active .mobile-week-label,.mobile-week-day.active .mobile-week-num{color:#fff}.mobile-week-label{color:#94a3b8;font-size:11px;font-weight:700}.mobile-week-num{color:#1e293b;font-size:15px;font-weight:800}.mobile-week-selected-date{text-align:center;color:#64748b;margin-top:10px;font-size:13px;font-weight:700}.mobile-tab-strip{background:#f1f4f8;border-radius:14px;grid-template-columns:repeat(3,1fr);gap:4px;padding:4px;display:grid}.mobile-tab-btn{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:10px;padding:9px 0;font-size:13px;font-weight:700}.mobile-tab-btn.active{color:#1e293b;background:#fff;box-shadow:0 2px 8px -2px #1e293b24}.qr-scanner-overlay{z-index:1000;background:#000000d9;justify-content:center;align-items:flex-end;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.qr-scanner-modal{width:100%;max-width:430px;padding-bottom:calc(env(safe-area-inset-bottom) + 24px);background:#0f1a2e;border-radius:28px 28px 0 0;animation:.25s cubic-bezier(.22,1,.36,1) slideUp;overflow:hidden}.qr-scanner-header{border-bottom:1px solid #ffffff12;justify-content:space-between;align-items:center;padding:18px 20px 14px;display:flex}.qr-scanner-title{color:#f0f9ff;align-items:center;gap:8px;font-size:15px;font-weight:800;display:flex}.qr-scanner-close{color:#f0f9ff;cursor:pointer;background:#ffffff14;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.qr-scanner-body{flex-direction:column;align-items:center;gap:16px;padding:20px 20px 8px;display:flex}.qr-scanner-view{border-radius:16px;width:100%;overflow:hidden}.qr-scanner-view video{border-radius:16px}#mobile-qr-scanner-container img{display:none}.qr-scanner-guide{color:#b4d2ffa6;text-align:center;padding:0 8px;font-size:13px;line-height:1.5}.qr-scanner-result{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:14px;min-height:280px;padding:32px 24px 8px;display:flex}.qr-scanner-spinner{border:3px solid #0891b233;border-top-color:#0891b2;border-radius:50%;width:48px;height:48px;animation:.8s linear infinite spin}.qr-scanner-icon{border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;font-size:28px;font-weight:900;display:flex}.qr-scanner-icon.success{color:#22d3a5;background:#22d3a526}.qr-scanner-icon.already{color:#0891b2;background:#0891b226}.qr-scanner-icon.error{color:#ff4d6d;background:#ff4d6d26}.qr-scanner-result-title{color:#f0f9ff;letter-spacing:-.03em;font-size:20px;font-weight:800}.qr-scanner-msg{color:#b4d2ffa6;font-size:13px;line-height:1.6}.qr-scanner-btn{cursor:pointer;border:none;border-radius:14px;flex:1;padding:14px;font-size:15px;font-weight:800;transition:opacity .15s}.qr-scanner-btn:active{opacity:.85}.qr-scanner-btn.primary{color:#fff;background:linear-gradient(135deg,#0891b2,#0e7490)}.qr-scanner-btn.ghost{color:#f0f9ff;background:#ffffff12;border:1px solid #ffffff1f}.qr-checkin-screen{background:linear-gradient(155deg,#0f1f3d 0%,#0a1628 50%,#071020 100%);justify-content:center;align-items:center;min-height:100dvh;padding:24px;display:flex}.qr-checkin-inner{text-align:center;flex-direction:column;align-items:center;gap:16px;width:100%;max-width:320px;display:flex}.qr-checkin-spinner{border:3px solid #0891b233;border-top-color:#0891b2;border-radius:50%;width:52px;height:52px;animation:.8s linear infinite spin}.qr-checkin-icon{border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;font-size:32px;font-weight:900;display:flex}.qr-checkin-icon.success{color:#22d3a5;background:#22d3a526}.qr-checkin-icon.already{color:#0891b2;background:#0891b226}.qr-checkin-icon.error{color:#ff4d6d;background:#ff4d6d26}.qr-checkin-title{color:#f0f9ff;letter-spacing:-.03em;font-size:24px;font-weight:800}.qr-checkin-msg{color:#b4d2ffb3;font-size:14px;line-height:1.6}.qr-checkin-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#0891b2,#0e7490);border:none;border-radius:14px;width:100%;margin-top:8px;padding:14px;font-size:15px;font-weight:800;transition:opacity .15s}.qr-checkin-btn:active{opacity:.85}.mobile-alert-banner{color:#92400e;background:#fff8e6;border:1px solid #fbbf24;border-radius:16px;padding:12px 16px;font-size:13px;line-height:1.5}@media (width>=768px){body{background:radial-gradient(circle at 0 0,#0891b21a,#0000 24%),linear-gradient(#f0fdfa 0%,#f4f9f8 100%)}.mobile-app{box-shadow:0 30px 70px -46px #1e293b57}}.onboarding-screen{max-width:430px;min-height:100dvh;padding:calc(env(safe-area-inset-top) + 24px) 32px calc(env(safe-area-inset-bottom) + 40px);background:linear-gradient(155deg,#0f1f3d 0%,#0a1628 50%,#071020 100%);flex-direction:column;justify-content:space-between;align-items:center;margin:0 auto;display:flex;position:relative;overflow:hidden}.onboarding-bg-circle{pointer-events:none;border-radius:50%;position:absolute}.onboarding-bg-circle-1{background:radial-gradient(circle,#64b4ff17 0%,#0000 70%);width:420px;height:420px;top:-140px;right:-120px}.onboarding-bg-circle-2{background:radial-gradient(circle,#50dca012 0%,#0000 70%);width:340px;height:340px;bottom:-100px;left:-80px}.onboarding-skip{color:#b4d2ff80;cursor:pointer;z-index:1;background:0 0;border:none;align-self:flex-end;padding:4px 0;font-size:14px;font-weight:600;position:relative}.onboarding-body{text-align:center;z-index:1;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:28px;display:flex;position:relative}.onboarding-icon-wrap{border-radius:32px;justify-content:center;align-items:center;width:108px;height:108px;display:flex;box-shadow:0 20px 50px #00000059}.onboarding-icon{font-size:48px;line-height:1}.onboarding-title{color:#f0f9ff;letter-spacing:-.04em;margin:0;font-size:30px;font-weight:800;line-height:1.28}.onboarding-desc{color:#b4d2ff9e;margin:0;font-size:15px;line-height:1.7}.onboarding-footer{z-index:1;flex-direction:column;align-items:center;gap:24px;width:100%;display:flex;position:relative}.onboarding-dots{gap:8px;display:flex}.onboarding-dot{cursor:pointer;background:#fff3;border-radius:999px;width:8px;height:8px;transition:width .25s,background .25s}.onboarding-dot.active{background:#4ade80;width:24px}.onboarding-btn{color:#071020;cursor:pointer;letter-spacing:-.02em;background:linear-gradient(135deg,#4ade80,#22d3ee);border:none;border-radius:16px;width:100%;height:54px;font-size:16px;font-weight:800;transition:opacity .15s;box-shadow:0 8px 28px #4ade8047}.onboarding-btn:active{opacity:.85}.layout{height:100vh;display:flex;overflow:hidden}.layout-main{flex-direction:column;flex:1;transition:margin-left .28s cubic-bezier(.4,0,.2,1);display:flex;overflow:hidden}.layout.sidebar-open .layout-main{margin-left:var(--sidebar-width)}.layout.sidebar-closed .layout-main{margin-left:68px}.layout-content{background:var(--bg-base);flex:1;padding:28px 32px;overflow-y:auto}.sidebar-mobile-overlay{display:none}@media (width<=768px){.layout.sidebar-open .layout-main,.layout.sidebar-closed .layout-main{margin-left:0}.layout-content{padding:16px 14px}.sidebar-mobile-overlay{z-index:99;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0009;display:block;position:fixed;inset:0}}@media (width<=480px){.layout-content{padding:12px}}
