:root{color-scheme:light;font-family:Inter,Segoe UI,Tahoma,sans-serif;background:#f5f7fb;color:#0f172a}*{box-sizing:border-box;min-width:0}body{margin:0;background:#f5f7fb;color:#0f172a}button,input,select{font:inherit}button{border:0}.auth-shell{min-height:100vh;display:grid;place-items:center;padding:24px}.auth-card{width:min(520px,100%);background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:28px;box-shadow:0 20px 50px #0f172a14;display:grid;gap:16px}.auth-head h1{margin:0;font-size:32px}.auth-tabs{display:flex;flex-wrap:wrap;gap:8px}.auth-tabs button{min-height:34px;padding:0 12px;border-radius:8px;background:#e2e8f0;color:#334155;font-weight:700}.auth-tabs button.selected{background:#2563eb;color:#fff}.auth-form{display:grid;gap:12px}.eyebrow{margin:0;color:#2563eb;font-weight:700}.muted{color:#64748b}.error{color:#be123c;font-weight:700}.notice{color:#0f766e;font-weight:700}.global-notice{margin:8px auto;width:min(1100px,100%);padding:8px 16px}label{display:grid;gap:6px;font-weight:600;color:#334155}input,select{border:1px solid #cbd5e1;border-radius:8px;background:#fff;color:#0f172a;min-height:40px;padding:8px 10px}.app-shell{width:min(1440px,100%);margin:0 auto;padding:24px}.topbar,.metrics,.section-heading,.topbar-actions{display:flex;align-items:center}.topbar{justify-content:space-between;gap:12px;margin-bottom:20px}.topbar h1{margin:2px 0 0;font-size:28px}.topbar-actions{gap:8px}.metrics{flex-wrap:wrap;gap:8px;margin-bottom:16px}.metrics>div,.duration-control{min-height:42px;display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid #dbe4f0;border-radius:8px;background:#fff;color:#334155}.duration-control input{width:76px;min-height:32px}.content-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(430px,.95fr);gap:16px}.panel{background:#fff;border:1px solid #dbe4f0;border-radius:10px;padding:16px}.section-heading{justify-content:space-between;gap:8px;margin-bottom:10px}.section-heading h2{margin:0;font-size:20px}.section-heading span{color:#64748b}.discovery-toolbar{display:grid;grid-template-columns:1.3fr repeat(3,minmax(120px,1fr));gap:8px;margin-bottom:12px}.device-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px}.table-wrap{overflow-x:auto;border:1px solid #e2e8f0;border-radius:8px}table{width:100%;border-collapse:collapse;min-width:640px;background:#fff}th,td{padding:12px;border-bottom:1px solid #edf2f7;text-align:left;vertical-align:top}th{color:#64748b;font-size:12px;text-transform:uppercase}.row-actions,.table-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.pin-row{display:flex;gap:8px;align-items:center}.pin-row input{min-width:120px}.link-panel{margin:8px 0 14px}.link-panel form{display:flex;flex-wrap:wrap;align-items:flex-end;gap:10px;margin-top:0}.link-panel label{flex:1 1 220px}.session-badge,.sunshine-badge,.agent-badge,.maintenance-badge{display:inline-flex;align-items:center;min-height:24px;border-radius:999px;padding:0 10px;font-size:12px;font-weight:700}.session-badge.active,.agent-badge.connected{background:#dbeafe;color:#1d4ed8}.session-badge.ended,.session-badge.expired,.agent-badge.stale{background:#e2e8f0;color:#475569}.sunshine-badge.running{background:#d1fae5;color:#047857}.sunshine-badge.stopped,.sunshine-badge.not-installed{background:#fef3c7;color:#b45309}.maintenance-badge{background:#ffe4e6;color:#be123c}.action-notice{display:grid;gap:6px;padding:12px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px}.action-notice p{margin:0;color:#334155;font-weight:500}.account-choice-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.primary-button,.secondary-button,.danger-button,.icon-button{min-height:40px;border-radius:8px;padding:0 12px;display:inline-flex;align-items:center;justify-content:center;gap:6px;font-weight:700;cursor:pointer}.primary-button{background:#2563eb;color:#fff}.secondary-button,.icon-button{background:#e2e8f0;color:#1e293b}.danger-button{background:#dc2626;color:#fff;min-height:34px}.icon-button{width:40px;padding:0}.compact-button{min-height:34px;padding:0 10px;font-size:13px}button:disabled{opacity:.55;cursor:not-allowed}.reservation-builder{grid-column:1 / -1}.language-toggle,.reservation-mode{display:inline-flex;gap:8px}.language-toggle button,.reservation-mode button{min-height:34px;padding:0 10px;border-radius:8px;background:#e2e8f0;color:#334155;font-weight:700}.language-toggle button.selected,.reservation-mode button.selected{background:#2563eb;color:#fff}.reservation-help{display:grid;gap:6px;padding:12px;border:1px solid #e2e8f0;border-radius:8px;background:#f8fafc;line-height:1.45}.reservation-help p{margin:0}.reservation-fields{display:grid;grid-template-columns:repeat(3,minmax(170px,1fr));gap:10px;margin-top:10px}.reservation-fields span{color:#64748b;font-size:12px}.disabled-reason{color:#b45309;font-size:12px;font-weight:700}@media(max-width:1024px){.content-grid{grid-template-columns:1fr}}@media(max-width:780px){.app-shell{padding:14px}.topbar{flex-direction:column;align-items:flex-start}.discovery-toolbar{grid-template-columns:1fr 1fr}.reservation-fields{grid-template-columns:1fr}.link-panel form,.account-choice-actions{display:grid;grid-template-columns:1fr}}@media(max-width:560px){.table-actions,.row-actions,.pin-row{flex-direction:column;align-items:stretch}.table-actions button,.row-actions button,.pin-row button{width:100%}.discovery-toolbar{grid-template-columns:1fr}}.ui-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}.ui-tabs button{min-height:36px;border-radius:8px;padding:0 12px;background:#e2e8f0;color:#334155;font-weight:700}.ui-tabs button.selected{background:#0f172a;color:#fff}.ui-card{background:#fff;border:1px solid #dbe4f0;border-radius:10px;padding:14px}.ui-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px}.ui-card-head h3{margin:0;font-size:18px}.ui-card-head p{margin:4px 0 0;color:#64748b}.ui-badge{display:inline-flex;align-items:center;min-height:24px;border-radius:999px;padding:0 10px;font-size:12px;font-weight:700;background:#e2e8f0;color:#334155}.ui-badge.success{background:#d1fae5;color:#047857}.ui-badge.warning{background:#fef3c7;color:#b45309}.ui-badge.primary{background:#dbeafe;color:#1d4ed8}.ui-badge.neutral{background:#e2e8f0;color:#334155}.ui-toast{margin:8px 0 14px;min-height:42px;display:flex;align-items:center;justify-content:space-between;gap:12px;border-radius:8px;padding:8px 12px}.ui-toast.info{background:#eff6ff;border:1px solid #bfdbfe;color:#1d4ed8}.ui-toast.success{background:#ecfdf5;border:1px solid #a7f3d0;color:#047857}.ui-toast.error{background:#fff1f2;border:1px solid #fecdd3;color:#be123c}.ui-toast button{min-height:28px;width:28px;border-radius:999px;background:#0f172a14;color:currentColor}.ui-skeleton{display:grid;gap:10px}.ui-skeleton span{height:14px;border-radius:999px;background:linear-gradient(90deg,#e2e8f0,#f1f5f9,#e2e8f0);background-size:200% 100%;animation:pulse 1.2s linear infinite}@keyframes pulse{0%{background-position:0% 0}to{background-position:200% 0}}.content-grid.single{grid-template-columns:1fr}.simple-list{display:grid;gap:8px}.simple-row{min-height:40px;display:flex;align-items:center;justify-content:space-between;gap:8px;border:1px solid #e2e8f0;border-radius:8px;padding:8px 10px}.state-line{display:flex;align-items:center;gap:8px;color:#334155;margin-bottom:6px}.session-horizontal-bar{display:flex;flex-wrap:wrap;align-items:center;gap:10px;border:1px solid #dbe4f0;background:#fff;border-radius:8px;padding:10px}.session-horizontal-bar>div{min-height:34px;display:flex;align-items:center}.session-horizontal-bar .bar-countdown{flex:1 1 280px}.countdown-badge{display:grid;gap:4px;border:1px solid #e2e8f0;border-radius:8px;padding:8px 10px;margin-top:6px;background:#f8fafc}.countdown-badge strong{font-size:20px}.countdown-badge small{color:#64748b;font-size:12px}.countdown-badge em{font-style:normal;font-weight:700;color:#b45309}.countdown-badge.tone-success{border-color:#86efac;background:#f0fdf4}.countdown-badge.tone-warning{border-color:#fcd34d;background:#fffbeb}.countdown-badge.tone-danger{border-color:#fda4af;background:#fff1f2}.market-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px}.market-card{border:1px solid #e2e8f0;border-radius:8px;padding:10px;display:grid;gap:8px;background:#fff}.market-thumb{height:90px;border-radius:8px;background:#f1f5f9;display:grid;place-items:center;color:#64748b;font-weight:700}.market-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.market-head h4{margin:0;font-size:15px}.market-specs{display:grid;gap:6px;color:#334155;font-size:13px}.market-actions{display:flex;align-items:center;justify-content:space-between;gap:8px}.session-overlay{border:1px solid #dbeafe;background:#eff6ff;border-radius:8px;padding:14px;margin-bottom:10px}.session-overlay h3{margin:0 0 8px;font-size:20px}
