@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";
:root{--brand-primary:#0ea5e9;--brand-primary-dark:#0284c7;--brand-primary-light:#38bdf8;--brand-accent:#8b5cf6;--brand-accent-light:#a78bfa;--status-online:#22c55e;--status-offline:#6b7280;--status-error:#ef4444;--status-printing:#f59e0b;--bg-base:#0a0e1a;--bg-surface:#111827;--bg-surface-elevated:#1e293b;--bg-surface-hover:#253249;--bg-card:linear-gradient(135deg, #111827f2, #1e293bd9);--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--border-subtle:#94a3b81a;--border-accent:#0ea5e94d;--glass-bg:#11182799;--glass-border:#94a3b81f;--shadow-card:0 4px 24px #0000004d, 0 1px 4px #0003;--shadow-glow:0 0 40px #0ea5e926;--chart-tooltip-bg:#1e293b;--chart-tooltip-border:#94a3b826;--chart-tooltip-text:#f1f5f9;--chart-grid:#94a3b81a;--chart-axis:#64748b;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}[data-theme=light]{--bg-base:#f1f5f9;--bg-surface:#fff;--bg-surface-elevated:#f8fafc;--bg-surface-hover:#e2e8f0;--bg-card:linear-gradient(135deg, #fffffff2, #f1f5f9d9);--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--border-subtle:#0f172a14;--border-accent:#0ea5e940;--glass-bg:#ffffffb3;--glass-border:#0f172a14;--shadow-card:0 4px 24px #0000000f, 0 1px 4px #0000000a;--shadow-glow:0 0 40px #0ea5e914;--chart-tooltip-bg:#fff;--chart-tooltip-border:#0f172a1a;--chart-tooltip-text:#0f172a;--chart-grid:#0f172a0f;--chart-axis:#94a3b8;--brand-primary-light:#0284c7;--brand-accent-light:#7c3aed;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{background-color:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;transition:background-color .3s,color .3s}.sidebar,.stat-card,.panel,.kiosk-item,.login-card,.main-content,.form-group input,.jobs-table td,.jobs-table th{transition:background-color .3s,border-color .3s,color .3s,box-shadow .3s}.theme-toggle-btn{border:1px solid var(--border-subtle);width:100%;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:10px;align-items:center;gap:10px;margin-bottom:8px;padding:12px 16px;font-family:Inter,sans-serif;font-size:.85rem;font-weight:500;transition:all .2s;display:flex}.theme-toggle-btn:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.theme-toggle-btn .theme-icon{justify-content:center;align-items:center;transition:transform .4s;display:flex}.theme-toggle-btn:hover .theme-icon{transform:rotate(30deg)}.login-container{background:var(--bg-base);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-container:before{content:"";background:radial-gradient(circle at 30% 40%,#0ea5e914 0%,#0000 50%),radial-gradient(circle at 70% 60%,#8b5cf60f 0%,#0000 50%);width:200%;height:200%;animation:15s ease-in-out infinite bgPulse;position:absolute;top:-50%;left:-50%}@keyframes bgPulse{0%,to{transform:translate(0)}50%{transform:translate(-2%,-1%)}}.login-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(24px);border:1px solid var(--glass-border);width:100%;max-width:420px;box-shadow:var(--shadow-card), var(--shadow-glow);border-radius:24px;padding:48px 40px;position:relative}.login-logo{text-align:center;margin-bottom:36px}.login-logo h1{background:linear-gradient(135deg, var(--brand-primary), var(--brand-accent));-webkit-text-fill-color:transparent;letter-spacing:-.5px;-webkit-background-clip:text;background-clip:text;font-size:2rem;font-weight:800}.login-logo .version-badge{color:var(--brand-primary-light);letter-spacing:1px;text-transform:uppercase;background:#0ea5e91a;border:1px solid #0ea5e933;border-radius:20px;margin-top:8px;padding:4px 12px;font-size:.75rem;font-weight:600;display:inline-block}.login-logo p{color:var(--text-secondary);margin-top:12px;font-size:.9rem}.form-group{margin-bottom:20px}.form-group label{color:var(--text-secondary);margin-bottom:8px;font-size:.85rem;font-weight:500;display:block}.form-group input{background:var(--bg-surface);border:1px solid var(--border-subtle);width:100%;color:var(--text-primary);border-radius:12px;outline:none;padding:14px 16px;font-family:Inter,sans-serif;font-size:.95rem;transition:all .2s}.form-group input:focus{border-color:var(--brand-primary);box-shadow:0 0 0 3px #0ea5e926}.form-group input::placeholder{color:var(--text-muted)}.login-btn{background:linear-gradient(135deg, var(--brand-primary), var(--brand-primary-dark));color:#fff;cursor:pointer;border:none;border-radius:12px;width:100%;margin-top:8px;padding:14px;font-family:Inter,sans-serif;font-size:1rem;font-weight:600;transition:all .2s;position:relative;overflow:hidden}.login-btn:hover{transform:translateY(-1px);box-shadow:0 8px 24px #0ea5e94d}.login-btn:active{transform:translateY(0)}.login-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-error{color:#fca5a5;text-align:center;background:#ef44441a;border:1px solid #ef444433;border-radius:10px;margin-top:16px;padding:12px 16px;font-size:.85rem}.dashboard-layout{min-height:100vh;display:flex}.sidebar{background:var(--bg-surface);border-right:1px solid var(--border-subtle);z-index:100;flex-direction:column;width:260px;padding:24px 0;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-logo{border-bottom:1px solid var(--border-subtle);margin-bottom:16px;padding:0 24px 24px}.sidebar-logo h2{background:linear-gradient(135deg, var(--brand-primary), var(--brand-accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.3rem;font-weight:800}.sidebar-logo .role-badge{letter-spacing:.5px;text-transform:uppercase;border-radius:16px;margin-top:6px;padding:3px 10px;font-size:.7rem;font-weight:600;display:inline-block}.role-badge.super-admin{color:var(--brand-accent-light);background:#8b5cf626;border:1px solid #8b5cf64d}.role-badge.franchisee{color:var(--brand-primary-light);background:#0ea5e926;border:1px solid #0ea5e94d}.sidebar-nav{flex:1;padding:0 12px}.sidebar-nav-item{color:var(--text-secondary);cursor:pointer;border-radius:10px;align-items:center;gap:12px;margin-bottom:4px;padding:12px 16px;font-size:.9rem;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.sidebar-nav-item:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.sidebar-nav-item.active{color:var(--brand-primary-light);background:#0ea5e91a}.sidebar-footer{border-top:1px solid var(--border-subtle);padding:16px 12px}.logout-btn{color:#f87171;cursor:pointer;background:0 0;border:1px solid #ef444433;border-radius:10px;align-items:center;gap:12px;width:100%;padding:12px 16px;font-family:Inter,sans-serif;font-size:.85rem;font-weight:500;transition:all .15s;display:flex}.logout-btn:hover{background:#ef44441a}.main-content{background:var(--bg-base);flex:1;margin-left:260px;padding:32px}.page-header{margin-bottom:32px}.page-header h1{color:var(--text-primary);font-size:1.8rem;font-weight:700}.page-header p{color:var(--text-secondary);margin-top:4px;font-size:.9rem}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-bottom:32px;display:grid}.stat-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:16px;padding:24px;transition:all .2s;position:relative;overflow:hidden}.stat-card:before{content:"";border-radius:16px 16px 0 0;height:3px;position:absolute;top:0;left:0;right:0}.stat-card.blue:before{background:linear-gradient(90deg, var(--brand-primary), var(--brand-primary-light))}.stat-card.green:before{background:linear-gradient(90deg,#22c55e,#4ade80)}.stat-card.purple:before{background:linear-gradient(90deg, var(--brand-accent), var(--brand-accent-light))}.stat-card.amber:before{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.stat-card.red:before{background:linear-gradient(90deg,#ef4444,#f87171)}.stat-card.cyan:before{background:linear-gradient(90deg,#06b6d4,#22d3ee)}.stat-card:hover{border-color:var(--border-accent);box-shadow:var(--shadow-card);transform:translateY(-2px)}.stat-card-icon{border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;margin-bottom:16px;display:flex}.stat-card.blue .stat-card-icon{color:var(--brand-primary-light);background:#0ea5e91f}.stat-card.green .stat-card-icon{color:#4ade80;background:#22c55e1f}.stat-card.purple .stat-card-icon{color:var(--brand-accent-light);background:#8b5cf61f}.stat-card.amber .stat-card-icon{color:#fbbf24;background:#f59e0b1f}.stat-card.red .stat-card-icon{color:#f87171;background:#ef44441f}.stat-card.cyan .stat-card-icon{color:#22d3ee;background:#06b6d41f}.stat-card-value{color:var(--text-primary);margin-bottom:4px;font-size:1.8rem;font-weight:700;line-height:1}.stat-card-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:.8rem;font-weight:500}.stat-card-sub{color:var(--text-secondary);margin-top:8px;font-size:.78rem}.content-grid{grid-template-columns:1fr 1fr;gap:24px;margin-bottom:32px;display:grid}.content-grid.full{grid-template-columns:1fr}.panel{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:16px;overflow:hidden}.panel-header{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.panel-header h3{color:var(--text-primary);font-size:1rem;font-weight:600}.panel-body{padding:24px}.chart-container{width:100%;height:260px}.kiosk-list{flex-direction:column;gap:12px;display:flex}.kiosk-item{background:var(--bg-surface-elevated);border:1px solid var(--border-subtle);border-radius:12px;align-items:center;gap:16px;padding:16px;transition:all .15s;display:flex}.kiosk-item:hover{border-color:var(--border-accent)}.kiosk-status-dot{border-radius:50%;flex-shrink:0;width:12px;height:12px}.kiosk-status-dot.ONLINE{background:var(--status-online);box-shadow:0 0 8px #22c55e66}.kiosk-status-dot.PRINTING{background:var(--status-printing);animation:2s infinite pulse;box-shadow:0 0 8px #f59e0b66}.kiosk-status-dot.OFFLINE{background:var(--status-offline)}.kiosk-status-dot.ERROR{background:var(--status-error);animation:1.5s infinite pulse;box-shadow:0 0 8px #ef444466}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.kiosk-info{flex:1}.kiosk-info .kiosk-name{color:var(--text-primary);font-size:.95rem;font-weight:600}.kiosk-info .kiosk-location{color:var(--text-secondary);margin-top:2px;font-size:.8rem}.kiosk-meta{flex-shrink:0;align-items:center;gap:16px;display:flex}.kiosk-meta-item{text-align:center}.kiosk-meta-item .meta-value{color:var(--text-primary);font-size:.95rem;font-weight:600}.kiosk-meta-item .meta-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;font-size:.7rem}.kiosk-error-badge{color:#f87171;text-transform:uppercase;letter-spacing:.3px;background:#ef44441f;border:1px solid #ef444440;border-radius:8px;padding:4px 10px;font-size:.72rem;font-weight:600}.kiosk-version-badge{color:var(--brand-primary-light);background:#0ea5e91a;border:1px solid #0ea5e933;border-radius:8px;padding:4px 10px;font-size:.72rem;font-weight:500}.pricing-badge{text-transform:uppercase;letter-spacing:.3px;border-radius:8px;padding:4px 10px;font-size:.72rem;font-weight:600}.pricing-badge.revenue-share{color:var(--brand-accent-light);background:#8b5cf61f;border:1px solid #8b5cf640}.pricing-badge.flat-fee{color:#22d3ee;background:#06b6d41f;border:1px solid #06b6d440}.jobs-table{border-collapse:collapse;width:100%}.jobs-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-subtle);padding:12px 16px;font-size:.75rem;font-weight:600}.jobs-table td{color:var(--text-secondary);border-bottom:1px solid var(--border-subtle);padding:14px 16px;font-size:.85rem}.jobs-table tr:hover td{background:var(--bg-surface-hover)}.job-status-badge{text-transform:uppercase;letter-spacing:.3px;border-radius:8px;padding:4px 10px;font-size:.72rem;font-weight:600}.job-status-badge.COMPLETED{color:#4ade80;background:#22c55e1f;border:1px solid #22c55e40}.job-status-badge.PENDING{color:#fbbf24;background:#f59e0b1f;border:1px solid #f59e0b40}.job-status-badge.FAILED{color:#f87171;background:#ef44441f;border:1px solid #ef444440}.job-status-badge.REFUNDED{color:var(--brand-accent-light);background:#8b5cf61f;border:1px solid #8b5cf640}.amount-text{color:var(--text-primary);font-weight:600}.payment-id-text{color:var(--text-muted);font-family:Courier New,monospace;font-size:.78rem}.loading-container{background:var(--bg-base);justify-content:center;align-items:center;min-height:100vh;display:flex}.spinner{border:3px solid var(--border-subtle);border-top-color:var(--brand-primary);border-radius:50%;width:48px;height:48px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width:1024px){.content-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.sidebar{display:none}.main-content{margin-left:0;padding:20px}.stats-grid{grid-template-columns:1fr}.kiosk-meta{display:none}}
