:root{color-scheme:light}*{box-sizing:border-box}body,html{margin:0;padding:0;height:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Arial,sans-serif;background:#f1f5f9;color:#111827;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}button,input,select,textarea{font-family:inherit}.dashboard-layout{height:100vh;background:#f1f5f9}.dashboard-layout,.sidebar{display:flex;overflow:hidden}.sidebar{width:232px;flex-shrink:0;background:#0f172a;flex-direction:column}.sidebar-header{padding:22px 20px 18px;border-bottom:1px solid rgba(255,255,255,.06)}.sidebar-wordmark{font-size:15px;font-weight:800;color:#f8fafc;letter-spacing:-.02em}.sidebar-sub{font-size:10px;color:#475569;margin-top:3px;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.sidebar-nav{flex:1 1;overflow-y:auto;padding:12px 10px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.06) transparent}.sidebar-group-label{font-size:9.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#334155;padding:12px 10px 5px;margin-top:2px}.sidebar-item{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:6px;font-size:13px;font-weight:500;color:#94a3b8;cursor:pointer;transition:background .12s,color .12s;text-decoration:none;border:none;background:none;width:100%;text-align:left;margin-bottom:1px;position:relative}.sidebar-item:hover{background:rgba(255,255,255,.05);color:#e2e8f0}.sidebar-item.active{background:rgba(59,130,246,.18);color:#93c5fd}.sidebar-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:18px;background:#3b82f6;border-radius:0 2px 2px 0}.sidebar-dot{width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0;opacity:.4}.sidebar-item.active .sidebar-dot{opacity:1;background:#3b82f6}.sidebar-footer{padding:10px 10px 16px;border-top:1px solid rgba(255,255,255,.06)}.sidebar-footer-item{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:6px;font-size:12.5px;font-weight:500;color:#475569;cursor:pointer;transition:background .12s,color .12s;text-decoration:none;margin-bottom:1px}.sidebar-footer-item:hover{background:rgba(255,255,255,.04);color:#94a3b8}.dashboard-main{flex:1 1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.dashboard-topbar{height:56px;flex-shrink:0;background:#ffffff;border-bottom:1px solid #e2e8f0;display:flex;align-items:center;padding:0 28px;gap:14px}.topbar-page-title{font-size:15px;font-weight:700;color:#0f172a;letter-spacing:-.01em}.topbar-sep{width:1px;height:18px;background:#e2e8f0}.topbar-breadcrumb{font-size:12.5px;color:#94a3b8;display:flex;align-items:center;gap:6px}.topbar-breadcrumb-sep{color:#cbd5e1}.topbar-breadcrumb-current{color:#64748b}.dashboard-content{flex:1 1;overflow-y:auto;padding:32px 32px 56px}.page-header{margin-bottom:28px}.page-title{font-size:20px;font-weight:700;color:#0f172a;letter-spacing:-.02em;margin:0 0 5px}.page-subtitle{font-size:13.5px;color:#64748b;margin:0;line-height:1.5}.page-actions-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:12px}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px}.kpi-card{background:#ffffff;border:1px solid #e2e8f0;border-radius:10px;padding:22px 24px;position:relative;overflow:hidden}.kpi-card-blue{background:#2563eb;border-color:#2563eb}.kpi-card-blue .kpi-label{color:rgba(255,255,255,.7)}.kpi-card-blue .kpi-value{color:#ffffff}.kpi-card-blue .kpi-hint{color:rgba(255,255,255,.6)}.kpi-label{font-size:11px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px}.kpi-value{font-size:28px;font-weight:800;color:#0f172a;letter-spacing:-.03em;line-height:1;margin-bottom:8px}.kpi-hint{font-size:12px;color:#94a3b8;display:flex;align-items:center;gap:5px}.kpi-trend-up{color:#16a34a;font-weight:600}.kpi-trend-down{color:#dc2626;font-weight:600}.panel{background:#ffffff;border:1px solid #e2e8f0;border-radius:10px;overflow:hidden}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px 22px;border-bottom:1px solid #f1f5f9}.panel-title{font-size:13.5px;font-weight:700;color:#0f172a;margin:0}.panel-title-sm{font-size:12px;font-weight:700;color:#374151;text-transform:uppercase;letter-spacing:.06em;margin:0}.panel-body{padding:22px}.panel-blue-header{background:#2563eb;border-bottom:none}.panel-blue-header .panel-title{color:#ffffff}.section-block{margin-bottom:36px}.section-label{font-size:11px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.1em;margin:0 0 12px}.filter-bar{display:flex;align-items:center;gap:8px;padding:12px 18px;border-bottom:1px solid #f1f5f9;background:#f8fafc}.filter-input{padding:7px 11px;border:1px solid #e2e8f0;border-radius:6px;font-size:13px;color:#0f172a;background:#fff;outline:none;transition:border-color .12s,box-shadow .12s;min-width:200px}.filter-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.1)}.filter-select{padding:7px 11px;border:1px solid #e2e8f0;border-radius:6px;font-size:13px;color:#374151;background:#fff;outline:none;cursor:pointer;transition:border-color .12s}.filter-select:focus{border-color:#2563eb}.filter-spacer{flex:1 1}.filter-count{font-size:12px;color:#94a3b8;font-weight:500}.table-wrapper{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:13.5px}.data-table thead th{text-align:left;padding:11px 20px;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:#64748b;background:#f8fafc;border-bottom:1px solid #e2e8f0;white-space:nowrap}.data-table tbody td{padding:14px 20px;border-bottom:1px solid #f1f5f9;color:#1e293b;vertical-align:middle}.data-table tbody tr:last-child td{border-bottom:none}.pagination-bar,.table-row:hover td{background:#f8fafc}.pagination-bar{display:flex;align-items:center;gap:6px;padding:12px 20px;border-top:1px solid #f1f5f9}.pagination-info{font-size:12.5px;color:#64748b}.pagination-spacer{flex:1 1}.pagination-btn{padding:5px 11px;border:1px solid #e2e8f0;border-radius:5px;background:#fff;font-size:12.5px;cursor:pointer;color:#374151;transition:all .12s;font-family:inherit}.pagination-btn:hover:not(:disabled){background:#f1f5f9;border-color:#94a3b8}.pagination-btn:disabled{opacity:.35;cursor:not-allowed}.pagination-btn.active{background:#2563eb;color:#fff;border-color:#2563eb;font-weight:600}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .12s;border:none;white-space:nowrap;line-height:1;letter-spacing:-.01em}.btn-sm{padding:5px 12px;font-size:12.5px}.btn-primary{background:#2563eb;color:#fff;border:1px solid #2563eb}.btn-primary:hover{background:#1d4ed8;border-color:#1d4ed8}.btn-secondary{background:#fff;color:#374151;border:1px solid #e2e8f0}.btn-secondary:hover{background:#f8fafc;border-color:#94a3b8}.btn-ghost{background:transparent;color:#64748b;border:1px solid transparent}.btn-ghost:hover{background:#f1f5f9;color:#1e293b;border-color:#e2e8f0}.btn-danger{background:#fff;color:#dc2626;border:1px solid #fecaca}.btn-danger:hover{background:#fef2f2}.btn:disabled{opacity:.4;cursor:not-allowed}.badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:4px;font-size:11.5px;font-weight:600;letter-spacing:.01em}.badge-blue{background:#dbeafe;color:#1d4ed8}.badge-green{background:#dcfce7;color:#15803d}.badge-amber{background:#fef3c7;color:#92400e}.badge-red{background:#fee2e2;color:#991b1b}.badge-gray{background:#f1f5f9;color:#475569}.badge-dark{background:#1e293b;color:#f1f5f9}.badge-indigo{background:#e0e7ff;color:#4338ca}.form-group{margin-bottom:18px}.form-label{display:block;font-size:12.5px;font-weight:600;color:#374151;margin-bottom:6px}.form-input,.form-select,.form-textarea{width:100%;padding:9px 13px;border:1px solid #e2e8f0;border-radius:6px;font-size:13.5px;color:#0f172a;background:#fff;outline:none;transition:border-color .12s,box-shadow .12s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.1)}.form-textarea{resize:vertical;min-height:88px;line-height:1.5}.form-hint{font-size:12px;color:#94a3b8;margin-top:5px}.status-dot{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:500;color:#64748b}.status-dot:before{content:"";display:block;width:7px;height:7px;border-radius:50%;flex-shrink:0}.status-dot.online:before{background:#22c55e;box-shadow:0 0 0 2px rgba(34,197,94,.2)}.status-dot.offline:before{background:#94a3b8}.status-dot.warning:before{background:#f59e0b;box-shadow:0 0 0 2px rgba(245,158,11,.2)}.status-dot.error:before{background:#ef4444}.stat-bar-track{height:6px;border-radius:99px;background:#f1f5f9;overflow:hidden;margin-top:6px}.stat-bar-fill{height:100%;border-radius:99px;background:#2563eb;transition:width .4s ease}.stat-bar-fill-green{background:#22c55e}.stat-bar-fill-amber{background:#f59e0b}.activity-item{display:flex;align-items:flex-start;gap:13px;padding:14px 22px;border-bottom:1px solid #f1f5f9;transition:background .1s}.activity-item:hover{background:#f8fafc}.activity-item:last-child{border-bottom:none}.activity-avatar{width:34px;height:34px;border-radius:50%;background:#e0e7ff;color:#4338ca;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.activity-avatar-green{background:#dcfce7;color:#16a34a}.activity-avatar-amber{background:#fef3c7;color:#d97706}.demo-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:4px;font-size:11px;font-weight:700;background:#fef3c7;color:#92400e;letter-spacing:.04em;text-transform:uppercase}.divider{border:none;border-top:1px solid #f1f5f9;margin:20px 0}.customer-shell{min-height:100vh;background:#f1f5f9;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Arial,sans-serif;-webkit-font-smoothing:antialiased;color:#111827}.customer-topbar{background:#0f172a;padding:0 20px;height:52px;display:flex;align-items:center;justify-content:space-between}.customer-logo{font-size:14px;font-weight:800;color:#f8fafc;letter-spacing:-.02em}.customer-center{max-width:440px;margin:0 auto;padding:0 0 40px}.membership-card{background:#0f172a;color:#f8fafc;border-radius:16px;padding:26px 26px 22px;margin:20px 16px 0;position:relative;overflow:hidden;min-height:175px;display:flex;flex-direction:column;justify-content:space-between}.membership-card:before{content:"";position:absolute;top:-40px;right:-40px;width:160px;height:160px;border-radius:50%;border:28px solid rgba(255,255,255,.04)}.membership-card:after{content:"";position:absolute;bottom:-20px;right:40px;width:100px;height:100px;border-radius:50%;border:20px solid rgba(255,255,255,.03)}.portal-tabs{display:flex;gap:0;border-bottom:1px solid #e2e8f0;background:#fff;padding:0 16px;margin:0;overflow-x:auto;-webkit-overflow-scrolling:touch}.portal-tab{padding:12px 16px;font-size:13px;font-weight:600;color:#94a3b8;cursor:pointer;white-space:nowrap;border-bottom:2px solid transparent;transition:color .12s,border-color .12s;text-decoration:none;display:inline-block;margin-bottom:-1px}.portal-tab:hover{color:#475569}.portal-tab.active{color:#2563eb;border-bottom-color:#2563eb}.reward-scroll{display:flex;gap:12px;overflow-x:auto;padding:16px;-webkit-overflow-scrolling:touch;scrollbar-width:none}.reward-scroll::-webkit-scrollbar{display:none}.reward-card{flex-shrink:0;width:160px;background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:16px;cursor:pointer;transition:border-color .12s,box-shadow .12s}.reward-card:hover{border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.08)}.activity-list-item{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid #f1f5f9}.activity-list-item:last-child{border-bottom:none}.kiosk-shell{min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Arial,sans-serif;-webkit-font-smoothing:antialiased;color:#f8fafc;flex-direction:column}.kiosk-shell,.kiosk-topbar{background:#0f172a;display:flex}.kiosk-topbar{border-bottom:1px solid rgba(255,255,255,.07);padding:0 40px;height:60px;align-items:center;justify-content:space-between;flex-shrink:0}.kiosk-logo{font-size:16px;font-weight:800;color:#f8fafc;letter-spacing:-.02em}.kiosk-body{flex:1 1;display:flex;align-items:center;justify-content:center;padding:32px 40px}.kiosk-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;width:100%;max-width:1000px}.kiosk-card{background:#1e293b;border:1px solid rgba(255,255,255,.07);border-radius:14px;overflow:hidden}.kiosk-card-header{padding:20px 28px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;justify-content:space-between}.kiosk-card-title{font-size:15px;font-weight:700;color:#f1f5f9}.kiosk-card-body{padding:28px}.kiosk-field-label{font-size:12px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.09em;margin-bottom:10px;display:block}.kiosk-input{width:100%;padding:0 20px;height:64px;border-radius:10px;border:1.5px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);color:#f8fafc;font-size:18px;font-weight:500;outline:none;transition:border-color .15s,background .15s;font-family:inherit}.kiosk-input:focus{border-color:#3b82f6;background:rgba(59,130,246,.08)}.kiosk-input::placeholder{color:#475569}.kiosk-confirm-btn{width:100%;height:72px;border-radius:12px;border:none;background:#2563eb;color:#ffffff;font-size:17px;font-weight:700;cursor:pointer;transition:background .15s,transform .1s;font-family:inherit;letter-spacing:-.01em}.kiosk-confirm-btn:hover{background:#1d4ed8}.kiosk-confirm-btn:active{transform:scale(.99)}.kiosk-confirm-btn.confirmed{background:#16a34a}.kiosk-stat{background:#1e293b;border:1px solid rgba(255,255,255,.07);border-radius:12px;padding:20px 24px}.kiosk-stat.accent{background:rgba(37,99,235,.2);border-color:rgba(59,130,246,.35)}.kiosk-stat-label{font-size:11px;font-weight:700;color:#475569;text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px}.kiosk-stat.accent .kiosk-stat-label{color:#93c5fd}.kiosk-stat-value{font-size:32px;font-weight:800;color:#f1f5f9;letter-spacing:-.03em;line-height:1}.kiosk-stat.accent .kiosk-stat-value{color:#dbeafe}.kiosk-stat-hint{font-size:12px;color:#475569;margin-top:6px}.portal-home{min-height:100vh;background:#f1f5f9;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Arial,sans-serif;-webkit-font-smoothing:antialiased;color:#111827;display:flex;flex-direction:column}.portal-topbar{background:#0f172a;padding:0 32px;height:52px;display:flex;align-items:center;gap:12px}.portal-wordmark{font-size:14px;font-weight:800;color:#f8fafc;letter-spacing:-.02em}.portal-content{flex:1 1;max-width:960px;margin:0 auto;padding:48px 32px;width:100%}.portal-card{display:block;background:#ffffff;border:1px solid #e2e8f0;border-radius:10px;padding:24px 26px;cursor:pointer;transition:border-color .15s,box-shadow .15s}.portal-card:hover{border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.08)}