:root{--font-sans:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;--font-mono:ui-monospace,Menlo,Monaco,"Cascadia Mono","Segoe UI Mono","Roboto Mono","Oxygen Mono","Ubuntu Monospace","Source Code Pro","Fira Mono","Droid Sans Mono","Courier New",monospace;--color-gray-50:#f9fafb;--color-gray-100:#f3f4f6;--color-gray-200:#e5e7eb;--color-gray-300:#d1d5db;--color-gray-400:#9ca3af;--color-gray-500:#6b7280;--color-gray-600:#4b5563;--color-gray-700:#374151;--color-gray-800:#1f2937;--color-gray-900:#111827;--color-blue-50:#eff6ff;--color-blue-100:#dbeafe;--color-blue-500:#3b82f6;--color-blue-600:#2563eb;--color-blue-700:#1d4ed8;--color-green-50:#f0fdf4;--color-green-100:#dcfce7;--color-green-500:#22c55e;--color-green-600:#16a34a;--color-red-50:#fef2f2;--color-red-100:#fee2e2;--color-red-500:#ef4444;--color-red-600:#dc2626;--color-red-700:#b91c1c;--color-yellow-50:#fefce8;--color-yellow-100:#fef9c3;--color-yellow-500:#eab308;--color-yellow-600:#ca8a04;--color-blue-200:#bfdbfe;--color-blue-800:#1e40af;--color-green-200:#bbf7d0;--color-green-800:#166534;--color-red-200:#fecaca;--color-red-800:#991b1b;--color-yellow-200:#fef08a;--color-yellow-800:#854d0e;--color-surface:#ffffff;--shadow-sm:0 1px 2px 0 rgba(0,0,0,0.05);--shadow-md:0 4px 6px -1px rgba(0,0,0,0.1),0 2px 4px -1px rgba(0,0,0,0.06);--shadow-lg:0 10px 15px -3px rgba(0,0,0,0.1),0 4px 6px -2px rgba(0,0,0,0.05);--radius-sm:6px;--radius-md:8px;--radius-lg:12px}*{box-sizing:border-box;padding:0;margin:0}body,html{max-width:100vw;overflow-x:hidden;font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{color:var(--color-gray-900);background:var(--color-gray-50)}a{color:inherit;text-decoration:none}.container{max-width:1200px;margin:0 auto;padding:2rem 1.5rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;border-radius:var(--radius-md);font-size:.9375rem;font-weight:500;border:none;cursor:pointer;transition:all .15s ease;text-decoration:none;line-height:1.5}.btn--primary{background:var(--color-blue-600);color:white}.btn--primary:hover{background:var(--color-blue-700)}.btn--secondary{background:var(--color-surface);color:var(--color-gray-700);border:1px solid var(--color-gray-300)}.btn--secondary:hover{background:var(--color-gray-50);border-color:var(--color-gray-400)}.btn--danger{background:var(--color-red-600);color:white}.btn--danger:hover{background:var(--color-red-700)}.btn--success{background:var(--color-green-600);color:white}.btn--success:hover{background:var(--color-green-500)}.btn--warning{background:var(--color-yellow-600);color:white}.btn--warning:hover{background:var(--color-yellow-500)}.btn--sm{padding:.5rem .75rem;font-size:.875rem}.btn--xsm{padding:.25rem .375rem;font-size:.8125rem}.btn--disabled,.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.card{background:var(--color-surface);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-sm)}.card__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.card__title{font-size:1.125rem;font-weight:600;color:var(--color-gray-900);margin:0}.card__actions{display:flex;gap:.5rem}.badge{display:inline-flex;align-items:center;padding:.25rem .625rem;border-radius:9999px;font-size:.75rem;font-weight:500;line-height:1.25rem}.badge--active,.badge--running{background:var(--color-green-100);color:var(--color-green-600)}.badge--inactive,.badge--stopped{background:var(--color-gray-100);color:var(--color-gray-600)}.badge--provisioning,.badge--starting{background:var(--color-blue-100);color:var(--color-blue-600)}.badge--error,.badge--failed{background:var(--color-red-100);color:var(--color-red-600)}.badge--warning{background:var(--color-yellow-100);color:var(--color-yellow-600)}.badge--info{background:var(--color-blue-50);color:var(--color-blue-600);font-family:var(--font-mono)}.page-header{margin-bottom:2rem}.page-header__title{font-size:1.875rem;font-weight:700;color:var(--color-gray-900);margin-bottom:.5rem}.page-header__subtitle{font-size:1rem;color:var(--color-gray-500)}.page-header__actions{display:flex;gap:.75rem;margin-top:1rem;flex-wrap:wrap;align-items:center}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));grid-gap:1rem;gap:1rem;margin:1rem 0 2rem}.stat-card{padding:1rem 1.25rem;background:var(--color-surface);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:.35rem}.stat-card__label{font-size:.875rem;color:var(--color-gray-500);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.stat-card__value{font-size:1.75rem;font-weight:700;color:var(--color-gray-900);line-height:1.1}.stat-card__meta{display:inline-flex;align-items:center;gap:.35rem;font-size:.9rem;color:var(--color-gray-600)}.tab-toolbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1rem;background:var(--color-surface);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin:1.25rem 0 1.5rem}.tab-toolbar__tabs{flex-wrap:wrap}.tab-toolbar__actions,.tab-toolbar__tabs{display:flex;gap:.5rem}.tab{display:inline-flex;align-items:center;gap:.5rem;padding:.55rem .9rem;border-radius:var(--radius-md);border:1px solid var(--color-gray-200);background:var(--color-surface);color:var(--color-gray-700);font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .15s ease}.tab:hover{border-color:var(--color-gray-300);background:var(--color-gray-50)}.tab--active{color:var(--color-blue-700);background:var(--color-blue-50);border-color:var(--color-blue-200);box-shadow:0 0 0 3px rgba(59,130,246,.15)}.tab__icon{display:inline-flex;align-items:center}.tab__label{letter-spacing:.01em}.tab__badge{display:inline-flex;align-items:center;justify-content:center;min-width:28px;padding:.15rem .45rem;border-radius:999px;background:var(--color-gray-100);color:var(--color-gray-700);font-size:.8125rem;font-weight:700}.tab--active .tab__badge{background:var(--color-surface);color:var(--color-blue-700)}.breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--color-gray-500);margin-bottom:1rem}.breadcrumb a{color:var(--color-blue-600);text-decoration:none}.breadcrumb a:hover{text-decoration:underline}.breadcrumb__separator{color:var(--color-gray-400)}.alert{padding:1rem;border-radius:var(--radius-md);font-size:.9375rem;margin:1.5rem 0}.alert--warning{background:var(--color-yellow-50);border:1px solid var(--color-yellow-200);color:var(--color-yellow-800)}.alert--error{background:var(--color-red-50);border:1px solid var(--color-red-200);color:var(--color-red-800)}.alert--success{background:var(--color-green-50);border:1px solid var(--color-green-200);color:var(--color-green-800)}.alert--info{background:var(--color-blue-50);border:1px solid var(--color-blue-200);color:var(--color-blue-800)}.form-group{margin-bottom:1.5rem}.form-button-group{display:flex;gap:.5rem;margin-bottom:.5rem}.form-label{display:block;font-size:.875rem;font-weight:500;color:var(--color-gray-700);margin-bottom:.5rem}.form-label--required:after{content:" *";color:var(--color-red-500)}.form-input,.form-select,.form-textarea{width:100%;padding:.625rem .875rem;border:1px solid var(--color-gray-300);border-radius:var(--radius-md);font-size:.9375rem;color:var(--color-gray-900);background:var(--color-surface);transition:all .15s ease}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--color-blue-500);box-shadow:0 0 0 3px rgba(59,130,246,.1)}.form-select option:checked{background:var(--color-blue-100)}.form-textarea{min-height:120px;resize:vertical;font-family:var(--font-mono)}.form-error{color:var(--color-red-600)}.form-error,.form-help{font-size:.875rem;margin-top:.375rem}.form-help{color:var(--color-gray-500)}.toggle-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.toggle-input{position:absolute;opacity:0;pointer-events:none}.toggle-icon{display:flex;align-items:center;font-size:2rem;transition:color .2s ease}.toggle-icon--on{color:var(--color-blue-600)}.toggle-icon--off{color:var(--color-gray-400)}.toggle-text{font-size:.9375rem;font-weight:500;color:var(--text-primary)}.empty-state{text-align:center;padding:3rem 1.5rem;color:var(--color-gray-500)}.empty-state__title{font-size:1.125rem;font-weight:600;color:var(--color-gray-900);margin-bottom:.5rem}.empty-state__description{font-size:.9375rem;margin-bottom:1.5rem}.grid{display:grid;grid-gap:1.5rem;gap:1.5rem}.grid--2{grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.detail-section{margin-bottom:2rem}.detail-section__title{font-size:1rem;font-weight:600;color:var(--color-gray-900);margin-bottom:1rem}.detail-grid{display:grid;grid-gap:1rem;gap:1rem;margin-bottom:1rem}.detail-item{display:flex;flex-direction:column;gap:.25rem}.detail-item__label{font-size:.875rem;color:var(--color-gray-500)}.detail-item__value{font-size:.9375rem;color:var(--color-gray-900);font-family:var(--font-mono)}.copy-button{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border:1px solid var(--color-gray-300);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-gray-700);font-size:.875rem;cursor:pointer;transition:all .15s ease}.copy-button:hover{background:var(--color-gray-50);border-color:var(--color-gray-400)}.loading-spinner{display:inline-block;width:1rem;height:1rem;border:2px solid var(--color-gray-300);border-top-color:var(--color-blue-600);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.app-layout{display:flex;min-height:100vh}.app-main{flex:1 1;display:flex;flex-direction:column;min-width:0}.app-content{flex:1 1}.sidebar{width:260px;background:var(--color-surface);border-right:1px solid var(--color-gray-200);display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;z-index:1000;transition:transform .3s ease}.sidebar__header{padding:1.5rem;border-bottom:1px solid var(--color-gray-200)}.sidebar__logo{font-size:1.25rem;font-weight:700;color:var(--color-gray-900);text-decoration:none;display:flex;align-items:center;gap:.5rem}.sidebar__nav{flex:1 1;padding:1rem;overflow-y:auto}.sidebar__link{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;color:var(--color-gray-700);text-decoration:none;border-radius:var(--radius-md);font-size:.9375rem;font-weight:500;transition:all .15s ease;margin-bottom:.25rem}.sidebar__link:hover{background:var(--color-gray-100);color:var(--color-gray-900)}.sidebar__link--active{background:var(--color-blue-50);color:var(--color-blue-700)}.sidebar__link--notifications{font-size:.75rem;opacity:.6;background:none;border:none;width:100%;text-align:left;cursor:pointer}.sidebar__link--notifications-denied{cursor:default;opacity:.4}.sidebar__link--notifications-denied:hover{background:none}.sidebar__link--logout{color:var(--color-red-600)}.sidebar__link--logout:hover{background:var(--color-red-50)}.sidebar__icon{font-size:1.25rem;display:flex;align-items:center;justify-content:center;width:1.5rem}.sidebar__section-header{padding:.5rem 1rem;margin-top:1rem}.sidebar__section-title{font-size:.75rem;font-weight:600;color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.05em}.sidebar__footer{padding:1rem;border-top:1px solid var(--color-gray-200)}.sidebar__user{padding:.75rem;margin-bottom:.5rem;background:var(--color-gray-50);border-radius:var(--radius-md)}.sidebar__user-info{display:flex;flex-direction:column;gap:.25rem}.sidebar__user-name{font-size:.875rem;font-weight:600;color:var(--color-gray-900)}.sidebar__user-email,.sidebar__user-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar__user-email{font-size:.75rem;color:var(--color-gray-500)}.sidebar-overlay{display:none}.mobile-header{display:none;align-items:center;gap:1rem;padding:1rem 1.5rem;background:var(--color-surface);border-bottom:1px solid var(--color-gray-200);position:-webkit-sticky;position:sticky;top:0;z-index:100}.mobile-header__toggle{display:flex;flex-direction:column;gap:4px;padding:.5rem;background:none;border:none;cursor:pointer}.mobile-header__toggle span{width:20px;height:2px;background:var(--color-gray-700);border-radius:2px;transition:all .3s ease}.mobile-header__title{font-size:1.125rem;font-weight:700;color:var(--color-gray-900)}@media (min-width:769px){.app-main{margin-left:260px}}@media (max-width:768px){.sidebar{transform:translateX(-100%)}.sidebar--open{transform:translateX(0)}.sidebar-overlay{display:block;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:999}.mobile-header{display:flex}.app-main{margin-left:0}.container{padding:1rem}.page-header__title{font-size:1.5rem}.grid--2,.stat-grid{grid-template-columns:1fr}.card__actions{flex-direction:column}.btn{width:100%;justify-content:center}.section-header{.btn{width:auto}}.tab-toolbar{flex-direction:column;align-items:stretch}.tab-toolbar__actions{width:100%;justify-content:flex-start}.tab-toolbar__actions .btn{width:100%;justify-content:center}}.section-header{display:flex;align-items:center;margin-bottom:1rem}.section-header__title{margin:0 1rem 0 0}.badge-group{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.badge--small{font-size:.75rem}.subsection-title{margin-bottom:1rem;font-size:1rem;font-weight:600;color:var(--text-secondary,var(--color-gray-600))}.form-section-divider{margin:2rem 0;border:none;border-top:1px solid var(--border-color,var(--color-gray-200))}.detail-item--full{grid-column:1/-1}.detail-item__value--capitalize{text-transform:capitalize}.detail-item__actions{display:flex;gap:.5rem;align-items:center}.container--narrow{max-width:600px}.alert--spaced{margin-top:1rem}:root{--text-secondary:var(--color-gray-600);--border-color:var(--color-gray-200)}.world-detail-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.25rem}.world-detail-header__title{font-size:1.75rem;font-weight:700;color:var(--color-gray-900);margin:0 0 .25rem}.world-detail-header__desc{font-size:.9375rem;color:var(--color-gray-500);margin:0}.world-controls{display:flex;flex-direction:column;gap:.875rem}.world-controls__connection{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.world-controls__address{font-family:var(--font-mono);font-size:1.125rem;font-weight:600;color:var(--color-green-600);background:var(--color-green-50);border:1px solid var(--color-green-100);border-radius:var(--radius-sm);padding:.3rem .75rem}.world-controls__host-select{max-width:360px}.world-controls__actions{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}.world-controls__status-msg{font-size:.9375rem;color:var(--color-gray-500);font-style:italic}.world-controls__qr{border-top:1px solid var(--color-gray-100);padding-top:.875rem}.world-danger-zone__actions{display:flex;gap:.5rem;flex-wrap:wrap}.detail-grid--2col{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.dash-tab__dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--color-blue-500);margin-left:2px;vertical-align:middle}@media (max-width:768px){.world-detail-header{flex-direction:column;gap:.5rem}.world-detail-header__title{font-size:1.375rem}.world-controls__address{font-size:.9375rem}.world-controls__actions{flex-direction:column}.world-controls__actions .btn{width:100%;justify-content:center;min-width:0}.world-danger-zone__actions .btn{flex:1 1;justify-content:center}.world-controls__host-select{max-width:100%}}.dash-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.25rem}.dash-tabs{display:flex;gap:.25rem}.dash-tab{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .875rem;border-radius:var(--radius-md);border:none;background:transparent;color:var(--color-gray-500);font-size:1rem;font-weight:600;cursor:pointer;transition:all .15s ease}.dash-tab:hover{color:var(--color-gray-800);background:var(--color-gray-100)}.dash-tab--active{color:var(--color-gray-900);background:var(--color-surface);border:1px solid var(--color-gray-200);box-shadow:var(--shadow-sm)}.dash-tab__count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;padding:.1rem .35rem;border-radius:999px;background:var(--color-gray-100);color:var(--color-gray-600);font-size:.75rem;font-weight:700}.dash-tab--active .dash-tab__count{background:var(--color-blue-100);color:var(--color-blue-700)}.world-list{display:flex;flex-direction:column;gap:.625rem}.world-row{display:flex;align-items:center;gap:1rem;background:var(--color-surface);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:1rem 1.25rem;box-shadow:var(--shadow-sm)}.world-row__info{flex:1 1;min-width:0;display:flex;flex-direction:column;gap:.3rem}.world-row__top{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.world-row__name{font-size:1rem;font-weight:600;color:var(--color-gray-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.world-row__connection{font-family:var(--font-mono);font-size:.875rem;color:var(--color-green-600);background:var(--color-green-50);border:1px solid var(--color-green-100);border-radius:var(--radius-sm);padding:.2rem .5rem;display:inline-block;width:-moz-fit-content;width:fit-content}.world-row__meta{font-size:.8125rem;color:var(--color-gray-400);font-family:var(--font-mono)}.world-row__actions{display:flex;gap:.5rem;flex-shrink:0}@media (max-width:768px){.dash-header{flex-wrap:wrap}.world-row{flex-direction:column;align-items:stretch;gap:.75rem}.world-row__actions{display:grid;grid-template-columns:1fr 1fr}.world-row__actions .btn{width:100%;justify-content:center}.world-row__actions .btn:only-child{grid-column:1/-1}}.material-symbols-outlined{font-family:Material Symbols Outlined;font-weight:400;font-style:normal;font-size:1.75rem;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;font-feature-settings:"liga";vertical-align:middle}.qr-code-section{margin:1rem 0}.qr-code-container{margin-top:1rem;padding:1.5rem;background:var(--color-gray-50);border-radius:var(--radius-md);border:1px solid var(--color-gray-200);display:flex;flex-direction:column;align-items:center;gap:1rem}.qr-code-wrapper{background:#ffffff;padding:1rem;border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.qr-code-info{text-align:center;width:100%}.qr-code-label{font-size:.875rem;color:var(--color-gray-600);margin-bottom:.5rem}.qr-code-url{display:block;font-size:.75rem;color:var(--color-gray-500);background:var(--color-surface);padding:.5rem;border-radius:var(--radius-sm);word-break:break-all;border:1px solid var(--color-gray-200)}.material-symbols-outlined.icon--small{font-size:1rem}.material-symbols-outlined.icon--large{font-size:1.5rem}.operation-logs{background:#000000;border:1px solid #333333;border-radius:8px;overflow:hidden;margin-top:1rem;box-shadow:0 4px 6px rgba(0,0,0,.3)}.operation-logs__header{padding:1rem;border-bottom:1px solid #333333;background:#1a1a1a}.operation-logs__title{margin:0;font-size:1rem;font-weight:600;display:flex;align-items:center;color:#00ff00}.operation-logs__content{max-height:400px;overflow-y:auto;background:#000000}.operation-logs__empty{padding:2rem;text-align:center;color:#00ff00;display:flex;align-items:center;justify-content:center;background:#000000}.operation-logs__list{padding:0;background:#000000}.operation-log-entry{padding:0 1rem;border-bottom:1px solid #1a1a1a;display:flex;align-items:flex-start;gap:1rem;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;font-size:.875rem;line-height:1.5;background:#000000}.operation-log-entry:last-child{border-bottom:none}.operation-log-entry:hover{background:#0a0a0a}.operation-log-entry__time{color:#00aa00;flex-shrink:0;font-size:.8125rem;opacity:.8}.operation-log-entry__message{color:#00ff00;flex:1 1;word-break:break-word}.status-badge{display:inline-flex;align-items:center;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace}.status-badge--success{background:#003300;color:#00ff00;border:1px solid #00aa00}.status-badge--error{background:#330000;color:#ff3333;border:1px solid #aa0000}.table{width:100%;border-collapse:collapse;margin-top:1rem;table-layout:fixed}.table thead{background:var(--color-gray-100)}.table tr{word-break:break-all}.table tr:nth-child(2n){border-top:1px solid var(--color-gray-200);border-bottom:1px solid var(--color-gray-200)}.table td,.table th{padding:.75rem 1rem;text-align:left}@media (prefers-color-scheme:dark){:root:not([data-theme=light]){--color-gray-50:#0f1115;--color-gray-100:#1a1d24;--color-gray-200:#262b36;--color-gray-300:#343b4a;--color-gray-400:#4a5568;--color-gray-500:#6b7280;--color-gray-600:#94a3b8;--color-gray-700:#cbd5e1;--color-gray-800:#e2e8f0;--color-gray-900:#f1f5f9;--color-blue-50:#0a1728;--color-blue-100:#0f2040;--color-blue-200:#1a3560;--color-blue-500:#60a5fa;--color-blue-600:#3b82f6;--color-blue-700:#93c5fd;--color-blue-800:#bfdbfe;--color-green-50:#071a0c;--color-green-100:#0d2b18;--color-green-200:#14421f;--color-green-500:#4ade80;--color-green-600:#22c55e;--color-green-800:#86efac;--color-red-50:#1f0808;--color-red-100:#3b1010;--color-red-200:#561818;--color-red-500:#f87171;--color-red-600:#ef4444;--color-red-700:#fca5a5;--color-red-800:#fca5a5;--color-yellow-50:#1a1200;--color-yellow-100:#2e1f00;--color-yellow-200:#453000;--color-yellow-500:#fbbf24;--color-yellow-600:#f59e0b;--color-yellow-800:#fcd34d;--color-surface:#1a1d24;--shadow-sm:0 1px 3px 0 rgba(0,0,0,0.4);--shadow-md:0 4px 8px -1px rgba(0,0,0,0.5),0 2px 4px -1px rgba(0,0,0,0.4);--shadow-lg:0 10px 20px -3px rgba(0,0,0,0.6),0 4px 8px -2px rgba(0,0,0,0.4)}.form-input,.form-select,.form-textarea{color-scheme:dark}.sidebar{border-right-color:var(--color-gray-200)}.mobile-header,.sidebar{background:var(--color-gray-100)}.mobile-header{border-bottom-color:var(--color-gray-200)}.copy-button:hover{background:var(--color-gray-200);border-color:var(--color-gray-300)}.btn--secondary:hover{background:var(--color-gray-100);border-color:var(--color-gray-400)}.qr-code-container{background:var(--color-gray-100)}.operation-logs,.qr-code-container{border-color:var(--color-gray-200)}.btn--primary{background:#2f6fd4}.btn--primary:hover{background:#2560bc}.btn--success{background:#1a8f47}.btn--success:hover{background:#177d3e}.btn--danger{background:#c93535}.btn--danger:hover{background:#b52e2e}.btn--warning{background:#b8790a}.btn--warning:hover{background:#a56c09}}:root[data-theme=dark]{--color-gray-50:#0f1115;--color-gray-100:#1a1d24;--color-gray-200:#262b36;--color-gray-300:#343b4a;--color-gray-400:#4a5568;--color-gray-500:#6b7280;--color-gray-600:#94a3b8;--color-gray-700:#cbd5e1;--color-gray-800:#e2e8f0;--color-gray-900:#f1f5f9;--color-blue-50:#0a1728;--color-blue-100:#0f2040;--color-blue-200:#1a3560;--color-blue-500:#60a5fa;--color-blue-600:#3b82f6;--color-blue-700:#93c5fd;--color-blue-800:#bfdbfe;--color-green-50:#071a0c;--color-green-100:#0d2b18;--color-green-200:#14421f;--color-green-500:#4ade80;--color-green-600:#22c55e;--color-green-800:#86efac;--color-red-50:#1f0808;--color-red-100:#3b1010;--color-red-200:#561818;--color-red-500:#f87171;--color-red-600:#ef4444;--color-red-700:#fca5a5;--color-red-800:#fca5a5;--color-yellow-50:#1a1200;--color-yellow-100:#2e1f00;--color-yellow-200:#453000;--color-yellow-500:#fbbf24;--color-yellow-600:#f59e0b;--color-yellow-800:#fcd34d;--color-surface:#1a1d24;--shadow-sm:0 1px 3px 0 rgba(0,0,0,0.4);--shadow-md:0 4px 8px -1px rgba(0,0,0,0.5),0 2px 4px -1px rgba(0,0,0,0.4);--shadow-lg:0 10px 20px -3px rgba(0,0,0,0.6),0 4px 8px -2px rgba(0,0,0,0.4)}:root[data-theme=dark] .form-input,:root[data-theme=dark] .form-select,:root[data-theme=dark] .form-textarea{color-scheme:dark}:root[data-theme=dark] .sidebar{background:var(--color-gray-100);border-right-color:var(--color-gray-200)}:root[data-theme=dark] .mobile-header{background:var(--color-gray-100);border-bottom-color:var(--color-gray-200)}:root[data-theme=dark] .copy-button:hover{background:var(--color-gray-200);border-color:var(--color-gray-300)}:root[data-theme=dark] .btn--secondary:hover{background:var(--color-gray-100);border-color:var(--color-gray-400)}:root[data-theme=dark] .qr-code-container{background:var(--color-gray-100);border-color:var(--color-gray-200)}:root[data-theme=dark] .operation-logs{border-color:var(--color-gray-200)}:root[data-theme=dark] .btn--primary{background:#2f6fd4}:root[data-theme=dark] .btn--primary:hover{background:#2560bc}:root[data-theme=dark] .btn--success{background:#1a8f47}:root[data-theme=dark] .btn--success:hover{background:#177d3e}:root[data-theme=dark] .btn--danger{background:#c93535}:root[data-theme=dark] .btn--danger:hover{background:#b52e2e}:root[data-theme=dark] .btn--warning{background:#b8790a}:root[data-theme=dark] .btn--warning:hover{background:#a56c09}.sidebar-prefs{padding:.75rem;background:var(--color-gray-50);border-radius:var(--radius-md);margin-bottom:.5rem;display:flex;flex-direction:column;gap:.625rem}.sidebar-prefs__row{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.sidebar-prefs__label{font-size:.8125rem;font-weight:500;color:var(--color-gray-600);white-space:nowrap}.theme-switcher{display:flex;gap:2px;background:var(--color-gray-200);border-radius:var(--radius-sm);padding:2px}.theme-btn{display:inline-flex;align-items:center;justify-content:center;padding:.25rem .4rem;border-radius:4px;border:none;background:transparent;color:var(--color-gray-500);cursor:pointer;transition:all .15s ease;font-size:.75rem;font-weight:600;line-height:1}.theme-btn:hover{color:var(--color-gray-700)}.theme-btn--active{background:var(--color-surface);color:var(--color-gray-900);box-shadow:var(--shadow-sm)}.notif-btn{color:var(--color-blue-600);background:none;border:none;cursor:pointer;padding:0;text-decoration:underline;text-underline-offset:2px}.notif-btn,.notif-status{font-size:.75rem;font-weight:600}.notif-status{color:var(--color-gray-500)}.notif-status--blocked{color:var(--color-red-500)}