*{box-sizing:border-box}:root{color-scheme:light dark;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;margin:0;padding:0;min-height:100vh}body{margin:0;padding:0;background:linear-gradient(145deg,#0f172a,#0b1220 45%,#0a1020);color:#f8fafc;width:100%;max-width:100%;overflow-x:hidden}#root{min-height:100vh;width:100%}.app-shell{flex:1;display:flex;flex-direction:column;padding:0 2.5rem 2.5rem;gap:2rem}main{padding-top:1.5rem}.site-header{position:sticky;top:0;z-index:20;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0f172acc;border-bottom:1px solid rgba(255,255,255,.08)}.site-header__inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 0}.site-brand{display:inline-flex;align-items:center;gap:.6rem;text-decoration:none;color:#f8fafc;font-weight:800;letter-spacing:-.01em}.site-brand__icon{width:32px;height:32px;display:grid;place-items:center;border-radius:10px;background:linear-gradient(135deg,#60a5fa,#2563eb);color:#0b1220}.site-nav{display:flex;align-items:center;gap:1rem}.site-nav__link{color:#e2e8f0;text-decoration:none;padding:.6rem .8rem;border-radius:10px;transition:background .15s ease,color .15s ease}.site-nav__link:hover,.site-nav__link.active{background:#3b82f629;color:#bfdbfe}.site-header__actions{display:flex;align-items:center;gap:.75rem}.site-header__user{color:#cbd5e1;font-size:.95rem}.site-header__burger{display:none;background:none;border:1px solid rgba(255,255,255,.2);color:#f8fafc;padding:.4rem .6rem;border-radius:10px;cursor:pointer}.pill-button{background:linear-gradient(135deg,#60a5fa,#2563eb);color:#0b1220;border:none;border-radius:999px;padding:.75rem 1.1rem;font-weight:700;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:.4rem;box-shadow:0 12px 25px #3b82f647}.pill-button.ghost{background:#ffffff14;color:#e2e8f0;border:1px solid rgba(255,255,255,.12);box-shadow:none}.page{display:flex;flex-direction:column;gap:2rem}.page.narrow{max-width:1200px;width:100%;margin:0 auto}.hero-section{background:radial-gradient(circle at 20% 20%,rgba(59,130,246,.18),transparent 30%),radial-gradient(circle at 80% 0%,rgba(37,99,235,.12),transparent 35%),linear-gradient(135deg,#0b1220,#0f172a);border:1px solid rgba(255,255,255,.08);border-radius:22px;padding:1.5rem}.hero-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:1.5rem;align-items:center}.hero-copy{display:flex;flex-direction:column;gap:1rem}.hero-cta{display:flex;gap:.75rem;flex-wrap:wrap}.hero-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem}.hero-stat{display:grid;grid-template-columns:auto 1fr;gap:.6rem;align-items:center;padding:.9rem 1rem;border-radius:14px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08)}.hero-card-shell{display:flex;justify-content:center}.hero-card{background:#ffffff05;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:1.5rem;width:100%;max-width:460px}.hero-card__eyebrow{margin:0;color:#a5b4fc;text-transform:uppercase;letter-spacing:.08em;font-size:.85rem}.hero-card__muted{color:#e2e8f0cc}.hero-card__muted.small{font-size:.9rem}.hero-carousel{background:#ffffff08;border:1px solid rgba(255,255,255,.08);padding:1.25rem;border-radius:18px;display:flex;flex-direction:column;gap:.75rem}.hero-carousel__tag{display:inline-flex;padding:.4rem .75rem;border-radius:999px;background:#3b82f633;color:#bfdbfe;font-weight:700;letter-spacing:.05em;text-transform:uppercase;width:fit-content}.hero-carousel__controls{display:flex;align-items:center;gap:.75rem}.hero-carousel__controls button{background:#ffffff14;border:1px solid rgba(255,255,255,.12);color:#f8fafc;padding:.5rem;border-radius:10px;cursor:pointer}.hero-carousel__dots{display:flex;gap:.4rem;align-items:center}.hero-carousel__dot{width:10px;height:10px;border-radius:50%;background:#ffffff4d;cursor:pointer}.hero-carousel__dot.active{background:#60a5fa;box-shadow:0 0 0 4px #60a5fa40}.section-heading{display:flex;flex-direction:column;gap:.25rem}.eyebrow{text-transform:uppercase;letter-spacing:.1em;color:#a5b4fc;font-size:.9rem}.updates-section,.products-section,.highlights-section{background:#0f172a80;border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.updates-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.updates-grid.large{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.update-card,.product-card,.highlight-card{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:1rem;height:100%}.badge{display:inline-flex;padding:.35rem .65rem;border-radius:999px;background:#3b82f62e;color:#bfdbfe;font-weight:700;font-size:.85rem}.product-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.highlight-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}.cta-panel{margin-top:1rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem;border-radius:14px;border:1px dashed rgba(255,255,255,.1);background:#ffffff05}.cta-actions{display:flex;gap:.75rem;flex-wrap:wrap}.site-footer{border-top:1px solid rgba(255,255,255,.08);padding-top:1.5rem;color:#cbd5e1}.site-footer__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.site-footer__eyebrow{text-transform:uppercase;letter-spacing:.08em;color:#94a3b8;margin:0}.site-footer__muted{color:#94a3b8}.site-footer ul{list-style:none;padding:0;margin:.5rem 0 0;display:flex;flex-direction:column;gap:.35rem}.site-footer a{color:#e2e8f0;text-decoration:none}.site-footer__meta{margin-top:1rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;color:#94a3b8;font-size:.95rem}.route-loader{padding:2rem;text-align:center;color:#e2e8f0}.dashboard-grid{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.card{background:#0f172aa6;border:1px solid rgba(148,163,184,.2);border-radius:18px;padding:1.5rem;box-shadow:0 12px 30px #0f172a73;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);display:flex;flex-direction:column;gap:.75rem}.card h2{margin:0;font-size:1.1rem;font-weight:600;color:#e2e8f0}.card .value{font-size:2.25rem;font-weight:700;letter-spacing:-.03em;color:#38bdf8}.trend{display:flex;align-items:center;gap:.5rem;font-size:.95rem;color:#94a3b8}.chart{flex:1;background:#0f172a73;border-radius:16px;padding:1.5rem;border:1px solid rgba(148,163,184,.2);min-height:280px}.chart canvas{width:100%!important;height:100%!important}.table{background:#0f172a73;border-radius:16px;border:1px solid rgba(148,163,184,.2);overflow:hidden}.table table{width:100%;border-collapse:collapse}.table thead{background:#47556933;text-transform:uppercase;letter-spacing:.08em;font-size:.75rem}.table th,.table td{padding:.85rem 1.25rem;text-align:left;border-bottom:1px solid rgba(148,163,184,.12)}.table tbody tr:hover{background:#3b82f614}.status-pill{display:inline-flex;align-items:center;gap:.35rem;padding:.25rem .65rem;border-radius:999px;font-size:.78rem;font-weight:600;background:#38bdf829;color:#38bdf8}.status-pill.offline{background:#f871711f;color:#f87171}.loading,.error-state{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:2rem;background:#0f172a8c;border-radius:16px;border:1px solid rgba(148,163,184,.2);color:#94a3b8}.error-state{color:#fca5a5}.rooms-dashboard{min-height:100vh;padding:clamp(1.5rem,2vw,2.75rem);background:radial-gradient(circle at top,#111827,#0b1120 60%);color:#e2e8f0;display:flex;flex-direction:column;gap:1.75rem;width:100%;max-width:100%;flex:1;box-sizing:border-box;position:relative;overflow-x:hidden}.data-loading-overlay{position:absolute;top:1.25rem;right:1.25rem;display:inline-flex;align-items:center;gap:.55rem;padding:.5rem .9rem;background:#0f172ae6;border:1px solid rgba(148,163,184,.4);border-radius:999px;font-size:.85rem;color:#e2e8f0;box-shadow:0 10px 20px #0206178c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:15;pointer-events:none}.rooms-top{width:100%;align-self:stretch;display:flex;flex-direction:column;gap:1.5rem}.rooms-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1.5rem}.rooms-pretitle{text-transform:uppercase;letter-spacing:.18em;font-size:.65rem;font-weight:700;color:#38bdf8;margin:0 0 .5rem}.rooms-header h1{margin:0;font-size:clamp(1.8rem,2.2vw + 1rem,2.6rem);letter-spacing:-.03em}.rooms-subtitle{margin:.35rem 0 0;color:#94a3b8;font-size:.95rem}.rooms-actions{display:flex;gap:.75rem;flex-wrap:wrap}.rooms-button{border-radius:999px;padding:.8rem 1.4rem;font-weight:600;display:inline-flex;align-items:center;gap:.6rem;border:none;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.rooms-button.primary{background:linear-gradient(135deg,#38bdf8,#22d3ee);color:#0f172a;box-shadow:0 12px 26px #22d3ee47}.rooms-button.primary:hover{transform:translateY(-1px);box-shadow:0 18px 32px #22d3ee59}.rooms-button.secondary{background:#94a3b81f;color:#e2e8f0;border:1px solid rgba(148,163,184,.25);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.rooms-button.secondary:hover{transform:translateY(-1px)}.rooms-controls{display:flex;flex-direction:column;gap:1.25rem}.rooms-control-row{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}.rooms-tabs{display:flex;gap:.75rem;overflow-x:auto;padding-bottom:.5rem}.rooms-tab{border-radius:999px;padding:.7rem 1.4rem;background:#94a3b826;color:#cbd5f5;border:none;cursor:pointer;font-weight:600;transition:background .2s ease,transform .2s ease;white-space:nowrap}.rooms-tab.active{background:linear-gradient(135deg,#8b5cf6,#3b82f6);color:#f8fafc;box-shadow:0 12px 24px #3b82f659;transform:translateY(-2px)}.rooms-time-range{display:flex;flex-wrap:wrap;gap:.65rem}.time-range-button{border-radius:12px;padding:.65rem 1.1rem;background:#94a3b81f;color:#cbd5f5;border:1px solid transparent;cursor:pointer;font-size:.85rem;font-weight:600;transition:all .2s ease}.time-range-button.active{background:#3b82f629;border-color:#3b82f666;color:#f8fafc;box-shadow:0 12px 24px #3b82f633}.rooms-refresh{display:inline-flex;flex-wrap:wrap;align-items:center;gap:.6rem}.refresh-button{border-radius:12px;padding:.65rem 1rem;background:#94a3b81a;color:#cbd5f5;border:1px solid transparent;cursor:pointer;font-size:.8rem;font-weight:600;transition:all .2s ease}.refresh-button.active{background:#38bdf82e;border-color:#38bdf873;color:#f8fafc;box-shadow:0 10px 20px #38bdf838}.refresh-button:hover{transform:translateY(-1px)}.rooms-content{display:flex;flex-direction:column;gap:1.6rem;width:100%;align-self:stretch}.rooms-overview,.rooms-stats,.rooms-charts,.rooms-summary,.rooms-recent{background:#0f172a8c;border-radius:24px;padding:clamp(1.4rem,2vw,1.8rem);border:1px solid rgba(148,163,184,.2);box-shadow:0 18px 40px #0f172a73;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);width:100%}.rooms-overview{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem}.overview-tile{display:flex;flex-direction:column;gap:.35rem}.overview-tile p{margin:0;text-transform:uppercase;letter-spacing:.1em;font-size:.7rem;color:#94a3b8}.overview-tile strong{font-size:clamp(1.6rem,1.1vw + 1.2rem,2rem);font-weight:700;color:#38bdf8}.overview-tile span{font-size:.85rem;color:#94a3b8}.rooms-stats{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.stat-card{background:#111827a6;border:1px solid rgba(148,163,184,.18);border-radius:18px;padding:1.25rem;display:flex;flex-direction:column;gap:.4rem}.stat-card p{margin:0;color:#94a3b8;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em}.stat-card strong{font-size:1.4rem;color:#f8fafc}.stat-card.trend{flex-direction:column;gap:.8rem}.stat-card.trend div{display:inline-flex;align-items:center;gap:.5rem;color:#fbbf24}.stat-card.trend span{font-size:.8rem;text-transform:uppercase;color:#fde68a}.rooms-charts{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));min-width:0;overflow:hidden}.panel header{margin-bottom:1rem;display:flex;align-items:baseline;justify-content:space-between;gap:.75rem}.panel h2{margin:0;font-size:1rem;color:#f8fafc}.panel{min-width:0}.panel header span{font-size:.75rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.08em}.panel-body{height:100%;min-width:0;overflow:hidden}.rooms-summary header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem;color:#c4b5fd}.rooms-summary h2{margin:0;font-size:1rem}.summary-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.summary-tile{background:#11182799;border-radius:16px;padding:1.1rem;border:1px solid rgba(148,163,184,.18);display:flex;flex-direction:column;gap:.3rem}.summary-tile p{margin:0;color:#94a3b8;font-size:.8rem}.summary-tile strong{font-size:1.2rem;color:#f8fafc}.rooms-recent header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1rem;gap:1rem}.rooms-recent h2{margin:0;font-size:1rem}.rooms-recent p{margin:0;color:#94a3b8;font-size:.85rem}.table-wrapper{max-width:100%;overflow-x:auto}.rooms-recent table{width:100%;border-collapse:collapse}.rooms-recent th,.rooms-recent td{padding:.8rem 1rem;text-align:left;border-bottom:1px solid rgba(148,163,184,.14);white-space:nowrap}.rooms-recent tbody tr:hover{background:#3b82f61a}.rooms-state{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1.75rem;background:#0f172a99;border-radius:18px;border:1px solid rgba(148,163,184,.25);color:#94a3b8}.rooms-state.error{color:#fca5a5}.rooms-state.empty{color:#cbd5f5}.pulse-dot{width:10px;height:10px;border-radius:999px;background:#38bdf8;box-shadow:0 0 #38bdf8b3;animation:pulse 1.6s infinite}@keyframes pulse{0%{transform:scale(.95);box-shadow:0 0 #38bdf899}70%{transform:scale(1);box-shadow:0 0 0 12px #38bdf800}to{transform:scale(.95);box-shadow:0 0 #38bdf800}}.rooms-footer{margin-top:auto;text-align:center;color:#64748b;font-size:.85rem}@media (max-width: 960px){.rooms-dashboard{padding:2.2rem 1.4rem 2.6rem}.rooms-header{flex-direction:column;align-items:flex-start}.rooms-actions{width:100%}.rooms-button{flex:1 1 auto;justify-content:center}.rooms-control-row{flex-direction:column;align-items:stretch}.rooms-refresh{justify-content:flex-start}}@media (max-width: 640px){.rooms-dashboard{padding:1.6rem .9rem 1.9rem}.rooms-controls{gap:.9rem}.rooms-tabs{gap:.5rem}.rooms-tab{padding:.6rem 1.1rem}.time-range-button{width:100%;text-align:center}.rooms-refresh{width:100%;gap:.5rem}.refresh-button{flex:1;text-align:center}.rooms-overview,.rooms-stats,.rooms-charts,.rooms-summary,.rooms-recent{border-radius:18px}}.device-manager-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.device-manager{background:linear-gradient(to bottom,#1e293b,#0f172a);border:1px solid rgba(148,163,184,.2);border-radius:20px;width:100%;max-width:1200px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080}.device-manager-header{padding:2rem;border-bottom:1px solid rgba(148,163,184,.15);display:flex;justify-content:space-between;align-items:flex-start}.device-manager-header h2{margin:0 0 .5rem;font-size:1.75rem;font-weight:700;display:flex;align-items:center;gap:.75rem;color:#f1f5f9}.device-manager-header p{margin:0;font-size:.95rem;color:#94a3b8}.close-button{background:#94a3b81a;border:1px solid rgba(148,163,184,.2);color:#cbd5e1;border-radius:8px;padding:.5rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.close-button:hover{background:#ef444433;border-color:#ef444466;color:#fca5a5}.device-manager-content{padding:2rem;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:1.5rem}.manager-section{margin-bottom:2.5rem}.manager-section:last-child{margin-bottom:0}.manager-section h3{margin:0 0 1rem;font-size:1.25rem;font-weight:600;color:#e2e8f0}.api-key-card{background:linear-gradient(135deg,#3b82f62e,#2563eb1f);border:1px solid rgba(148,163,184,.3);border-radius:14px;padding:1rem;display:flex;flex-direction:column;gap:.6rem;color:#f8fafc;box-shadow:0 16px 40px #0f172a59}.api-key-meta{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap}.api-key-label{margin:0;color:#e2e8f0e6;font-size:.95rem}.api-key-copied{background:#10b98133;color:#bbf7d0;padding:.25rem .6rem;border-radius:999px;font-size:.85rem;border:1px solid rgba(16,185,129,.4)}.api-key-value{margin:0;font-family:JetBrains Mono,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;word-break:break-all;font-size:1.05rem;color:#f8fafc;background:#0f172a40;padding:.75rem .85rem;border-radius:10px;border:1px solid rgba(148,163,184,.35)}.api-key-actions{display:flex;gap:.5rem;flex-wrap:wrap}.create-room-form{display:flex;gap:.75rem;margin-bottom:1.5rem}.room-input{flex:1;background:#0f172a99;border:1px solid rgba(148,163,184,.25);border-radius:10px;padding:.75rem 1rem;color:#f1f5f9;font-size:.95rem;transition:all .2s}.room-input:focus{outline:none;border-color:#3b82f6;background:#0f172acc}.room-input::placeholder{color:#64748b}.create-button{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;color:#fff;border-radius:10px;padding:.75rem 1.5rem;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem;white-space:nowrap}.create-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 20px #3b82f64d}.create-button:disabled{opacity:.5;cursor:not-allowed}.rooms-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.room-item{background:#0f172a99;border:1px solid rgba(148,163,184,.2);border-radius:10px;padding:1rem;display:flex;justify-content:space-between;align-items:center}.room-name{font-weight:500;color:#e2e8f0}.delete-room-button{background:transparent;border:none;color:#94a3b8;cursor:pointer;padding:.25rem;border-radius:6px;transition:all .2s;display:flex;align-items:center;justify-content:center}.delete-room-button:hover{background:#ef444433;color:#fca5a5}.devices-section{margin-bottom:0}.devices-table{background:#0f172a99;border:1px solid rgba(148,163,184,.2);border-radius:12px;overflow:hidden;overflow-x:auto}.devices-table table{width:100%;border-collapse:collapse;min-width:640px}.devices-table thead{background:#0f172acc;border-bottom:1px solid rgba(148,163,184,.2)}.devices-table th{text-align:left;padding:1rem;font-weight:600;font-size:.85rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em}.devices-table tbody tr{border-bottom:1px solid rgba(148,163,184,.1);transition:background .2s}.devices-table tbody tr:last-child{border-bottom:none}.devices-table tbody tr:hover{background:#3b82f60d}.devices-table td{padding:1rem;color:#cbd5e1;font-size:.95rem}.device-id{font-family:Fira Code,Courier New,monospace;background:#3b82f626;padding:.25rem .5rem;border-radius:6px;font-size:.85rem;color:#93c5fd;word-break:break-all}.device-name{color:#e2e8f0;font-weight:500}.device-name-input{background:#0f172acc;border:1px solid rgba(148,163,184,.3);border-radius:6px;padding:.5rem .75rem;color:#f1f5f9;font-size:.95rem;width:100%;max-width:200px}.device-name-input:focus{outline:none;border-color:#3b82f6}.room-select{background:#0f172acc;border:1px solid rgba(148,163,184,.3);border-radius:6px;padding:.5rem .75rem;color:#f1f5f9;font-size:.95rem;cursor:pointer}.room-select:focus{outline:none;border-color:#3b82f6}.room-badge{background:#3b82f633;color:#93c5fd;padding:.35rem .75rem;border-radius:6px;font-size:.85rem;font-weight:500;display:inline-block}.last-seen{color:#94a3b8;font-size:.85rem}.device-actions{display:flex;gap:.5rem}.action-button{background:#94a3b81a;border:1px solid rgba(148,163,184,.2);color:#cbd5e1;border-radius:6px;padding:.5rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.action-button.edit:hover{background:#3b82f633;border-color:#3b82f666;color:#93c5fd}.action-button.save:hover{background:#22c55e33;border-color:#22c55e66;color:#86efac}.action-button.cancel:hover{background:#ef444433;border-color:#ef444466;color:#fca5a5}.empty-state{padding:3rem 2rem;text-align:center;color:#94a3b8}.empty-state p{margin:0;font-size:.95rem}.view-switcher{position:fixed;bottom:2rem;right:2rem;z-index:100;display:flex;gap:.5rem;background:#0f172acc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(148,163,184,.2);border-radius:12px;padding:.5rem;box-shadow:0 8px 24px #0000004d}.view-switcher-button{background:transparent;border:none;color:#94a3b8;border-radius:8px;padding:.6rem 1rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem;white-space:nowrap}.view-switcher-button:hover{background:#94a3b81a;color:#cbd5e1}.view-switcher-button.active{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 12px #3b82f64d}.device-filter{display:flex;align-items:center;gap:.75rem;padding:1rem 0;flex-wrap:wrap}.filter-label{font-size:.9rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em}.device-filter-button{background:#0f172a99;border:2px solid rgba(148,163,184,.2);color:#cbd5e1;border-radius:10px;padding:.6rem 1rem;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem}.device-filter-button:hover{background:#0f172acc;transform:translateY(-1px)}.device-filter-button.active{background:#3b82f626;color:#f1f5f9}.device-badge{background:#3b82f633;color:#93c5fd;padding:.25rem .6rem;border-radius:6px;font-size:.85rem;font-weight:500;display:inline-block}.log-filters{display:flex;gap:1.5rem;padding:1.5rem 0;flex-wrap:wrap}.log-filter-group{display:flex;flex-direction:column;gap:.5rem;min-width:200px}.log-filter-group label{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em}.log-filter-select{background:#0f172a99;border:1px solid rgba(148,163,184,.25);border-radius:10px;padding:.75rem 1rem;color:#f1f5f9;font-size:.95rem;cursor:pointer;transition:all .2s}.log-filter-select:focus{outline:none;border-color:#3b82f6;background:#0f172acc}.logs-table-section{display:flex;flex-direction:column;gap:1.5rem}.logs-table{width:100%;border-collapse:collapse}.logs-table thead{background:#0f172acc;border-bottom:2px solid rgba(148,163,184,.2)}.logs-table th{text-align:left;padding:1rem;font-weight:600;font-size:.85rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em}.logs-table tbody tr{border-bottom:1px solid rgba(148,163,184,.1);transition:background .2s}.logs-table tbody tr:last-child{border-bottom:none}.logs-table tbody tr:hover{background:#3b82f60d}.logs-table td{padding:.875rem 1rem;color:#cbd5e1;font-size:.95rem}.timestamp-cell{color:#94a3b8;font-size:.9rem;white-space:nowrap}.numeric-cell{font-family:Fira Code,Courier New,monospace;color:#e2e8f0;font-weight:500}.room-label{color:#cbd5e1;font-size:.9rem}.proximity-badge{background:#94a3b833;color:#cbd5e1;padding:.25rem .6rem;border-radius:6px;font-size:.85rem;display:inline-block}.load-more-container{display:flex;justify-content:center;padding:1.5rem 0}.load-more-button{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;color:#fff;border-radius:10px;padding:.875rem 2rem;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem}.load-more-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 20px #3b82f64d}.load-more-button:disabled{opacity:.7;cursor:not-allowed}.user-banner{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-radius:14px;border:1px solid rgba(255,255,255,.14);background:linear-gradient(135deg,#3b82f640,#2563eb2e);color:#0b1220;margin-bottom:1.5rem;box-shadow:0 10px 30px #2563eb33}.user-banner__eyebrow{margin:0;text-transform:uppercase;letter-spacing:.08em;font-size:.75rem;opacity:.8}.user-banner__meta{display:flex;gap:.75rem;align-items:center;margin-top:.25rem}.user-banner__api{font-family:JetBrains Mono,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.9rem;padding:.2rem .5rem;background:#0f172a1f;border-radius:8px;border:1px dashed rgba(15,23,42,.25);color:#f8fafc}.user-banner__logout{background:#0f172a;color:#f8fafc;border:none;border-radius:10px;padding:.55rem 1rem;cursor:pointer;font-weight:600;box-shadow:0 8px 20px #0f172a40;transition:transform .15s ease,box-shadow .15s ease}.user-banner__logout:hover{transform:translateY(-1px);box-shadow:0 12px 25px #0f172a4d}.login-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:radial-gradient(circle at 20% 20%,rgba(59,130,246,.08),transparent 30%),radial-gradient(circle at 80% 0%,rgba(37,99,235,.1),transparent 28%),linear-gradient(135deg,#0f172a,#111827)}.hero-card-shell .login-shell{min-height:auto;padding:0;background:none}.hero-card-shell .login-card{max-width:520px;grid-template-columns:1fr}.login-card{width:min(960px,100%);background:#0b1220;color:#e2e8f0;padding:2rem;border-radius:24px;border:1px solid rgba(255,255,255,.08);display:grid;grid-template-columns:1.2fr 1fr;gap:2rem;box-shadow:0 25px 80px #00000059}.login-shell.inline{min-height:auto;background:none;padding:0}.login-shell.inline .login-card{width:100%;max-width:640px}.landing{padding:2rem;color:#0f172a}.landing-hero{display:grid;grid-template-columns:1.3fr 1fr;gap:2rem;align-items:center;margin-bottom:3rem}.landing-intro{background:linear-gradient(135deg,#ebf1ff,#f8fafc);padding:2rem;border-radius:20px;border:1px solid rgba(59,130,246,.15);box-shadow:0 15px 45px #3b82f62e}.landing-intro h1{margin:.4rem 0 .75rem;font-size:clamp(1.8rem,3vw,2.4rem)}.landing-intro p{margin:0 0 1rem;color:#1f2937;line-height:1.6}.landing-pill{display:inline-flex;gap:.5rem;align-items:center;padding:.4rem .9rem;border-radius:999px;background:#2563eb24;color:#1d4ed8;font-weight:700;letter-spacing:.04em;text-transform:uppercase;font-size:.85rem}.landing-highlight{display:inline-flex;gap:.6rem;align-items:center;padding:.7rem 1rem;background:#0ea5e91f;border-radius:12px;color:#0f172a;border:1px solid rgba(14,165,233,.25);margin:.5rem 0 1rem;font-weight:600}.landing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem}.landing-feature{display:grid;grid-template-columns:auto 1fr;gap:.75rem;padding:.75rem .9rem;border-radius:12px;background:#fffc;border:1px solid rgba(15,23,42,.05)}.landing-login{display:flex;align-items:stretch}.landing-login .login-shell{min-height:auto;background:none;padding:0}.landing-login .login-card{width:100%}.landing-products{background:#0b1220;color:#e2e8f0;padding:2rem;border-radius:20px;border:1px solid rgba(255,255,255,.08);box-shadow:0 20px 60px #00000059}.landing-products header h2{margin:.35rem 0 .5rem;font-size:clamp(1.6rem,2.5vw,2rem)}.landing-products header p{margin:0}.landing-products__eyebrow{text-transform:uppercase;letter-spacing:.08em;color:#e2e8f0cc;margin:0}.landing-products__subtitle{color:#e2e8f0cc}.landing-products__grid{margin-top:1.5rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.landing-product{background:#ffffff05;border-radius:14px;padding:1rem;border:1px solid rgba(255,255,255,.06);position:relative;min-height:180px}.landing-product__badge{position:absolute;top:12px;right:12px;padding:.35rem .65rem;border-radius:999px;background:#3b82f62e;color:#bfdbfe;font-weight:700;font-size:.8rem}.landing-product__icon{width:42px;height:42px;display:grid;place-items:center;border-radius:12px;background:#2563eb1f;color:#bfdbfe;margin-bottom:.75rem}.landing-product h3{margin:0 0 .35rem}.landing-product p{margin:0;color:#e2e8f0cc}.login-hero h1{margin:.25rem 0 .5rem;font-size:clamp(1.6rem,2vw,2rem)}.login-hero p{margin:0;color:#e2e8f0cc;line-height:1.6}.login-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.35rem .7rem;border-radius:999px;background:#3b82f62e;color:#bfdbfe;font-weight:700;letter-spacing:.04em;text-transform:uppercase;font-size:.8rem}.login-form{background:#ffffff05;padding:1.25rem;border-radius:16px;border:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;gap:.75rem}.login-form label{display:flex;align-items:center;justify-content:space-between;color:#cbd5e1;font-weight:600}.login-form input{width:100%;padding:.9rem 1rem;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:#ffffff0a;color:#f8fafc;font-size:1rem}.login-form input:focus{outline:none;border-color:#3b82f6cc;box-shadow:0 0 0 3px #3b82f633}.login-actions{display:flex;gap:.75rem;align-items:center}.login-button{background:linear-gradient(135deg,#60a5fa,#2563eb);border:none;color:#0b1220;font-weight:800;padding:.95rem 1.1rem;border-radius:12px;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;text-transform:uppercase;letter-spacing:.02em}.login-button:hover{transform:translateY(-1px);box-shadow:0 12px 25px #3b82f659}.login-button:disabled{opacity:.7;cursor:not-allowed}.login-secondary{background:#ffffff14;color:#e2e8f0;border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:.85rem 1rem;cursor:pointer;transition:transform .15s ease,border-color .15s ease,color .15s ease}.login-secondary:hover{transform:translateY(-1px);border-color:#3b82f666;color:#bfdbfe}.login-error{color:#fca5a5;background:#f8717114;border:1px solid rgba(248,113,113,.2);padding:.75rem .9rem;border-radius:12px;margin:.25rem 0}.login-hint{margin:0;color:#e2e8f0b3;font-size:.9rem}@media (max-width: 768px){.app-shell{padding:0 1rem 1.5rem;gap:1.25rem}main{padding-top:1rem}.site-header__inner{align-items:flex-start;flex-wrap:wrap;gap:.75rem}.site-nav{position:absolute;top:64px;left:1rem;right:1rem;background:#0f172af2;padding:1rem;border-radius:12px;border:1px solid rgba(255,255,255,.08);flex-direction:column;align-items:flex-start;display:none;box-shadow:0 18px 40px #00000059}.site-nav__link{width:100%}.site-nav.open{display:flex}.site-header__burger{display:inline-flex}.site-header__actions{width:100%;justify-content:flex-end;flex-wrap:wrap}.hero-grid{grid-template-columns:1fr}.hero-section{padding:1.1rem}.hero-cta{flex-direction:column}.hero-stats{grid-template-columns:1fr}.hero-card{padding:1.25rem}.cta-panel{flex-direction:column;align-items:flex-start}.device-manager{max-width:100%;max-height:100vh;border-radius:0}.devices-table{overflow-x:auto}.rooms-list{grid-template-columns:1fr}.device-filter{padding:.75rem 0}.device-filter-button{font-size:.85rem;padding:.5rem .85rem}.log-filters{flex-direction:column;gap:1rem}.log-filter-group{width:100%}.logs-table{font-size:.85rem}.logs-table th,.logs-table td{padding:.75rem .5rem}.login-shell{padding:1.25rem}.login-card{grid-template-columns:1fr;padding:1.5rem}.login-actions{flex-direction:column;align-items:stretch}.login-button,.login-secondary{width:100%;text-align:center}.user-banner{flex-direction:column;align-items:flex-start;gap:.5rem}.landing-hero{grid-template-columns:1fr}.landing{padding:1.25rem}.view-switcher{left:1rem;right:1rem;bottom:1rem;gap:.4rem;justify-content:space-between;flex-wrap:wrap}.view-switcher-button{flex:1 1 45%;justify-content:center}.rooms-charts{grid-template-columns:1fr;padding:1rem}.device-manager{border-radius:12px}.device-manager-content{padding:1.25rem}.create-room-form{flex-direction:column}.create-button{width:100%;justify-content:center}}
