/*! tailwindcss v4.3.0 | MIT License | https://tailwindcss.com */
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--radius-sm:.25rem;--radius-lg:.5rem;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.collapse{visibility:collapse}.visible{visibility:visible}.fixed{position:fixed}.static{position:static}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.table{display:table}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.border{border-style:var(--tw-border-style);border-width:1px}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}}.counter{color:var(--accent);background:var(--accent-bg);border:2px solid #0000;border-radius:5px;margin-bottom:24px;padding:5px 10px;font-size:16px;transition:border-color .3s}.counter:hover{border-color:var(--accent-border)}.counter:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.hero{position:relative}.hero .base,.hero .framework,.hero .vite{margin:0 auto;inset-inline:0}.hero .base{z-index:0;width:170px;position:relative}.hero .framework,.hero .vite{position:absolute}.hero .framework{z-index:1;height:28px;top:34px;transform:perspective(2000px)rotate(300deg)rotateX(44deg)rotateY(39deg)scale(1.4)}.hero .vite{z-index:0;width:auto;height:26px;top:107px;transform:perspective(2000px)rotate(300deg)rotateX(40deg)rotateY(39deg)scale(.8)}#center{flex-direction:column;flex-grow:1;place-content:center;place-items:center;gap:25px;display:flex}@media (width<=1024px){#center{gap:18px;padding:32px 20px 24px}}#next-steps{border-top:1px solid var(--border);text-align:left;display:flex}#next-steps>div{flex:1 1 0;padding:32px}@media (width<=1024px){#next-steps>div{padding:24px 20px}}#next-steps .icon{width:22px;height:22px;margin-bottom:16px}@media (width<=1024px){#next-steps{text-align:center;flex-direction:column}}#docs{border-right:1px solid var(--border)}@media (width<=1024px){#docs{border-right:none;border-bottom:1px solid var(--border)}}#next-steps ul{gap:8px;margin:32px 0 0;padding:0;list-style:none;display:flex}#next-steps ul .logo{height:18px}#next-steps ul a{color:var(--text-h);background:var(--social-bg);border-radius:6px;align-items:center;gap:8px;padding:6px 12px;font-size:16px;text-decoration:none;transition:box-shadow .3s;display:flex}#next-steps ul a:hover{box-shadow:var(--shadow)}#next-steps ul a .button-icon{width:18px;height:18px}@media (width<=1024px){#next-steps ul{flex-wrap:wrap;justify-content:center;margin-top:20px}#next-steps ul li{flex:calc(50% - 8px)}#next-steps ul a{box-sizing:border-box;justify-content:center;width:100%}}#spacer{border-top:1px solid var(--border);height:88px}@media (width<=1024px){#spacer{height:48px}}.ticks{width:100%;position:relative}.ticks:before,.ticks:after{content:"";border:5px solid #0000;position:absolute;top:-4.5px}.ticks:before{border-left-color:var(--border);left:0}.ticks:after{border-right-color:var(--border);right:0}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}:root{--green-50:#ecfdf5;--green-100:#d1fae5;--green-500:#22c55e;--green-600:#16a34a;--green-700:#15803d;--green-800:#166534;--orange-100:#ffedd5;--orange-600:#ea580c;--red-100:#fee2e2;--red-600:#dc2626;--blue-100:#dbeafe;--blue-600:#2563eb;--purple-100:#f3e8ff;--purple-600:#9333ea;--bg:#f5f7f9;--surface:#fff;--surface-2:#f9fafb;--border:#e5e7eb;--border-2:#d1d5db;--text:#4b5563;--text-muted:#6b7280;--text-soft:#9ca3af;--text-h:#0f172a;--shadow-sm:0 1px 2px #0f172a0a;--shadow:0 4px 16px #0f172a0f;--shadow-lg:0 10px 28px #0f172a1a;--radius-sm:8px;--radius:12px;--radius-lg:16px;--sans:"Inter", system-ui, "Segoe UI", Roboto, sans-serif;--heading:"Inter", system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font-family:var(--sans);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:16px;line-height:1.5}*{box-sizing:border-box}body{background:var(--bg);color:var(--text);font-family:var(--sans);margin:0}#root{text-align:left;border:none;flex-direction:column;width:100%;min-height:100vh;margin:0;display:flex}h1,h2,h3,h4{font-family:var(--heading);color:var(--text-h);margin:0;font-weight:600}h1{font-size:32px;line-height:1.2}h2{font-size:22px;line-height:1.3}h3{font-size:18px;line-height:1.35}h4{font-size:16px;line-height:1.4}p{margin:0}a{color:var(--green-700);text-decoration:none}a:hover{text-decoration:underline}code{font-family:var(--mono);background:var(--surface-2);color:var(--text-h);border-radius:4px;padding:2px 6px;font-size:13px}.app-shell{background:var(--bg);min-height:100vh;color:var(--text)}.app-main{width:100%;max-width:1200px;margin:0 auto;padding:28px 24px 64px}.navbar{background:var(--surface);border-bottom:1px solid var(--border);z-index:50;justify-content:space-between;align-items:center;padding:14px 28px;display:flex;position:sticky;top:0}.nav-brand{align-items:center;gap:14px;display:flex}.nav-logo{color:var(--green-700);align-items:center;gap:8px;font-size:20px;font-weight:700;display:flex}.nav-logo:before{content:"";background:var(--green-600);width:22px;height:22px;-webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M11 20A7 7 0 0 1 9.8 6.1C15.5 5 17 4.48 19 2c1 2 2 4.18 2 8 0 5.5-4.78 10-10 10Z'/><path d='M2 21c0-3 1.85-5.36 5.08-6'/></svg>") 50%/contain no-repeat;mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M11 20A7 7 0 0 1 9.8 6.1C15.5 5 17 4.48 19 2c1 2 2 4.18 2 8 0 5.5-4.78 10-10 10Z'/><path d='M2 21c0-3 1.85-5.36 5.08-6'/></svg>") 50%/contain no-repeat}.nav-school{color:var(--green-700);border-left:1px solid var(--border);padding-left:14px;font-size:15px;font-weight:600}.nav-links{align-items:center;gap:26px;display:flex}.nav-links a,.nav-links .nav-link{cursor:pointer;color:var(--text);background:0 0;border:none;align-items:center;gap:6px;padding:0;font-size:14px;font-weight:500;display:inline-flex}.nav-links a:hover,.nav-links .nav-link:hover{color:var(--green-700);text-decoration:none}.hero-banner{width:100%;max-width:1200px;margin:24px auto 0;padding:0 24px}.hero-banner-inner{border-radius:var(--radius-lg);color:#fff;text-align:center;height:240px;box-shadow:var(--shadow);background-color:#0000;background-image:linear-gradient(#0f172a8c,#0f172a8c),linear-gradient(135deg,#0f766e,#15803d 60%,#166534);background-position:50%;background-repeat:repeat,repeat;background-size:cover;background-attachment:scroll,scroll;background-origin:padding-box,padding-box;background-clip:border-box,border-box;flex-direction:column;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.hero-banner-inner h1{color:#fff;letter-spacing:-.5px;text-shadow:0 2px 12px #00000059;margin:0;font-size:40px;font-weight:700}.hero-banner-inner .hero-sub{color:#ffffffe6;text-shadow:0 1px 6px #0006;margin-top:6px;font-size:16px}.stats-grid{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);grid-template-columns:repeat(4,1fr);margin:24px 0 0;display:grid;overflow:hidden}.stat-card{text-align:center;border-right:1px solid var(--border);flex-direction:column;align-items:center;gap:6px;padding:28px 20px 24px;display:flex}.stat-card:last-child{border-right:none}.stat-icon{width:28px;height:28px;color:var(--green-600);margin-bottom:4px}.stat-value{color:var(--text-h);font-size:32px;font-weight:700;line-height:1}.stat-label{color:var(--text-muted);margin-top:4px;font-size:13px}.stat-meta{color:var(--green-700);margin-top:12px;font-size:12px;font-weight:500}button{font-family:var(--sans);border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--text-h);cursor:pointer;padding:9px 16px;font-size:14px;font-weight:500;transition:background .15s,border-color .15s,color .15s}button:hover{background:var(--surface-2);border-color:var(--border-2)}.btn-primary,.dashboard-button{background:var(--green-600);color:#fff;border:1px solid var(--green-600);padding:12px 22px;font-size:15px;font-weight:600}.btn-primary:hover,.dashboard-button:hover{background:var(--green-700);border-color:var(--green-700)}.btn-outline{color:var(--green-700);border:1px solid var(--green-600);background:0 0;font-weight:600}.btn-outline:hover{background:var(--green-50)}.btn-danger,.btn-logout{background:var(--red-600);color:#fff;border:1px solid var(--red-600);font-weight:600}.btn-danger:hover,.btn-logout:hover{background:#b91c1c;border-color:#b91c1c}.btn-ghost{color:var(--text);background:0 0;border:1px solid #0000}.btn-ghost:hover{background:var(--surface-2)}.cta-row{text-align:center;margin-top:28px}.cta-sub{color:var(--text-muted);margin-top:10px;font-size:13px}.section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-top:24px;padding:24px}.section-header{justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px;display:flex}.section-header h2,.section-header h3{margin:0}.subtitle{color:var(--text-muted);margin-top:4px;font-size:14px}.header-section{justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px;display:flex}.header-section h3{margin:0}.aq-overview{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.aq-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);flex-direction:column;gap:10px;padding:18px;display:flex}.aq-card-head{justify-content:space-between;align-items:center;gap:8px;display:flex}.aq-card-title{color:var(--text-h);font-size:14px;font-weight:600}.badge{letter-spacing:.3px;text-transform:uppercase;border-radius:999px;padding:4px 10px;font-size:11px;font-weight:700;display:inline-block}.badge-good{background:var(--green-100);color:var(--green-800)}.badge-moderate{background:var(--orange-100);color:var(--orange-600)}.badge-poor{background:var(--red-100);color:var(--red-600)}.badge-active{background:var(--green-100);color:var(--green-800)}.badge-inactive{background:var(--red-100);color:var(--red-600)}.table-wrapper{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.users-table,.data-table{border-collapse:collapse;width:100%}.users-table th,.users-table td,.data-table th,.data-table td{text-align:left;border-bottom:1px solid var(--border);padding:12px 16px;font-size:14px}.users-table th,.data-table th{background:var(--surface-2);color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;font-size:12px;font-weight:600}.users-table tbody tr:hover,.data-table tbody tr:hover{background:var(--surface-2)}.users-table tbody tr:last-child td,.data-table tbody tr:last-child td{border-bottom:none}.role-filters{flex-wrap:wrap;gap:8px;margin:8px 0 18px;display:flex}.role-filters button{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:999px;padding:8px 16px;font-size:13px;font-weight:500}.role-filters button:hover{background:var(--surface-2)}.role-filters .active-filter{background:var(--green-600);color:#fff;border-color:var(--green-600)}.api-section{margin-top:24px}.api-card-grid{grid-template-columns:repeat(3,1fr);gap:18px;margin-top:16px;display:grid}.api-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);flex-direction:column;gap:14px;padding:20px;display:flex}.api-card-header{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.api-card h4{color:var(--text-h);margin:0 0 8px;font-size:16px}.status-badge{background:var(--green-100);color:var(--green-800);text-transform:uppercase;letter-spacing:.4px;border-radius:999px;padding:4px 10px;font-size:11px;font-weight:700}.role-badge{background:var(--surface-2);color:var(--text);text-transform:uppercase;letter-spacing:.3px;border:1px solid var(--border);border-radius:999px;padding:4px 10px;font-size:11px;font-weight:600;display:inline-block}.role-badge.admin{background:var(--red-100);color:var(--red-600);border-color:#0000}.role-badge.teacher{background:var(--blue-100);color:var(--blue-600);border-color:#0000}.role-badge.researcher{background:var(--purple-100);color:var(--purple-600);border-color:#0000}.role-badge.student{background:var(--green-100);color:var(--green-800);border-color:#0000}.role-badge.mentor{background:var(--orange-100);color:var(--orange-600);border-color:#0000}.api-key-box{border-radius:var(--radius-sm);background:var(--surface-2);border:1px solid var(--border);font-family:var(--mono);color:var(--text-h);text-overflow:ellipsis;white-space:nowrap;padding:10px 12px;font-size:12px;overflow:hidden}.api-details p{color:var(--text-muted);justify-content:space-between;margin:6px 0;font-size:13px;display:flex}.api-details strong{color:var(--text-h);font-weight:600}.api-actions{justify-content:flex-end;gap:8px;margin-top:4px;display:flex}.create-key-button,.create-user-button{background:var(--surface);border:1px solid var(--green-600);color:var(--green-700);font-weight:600}.create-key-button:hover,.create-user-button:hover{background:var(--green-50)}.info-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:18px 20px}.info-card-label{color:var(--text-muted);margin:0;font-size:13px;font-weight:500}.info-card-value{color:var(--text-h);margin-top:8px;font-size:26px;font-weight:700;display:block}.info-grid{grid-template-columns:repeat(4,1fr);gap:14px;margin-top:16px;display:grid}@media (width<=900px){.stats-grid{grid-template-columns:repeat(2,1fr)}.stat-card{border-right:none;border-bottom:1px solid var(--border)}.aq-overview{grid-template-columns:repeat(2,1fr)}.api-card-grid{grid-template-columns:1fr}.info-grid{grid-template-columns:repeat(2,1fr)}.hero-banner-inner h1{font-size:28px}.hero-banner-inner{height:180px}}@media (width<=560px){.navbar{flex-wrap:wrap;gap:10px;padding:12px 16px}.nav-school{border-left:none;padding-left:0}.nav-links{gap:14px}.stats-grid,.aq-overview,.info-grid{grid-template-columns:1fr}.stat-card{border-right:none;border-bottom:1px solid var(--border)}}.modal-backdrop{z-index:50;background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.assign-users-modal{background:#fff;border:1px solid #d1d5db;border-radius:10px;width:500px;max-height:80vh;overflow:hidden}.modal-header{justify-content:space-between;align-items:flex-start;padding:18px 22px 12px;display:flex}.modal-header h3{margin:0;font-size:18px}.modal-header p{color:#6b7280;margin:4px 0 0;font-size:14px}.modal-close-button{cursor:pointer;color:#6b7280;background:0 0;border:none;font-size:26px}.modal-tabs{border-bottom:1px solid #e5e7eb;gap:8px;padding:0 22px 14px;display:flex}.modal-tab,.modal-tab-active{cursor:pointer;border:1px solid #d1d5db;border-radius:999px;padding:7px 14px}.modal-tab{color:#374151;background:#fff}.modal-tab-active{color:#fff;background:#059669;border-color:#059669}.user-search-input{border:1px solid #d1d5db;border-radius:8px;width:calc(100% - 44px);margin:14px 22px;padding:11px 14px}.assign-user-list{border-top:1px solid #e5e7eb;max-height:300px;overflow-y:auto}.assign-user-row{border-bottom:1px solid #e5e7eb;grid-template-columns:38px 1fr auto;align-items:center;gap:10px;padding:12px 22px;display:grid}.user-avatar{color:#065f46;background:#d1fae5;border-radius:999px;justify-content:center;align-items:center;width:30px;height:30px;font-size:12px;font-weight:700;display:flex}.modal-footer{justify-content:space-between;align-items:center;padding:14px 22px;display:flex}.modal-cancel-button,.modal-save-button{cursor:pointer;border-radius:8px;padding:9px 16px;font-weight:600}.modal-cancel-button{background:#fff;border:1px solid #d1d5db;margin-right:8px}.modal-save-button{color:#fff;background:#059669;border:1px solid #059669}.asset-section{padding:0;overflow:hidden}.asset-section .section-header{border-bottom:1px solid #e5e7eb;margin-bottom:0;padding:20px 24px}.asset-filters{border-bottom:1px solid #e5e7eb;gap:10px;padding:16px 24px;display:grid}.asset-filters input,.asset-filters select{background:#fff;border:1px solid #d1d5db;border-radius:8px;padding:11px 14px}.asset-table th{text-transform:uppercase;letter-spacing:.04em;padding:14px 20px;font-size:12px}.asset-table td{vertical-align:middle;padding:16px 20px}.asset-name{font-weight:700}.asset-table code{background:#f3f4f6;border-radius:5px;padding:3px 6px}.type-badge{text-transform:capitalize;border-radius:999px;padding:4px 10px;font-size:12px;font-weight:700}.type-badge.indoor{color:#5b21b6;background:#ede9fe}.type-badge.outdoor{color:#065f46;background:#d1fae5}.threshold-pill{background:#f3f4f6;border-radius:999px;padding:5px 10px;font-weight:600}.asset-table th:last-child,.asset-table td:last-child{text-align:center}.asset-actions{white-space:nowrap;justify-content:center;align-items:center;gap:8px;display:flex}.asset-actions button{min-width:92px}.asset-count{padding:14px 24px 20px}.modal-backdrop{z-index:100;background:#0f172a59;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.threshold-modal{color:#1f2937;background:#fff;border:1px solid #d1d5db;border-radius:10px;flex-direction:column;width:620px;height:620px;display:flex;overflow:hidden}.threshold-modal-header{border-bottom:1px solid #e5e7eb;flex-shrink:0;justify-content:space-between;align-items:flex-start;padding:18px 22px;display:flex}.threshold-modal-header h3{margin:0;font-size:18px;font-weight:700}.threshold-modal-subtitle{color:#6b7280;align-items:center;gap:8px;margin-top:6px;font-size:13px;display:flex}.threshold-modal-subtitle code{color:#374151;background:#f3f4f6;border-radius:4px;padding:3px 7px}.modal-close-button{color:#6b7280;cursor:pointer;background:0 0;border:none;font-size:28px;line-height:1}.threshold-tabs{border-bottom:1px solid #e5e7eb;flex-shrink:0;gap:8px;padding:12px 22px;display:flex}.threshold-tab,.threshold-tab-active{cursor:pointer;border-radius:999px;padding:7px 15px;font-weight:600}.threshold-tab{color:#374151;background:#fff;border:1px solid #d1d5db}.threshold-tab-active{color:#fff;background:#059669;border:1px solid #059669}.threshold-rules-table{border-collapse:collapse;width:100%}.threshold-rules-table th{text-align:left;color:#6b7280;border-bottom:1px solid #e5e7eb;padding:11px 18px;font-size:12px;font-weight:700}.threshold-rules-table td{border-bottom:1px solid #e5e7eb;padding:11px 18px;font-size:14px;font-weight:600}.severity-badge{text-transform:capitalize;border-radius:999px;padding:3px 9px;font-size:12px;font-weight:700;display:inline-block}.severity-badge.warning{color:#92400e;background:#fff3d7}.severity-badge.critical{color:#b91c1c;background:#ffe4e6}.severity-badge.info{color:#1d4ed8;background:#dbeafe}.active-pill,.off-pill{border-radius:999px;padding:3px 10px;font-size:12px;font-weight:700;display:inline-block}.active-pill{color:#047857;background:#d1fae5}.off-pill{color:#6b7280;background:#f3f4f6}.delete-rule-button{color:#dc2626;cursor:pointer;background:0 0;border:none;font-size:20px}.add-rule-box{border-top:1px solid #e5e7eb;flex-shrink:0;padding:16px 22px 18px}.add-rule-box h4{margin:0 0 12px;font-size:15px}.add-rule-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.add-rule-grid label{color:#374151;gap:6px;font-size:12px;font-weight:600;display:grid}.add-rule-grid input,.add-rule-grid select{color:#1f2937;background:#fff;border:1px solid #d1d5db;border-radius:7px;height:38px;padding:0 10px}.add-rule-footer{justify-content:flex-end;margin-top:12px;display:flex}.modal-save-button{color:#fff;cursor:pointer;background:#059669;border:1px solid #059669;border-radius:7px;height:38px;padding:0 14px;font-weight:700}.recent-alert-list{overflow-y:auto}.recent-alert-row{border-bottom:1px solid #e5e7eb;grid-template-columns:8px 1fr auto;align-items:center;gap:10px;padding:13px 20px;display:grid}.alert-dot{border-radius:999px;width:6px;height:6px}.alert-dot.warning{background:#d97706}.alert-dot.critical{background:#dc2626}.alert-dot.info{background:#3b82f6}.recent-alert-main div{align-items:center;gap:8px;display:flex}.recent-alert-main p{color:#6b7280;margin:4px 0 0;font-size:13px}.alert-time{color:#6b7280;white-space:nowrap;font-size:12px}.threshold-content{flex:1;min-height:0;overflow-y:auto}.filter-row{flex-wrap:wrap;gap:8px;margin:8px 0 18px;display:flex}.filter-button,.filter-active{cursor:pointer;border-radius:999px;padding:8px 16px;font-size:13px;font-weight:500}.filter-button{background:var(--surface);color:var(--text);border:1px solid var(--border)}.filter-button:hover{background:var(--surface-2)}.filter-active{background:var(--green-600);color:#fff;border:1px solid var(--green-600)}.icon-button{border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);background:0 0;padding:6px 12px}.icon-button:hover{background:var(--surface-2)}.site-name{color:var(--text-h);font-weight:600}.muted-cell{color:var(--text-muted)}.plain-select{border:1px solid var(--border-2);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);cursor:pointer;padding:7px 10px;font-size:13px}.user-count-pill{border:1px solid var(--border);background:var(--surface-2);cursor:pointer;border-radius:999px;align-items:center;gap:5px;padding:5px 12px;font-size:13px;font-weight:700;display:inline-flex}.user-count-pill small{color:var(--text-muted);font-weight:500}.user-count-pill:hover{background:var(--green-50);border-color:var(--green-600)}.row-actions{white-space:nowrap;gap:8px;display:flex}.empty-row{text-align:center;color:var(--text-muted);padding:28px 16px!important}.loading-text{color:var(--text-muted);padding:24px}.site-form-modal{background:var(--surface);border:1px solid var(--border-2);border-radius:10px;flex-direction:column;width:480px;display:flex;overflow:hidden}.site-form-body{padding:6px 22px 18px}.form-field{color:#374151;gap:6px;margin-top:12px;font-size:13px;font-weight:600;display:grid}.form-field input{border:1px solid var(--border-2);background:var(--surface);height:40px;color:var(--text-h);border-radius:8px;padding:0 12px;font-size:14px;font-weight:400}.form-field input:focus{outline:2px solid var(--green-500);outline-offset:-1px;border-color:var(--green-500)}.form-field-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-error{color:var(--red-600);margin-top:12px;font-size:13px;font-weight:500}.delete-warning{color:var(--text);margin-top:10px;font-size:14px;line-height:1.6}.alerts-site-group{margin-top:20px}.alerts-site-title{margin-bottom:4px;font-size:16px}.alerts-asset-group{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);margin-top:10px;overflow:hidden}.alerts-asset-head{background:var(--surface-2);border-bottom:1px solid var(--border);color:var(--text-h);justify-content:space-between;align-items:center;padding:10px 16px;font-size:14px;font-weight:600;display:flex}.alerts-asset-group .recent-alert-row:last-child{border-bottom:none}.alert-row-deletable{grid-template-columns:8px 1fr auto auto}.reg-step{border-top:1px solid var(--border);margin-top:18px;padding-top:18px}.reg-step:first-of-type{border-top:none;margin-top:0;padding-top:0}.reg-step-title{color:var(--text-h);align-items:center;gap:8px;font-size:14px;font-weight:700;display:flex}.reg-step-num{background:var(--green-100);width:22px;height:22px;color:var(--green-800);border-radius:999px;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:inline-flex}.reg-step-hint{color:var(--text-muted);margin:4px 0 10px;font-size:13px}.explorer-controls{flex-wrap:wrap;align-items:flex-end;gap:12px;display:flex}.explorer-controls .form-field{flex:1;min-width:160px;margin-top:0}.load-button{height:40px;padding:0 22px}.records-label{color:var(--text-muted);white-space:nowrap;padding-bottom:11px;font-size:13px}.chart-wrap{width:100%}.scroll-table{max-height:440px;overflow-y:auto}.raw-json summary{cursor:pointer;color:var(--green-700);-webkit-user-select:none;user-select:none;font-size:13px;font-weight:600}.raw-json pre{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;margin:8px 0 0;padding:10px 12px;font-size:12px;overflow-x:auto}.form-label{color:#374151;flex-direction:column;gap:5px;font-size:13px;font-weight:600;display:flex}.form-input{border:1px solid var(--border-2);background:var(--surface);height:40px;color:var(--text-h);border-radius:8px;width:100%;padding:0 12px;font-size:14px;font-weight:400}.form-input:focus{outline:2px solid var(--green-500);outline-offset:-1px;border-color:var(--green-500)}.token-form{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2);margin-bottom:16px;padding:16px}.cancel-button{background:var(--surface);border:1px solid var(--border-2);color:var(--text);font-weight:500}
