@import"https://fonts.googleapis.com/css2?family=Syne:wght@400;500;600;700;800&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,300&display=swap";:root{--bg-void: #050709;--bg-base: #080b10;--bg-raised: #0d1117;--bg-surface: #111720;--bg-elevated: #161e2a;--bg-overlay: #1a2232;--bg-highlight: #1f2a3e;--ember-core: #ff6b35;--ember-bright: #ff8c5a;--ember-glow: rgba(255, 107, 53, .18);--ember-trace: rgba(255, 107, 53, .08);--ember-subtle: rgba(255, 107, 53, .04);--cyan-core: #00d4ff;--cyan-bright: #40e0ff;--cyan-glow: rgba(0, 212, 255, .15);--cyan-trace: rgba(0, 212, 255, .06);--violet-core: #9b59ff;--violet-bright: #b07aff;--violet-glow: rgba(155, 89, 255, .15);--jade-core: #00e5a0;--jade-glow: rgba(0, 229, 160, .15);--amber-core: #ffb020;--amber-glow: rgba(255, 176, 32, .15);--crimson-core: #ff3b5c;--crimson-glow: rgba(255, 59, 92, .15);--text-primary: #f0f4ff;--text-secondary: #8892a4;--text-muted: #4c5668;--text-whisper: #2d3548;--border-dim: rgba(255, 255, 255, .04);--border-soft: rgba(255, 255, 255, .08);--border-medium: rgba(255, 255, 255, .13);--border-bright: rgba(255, 255, 255, .22);--sensor-temp: #ff6b35;--sensor-humid: #00d4ff;--sensor-smoke: #ff3b5c;--sensor-water: #3b9eff;--sensor-motion: #9b59ff;--sensor-weight: #00e5a0;--sensor-moisture: #00e5a0;--sensor-light: #ffb020;--font-display: "Syne", sans-serif;--font-body: "DM Sans", sans-serif;--size-xxs: .625rem;--size-xs: .75rem;--size-sm: .8125rem;--size-base: .9rem;--size-md: 1rem;--size-lg: 1.125rem;--size-xl: 1.375rem;--size-2xl: 1.75rem;--size-3xl: 2.25rem;--size-4xl: 3rem;--size-5xl: 4rem;--size-6xl: 5.5rem;--s1: .25rem;--s2: .5rem;--s3: .75rem;--s4: 1rem;--s5: 1.25rem;--s6: 1.5rem;--s8: 2rem;--s10: 2.5rem;--s12: 3rem;--s16: 4rem;--sidebar-width: 240px;--header-height: 60px;--r-sm: 6px;--r-md: 10px;--r-lg: 16px;--r-xl: 22px;--r-2xl: 32px;--r-full: 9999px;--ease-out: cubic-bezier(.22, 1, .36, 1);--ease-snap: cubic-bezier(.43, .195, .02, 1);--t-fast: .15s;--t-base: .28s;--t-slow: .5s;--t-lush: .8s;--ambient-1: rgba(255, 107, 53, .04);--ambient-2: rgba(0, 212, 255, .04);--ambient-3: rgba(155, 89, 255, .03);--shadow-card: 0 24px 64px rgba(0, 0, 0, .4);--shadow-modal: 0 40px 120px rgba(0, 0, 0, .6);--header-tint: rgba(8, 11, 16, .8);--select-arrow: %234c5668;--blueprint-bg: #0a0c10;--blueprint-grid: rgba(255, 255, 255, .08);--blueprint-frame: rgba(255, 255, 255, .1);--blueprint-room-border: rgba(255, 255, 255, .1);--blueprint-room-label: rgba(255, 255, 255, .9);--blueprint-room-meta: rgba(255, 255, 255, .5);--blueprint-pin-bg: rgba(15, 17, 23, .85);--blueprint-pin-shadow: 0 4px 12px rgba(0, 0, 0, .5)}:root[data-theme=light]{--bg-void: #f3f5fa;--bg-base: #ffffff;--bg-raised: #f7f9fc;--bg-surface: #ffffff;--bg-elevated: #f1f4f9;--bg-overlay: #e9edf4;--bg-highlight: #e2e7f0;--ember-core: #e85d2a;--ember-bright: #ff7a44;--ember-glow: rgba(232, 93, 42, .18);--ember-trace: rgba(232, 93, 42, .1);--ember-subtle: rgba(232, 93, 42, .06);--cyan-core: #0099c4;--cyan-bright: #00b6e0;--cyan-glow: rgba(0, 153, 196, .18);--cyan-trace: rgba(0, 153, 196, .08);--violet-core: #7a3fe4;--violet-bright: #9462ff;--violet-glow: rgba(122, 63, 228, .18);--jade-core: #00a878;--jade-glow: rgba(0, 168, 120, .18);--amber-core: #d68910;--amber-glow: rgba(214, 137, 16, .18);--crimson-core: #d8284a;--crimson-glow: rgba(216, 40, 74, .18);--text-primary: #0c121f;--text-secondary: #4a5468;--text-muted: #6b7587;--text-whisper: #aab2c2;--border-dim: rgba(12, 18, 31, .06);--border-soft: rgba(12, 18, 31, .1);--border-medium: rgba(12, 18, 31, .16);--border-bright: rgba(12, 18, 31, .28);--sensor-temp: #e85d2a;--sensor-humid: #0099c4;--sensor-smoke: #d8284a;--sensor-water: #2c7fd8;--sensor-motion: #7a3fe4;--sensor-weight: #00a878;--sensor-moisture: #00a878;--sensor-light: #d68910;--ambient-1: rgba(232, 93, 42, .06);--ambient-2: rgba(0, 153, 196, .06);--ambient-3: rgba(122, 63, 228, .04);--shadow-card: 0 12px 32px rgba(15, 23, 42, .1);--shadow-modal: 0 30px 80px rgba(15, 23, 42, .18);--header-tint: rgba(255, 255, 255, .85);--select-arrow: %236b7587;--blueprint-bg: #eef2f8;--blueprint-grid: rgba(12, 18, 31, .08);--blueprint-frame: rgba(12, 18, 31, .12);--blueprint-room-border: rgba(12, 18, 31, .14);--blueprint-room-label: rgba(12, 18, 31, .85);--blueprint-room-meta: rgba(12, 18, 31, .5);--blueprint-pin-bg: rgba(255, 255, 255, .95);--blueprint-pin-shadow: 0 4px 10px rgba(15, 23, 42, .12)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body{font-family:var(--font-body);background:var(--bg-void);color:var(--text-primary);line-height:1.65;min-height:100vh;overflow-x:hidden;transition:background-color var(--t-base) var(--ease-out),color var(--t-base) var(--ease-out)}#root{min-height:100vh}body,.card,.sidebar,.header,.form-input,.table-container,.modal,.auth-card,.auth-page,.auth-visual,.auth-panel,.btn-secondary,.btn-ghost{transition:background-color var(--t-base) var(--ease-out),color var(--t-base) var(--ease-out),border-color var(--t-base) var(--ease-out),box-shadow var(--t-base) var(--ease-out)}a{color:var(--ember-core);text-decoration:none;transition:color var(--t-fast) var(--ease-out)}a:hover{color:var(--ember-bright)}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-soft);border-radius:var(--r-full)}::-webkit-scrollbar-thumb:hover{background:var(--border-medium)}body:before{content:"";position:fixed;inset:0;z-index:0;background:radial-gradient(ellipse 800px 600px at 20% 10%,var(--ambient-1) 0%,transparent 70%),radial-gradient(ellipse 600px 800px at 80% 80%,var(--ambient-2) 0%,transparent 70%),radial-gradient(ellipse 500px 500px at 50% 50%,var(--ambient-3) 0%,transparent 70%);pointer-events:none}.app-layout{display:flex;min-height:100vh;position:relative;z-index:1}.main-content{flex:1;margin-left:var(--sidebar-width);padding-top:var(--header-height);min-height:100vh;transition:margin-left var(--t-base) var(--ease-out)}.page-container{padding:var(--s8) var(--s10);max-width:1480px;margin:0 auto}.page-header{margin-bottom:var(--s8);padding-bottom:var(--s6);border-bottom:1px solid var(--border-dim)}.page-header h1{font-family:var(--font-display);font-size:var(--size-3xl);font-weight:700;letter-spacing:-.03em;color:var(--text-primary);line-height:1.1}.page-header p{font-size:var(--size-sm);color:var(--text-muted);margin-top:var(--s2);font-weight:300;letter-spacing:.02em}.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-width);background:var(--bg-base);border-right:1px solid var(--border-dim);display:flex;flex-direction:column;z-index:100;overflow:hidden}.sidebar:before{content:"";position:absolute;top:0;left:0;right:0;height:200px;background:radial-gradient(ellipse at 50% 0%,var(--ember-trace) 0%,transparent 70%);pointer-events:none}.sidebar-logo{padding:var(--s6) var(--s6) var(--s5);display:flex;align-items:center;gap:var(--s3);position:relative}.sidebar-logo-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--ember-core),var(--violet-core));border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 0 24px #ff6b3566;flex-shrink:0}.sidebar-logo-text{font-family:var(--font-display);font-size:var(--size-lg);font-weight:700;letter-spacing:-.02em}.sidebar-logo-sub{font-size:var(--size-xxs);color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase}.sidebar-nav{flex:1;padding:var(--s4) var(--s3);display:flex;flex-direction:column;gap:var(--s1);overflow-y:auto}.sidebar-section-label{font-size:var(--size-xxs);font-weight:600;color:var(--text-whisper);text-transform:uppercase;letter-spacing:.1em;padding:var(--s4) var(--s3) var(--s2)}.nav-item{display:flex;align-items:center;gap:var(--s3);padding:10px var(--s3);border-radius:var(--r-md);color:var(--text-secondary);font-size:var(--size-sm);font-weight:500;transition:all var(--t-fast) var(--ease-out);cursor:pointer;text-decoration:none;position:relative;overflow:hidden}.nav-item:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,var(--ember-trace) 0%,transparent 100%);opacity:0;transition:opacity var(--t-base) var(--ease-out)}.nav-item:hover{color:var(--text-primary);background:var(--border-dim)}.nav-item.active{color:var(--ember-core);background:var(--ember-subtle);border:1px solid var(--ember-trace)}.nav-item.active:before{opacity:1}.nav-item.active .nav-icon{color:var(--ember-core)}.nav-dot{position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--ember-core);border-radius:0 2px 2px 0;box-shadow:0 0 10px var(--ember-glow);opacity:0;transition:opacity var(--t-fast)}.nav-item.active .nav-dot{opacity:1}.sidebar-footer{padding:var(--s4) var(--s3);border-top:1px solid var(--border-dim)}.sidebar-user{display:flex;align-items:center;gap:var(--s3);padding:var(--s3);border-radius:var(--r-md);cursor:pointer;transition:background var(--t-fast)}.sidebar-user:hover{background:var(--border-dim)}.sidebar-avatar{width:36px;height:36px;background:linear-gradient(135deg,var(--ember-core),var(--violet-core));border-radius:var(--r-full);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:var(--size-sm);color:#fff;flex-shrink:0}.sidebar-user-name{font-size:var(--size-sm);font-weight:600;color:var(--text-primary)}.sidebar-user-role{font-size:var(--size-xxs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.header{position:fixed;top:0;left:var(--sidebar-width);right:0;height:var(--header-height);background:var(--header-tint);-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid var(--border-dim);display:flex;align-items:center;justify-content:flex-end;padding:0 var(--s8);z-index:50}.system-status{display:flex;align-items:center;gap:var(--s2);font-size:var(--size-xs);font-weight:500;color:var(--jade-core);background:#00e5a014;border:1px solid rgba(0,229,160,.2);padding:6px var(--s3);border-radius:var(--r-full);letter-spacing:.04em}.status-pulse{width:6px;height:6px;background:var(--jade-core);border-radius:50%;box-shadow:0 0 #00e5a066;animation:statusPulse 2s ease-out infinite}@keyframes statusPulse{0%{box-shadow:0 0 #00e5a066}70%{box-shadow:0 0 0 6px #00e5a000}to{box-shadow:0 0 #00e5a000}}.card{background:var(--bg-surface);border:1px solid var(--border-soft);border-radius:var(--r-xl);padding:var(--s6);transition:all var(--t-base) var(--ease-out);position:relative;overflow:hidden}.card:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at var(--mouse-x, 50%) var(--mouse-y, 50%),rgba(255,255,255,.03),transparent 60%);opacity:0;transition:opacity var(--t-base);pointer-events:none}.card:hover:before{opacity:1}.card:hover{border-color:var(--border-medium);transform:translateY(-2px);box-shadow:var(--shadow-card)}.card-glass{background:#11172099;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border:1px solid var(--border-soft);border-radius:var(--r-xl)}.sensor-card{position:relative;overflow:hidden}.sensor-card-glow{position:absolute;top:-50%;right:-30%;width:200px;height:200px;border-radius:50%;opacity:.12;filter:blur(40px);transition:opacity var(--t-slow)}.sensor-card:hover .sensor-card-glow{opacity:.2}.sensor-value-xl{font-family:var(--font-display);font-size:var(--size-4xl);font-weight:800;letter-spacing:-.04em;line-height:1}.sensor-label{font-size:var(--size-xs);font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-top:var(--s2)}.sensor-icon-ring{width:52px;height:52px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;position:relative}.sensor-icon-ring:after{content:"";position:absolute;inset:-1px;border-radius:inherit;padding:1px;background:linear-gradient(135deg,currentColor,transparent);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:.3}.btn{display:inline-flex;align-items:center;gap:var(--s2);padding:10px var(--s5);font-family:var(--font-body);font-size:var(--size-sm);font-weight:600;border:none;border-radius:var(--r-md);cursor:pointer;transition:all var(--t-fast) var(--ease-out);white-space:nowrap;letter-spacing:.01em}.btn:active{transform:scale(.97)}.btn-primary{background:var(--ember-core);color:#fff;box-shadow:0 4px 20px #ff6b354d}.btn-primary:hover{background:var(--ember-bright);box-shadow:0 4px 32px #ff6b3580;transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border-soft)}.btn-ghost:hover{border-color:var(--border-medium);color:var(--text-primary);background:var(--border-dim)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-soft)}.btn-secondary:hover{border-color:var(--border-medium);background:var(--bg-highlight)}.btn-danger{background:#ff3b5c26;color:var(--crimson-core);border:1px solid rgba(255,59,92,.25)}.btn-danger:hover{background:#ff3b5c40;box-shadow:0 0 20px var(--crimson-glow)}.btn-sm{padding:6px var(--s3);font-size:var(--size-xs)}.btn-lg{padding:var(--s3) var(--s8);font-size:var(--size-md)}.form-group{margin-bottom:var(--s5)}.form-label{display:block;font-size:var(--size-xs);font-weight:600;color:var(--text-secondary);margin-bottom:var(--s2);letter-spacing:.06em;text-transform:uppercase}.form-input{width:100%;padding:12px var(--s4);background:var(--bg-raised);border:1px solid var(--border-soft);border-radius:var(--r-md);color:var(--text-primary);font-family:var(--font-body);font-size:var(--size-base);transition:all var(--t-fast) var(--ease-out);outline:none}.form-input::placeholder{color:var(--text-whisper)}.form-input:hover{border-color:var(--border-medium)}.form-input:focus{border-color:var(--ember-core);box-shadow:0 0 0 3px var(--ember-glow);background:var(--bg-surface)}select.form-input{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M6 8L1 3h10z' fill='%234c5668'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--s3) center;padding-right:var(--s8)}:root[data-theme=light] select.form-input{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M6 8L1 3h10z' fill='%236b7587'/%3E%3C/svg%3E")}select.form-input option{background:var(--bg-surface)}.table-container{overflow-x:auto;border-radius:var(--r-xl);border:1px solid var(--border-soft);background:var(--bg-surface)}table{width:100%;border-collapse:collapse}th{text-align:left;padding:var(--s3) var(--s5);font-size:var(--size-xxs);font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;background:var(--bg-raised);border-bottom:1px solid var(--border-dim)}td{padding:var(--s4) var(--s5);font-size:var(--size-sm);border-bottom:1px solid var(--border-dim);color:var(--text-primary);transition:background var(--t-fast)}tr:last-child td{border-bottom:none}tr:hover td{background:var(--border-dim)}.badge{display:inline-flex;align-items:center;gap:var(--s1);padding:3px var(--s3);font-size:var(--size-xxs);font-weight:700;border-radius:var(--r-full);letter-spacing:.05em;text-transform:uppercase}.badge-success{background:#00e5a01a;color:var(--jade-core);border:1px solid rgba(0,229,160,.2)}.badge-warning{background:#ffb0201a;color:var(--amber-core);border:1px solid rgba(255,176,32,.2)}.badge-danger{background:#ff3b5c1a;color:var(--crimson-core);border:1px solid rgba(255,59,92,.2)}.badge-info{background:#00d4ff1a;color:var(--cyan-core);border:1px solid rgba(0,212,255,.2)}.badge-neutral{background:var(--border-dim);color:var(--text-secondary)}.alert-banner{padding:var(--s4) var(--s5);border-radius:var(--r-lg);display:flex;align-items:center;gap:var(--s3);margin-bottom:var(--s6);position:relative;overflow:hidden}.alert-banner:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:3px 0 0 3px}.alert-banner-critical{background:#ff3b5c14;border:1px solid rgba(255,59,92,.2);color:var(--crimson-core);animation:alertBreath 2.5s ease-in-out infinite}.alert-banner-critical:before{background:var(--crimson-core)}.alert-banner-warning{background:#ffb02014;border:1px solid rgba(255,176,32,.2);color:var(--amber-core)}.alert-banner-warning:before{background:var(--amber-core)}@keyframes alertBreath{0%,to{box-shadow:0 0 #ff3b5c00}50%{box-shadow:0 0 24px #ff3b5c1f}}.sensor-icon{width:44px;height:44px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.sensor-icon-temperature{background:#ff6b351f;color:var(--sensor-temp)}.sensor-icon-humidity{background:#00d4ff1f;color:var(--sensor-humid)}.sensor-icon-smoke{background:#ff3b5c1f;color:var(--sensor-smoke)}.sensor-icon-water{background:#3b9eff1f;color:var(--sensor-water)}.sensor-icon-motion{background:#9b59ff1f;color:var(--sensor-motion)}.sensor-icon-weight{background:#00e5a01f;color:var(--sensor-weight)}.sensor-icon-moisture{background:#00e5a01f;color:var(--sensor-moisture)}.sensor-icon-light{background:#ffb0201f;color:var(--sensor-light)}.spinner{width:24px;height:24px;border:2px solid var(--border-soft);border-top-color:var(--ember-core);border-radius:50%;animation:spin .7s linear infinite}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:280px;gap:var(--s4)}.loading-text{font-size:var(--size-sm);color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase}@keyframes spin{to{transform:rotate(360deg)}}.auth-page{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;align-items:stretch;position:relative;overflow:hidden;background:var(--bg-void)}.auth-visual{position:relative;overflow:hidden;background:var(--bg-base);display:flex;align-items:center;justify-content:center}.auth-visual:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 30% 30%,rgba(255,107,53,.25) 0%,transparent 60%),radial-gradient(ellipse at 70% 70%,rgba(155,89,255,.2) 0%,transparent 60%);animation:authGlow 8s ease-in-out infinite alternate}.auth-visual:after{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.02'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}@keyframes authGlow{0%{transform:scale(1) rotate(0)}to{transform:scale(1.1) rotate(5deg)}}.auth-visual-content{position:relative;z-index:1;text-align:center;padding:var(--s12)}.auth-visual-badge{display:inline-flex;align-items:center;gap:var(--s2);background:#ff6b351a;border:1px solid rgba(255,107,53,.2);padding:6px var(--s4);border-radius:var(--r-full);font-size:var(--size-xs);color:var(--ember-core);letter-spacing:.08em;text-transform:uppercase;font-weight:600;margin-bottom:var(--s6)}.auth-visual-title{font-family:var(--font-display);font-size:var(--size-5xl);font-weight:800;letter-spacing:-.05em;line-height:.95;color:var(--text-primary);margin-bottom:var(--s6)}.auth-visual-title span{background:linear-gradient(135deg,var(--ember-core),var(--violet-core));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-visual-desc{color:var(--text-secondary);font-size:var(--size-md);max-width:340px;margin:0 auto;line-height:1.7;font-weight:300}.auth-panel{display:flex;align-items:center;justify-content:center;padding:var(--s12);background:var(--bg-void)}.auth-form-wrap{width:100%;max-width:380px}.auth-eyebrow{font-size:var(--size-xxs);font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ember-core);margin-bottom:var(--s5)}.auth-title{font-family:var(--font-display);font-size:var(--size-2xl);font-weight:700;letter-spacing:-.03em;margin-bottom:var(--s2)}.auth-subtitle{font-size:var(--size-sm);color:var(--text-muted);margin-bottom:var(--s8);font-weight:300}.auth-card{position:relative;width:100%;max-width:420px;padding:var(--s10);background:var(--bg-surface);border:1px solid var(--border-soft);border-radius:var(--r-2xl);box-shadow:var(--shadow-modal)}.auth-logo{display:flex;align-items:center;gap:var(--s3);margin-bottom:var(--s8)}.auth-logo-icon{width:48px;height:48px;background:linear-gradient(135deg,var(--ember-core),var(--violet-core));border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 0 32px #ff6b3559}.auth-logo h1{font-family:var(--font-display);font-size:var(--size-xl);font-weight:700}.auth-logo p{font-size:var(--size-xs);color:var(--text-muted)}.auth-error{padding:var(--s3) var(--s4);background:#ff3b5c14;color:var(--crimson-core);border-radius:var(--r-md);font-size:var(--size-sm);margin-bottom:var(--s5);border:1px solid rgba(255,59,92,.2)}@media(max-width:768px){.auth-page{grid-template-columns:1fr}.auth-visual{display:none}}.grid{display:grid;gap:var(--s5)}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media(max-width:1200px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}.main-content{margin-left:0}.page-container{padding:var(--s5)}}.modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s var(--ease-out)}.modal{background:var(--bg-elevated);border:1px solid var(--border-soft);border-radius:var(--r-2xl);padding:var(--s8);width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-modal);animation:modalSlide .3s var(--ease-out)}@keyframes modalSlide{0%{transform:translateY(24px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--s6)}.modal-header h2{font-family:var(--font-display);font-size:var(--size-xl);font-weight:700;letter-spacing:-.02em}.modal-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:var(--s2);border-radius:var(--r-md);transition:all var(--t-fast)}.modal-close:hover{background:var(--border-soft);color:var(--text-primary)}.empty-state{text-align:center;padding:var(--s16) var(--s6);color:var(--text-muted)}.empty-state-icon{margin-bottom:var(--s5);opacity:.3}.empty-state h3{font-family:var(--font-display);font-size:var(--size-lg);font-weight:600;color:var(--text-secondary);margin-bottom:var(--s2);letter-spacing:-.02em}.empty-state p{font-size:var(--size-sm);max-width:280px;margin:0 auto;line-height:1.7;font-weight:300}.stat-inline{display:flex;align-items:baseline;gap:var(--s2)}.stat-delta{font-size:var(--size-xs);font-weight:600;padding:2px 6px;border-radius:var(--r-sm)}.delta-up{background:#00e5a01a;color:var(--jade-core)}.delta-down{background:#ff3b5c1a;color:var(--crimson-core)}.chip{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:var(--r-full);font-size:var(--size-xs);font-weight:600;border:1px solid;cursor:pointer;transition:all var(--t-fast) var(--ease-out);letter-spacing:.04em}.chip-active{background:#ff6b351f;color:var(--ember-core);border-color:#ff6b354d;box-shadow:0 0 16px #ff6b3526}.chip-inactive{background:var(--border-dim);color:var(--text-secondary);border-color:var(--border-soft)}.chip-inactive:hover{border-color:var(--border-medium);color:var(--text-primary)}.divider{height:1px;background:var(--border-dim);margin:var(--s6) 0}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.animate-fade-in{animation:fadeIn .45s var(--ease-out) forwards}.animate-slide-left{animation:slideInLeft .35s var(--ease-out) forwards}.animate-scale-in{animation:scaleIn .3s var(--ease-out) forwards}.grid>*{animation:fadeIn .5s var(--ease-out) both;opacity:0}.grid>*:nth-child(1){animation-delay:0ms}.grid>*:nth-child(2){animation-delay:70ms}.grid>*:nth-child(3){animation-delay:.14s}.grid>*:nth-child(4){animation-delay:.21s}.grid>*:nth-child(5){animation-delay:.28s}.grid>*:nth-child(6){animation-delay:.35s}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-2{gap:var(--s2)}.gap-3{gap:var(--s3)}.gap-4{gap:var(--s4)}.gap-6{gap:var(--s6)}.mt-2{margin-top:var(--s2)}.mt-4{margin-top:var(--s4)}.mt-6{margin-top:var(--s6)}.mb-4{margin-bottom:var(--s4)}.mb-6{margin-bottom:var(--s6)}.flex-1{flex:1}.text-sm{font-size:var(--size-sm)}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.font-semibold{font-weight:600}.font-bold{font-weight:700}.w-full{width:100%}.relative{position:relative}.overflow-hidden{overflow:hidden}.text-right{text-align:right}.tracking-wide{letter-spacing:.06em}.uppercase{text-transform:uppercase}.recharts-cartesian-grid-horizontal line,.recharts-cartesian-grid-vertical line{stroke:var(--border-dim)!important}.recharts-text{fill:var(--text-muted)!important;font-size:11px!important}.recharts-tooltip-wrapper .recharts-default-tooltip{background:var(--bg-elevated)!important;border:1px solid var(--border-soft)!important;border-radius:var(--r-md)!important;box-shadow:0 8px 32px #0006!important}
