@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600&display=swap";:root{--color-primary:#3ba776;--color-primary-light:#50c28e;--color-primary-dark:#2d8a5e;--color-primary-glow:#3ba77626;--color-primary-glow-strong:#3ba7764d;--color-bg:#101010;--color-bg-alt:#0a0a0a;--color-surface:#1a1a1a;--color-surface-hover:#222;--color-surface-active:#2a2a2a;--color-text:#fff;--color-text-secondary:#ccc;--color-text-muted:#888;--color-text-dim:#666;--color-border:#ffffff14;--color-border-hover:#ffffff26;--color-border-active:#3ba77666;--color-success:#28a745;--color-error:#dc3545;--color-warning:#ffc107;--color-info:#17a2b8;--glass-bg:#1a1a1a99;--glass-bg-solid:#1a1a1ad9;--glass-blur:blur(20px);--glass-border:1px solid var(--color-border);--glass-shadow:0 8px 32px #0006;--font-family:"Inter", system-ui, -apple-system, sans-serif;--font-size-xs:.75rem;--font-size-sm:.8125rem;--font-size-base:.9375rem;--font-size-md:1rem;--font-size-lg:1.25rem;--font-size-xl:1.5rem;--font-size-2xl:2rem;--font-weight-light:300;--font-weight-regular:400;--font-weight-medium:500;--font-weight-semibold:600;--line-height:1.6;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-2xl:24px;--radius-pill:30px;--radius-full:50%;--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 4px 16px #00000059;--shadow-lg:0 8px 32px #0006;--shadow-glow:0 0 20px var(--color-primary-glow-strong);--sidebar-width:250px;--sidebar-collapsed:70px;--topbar-height:70px;--drawer-width:480px;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s ease;--transition-spring:.3s cubic-bezier(.34, 1.56, .64, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-family);font-size:var(--font-size-base);font-weight:var(--font-weight-regular);line-height:var(--line-height);color:var(--color-text);background:linear-gradient(135deg, var(--color-bg) 0%, var(--color-bg-alt) 100%);min-height:100dvh;overflow-x:hidden}body:before{content:"";background-image:radial-gradient(circle at 20% 50%, var(--color-primary-glow) 0%, transparent 50%), radial-gradient(circle at 80% 20%, #3ba7760d 0%, transparent 40%);pointer-events:none;z-index:0;position:fixed;inset:0}#root{z-index:1;min-height:100dvh;position:relative}a{color:var(--color-primary-light);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-primary)}img{max-width:100%;display:block}ul,ol{list-style:none}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-semibold);color:var(--color-text);line-height:1.3}h1{font-size:var(--font-size-2xl)}h2{font-size:var(--font-size-xl)}h3{font-size:var(--font-size-lg)}h4{font-size:var(--font-size-md)}p{color:var(--color-text-secondary)}.glass-card{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border:var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--glass-shadow);transition:border-color var(--transition-base), box-shadow var(--transition-base)}.glass-card:hover{border-color:var(--color-border-hover)}.glass-card--interactive:hover{box-shadow:var(--glass-shadow), var(--shadow-glow);border-color:var(--color-border-active)}.glass-card--solid{background:var(--glass-bg-solid)}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-5);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast), opacity var(--transition-fast);white-space:nowrap;-webkit-user-select:none;user-select:none;border:1px solid #0000;line-height:1.4;text-decoration:none;display:inline-flex}.btn:active:not(:disabled){transform:scale(.97)}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.btn--primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn--primary:hover:not(:disabled){background:var(--color-primary-light);border-color:var(--color-primary-light);box-shadow:var(--shadow-glow)}.btn--secondary{color:var(--color-text);border-color:var(--color-border);background:0 0}.btn--secondary:hover:not(:disabled){background:var(--color-surface-hover);border-color:var(--color-border-hover)}.btn--ghost{color:var(--color-text-secondary);padding:var(--space-2);background:0 0;border:none}.btn--ghost:hover:not(:disabled){background:var(--color-surface-hover);color:var(--color-text)}.btn--danger{color:var(--color-error);background:0 0;border-color:#dc35454d}.btn--danger:hover:not(:disabled){border-color:var(--color-error);background:#dc35451a}.btn--sm{padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs)}.btn--lg{padding:var(--space-3) var(--space-8);font-size:var(--font-size-md)}.btn--icon{padding:var(--space-2);width:36px;height:36px}.form-group{gap:var(--space-2);flex-direction:column;display:flex}.form-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.form-label--required:after{content:" *";color:var(--color-error)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--space-3) var(--space-4);font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-glow)}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-text-dim)}.form-input--error{border-color:var(--color-error)}.form-input--error:focus{box-shadow:0 0 0 3px #dc354526}.form-helper{font-size:var(--font-size-xs);color:var(--color-text-muted)}.form-error{font-size:var(--font-size-xs);color:var(--color-error)}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-4) center;padding-right:var(--space-10)}.form-textarea{resize:vertical;min-height:80px}.toggle{align-items:center;gap:var(--space-3);cursor:pointer;-webkit-user-select:none;user-select:none;display:inline-flex;position:relative}.toggle input{opacity:0;width:0;height:0;position:absolute}.toggle__track{background:var(--color-surface);border:1px solid var(--color-border);width:40px;height:22px;transition:background var(--transition-fast), border-color var(--transition-fast);border-radius:11px;position:relative}.toggle__track:after{content:"";background:var(--color-text-muted);width:16px;height:16px;transition:transform var(--transition-base), background var(--transition-fast);border-radius:50%;position:absolute;top:2px;left:2px}.toggle input:checked+.toggle__track{background:var(--color-primary);border-color:var(--color-primary)}.toggle input:checked+.toggle__track:after{background:#fff;transform:translate(18px)}.badge{align-items:center;gap:var(--space-1);padding:2px var(--space-2);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border-radius:var(--radius-md);white-space:nowrap;line-height:1.4;display:inline-flex}.badge--dot:before{content:"";border-radius:50%;flex-shrink:0;width:6px;height:6px}.badge--success{color:var(--color-success);background:#28a74526}.badge--success:before{background:var(--color-success)}.badge--error{color:var(--color-error);background:#dc354526}.badge--error:before{background:var(--color-error)}.badge--warning{color:var(--color-warning);background:#ffc10726}.badge--warning:before{background:var(--color-warning)}.badge--info{color:var(--color-info);background:#17a2b826}.badge--info:before{background:var(--color-info)}.badge--neutral{color:var(--color-text-muted);background:#ffffff0f}.badge--neutral:before{background:var(--color-text-muted)}.badge--primary{background:var(--color-primary-glow);color:var(--color-primary-light)}.badge--primary:before{background:var(--color-primary-light)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#fff3}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes slideOutRight{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-fade-in{animation:fadeIn var(--transition-base) ease}.animate-fade-in-up{animation:fadeInUp var(--transition-base) ease}.animate-scale-in{animation:scaleIn var(--transition-spring)}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.skeleton{background:linear-gradient(90deg, var(--color-surface) 25%, var(--color-surface-hover) 50%, var(--color-surface) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s infinite shimmer}.spinner{border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin}.spinner--lg{border-width:3px;width:32px;height:32px}@media (width<=768px){:root{--sidebar-width:0px;--drawer-width:100vw}.btn,.btn--sm,.btn--lg,.form-input,.form-select,.form-textarea{font-size:16px}}.toast-container{top:var(--space-6);right:var(--space-6);z-index:9999;gap:var(--space-3);pointer-events:none;flex-direction:column;max-width:400px;display:flex;position:fixed}.toast{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--glass-bg-solid);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--glass-shadow);pointer-events:auto;animation:fadeInDown var(--transition-base) ease;font-size:var(--font-size-sm);display:flex}.toast--success{border-left:3px solid var(--color-success)}.toast--success svg{color:var(--color-success)}.toast--error{border-left:3px solid var(--color-error)}.toast--error svg{color:var(--color-error)}.toast--warning{border-left:3px solid var(--color-warning)}.toast--warning svg{color:var(--color-warning)}.toast--info{border-left:3px solid var(--color-info)}.toast--info svg{color:var(--color-info)}.toast__message{color:var(--color-text);flex:1}.toast__close{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;align-items:center;padding:2px;display:flex}.toast__close:hover{color:var(--color-text)}.operation-status{align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);border:1px solid var(--color-border);background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);display:flex}.operation-status--dense{padding:var(--space-2) var(--space-3);gap:var(--space-2)}.operation-status--info{background:#17a2b814;border-color:#17a2b847}.operation-status--success{background:#28a74514;border-color:#28a74547}.operation-status--error{background:#dc354514;border-color:#dc354547}.operation-status--warning{background:#ffc10714;border-color:#ffc10747}.operation-status--neutral{border-color:var(--color-border);background:#ffffff0a}.operation-status__icon{color:var(--color-text);flex-shrink:0;justify-content:center;align-items:center;margin-top:1px;line-height:1;display:flex}.operation-status__content{flex-direction:column;gap:2px;min-width:0;display:flex}.operation-status__label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text)}.operation-status__detail{font-size:var(--font-size-xs);color:var(--color-text-muted);line-height:1.45}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;padding:var(--space-6);background:#000000a6;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--glass-bg-solid);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:var(--glass-border);border-radius:var(--radius-xl);box-shadow:var(--glass-shadow);width:100%;max-width:520px;max-height:85vh;animation:scaleIn var(--transition-spring);overflow-y:auto}.modal__header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.modal__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.modal__body{padding:var(--space-6)}.modal__footer{justify-content:flex-end;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border);display:flex}.drawer-overlay{z-index:900;background:#0006;animation:.15s fadeIn;position:fixed;inset:0}.drawer{width:var(--drawer-width);background:var(--glass-bg-solid);max-width:100vw;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-left:1px solid var(--color-border);z-index:901;animation:slideInRight var(--transition-base) ease;position:fixed;top:0;bottom:0;right:0;overflow-y:auto;box-shadow:-8px 0 32px #0006}.drawer__header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border);background:var(--glass-bg-solid);z-index:1;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.drawer__body{padding:var(--space-6)}.app-layout{min-height:100dvh;display:flex}.sidebar{width:var(--sidebar-width);z-index:100;background:var(--glass-bg-solid);height:100vh;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-right:1px solid var(--color-border);transition:width var(--transition-base);flex-direction:column;display:flex;position:fixed;top:0;left:0;overflow:hidden}.sidebar--collapsed{width:var(--sidebar-collapsed)}.sidebar__logo{height:var(--topbar-height);padding:0 var(--space-5);border-bottom:1px solid var(--color-border);align-items:center;gap:var(--space-3);flex-shrink:0;display:flex}.sidebar__logo img{object-fit:contain;width:auto;height:32px}.sidebar__logo-text{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-primary-light);white-space:nowrap;overflow:hidden}.sidebar__nav{padding:var(--space-4) var(--space-3);gap:var(--space-1);flex-direction:column;flex:1;display:flex;overflow-y:auto}.sidebar__section{margin-top:var(--space-4);padding-top:var(--space-3);border-top:1px solid var(--color-border)}.sidebar__section-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.05em;padding:var(--space-1) var(--space-3);margin-bottom:var(--space-1)}.sidebar__link{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);transition:background var(--transition-fast), color var(--transition-fast);white-space:nowrap;text-decoration:none;display:flex}.sidebar__link:hover{background:var(--color-surface-hover);color:var(--color-text)}.sidebar__link--active{background:var(--color-primary-glow);color:var(--color-primary-light)}.sidebar__link--active:hover{background:var(--color-primary-glow)}.sidebar__link svg{flex-shrink:0}.sidebar__footer{padding:var(--space-4);border-top:1px solid var(--color-border)}.sidebar__user{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast);display:flex}.sidebar__user:hover{background:var(--color-surface-hover)}.sidebar__avatar{border-radius:var(--radius-full);background:var(--color-primary);width:32px;height:32px;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:#fff;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar__user-info{overflow:hidden}.sidebar__user-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.sidebar__user-role{font-size:var(--font-size-xs);color:var(--color-text-muted)}.main-content{margin-left:var(--sidebar-width);transition:margin-left var(--transition-base);-webkit-overflow-scrolling:touch;flex:1;min-height:100dvh;overflow:hidden auto}.main-content--collapsed{margin-left:var(--sidebar-collapsed)}.topbar{height:var(--topbar-height);padding:0 var(--space-8);border-bottom:1px solid var(--color-border);background:var(--glass-bg-solid);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);z-index:50;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.topbar__left{align-items:center;gap:var(--space-4);display:flex}.topbar__breadcrumb{align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--color-text-muted);display:flex}.topbar__breadcrumb-sep{color:var(--color-text-dim)}.topbar__breadcrumb-current{color:var(--color-text);font-weight:var(--font-weight-medium)}.topbar__right{align-items:center;gap:var(--space-3);display:flex}.page{padding:var(--space-8);width:100%;max-width:1400px;animation:fadeIn var(--transition-base) ease;margin:0 auto}.dashboard-bottom-grid{gap:var(--space-6);grid-template-columns:1fr 320px;display:grid}.settings-layout{gap:var(--space-6);grid-template-columns:220px minmax(0,1fr);align-items:start;display:grid}.settings-nav{padding:var(--space-3);gap:var(--space-2);flex-direction:column;display:flex}.settings-nav__item{text-align:left;cursor:pointer;background:0 0;border:none;align-items:center;gap:12px;width:100%;display:flex}.settings-content{padding:var(--space-6);min-width:0}.page-toolbar{gap:var(--space-3);margin-bottom:var(--space-6);flex-wrap:wrap;display:flex}.page-toolbar__search{flex:240px;min-width:240px;position:relative}.page-toolbar__inline-select{width:auto}.page__header{margin-bottom:var(--space-8);justify-content:space-between;align-items:center;gap:var(--space-4);display:flex}.page__title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold)}.page__subtitle{font-size:var(--font-size-base);color:var(--color-text-muted);margin-top:var(--space-1)}.stat-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));display:grid}.stat-card{padding:var(--space-5)}.stat-card__label{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-2)}.stat-card__value{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text)}.stat-card__value--primary{color:var(--color-primary-light)}.tag-input{gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:text;min-height:42px;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);flex-wrap:wrap;display:flex}.tag-input:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-glow)}.tag-input__tag{align-items:center;gap:var(--space-1);padding:2px var(--space-2);background:var(--color-primary-glow);color:var(--color-primary-light);border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);line-height:1.4;display:inline-flex}.tag-input__remove{color:inherit;cursor:pointer;opacity:.7;background:0 0;border:none;align-items:center;padding:0;display:flex}.tag-input__remove:hover{opacity:1}.tag-input__input{min-width:100px;font-family:var(--font-family);font-size:var(--font-size-sm);color:var(--color-text);padding:var(--space-1) 0;background:0 0;border:none;outline:none;flex:1}.tag-input__input::placeholder{color:var(--color-text-dim)}.empty-state{padding:var(--space-16) var(--space-8);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state__icon{color:var(--color-text-dim);margin-bottom:var(--space-4)}.empty-state__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text);margin-bottom:var(--space-2)}.empty-state__desc{font-size:var(--font-size-sm);color:var(--color-text-muted);max-width:400px}.empty-state__action{margin-top:var(--space-6)}.loader-wrapper{justify-content:center;align-items:center;gap:var(--space-4);padding:var(--space-16) 0;flex-direction:column;display:flex}.loader-text{font-size:var(--font-size-sm);color:var(--color-text-muted)}.progress-bar{background:var(--color-surface);border-radius:3px;width:100%;height:6px;overflow:hidden}.progress-bar__fill{background:var(--color-primary);height:100%;transition:width var(--transition-base);border-radius:3px}.progress-bar__fill--warning{background:var(--color-warning)}.progress-bar__fill--error{background:var(--color-error)}.data-table-wrapper{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);overflow-x:auto}.data-table{border-collapse:collapse;width:100%}.data-table th{text-align:left;padding:var(--space-3) var(--space-4);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--color-border);white-space:nowrap;-webkit-user-select:none;user-select:none}.data-table th.sortable{cursor:pointer}.data-table th.sortable:hover{color:var(--color-text)}.data-table td{padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);vertical-align:middle}.data-table tr:last-child td{border-bottom:none}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:var(--color-surface-hover)}.data-table tbody tr.row--selected{background:#3ba7760f}.data-table tbody tr.row--pending{opacity:.65}.data-table tbody tr.row--failed td:first-child{border-left:3px solid var(--color-error)}.data-table .cell-score{font-weight:var(--font-weight-semibold);font-variant-numeric:tabular-nums}.data-table .cell-domain{color:var(--color-primary-light)}.data-table .checkbox-cell{text-align:center;width:40px}.data-table .checkbox-cell input[type=checkbox]{accent-color:var(--color-primary);cursor:pointer;width:16px;height:16px}.table-toolbar{justify-content:space-between;align-items:center;gap:var(--space-4);padding:var(--space-4);border-bottom:1px solid var(--color-border);flex-wrap:wrap;display:flex}.table-toolbar__filters{align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.table-toolbar__actions{align-items:center;gap:var(--space-3);display:flex}.filter-input{padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);outline:none;min-width:140px}.filter-input:focus{border-color:var(--color-primary)}.filter-select{padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);appearance:none;cursor:pointer;outline:none}.json-viewer{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-4);font-family:SF Mono,Fira Code,monospace;font-size:var(--font-size-xs);color:var(--color-text-secondary);white-space:pre-wrap;word-break:break-all;max-height:300px;line-height:1.6;overflow:auto}.collapsible__trigger{align-items:center;gap:var(--space-2);color:var(--color-text-secondary);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;padding:var(--space-2) 0;background:0 0;border:none;display:flex}.collapsible__trigger:hover{color:var(--color-text)}.collapsible__trigger svg{transition:transform var(--transition-fast)}.collapsible__trigger--open svg{transform:rotate(90deg)}@media (width<=768px){.sidebar{display:none}.main-content{min-height:calc(100dvh - 60px - env(safe-area-inset-bottom,0px));margin-left:0}.page{padding:var(--space-4);padding-bottom:calc(var(--space-8) + 60px + env(safe-area-inset-bottom,0px))}.page__header{flex-direction:column;align-items:flex-start}.stat-grid{grid-template-columns:repeat(2,1fr)}.table-toolbar{flex-direction:column;align-items:stretch}.topbar{padding:0 var(--space-4)}.dashboard-hero{padding:var(--space-6) var(--space-5)!important}.dashboard-bottom-grid,.settings-layout{grid-template-columns:1fr}.settings-nav{padding:var(--space-2);scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;flex-direction:row;overflow-x:auto}.settings-nav__item{white-space:nowrap;scroll-snap-align:start;flex:none;width:auto}.settings-content{padding:var(--space-5)}.page-toolbar{align-items:stretch}.page-toolbar__search{flex-basis:100%;min-width:0}.page-toolbar__inline-select,.page-toolbar>.btn,.page-toolbar>button{width:100%}.mobile-nav{height:60px;padding-bottom:env(safe-area-inset-bottom,0px);background:var(--glass-bg-solid);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-top:1px solid var(--color-border);z-index:100;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0}.mobile-nav__item{color:var(--color-text-muted);font-size:var(--font-size-xs);padding:var(--space-2);flex-direction:column;flex:1 1 0;align-items:center;gap:2px;min-width:0;text-decoration:none;display:flex}.mobile-nav__item--active{color:var(--color-primary-light)}.mobile-nav__item span{text-overflow:ellipsis;white-space:nowrap;max-width:100%;overflow:hidden}}@media (width>=769px){.mobile-nav{display:none}}.studio{padding:var(--space-8);width:100%;max-width:1200px;animation:fadeIn var(--transition-base) ease;margin:0 auto}.studio__header{align-items:center;gap:var(--space-4);margin-bottom:var(--space-6);display:flex}.studio__back{flex-shrink:0}.studio__title-group{flex:1;min-width:0}.studio__title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text);align-items:center;gap:var(--space-2);display:flex}.studio__subtitle{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:2px}.studio__title-input{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);border-radius:var(--radius-sm);color:var(--color-text);padding:var(--space-1) var(--space-2);margin-left:calc(-1 * var(--space-2));width:100%;transition:all var(--transition-fast);background:0 0;border:none;border-bottom:2px solid #0000;outline:none}.studio__title-input::placeholder{color:var(--color-text-dim);font-weight:var(--font-weight-medium)}.studio__title-input:hover{background:var(--color-surface-hover);border-bottom-color:var(--color-border)}.studio__title-input:focus{background:var(--glass-bg);border-bottom-color:var(--color-primary);box-shadow:0 4px 12px #0000001a}.studio-tabs{background:var(--color-surface);border-radius:var(--radius-lg);margin-bottom:var(--space-6);border:1px solid var(--color-border);gap:2px;width:fit-content;padding:4px;display:flex}.studio-tab{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-5);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;border:none;display:flex;position:relative}.studio-tab:hover:not(.studio-tab--disabled){color:var(--color-text);background:var(--color-surface-hover)}.studio-tab--active{background:var(--glass-bg-solid);color:var(--color-text);box-shadow:var(--shadow-sm);border:1px solid var(--color-border)}.studio-tab--active .studio-tab__icon{color:var(--color-primary-light)}.studio-tab--disabled{opacity:.4;cursor:not-allowed}.studio-tab__icon{flex-shrink:0}.studio-tab__dot{background:var(--color-primary);border-radius:50%;flex-shrink:0;width:6px;height:6px}.studio-panel{animation:fadeInUp var(--transition-base) ease}.recorder{gap:var(--space-6);flex-direction:column;display:flex}.recorder__main{justify-content:center;gap:var(--space-6);flex-wrap:wrap;display:flex}.recorder__main>*{flex:1;min-width:320px;max-width:100%}.record-card{justify-content:center;align-items:center;gap:var(--space-6);padding:var(--space-12) var(--space-8);text-align:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-2xl);box-shadow:var(--shadow-md);transition:all var(--transition-base);flex-direction:column;display:flex}.record-card:hover{border-color:var(--color-primary-glow);box-shadow:var(--shadow-lg), 0 0 30px #3ba7760d}.record-button-wrap{justify-content:center;align-items:center;display:flex;position:relative}.record-button-ring{border:2px solid var(--color-primary-glow-strong);width:120px;height:120px;transition:all var(--transition-base);border-radius:50%;animation:none;position:absolute}.record-button-ring--recording{border-color:var(--color-error);animation:1.5s ease-in-out infinite recordPulse}@keyframes recordPulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:.2;transform:scale(1.15)}}.record-button{background:var(--color-primary);width:88px;height:88px;color:var(--color-surface);cursor:pointer;transition:all var(--transition-base);box-shadow:0 0 24px var(--color-primary-glow-strong);z-index:1;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:relative}.record-button:hover:not(:disabled){background:var(--color-primary-light);box-shadow:0 0 40px var(--color-primary-glow-strong);transform:scale(1.05)}.record-button:active:not(:disabled){transform:scale(.97)}.record-button--recording{background:var(--color-error);box-shadow:0 0 24px #dc354566}.record-button--recording:hover:not(:disabled){background:#e84b5b;box-shadow:0 0 40px #dc354580}.record-button:disabled{opacity:.5;cursor:not-allowed}.record-controls{justify-content:center;align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.record-timer{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text);font-variant-numeric:tabular-nums;letter-spacing:.05em}.record-status{font-size:var(--font-size-sm);color:var(--color-text-muted)}.record-status--recording{color:var(--color-error);align-items:center;gap:var(--space-2);display:flex}.record-status--busy{align-items:center;gap:var(--space-2);display:flex}.record-status--busy .spinner{width:14px;height:14px}.record-dot{background:var(--color-error);border-radius:50%;width:8px;height:8px;animation:1s ease-in-out infinite pulse}.signal-indicator{align-items:flex-end;gap:3px;height:20px;display:flex}.signal-bar{background:var(--color-border);width:4px;transition:background var(--transition-fast), height var(--transition-fast);border-radius:2px}.signal-bar--1{height:6px}.signal-bar--2{height:10px}.signal-bar--3{height:14px}.signal-bar--4{height:18px}.signal-bar--active{background:var(--color-primary)}.signal-bar--strong{background:var(--color-success)}.signal-bar--warn{background:var(--color-warning)}.waveform{width:100%;height:48px;padding:0 var(--space-4);justify-content:center;align-items:center;gap:2px;display:flex;overflow:hidden}.waveform__bar{background:var(--color-primary);opacity:.7;width:3px;transition:height var(--transition-fast);border-radius:2px;flex-shrink:0;min-height:4px}.dropzone{justify-content:center;align-items:center;gap:var(--space-4);padding:var(--space-10) var(--space-8);text-align:center;border-style:dashed;border-color:var(--color-border);cursor:pointer;transition:all var(--transition-base);border-width:2px;flex-direction:column;display:flex}.dropzone:hover,.dropzone--drag-over{border-color:var(--color-primary);background:var(--color-primary-glow)}.dropzone__icon{color:var(--color-text-muted);transition:color var(--transition-fast)}.dropzone:hover .dropzone__icon,.dropzone--drag-over .dropzone__icon{color:var(--color-primary-light)}.dropzone__title{font-size:var(--font-size-md);font-weight:var(--font-weight-medium);color:var(--color-text)}.dropzone__hint{font-size:var(--font-size-xs);color:var(--color-text-dim)}.dropzone__formats{gap:var(--space-2);flex-wrap:wrap;justify-content:center;display:flex}.audio-loaded{gap:var(--space-4);padding:var(--space-6);flex-direction:column;display:flex}.audio-loaded__info{align-items:center;gap:var(--space-3);display:flex}.audio-loaded__icon{border-radius:var(--radius-lg);background:var(--color-primary-glow);width:48px;height:48px;color:var(--color-primary-light);flex-shrink:0;justify-content:center;align-items:center;display:flex}.audio-loaded__meta{flex:1;min-width:0}.audio-loaded__name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.audio-loaded__size{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:2px}.audio-player{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);display:flex}.audio-player__btn{background:var(--color-primary);color:#fff;cursor:pointer;width:36px;height:36px;transition:all var(--transition-fast);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.audio-player__btn:hover{background:var(--color-primary-light)}.audio-player__scrubber-wrapper{height:24px;padding:0 var(--space-1);flex:1;align-items:center;display:flex}.audio-player__scrubber{background:linear-gradient(90deg, var(--color-primary) var(--progress,0%), var(--color-surface-active) var(--progress,0%));cursor:pointer;appearance:none;width:100%;height:4px;transition:height var(--transition-fast);border-radius:2px;outline:none}.audio-player__scrubber:hover{height:6px}.audio-player__scrubber::-webkit-slider-thumb{-webkit-appearance:none;background:var(--color-primary);cursor:pointer;width:12px;height:12px;box-shadow:0 0 0 2px var(--color-surface), 0 2px 4px #0003;transition:transform var(--transition-fast), box-shadow var(--transition-fast);border-radius:50%}.audio-player__scrubber:hover::-webkit-slider-thumb{box-shadow:0 0 0 2px var(--color-surface), 0 0 10px var(--color-primary-glow-strong);transform:scale(1.3)}.audio-player__scrubber::-moz-range-thumb{background:var(--color-primary);cursor:pointer;width:12px;height:12px;box-shadow:0 0 0 2px var(--color-surface), 0 2px 4px #0003;transition:transform var(--transition-fast), box-shadow var(--transition-fast);border:none;border-radius:50%}.audio-player__scrubber:hover::-moz-range-thumb{box-shadow:0 0 0 2px var(--color-surface), 0 0 10px var(--color-primary-glow-strong);transform:scale(1.3)}.audio-player__time{font-size:var(--font-size-xs);color:var(--color-text-muted);font-variant-numeric:tabular-nums;white-space:nowrap;flex-shrink:0}.session-meta{gap:var(--space-4);grid-template-columns:1fr auto;align-items:end;display:grid}@media (width<=768px){.studio{padding:var(--space-4);padding-bottom:calc(var(--space-8) + 72px + env(safe-area-inset-bottom,0px));overflow:visible}.recorder__main{grid-template-columns:1fr}.studio-tabs{width:100%;overflow-x:auto}.studio-tab{padding:var(--space-2) var(--space-3);font-size:var(--font-size-xs)}.session-meta{grid-template-columns:1fr}}.estudio-model-menu{z-index:50;background:var(--glass-bg-solid);min-width:240px;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-2);box-shadow:var(--shadow-lg), 0 10px 40px #00000080;animation:fadeInDown var(--transition-fast) ease-out;flex-direction:column;gap:4px;display:flex;position:absolute;top:calc(100% + 8px);left:0}.estudio-model-option{width:100%;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-sm);text-align:left;cursor:pointer;transition:all var(--transition-fast);background:0 0;border:1px solid #0000;justify-content:space-between;align-items:center;display:flex}.estudio-model-option:hover{background:var(--color-surface-hover);color:var(--color-text)}.estudio-model-option--active{background:var(--color-primary-glow);color:var(--color-primary);border-color:#3ba7764d;font-weight:500}.studio-retention-notice{align-items:flex-start;gap:var(--space-2);background:rgba(var(--color-warning-rgb,245, 158, 11), .07);border:1px solid rgba(var(--color-warning-rgb,245, 158, 11), .2);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--font-size-xs);color:var(--color-text-muted);margin-bottom:var(--space-4);line-height:1.5;display:flex}.studio-retention-notice svg{color:var(--color-warning);flex-shrink:0;margin-top:1px}.upload-progress{background:var(--color-surface-active);border-radius:3px;height:6px;position:relative;overflow:hidden}.upload-progress__bar{background:linear-gradient(90deg, var(--color-primary), var(--color-primary-light));border-radius:3px;height:100%;transition:width .2s;position:absolute;top:0;left:0}.upload-progress__label{font-size:var(--font-size-xs);color:var(--color-text-muted);text-align:center;margin-top:var(--space-2);display:block}.studio-error{align-items:center;gap:var(--space-2);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);color:var(--color-error);background:#dc354514;border:1px solid #dc354540;display:flex}.estudio-chat{background:radial-gradient(circle at top left, #0ea5e914, transparent 32%), linear-gradient(180deg, #080f1a05 0%, #080f1a00 24%), var(--color-surface);border-radius:var(--radius-2xl);border:1px solid #7dd3fc2e;flex-direction:column;height:720px;min-height:560px;display:flex;overflow:hidden;box-shadow:0 28px 80px #02081714}.estudio-chat__header{padding:var(--space-5);background:linear-gradient(135deg, #0ea5e914 0%, #0f172a08 48%, transparent 100%), var(--color-surface-elevated);border-bottom:1px solid #7dd3fc29;flex-shrink:0}.estudio-chat__hero{justify-content:space-between;align-items:flex-start;gap:var(--space-4);margin-bottom:var(--space-4);display:flex}.estudio-chat__hero-eyebrow{font-size:11px;font-weight:var(--font-weight-bold);letter-spacing:.1em;text-transform:uppercase;color:var(--color-primary-light);margin-bottom:var(--space-2)}.estudio-chat__hero-title{margin:0 0 var(--space-2);color:var(--color-text);font-size:clamp(1.15rem,1.1rem + .4vw,1.45rem);line-height:1.18}.estudio-chat__hero-copy{max-width:70ch;font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0;line-height:1.6}.estudio-chat__hero-badges{justify-content:flex-end;gap:var(--space-2);flex-wrap:wrap;display:flex}.estudio-chat__toolbar{justify-content:space-between;align-items:flex-start;gap:var(--space-3);flex-wrap:wrap;display:flex}.estudio-chat__toolbar-section{align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.estudio-chat__toolbar-section--end{margin-left:auto}.estudio-chat__context-group{gap:var(--space-2);flex-wrap:wrap;display:flex}.estudio-chat__notice{padding:var(--space-2) var(--space-5);font-size:var(--font-size-xs);color:var(--color-text-muted);background:#0ea5e908;border-bottom:1px solid #7dd3fc1f;align-items:center;gap:6px;display:flex}.estudio-chat__messages{padding:var(--space-6);gap:var(--space-5);overscroll-behavior:contain;overflow-anchor:none;background:linear-gradient(#ffffff05,#0000 14%),repeating-linear-gradient(#0ea5e90d 0 1px,#0000 1px 40px);flex-direction:column;flex:1;display:flex;overflow-y:auto}.estudio-chat__bubble{gap:var(--space-2);flex-direction:column;display:flex}.estudio-chat__bubble--user{align-self:flex-end;align-items:flex-end;max-width:min(58%,520px)}.estudio-chat__bubble--assistant{width:100%;max-width:none}.estudio-chat__bubble-label{font-size:var(--font-size-xs);color:var(--color-text-muted);width:min(100%,960px);padding-inline:var(--space-1);justify-content:space-between;align-items:center;display:flex}.estudio-chat__bubble-content{font-size:var(--font-size-sm);line-height:1.7}.estudio-chat__bubble-content--user{padding:var(--space-3) var(--space-4);background:linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-light,var(--color-primary)) 100%);color:#fff;border-radius:20px 20px 8px;box-shadow:0 16px 32px #0284c733}.estudio-chat__bubble-content--assistant{width:min(100%,960px);padding:var(--space-5);background:linear-gradient(180deg, #ffffff0a, transparent 18%), linear-gradient(135deg, #0ea5e914 0%, #0f172a05 100%), var(--color-surface-elevated);color:var(--color-text);border:1px solid #7dd3fc2e;border-radius:24px;box-shadow:0 18px 50px #02081714}.estudio-chat__copy{width:30px;height:30px;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);background:#ffffff0a;border:1px solid #94a3b833;border-radius:999px;justify-content:center;align-items:center;gap:4px;display:inline-flex}.estudio-chat__copy:hover{color:var(--color-text);background:#0ea5e914;border-color:#7dd3fc47}.estudio-chat__user-text{white-space:pre-wrap;word-break:break-word}.estudio-chat__typing{padding:var(--space-3) var(--space-4);align-items:center;gap:5px;display:flex}.estudio-chat__typing span{background:var(--color-primary);border-radius:50%;width:7px;height:7px;animation:1.2s ease-in-out infinite typing-dot}.estudio-chat__typing span:nth-child(2){animation-delay:.2s}.estudio-chat__typing span:nth-child(3){animation-delay:.4s}@keyframes typing-dot{0%,80%,to{opacity:.3;transform:scale(.85)}40%{opacity:1;transform:scale(1)}}.estudio-chat__input-row{align-items:flex-end;gap:var(--space-2);padding:var(--space-4) var(--space-5);background:linear-gradient(180deg, #0ea5e90d 0%, transparent 100%), var(--color-surface-elevated);border-top:1px solid #7dd3fc1f;flex-shrink:0;display:flex;position:relative}.estudio-chat__textarea{resize:none;min-height:52px;max-height:160px;padding:var(--space-3) var(--space-4);border-radius:18px;flex:1;line-height:1.6;overflow-y:auto}.estudio-chat__send{padding:var(--space-2) var(--space-3);border-radius:18px;flex-shrink:0;justify-content:center;align-items:center;min-width:52px;height:52px;display:flex}.estudio-chat__input-warning{text-align:center;width:100%;color:var(--color-error);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);position:absolute;top:-28px;left:0}.record-main-controls{justify-content:center;align-items:center;gap:var(--space-8);width:100%;display:flex}.record-button--secondary{border:1px solid var(--color-border);background:var(--color-surface);width:44px;height:44px;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-sm);border-radius:50%;justify-content:center;align-items:center;display:flex}.record-button--secondary:hover:not(:disabled){background:var(--color-surface-hover);color:var(--color-primary-light);border-color:var(--color-primary-glow-strong);box-shadow:0 0 15px var(--color-primary-glow);transform:scale(1.1)}.record-button--secondary:disabled{opacity:.5;cursor:not-allowed}.audio-scratchpad{padding:var(--space-4);gap:var(--space-3);flex-direction:column;display:flex}.audio-scratchpad__header{justify-content:space-between;align-items:flex-start;gap:var(--space-3);display:flex}.audio-scratchpad__title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text)}.audio-scratchpad__hint{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:2px;line-height:1.5}.audio-scratchpad__textarea{min-height:120px}.recording-badge{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#ef4444;letter-spacing:.08em;text-transform:uppercase;margin-left:var(--space-3);-webkit-user-select:none;user-select:none;background:#ef44440a;border:1px solid #ef444440;border-radius:100px;align-items:center;gap:8px;padding:4px 10px;font-size:10px;font-weight:800;transition:all .3s;display:inline-flex;box-shadow:0 0 12px #ef44441a}.recording-badge__visualizer{align-items:center;gap:2px;height:10px;display:flex}.recording-badge__bar{background-color:currentColor;border-radius:1px;width:2px;animation:.8s ease-in-out infinite recordingBarGrow}.recording-badge__bar:nth-child(2){animation-delay:.15s}.recording-badge__bar:nth-child(3){animation-delay:.3s}@keyframes recordingBarGrow{0%,to{opacity:.6;height:3px}50%{opacity:1;height:9px}}@media (width<=900px){.estudio-chat{height:auto;min-height:620px}.estudio-chat__header,.estudio-chat__messages,.estudio-chat__input-row{padding-left:var(--space-4);padding-right:var(--space-4)}.estudio-chat__hero,.estudio-chat__toolbar{flex-direction:column;align-items:stretch}.estudio-chat__hero-badges,.estudio-chat__toolbar-section--end{justify-content:flex-start;margin-left:0}.estudio-chat__bubble--user{max-width:min(100%,640px)}}@media (width<=640px){.studio__title-input,.estudio-chat__textarea,.audio-scratchpad__textarea,.tag-input__input{font-size:16px}.estudio-chat__messages{gap:var(--space-4)}.estudio-chat__bubble-label,.estudio-chat__bubble-content--assistant{width:100%}.estudio-chat__bubble-content--assistant{padding:var(--space-4);border-radius:20px}.estudio-chat__bubble-content--user{width:100%}.estudio-chat__toolbar-section{align-items:stretch}.estudio-chat__context-group{width:100%}}.mode-grid-container{gap:var(--space-4);flex-direction:column;display:flex}.mode-grid{gap:var(--space-3);grid-template-columns:repeat(auto-fill,minmax(220px,1fr));display:grid}.mode-card{align-items:flex-start;gap:var(--space-3);padding:var(--space-4);background:var(--glass-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);text-align:left;display:flex;position:relative;overflow:hidden}.mode-card:hover{border-color:var(--color-primary-glow-strong);background:var(--color-surface-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.mode-card--selected{border-color:var(--color-primary);background:var(--color-primary-glow);box-shadow:0 0 20px var(--color-primary-glow-strong)}.mode-card--custom{border-style:dashed}.mode-card--custom.mode-card--selected{border-style:solid}.mode-card__icon{border-radius:var(--radius-md);background:var(--color-primary-glow);width:40px;height:40px;color:var(--color-primary-light);transition:all var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.mode-card--selected .mode-card__icon{background:var(--color-primary);color:#fff}.mode-card__body{flex:1;min-width:0}.mode-card__name{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text);margin-bottom:2px}.mode-card__desc{font-size:var(--font-size-xs);color:var(--color-text-muted);-webkit-line-clamp:4;-webkit-box-orient:vertical;line-height:1.4;display:-webkit-box;overflow:hidden}.mode-card__check{top:var(--space-2);right:var(--space-2);background:var(--color-primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;display:flex;position:absolute;box-shadow:0 2px 8px #0000004d}.mode-custom-prompt{padding:var(--space-4);border-left:3px solid var(--color-primary);border-radius:var(--radius-md);animation:fadeInUp var(--transition-base) ease}.model-selector{gap:var(--space-3);flex-direction:column;display:flex}.model-selector__grid{gap:var(--space-2);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));display:grid}.process-config-grid{gap:var(--space-5);grid-template-columns:minmax(0,1fr) minmax(320px,1fr);align-items:start;display:grid}.model-chip{justify-content:space-between;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--glass-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;display:flex}.model-chip:hover{border-color:var(--color-primary-glow-strong);background:var(--color-surface-hover);transform:translateY(-1px)}.model-chip--selected{border-color:var(--color-primary);background:var(--color-primary-glow);box-shadow:inset 0 0 0 1px var(--color-primary), 0 0 16px var(--color-primary-glow-strong)}.model-chip__name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text)}.model-chip__badge{font-size:10px;font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.5px;background:var(--color-surface-active);border-radius:var(--radius-sm);color:var(--color-text-muted);transition:all var(--transition-fast);padding:3px 6px}.model-chip--selected .model-chip__badge{background:var(--color-primary);color:#fff}.model-chip__badge--pref{background:var(--color-primary-glow);color:var(--color-primary-light)}.model-chip--selected .model-chip__badge--pref{background:#fff3}.format-picker,.format-picker__stack{gap:var(--space-2);flex-direction:column;display:flex}.format-family-panel{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--glass-bg);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);overflow:hidden}.format-family-panel--active{border-color:#0ea5e947;box-shadow:0 10px 24px #0284c714}.format-family-panel__toggle{justify-content:space-between;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);text-align:left;cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;display:flex}.format-family-panel__toggle:hover{background:var(--color-surface-hover)}.format-family-panel__toggle--active{background:linear-gradient(135deg,#0ea5e91a 0%,#0f172a05 100%)}.format-family-panel__copy{flex-direction:column;gap:4px;min-width:0;display:flex}.format-family-panel__label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text)}.format-family-panel__desc{font-size:var(--font-size-xs);color:var(--color-text-muted);line-height:1.45}.format-family-panel__chevron{color:var(--color-text-muted);transition:transform var(--transition-fast), color var(--transition-fast);flex-shrink:0}.format-family-panel__chevron--open{color:var(--color-primary-light);transform:rotate(180deg)}.format-family-panel__body{padding:0 var(--space-4) var(--space-4);border-top:1px solid #94a3b81f}.format-family-panel__options{gap:var(--space-2);padding-top:var(--space-3);grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.format-suboption{align-items:center;gap:var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-align:left;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-muted);background:#ffffff05;padding:12px 14px;display:flex}.format-suboption:hover{border-color:var(--color-primary-glow-strong);background:var(--color-surface-hover)}.format-suboption--active{border-color:var(--color-primary);color:var(--color-text);background:linear-gradient(145deg,#0ea5e91f 0%,#0f172a05 100%);box-shadow:inset 0 0 0 1px #0ea5e92e}.process-cta{gap:var(--space-3);padding:var(--space-5);background:linear-gradient(135deg, var(--color-primary-glow) 0%, transparent 100%);border:1px solid var(--color-primary);border-radius:var(--radius-lg);flex-direction:column;display:flex}.process-cta__divider{background:var(--color-border);height:1px;margin:var(--space-2) 0}@media (width<=768px){.mode-grid,.process-config-grid,.format-family-panel__options{grid-template-columns:1fr}.format-family-panel__toggle,.format-family-panel__body{padding-left:var(--space-3);padding-right:var(--space-3)}.model-selector__grid{flex-direction:column}.model-chip{border-radius:var(--radius-md);justify-content:space-between}}.output-renderer{gap:var(--space-4);flex-direction:column;display:flex}.output-renderer__header{justify-content:space-between;align-items:flex-start;gap:var(--space-3);padding-bottom:var(--space-4);border-bottom:1px solid #7dd3fc29;flex-wrap:wrap;display:flex}.output-renderer__header-main{flex-direction:column;gap:6px;display:flex}.output-renderer__eyebrow{font-size:11px;font-weight:var(--font-weight-bold);letter-spacing:.08em;text-transform:uppercase;color:var(--color-primary-light);align-items:center;gap:6px;display:inline-flex}.output-renderer__header-title{font-size:clamp(1.05rem,1rem + .3vw,1.3rem);font-weight:var(--font-weight-semibold);color:var(--color-text)}.output-renderer__badges{gap:var(--space-2);flex-wrap:wrap;display:flex}.output-renderer__canvas{padding:clamp(var(--space-4), 2vw, var(--space-6));border-radius:var(--radius-2xl);background:radial-gradient(circle at top left, #0ea5e914, transparent 26%), linear-gradient(180deg, #ffffff08, transparent 14%), var(--color-surface-elevated);border:1px solid #7dd3fc29;box-shadow:inset 0 1px #ffffff0a}.output-content{font-size:var(--font-size-base);color:var(--color-text);line-height:1.7}.output-content__markdown{width:min(100%,920px)}.markdown-renderer{color:var(--color-text);font-size:var(--font-size-base);line-height:1.75}.markdown-renderer>:first-child{margin-top:0}.markdown-renderer>:last-child{margin-bottom:0}.markdown-renderer__p{margin:0 0 var(--space-4);color:var(--color-text)}.markdown-renderer__h1,.markdown-renderer__h2,.markdown-renderer__h3{color:var(--color-text);letter-spacing:-.02em;font-family:IBM Plex Sans,Inter,system-ui,sans-serif}.markdown-renderer__h1{margin:var(--space-8) 0 var(--space-4);font-size:clamp(1.55rem,1.4rem + .4vw,2rem)}.markdown-renderer__h2{margin:var(--space-7) 0 var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid #94a3b82e;font-size:clamp(1.25rem,1.15rem + .3vw,1.55rem)}.markdown-renderer__h3{margin:var(--space-5) 0 var(--space-2);font-size:clamp(1.02rem,.96rem + .2vw,1.2rem)}.markdown-renderer__ul,.markdown-renderer__ol{margin:var(--space-3) 0 var(--space-4);padding-left:var(--space-6)}.markdown-renderer__li{margin-bottom:var(--space-2)}.markdown-renderer strong{font-weight:var(--font-weight-semibold);color:var(--color-text)}.markdown-renderer em{font-style:italic}.markdown-renderer__inline-code{color:var(--color-primary-light);background:#94a3b81f;border:1px solid #94a3b82e;border-radius:6px;padding:2px 6px;font-family:Fira Code,Cascadia Code,monospace;font-size:.875em}.markdown-renderer__hr{margin:var(--space-6) 0;border:none;border-top:1px solid #94a3b82e}.markdown-renderer__a{color:var(--color-primary-light);text-underline-offset:3px;text-decoration:underline}.markdown-renderer__blockquote{margin:var(--space-5) 0;padding:var(--space-3) var(--space-4);border-left:3px solid var(--color-primary);border-radius:0 var(--radius-lg) var(--radius-lg) 0;color:var(--color-text-muted);background:#0ea5e90f}.markdown-renderer__table-wrap{margin:var(--space-5) 0;overflow-x:auto}.markdown-renderer__table{border-collapse:separate;border-spacing:0;width:100%;font-size:var(--font-size-sm);border-radius:var(--radius-lg);border:1px solid #94a3b82e;overflow:hidden}.markdown-renderer__th,.markdown-renderer__td{padding:var(--space-3);text-align:left;vertical-align:top;border-bottom:1px solid #94a3b824}.markdown-renderer__th{font-weight:var(--font-weight-semibold);color:var(--color-text);background:#94a3b814}.markdown-renderer__td{color:var(--color-text-muted)}.markdown-renderer__code{margin:var(--space-5) 0;border-radius:var(--radius-xl);background:#0f172a;border:1px solid #94a3b829;overflow:hidden;box-shadow:inset 0 1px #ffffff0a}.markdown-renderer__code-header{padding:var(--space-2) var(--space-4);color:#e2e8f0cc;text-transform:uppercase;letter-spacing:.08em;background:#0f172ad1;justify-content:space-between;align-items:center;font-size:11px;display:flex}.markdown-renderer__code-body{padding:var(--space-4);color:#e2e8f0f5;margin:0;overflow-x:auto}.mermaid-block{margin:var(--space-6) 0;background:linear-gradient(180deg, #ffffff08, transparent 12%), linear-gradient(135deg, #0ea5e914 0%, #0f172a05 100%), var(--color-surface);border:1px solid #7dd3fc2e;border-radius:24px;overflow:hidden;box-shadow:0 20px 56px #02081714}.mermaid-block__toolbar{justify-content:space-between;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-bottom:1px solid #7dd3fc24;flex-wrap:wrap;display:flex}.mermaid-block__toolbar-meta{flex-direction:column;gap:4px;display:flex}.mermaid-block__eyebrow{font-size:11px;font-weight:var(--font-weight-bold);letter-spacing:.08em;text-transform:uppercase;color:var(--color-primary-light)}.mermaid-block__title{font-size:var(--font-size-sm);color:var(--color-text)}.mermaid-block__toolbar-actions{align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.mermaid-block__tabs{background:#94a3b81f;border:1px solid #94a3b829;border-radius:999px;padding:4px;display:inline-flex}.mermaid-block__tab,.mermaid-block__copy{color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);background:0 0;border:none;border-radius:999px;align-items:center;gap:6px;padding:8px 12px;display:inline-flex}.mermaid-block__tab:hover,.mermaid-block__copy:hover{color:var(--color-text);background:#94a3b81f}.mermaid-block__tab--active{color:var(--color-text);background:#0ea5e924;box-shadow:inset 0 0 0 1px #0ea5e929}.mermaid-block__copy{border:1px solid #94a3b829}.mermaid-block__viewport,.mermaid-block__source,.mermaid-block__fallback{padding:clamp(var(--space-4), 2vw, var(--space-6))}.mermaid-block__viewport{overflow-x:auto}.mermaid-block__viewport--loading{justify-content:center;align-items:center;min-height:220px;display:flex}.mermaid-block__stage{min-width:fit-content}.mermaid-block__source,.mermaid-block__fallback-source{border-radius:var(--radius-xl);color:#e2e8f0f5;white-space:pre;background:#0f172af5;border:1px solid #94a3b829;margin:0;font-family:Fira Code,Cascadia Code,monospace;font-size:12px;line-height:1.7;overflow-x:auto}.mermaid-block__source code,.mermaid-block__fallback-source code{padding:var(--space-4);display:block}.mermaid-block__fallback{gap:var(--space-3);flex-direction:column;display:flex}.mermaid-block__fallback-title{font-weight:var(--font-weight-semibold);color:var(--color-text)}.mermaid-block__fallback-error{font-size:var(--font-size-xs);color:var(--color-error)}.output-checkbox{align-items:flex-start;gap:var(--space-2);margin-bottom:var(--space-2);list-style:none;display:flex}.output-checkbox:before{content:"";border:2px solid var(--color-border);border-radius:4px;flex-shrink:0;width:16px;height:16px;margin-top:2px}.output-checkbox--checked:before{background:var(--color-primary);border-color:var(--color-primary);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-position:50%;background-repeat:no-repeat}.output-table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm);margin:var(--space-3) 0}.output-table td,.output-table th{padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);text-align:left;vertical-align:top}.output-table tr:first-child td{font-weight:var(--font-weight-semibold);background:var(--color-surface-active);color:var(--color-text)}.output-table tr:nth-child(2n) td{background:var(--color-surface)}.share-toolbar{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);flex-wrap:wrap;display:flex}.share-btn{align-items:center;gap:var(--space-2);display:flex}.output-history{gap:var(--space-2);flex-direction:column;display:flex}.output-history__label{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.output-history__list{gap:var(--space-2);flex-wrap:wrap;display:flex}.output-history__item{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);font-size:var(--font-size-xs);display:flex}.output-history__item:hover{border-color:var(--color-primary-glow-strong)}.output-history__item--active{border-color:var(--color-primary);background:var(--color-primary-glow)}.output-history__time{color:var(--color-text-dim);align-items:center;gap:4px;display:flex}@media (width<=768px){.output-renderer__canvas,.mermaid-block__toolbar,.mermaid-block__viewport,.mermaid-block__source,.mermaid-block__fallback{padding:var(--space-4)}.mermaid-block__toolbar{align-items:stretch}.mermaid-block__toolbar-actions{justify-content:space-between;width:100%}.mermaid-block__tabs{flex:1;justify-content:space-between}.mermaid-block__tab{flex:1;justify-content:center}}@media print{.studio__header,.studio-tabs,.studio-retention-notice,.share-toolbar,.output-history,.output-renderer__header,.sidebar,.app-nav,nav{display:none!important}.output-content{color:#000;font-size:12pt;line-height:1.6}.markdown-renderer__h1,.markdown-renderer__h2,.markdown-renderer__h3{color:#000;page-break-after:avoid}.markdown-renderer__td,.markdown-renderer__th{border:1px solid #ccc}.markdown-renderer__th{background:#f5f5f5}}.transcript-viewer{gap:var(--space-4);flex-direction:column;display:flex}.transcript-viewer__player{gap:var(--space-2);flex-direction:column;display:flex}.transcript-viewer__loading{align-items:center;gap:var(--space-4);padding:var(--space-6);display:flex}.transcript-loading__title{font-size:var(--font-size-md);font-weight:var(--font-weight-medium);color:var(--color-text)}.transcript-loading__sub{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:var(--space-1)}.transcript-viewer__empty{text-align:center;align-items:center;gap:var(--space-4);padding:var(--space-10) var(--space-8);flex-direction:column;display:flex}.transcript-empty__icon{background:var(--color-primary-glow);width:72px;height:72px;color:var(--color-primary-light);border-radius:50%;justify-content:center;align-items:center;display:flex}.transcript-viewer__content{gap:var(--space-3);padding:var(--space-5);flex-direction:column;display:flex}.transcript-meta{align-items:center;gap:var(--space-2);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border);flex-wrap:wrap;display:flex}.transcript-textarea{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;min-height:320px;padding:var(--space-4);color:var(--color-text);font-size:var(--font-size-sm);resize:vertical;transition:border-color var(--transition-fast);outline:none;font-family:inherit;line-height:1.8}.transcript-textarea:focus{border-color:var(--color-primary)}.transcript-edit-hint{font-size:var(--font-size-xs);color:var(--color-text-dim);margin:0}@media (width<=768px){.share-toolbar{flex-direction:column;align-items:stretch}.share-btn{justify-content:center}}.session-card{gap:var(--space-2);padding:var(--space-4) var(--space-5);cursor:pointer;-webkit-user-select:none;user-select:none;transition:border-color var(--transition-fast), transform var(--transition-fast);border-left:3px solid #0000;flex-direction:column;display:flex}.session-card:hover,.session-card:focus{border-left-color:var(--color-primary);outline:none;transform:translate(2px)}.session-card__header{justify-content:space-between;align-items:center;gap:var(--space-2);display:flex}.session-card__status{align-items:center;gap:var(--space-2);font-size:var(--font-size-xs);display:inline-flex}.session-card__date{font-size:var(--font-size-xs);color:var(--color-text-dim);white-space:nowrap}.session-card__title{font-size:var(--font-size-md);font-weight:var(--font-weight-medium);color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.session-card__meta{align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.session-card__meta-item{align-items:center;gap:var(--space-1);font-size:var(--font-size-xs);color:var(--color-text-muted);display:inline-flex}.session-card__warn{align-items:flex-start;gap:var(--space-2);font-size:var(--font-size-xs);color:var(--color-warning);background:rgba(var(--color-warning-rgb,245, 158, 11), .08);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);border:1px solid rgba(var(--color-warning-rgb,245, 158, 11), .2);line-height:1.4;display:flex}.session-card__warn svg{flex-shrink:0;margin-top:1px}.session-card__actions{margin-top:var(--space-1);justify-content:space-between;align-items:center;display:flex}.session-card__arrow{color:var(--color-text-dim);transition:transform var(--transition-fast), color var(--transition-fast);flex-shrink:0;margin-left:auto}.session-card:hover .session-card__arrow{color:var(--color-primary-light);transform:translate(3px)}.session-card__delete--confirm{color:var(--color-error)!important;border-color:var(--color-error)!important}.history-skeleton{border-radius:var(--radius-lg)}.spin{animation:1s linear infinite spinAnim}@keyframes spinAnim{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (width<=768px){.session-card{padding:var(--space-3) var(--space-4)}.session-card__title{font-size:var(--font-size-sm)}}
