*,*:before,*:after{box-sizing:border-box;margin:0;padding:0;border:0;font-size:100%;font:inherit;vertical-align:baseline;background:transparent}article,aside,details,figcaption,figure,footer,header,hgroup,main,menu,nav,section,summary{display:block}body{line-height:1}ol,ul,menu{list-style:none}blockquote,q{quotes:none}blockquote:before,blockquote:after,q:before,q:after{content:"";content:none}table{border-collapse:collapse;border-spacing:0}input,button,textarea,select,optgroup{margin:0;padding:0;border:0;font-family:inherit;font-size:inherit;font-weight:inherit;line-height:inherit;color:inherit;background:none;appearance:none;-webkit-appearance:none;-moz-appearance:none}button{cursor:pointer;background:none}input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}input[type=search]::-webkit-search-decoration,input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-results-button,input[type=search]::-webkit-search-results-decoration{-webkit-appearance:none}textarea{resize:none;overflow:auto}a{color:inherit;text-decoration:none;background-color:transparent}img,picture,video,canvas,svg{display:block;max-width:100%;height:auto}img{border-style:none}fieldset{border:0;margin:0;padding:0}legend{padding:0;display:table;max-width:100%;white-space:normal}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}b,strong{font-weight:inherit}i,em{font-style:inherit}small{font-size:inherit}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}hr{box-sizing:content-box;height:0;overflow:visible;border:0;border-top:1px solid}abbr[title]{text-decoration:none}code,kbd,samp,pre{font-family:inherit;font-size:inherit}[hidden]{display:none!important}:focus:not(:focus-visible){outline:none}:focus-visible{outline:2px solid var(--color-primary, #6366f1);outline-offset:2px}html{-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%}#root,#__next{isolation:isolate}:root{--theme-transition: background-color .3s ease, color .3s ease, border-color .3s ease, box-shadow .3s ease}:root,[data-theme=light]{--color-primary: #18181b;--color-primary-foreground: #ffffff;--color-primary-hover: #27272a;--color-primary-light: #a1a1aa;--color-primary-bg: #f4f4f5;--color-success: #22c55e;--color-success-bg: #dcfce7;--color-error: #ef4444;--color-error-bg: #fee2e2;--color-warning: #f59e0b;--color-warning-bg: #fef3c7;--color-text: #0f172a;--color-text-secondary: #334155;--color-text-muted: #64748b;--color-text-placeholder: #94a3b8;--color-bg: #f8fafc;--color-bg-secondary: #f1f5f9;--color-bg-tertiary: #e2e8f0;--color-bg-card: #ffffff;--color-bg-elevated: #ffffff;--color-bg-white: #ffffff;--color-border: #e2e8f0;--color-border-hover: #cbd5e1;--color-border-focus: #18181b;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);--shadow-glow: none;--glass-bg: #ffffff;--glass-border: #e2e8f0;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--radius-full: 9999px;--font-xs: 12px;--font-sm: 13px;--font-base: 14px;--font-md: 16px;--font-lg: 18px;--font-xl: 24px;--font-2xl: 28px;--transition-fast: .15s ease;--transition-normal: .2s ease;--primary: #18181b;--text: #0f172a;--muted: #64748b;--border: #e2e8f0;--bg: #f8fafc}[data-theme=dark]{--color-primary: #fafafa;--color-primary-foreground: #09090b;--color-primary-hover: #e4e4e7;--color-primary-light: #52525b;--color-primary-bg: rgba(255, 255, 255, .08);--color-success: #4ade80;--color-success-bg: rgba(34, 197, 94, .15);--color-error: #f87171;--color-error-bg: rgba(239, 68, 68, .15);--color-warning: #fbbf24;--color-warning-bg: rgba(245, 158, 11, .15);--color-text: #f1f5f9;--color-text-secondary: #cbd5e1;--color-text-muted: #94a3b8;--color-text-placeholder: #64748b;--color-bg: #09090b;--color-bg-secondary: #18181b;--color-bg-tertiary: #27272a;--color-bg-card: #111113;--color-bg-elevated: #1c1c1e;--color-bg-white: #18181b;--color-border: rgba(255, 255, 255, .08);--color-border-hover: rgba(255, 255, 255, .14);--color-border-focus: #fafafa;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .5);--shadow-md: 0 2px 8px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .6);--shadow-xl: 0 12px 40px rgba(0, 0, 0, .7);--shadow-glow: none;--glass-bg: #111113;--glass-border: rgba(255, 255, 255, .08);--primary: #fafafa;--text: #f1f5f9;--muted: #94a3b8;--border: rgba(255, 255, 255, .08);--bg: #09090b}html,body,#root{width:100%;height:100%;font-size:16px;font-weight:500;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;overflow:hidden;background-color:var(--color-bg);color:var(--color-text);transition:var(--theme-transition)}html.theme-loading,html.theme-loading *,html.theme-loading *:before,html.theme-loading *:after{transition:none!important}html.theme-transitioning,html.theme-transitioning *,html.theme-transitioning *:before,html.theme-transitioning *:after{transition:background-color .2s ease,color .2s ease,border-color .2s ease,box-shadow .2s ease,background .2s ease!important}body,p,span,div,h1,h2,h3,h4,h5,h6,label,a,li,td,th{color:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-secondary);border-radius:4px}::-webkit-scrollbar-thumb{background:var(--color-border-hover);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}::selection{background:var(--color-primary-bg);color:var(--color-text)}@keyframes fadeInOpacity{0%{opacity:0}to{opacity:1}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease-out}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes spinner-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.profile-divider,.divider{height:1px;background-color:var(--color-border);margin:8px 0}.divider{display:flex;align-items:center;gap:12px;margin:20px 0 2px;color:var(--color-text-muted);font-size:12px;text-align:center;justify-content:center}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.mb-xs{margin-bottom:var(--spacing-xs)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.navbar{width:100%;height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 20px;position:fixed;top:0;left:0;z-index:80;box-shadow:var(--shadow-sm);background:var(--color-bg-card);border-bottom:1px solid var(--color-border);transition:var(--theme-transition)}.navbar-left{display:flex;align-items:center;gap:16px}.navbar-right{display:flex;align-items:center;gap:8px}.navbar-logo{font-size:24px;font-weight:800;color:var(--color-text);transition:color var(--transition-fast)}.navbar-logo:hover{color:var(--color-text-muted)}.navbar-profile{width:32px;height:32px;border-radius:50%;object-fit:cover;cursor:pointer;border:2px solid var(--color-border);transition:border-color var(--transition-fast)}.navbar-profile:hover{border-color:var(--color-text-muted)}.navbar-profile-fallback{display:flex;align-items:center;justify-content:center;background:var(--color-bg-tertiary);color:var(--color-text-muted)}.navbar-profile-btn{background:transparent;border:none;padding:0;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center}.navbar-bell{position:relative;width:42px;height:42px;display:flex;align-items:center;justify-content:center;background:transparent;border:0;cursor:pointer;padding:0;border-radius:50%;color:var(--color-text);transition:background-color var(--transition-fast),color var(--transition-fast)}.navbar-bell:hover,.navbar-bell:focus-visible{background-color:var(--color-bg-secondary);outline:none}.navbar-bell:active{background-color:var(--color-bg-tertiary)}.bell-badge{position:absolute;right:2px;top:2px;min-width:18px;height:18px;padding:0 5px;background:var(--color-error);border-radius:9px;color:#fff;font-size:11px;font-weight:600;display:flex;align-items:center;justify-content:center;line-height:1}.notification-wrapper{position:relative}.notification-dropdown{position:absolute;top:48px;right:0;width:320px;max-height:400px;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);z-index:100;overflow:hidden;animation:dropdownFadeIn .2s ease}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.notification-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--color-border)}.notification-title{font-weight:600;font-size:15px;color:var(--color-text)}.notification-clear{background:none;border:none;color:var(--color-primary);font-size:13px;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);transition:background-color var(--transition-fast)}.notification-clear:hover{background-color:var(--color-primary-bg)}.notification-list{max-height:340px;overflow-y:auto}.notification-empty{padding:40px 16px;text-align:center;color:var(--color-text-muted);font-size:14px}.notification-item{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;border-bottom:1px solid var(--color-border);transition:background-color var(--transition-fast)}.notification-item:last-child{border-bottom:none}.notification-item:hover{background-color:var(--color-bg-secondary)}.notification-item.unread,.notification-item.unread:hover{background-color:var(--color-primary-bg)}.notification-icon{flex-shrink:0;margin-top:2px}.notification-content{flex:1;min-width:0}.notification-message{display:block;font-size:14px;color:var(--color-text);line-height:1.4;word-break:break-word}.notification-time{display:block;font-size:12px;color:var(--color-text-muted);margin-top:4px}.sidebar{display:flex;flex-direction:column;position:fixed;justify-content:space-between;top:56px;left:0;bottom:0;width:240px;overflow-y:auto;transition:transform .3s ease,background-color var(--transition-normal);z-index:60;background:var(--color-bg-card);border-right:1px solid var(--color-border);box-shadow:none}.sidebar.closed{transform:translate(-240px)}.sidebar-content{width:100%;padding:16px}.sidebar-footer{padding:16px;display:flex;flex-direction:column;gap:6px}.sidebar-footer-divider{height:1px;background:var(--color-border);margin-bottom:10px}.footer-link{font-size:13px;color:var(--color-text-muted);display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:var(--radius-md);transition:all var(--transition-fast)}.footer-link:hover{color:var(--color-text);background:var(--color-bg-secondary)}.main-content{margin-top:56px;margin-left:240px;padding:24px;height:calc(100vh - 56px);overflow-y:auto;background:var(--color-bg);transition:var(--theme-transition)}.menu-tree{display:flex;flex-direction:column;gap:8px}.menu-item{display:flex;width:100%;border-radius:var(--radius-lg);align-items:center}.menu-button{background:none;border:none;text-align:left;width:100%;padding:12px 14px;cursor:pointer;border-radius:var(--radius-lg);color:var(--color-text-secondary);display:flex;align-items:center;gap:10px;font-size:14px;font-weight:500;transition:all var(--transition-fast);text-decoration:none}.menu-button:hover{background:var(--color-bg-secondary);color:var(--color-text)}.menu-button.active{background:var(--color-primary);color:#fff;font-weight:600}[data-theme=dark] .menu-button.active{background:var(--color-bg-tertiary);color:var(--color-text)}.menu-button.active:hover{background:var(--color-primary-hover)}[data-theme=dark] .menu-button.active:hover{background:var(--color-bg-tertiary)}.menu-icon{flex-shrink:0;opacity:.7;transition:opacity var(--transition-fast)}.menu-button:hover .menu-icon,.menu-button.active .menu-icon{opacity:1}.arrow{margin-right:6px}.menu-children{margin-left:16px}.profile-menu{position:absolute;top:56px;right:16px;width:300px;background-color:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);padding:8px 0;z-index:90;overflow:hidden;animation:dropdownFadeIn .2s ease}.profile-header{display:flex;align-items:flex-start;gap:12px;padding:12px 16px}.profile-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;flex-shrink:0;border:2px solid var(--color-border)}.profile-avatar-fallback{display:flex;align-items:center;justify-content:center;background:var(--color-bg-tertiary);color:var(--color-text-muted)}.profile-info{display:flex;flex-direction:column;font-size:14px;min-width:0;gap:2px}.profile-name{font-weight:700;color:var(--color-text);font-size:14px;line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-email{color:var(--color-text-muted);font-size:13px;line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-link{background:none;border:none;padding:0;color:var(--color-primary);font-size:13px;text-decoration:none;text-align:left;line-height:1.4;margin-top:2px;cursor:pointer}.profile-link:hover{text-decoration:underline}.profile-item{display:block;width:100%;padding:10px 16px;cursor:pointer;font-size:14px;transition:background-color var(--transition-fast);background:transparent;border:none;text-align:left;font-family:inherit;color:var(--color-text)}.profile-item:hover:not(:disabled){background-color:var(--color-bg-secondary)}.profile-item:disabled{cursor:default;color:var(--color-text-muted)}.profile-divider{height:1px;background-color:var(--color-border);margin:8px 0}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:var(--font-base);color:var(--color-text);font-weight:600}.input{height:48px;padding:0 16px;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-secondary);color:var(--color-text);font-size:var(--font-base);outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast)}.input::placeholder{color:var(--color-text-placeholder)}.input:hover{border-color:var(--color-border-hover)}.input:focus{border-color:var(--color-primary);background:var(--color-bg-card);box-shadow:0 0 0 2px var(--color-primary-bg)}.btn{height:48px;border:0;border-radius:var(--radius-lg);font-weight:600;font-size:var(--font-base);cursor:pointer;transition:transform .04s ease,background-color var(--transition-fast),box-shadow var(--transition-fast)}.btn:active{transform:translateY(1px)}.btn--primary{background:var(--color-primary);color:var(--color-primary-foreground)}.btn--primary:hover{background:var(--color-primary-hover)}.btn--primary:active{transform:translateY(1px)}.btn--secondary{background:var(--color-bg-secondary);color:var(--color-text);border:1px solid var(--color-border)}.btn--secondary:hover{background:var(--color-bg-tertiary);border-color:var(--color-border-hover)}.social-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:20px}.social-btn{height:48px;border:1px solid var(--color-border);background:var(--color-bg-secondary);border-radius:var(--radius-lg);font-weight:600;color:var(--color-text);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all var(--transition-fast)}.social-btn:hover{background:var(--color-bg-tertiary);border-color:var(--color-border-hover)}.custom-dropdown{position:relative}.custom-dropdown .dropdown-toggle{display:flex;align-items:center;gap:8px;padding:8px 14px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-sm);background:var(--color-bg-secondary);cursor:pointer;color:var(--color-text);min-width:100px;justify-content:space-between;transition:all var(--transition-fast)}.custom-dropdown .dropdown-toggle:hover{border-color:var(--color-border-hover);background:var(--color-bg-tertiary)}.custom-dropdown .dropdown-arrow{font-size:8px;color:var(--color-text-muted);transition:transform var(--transition-fast)}.custom-dropdown .dropdown-menu{position:absolute;top:calc(100% + 4px);left:0;min-width:100%;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);list-style:none;padding:4px 0;margin:0;z-index:50}.custom-dropdown .dropdown-menu li{padding:10px 14px;font-size:var(--font-sm);color:var(--color-text);cursor:pointer;transition:background-color var(--transition-fast)}.custom-dropdown .dropdown-menu li:hover{background:var(--color-bg-secondary)}.custom-dropdown .dropdown-menu li.active{background:var(--color-primary-bg);color:var(--color-primary);font-weight:500}.pagination{margin-top:24px;display:flex;justify-content:center;gap:12px;align-items:center}.pagination button{padding:8px 16px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-secondary);color:var(--color-text);cursor:pointer;font-size:var(--font-base);font-weight:500;transition:all var(--transition-fast)}.pagination button:hover:not(:disabled){background:var(--color-bg-tertiary);border-color:var(--color-border-hover)}.pagination button:disabled{background:var(--color-bg-secondary);color:var(--color-text-muted);cursor:not-allowed;opacity:.6}.pagination span{font-size:var(--font-base);color:var(--color-text-muted);font-weight:500}.skeleton{background:linear-gradient(90deg,var(--color-bg-secondary) 25%,var(--color-bg-tertiary) 50%,var(--color-bg-secondary) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite;border-radius:var(--radius-md)}.skeleton-row td{padding:14px 16px}.skeleton-card{padding:var(--spacing-md);background:var(--color-bg-card);border-radius:var(--radius-lg);border:1px solid var(--color-border)}.spinner{border-radius:50%;border-style:solid;border-color:var(--color-border);border-top-color:var(--color-primary);animation:spinner-rotate .8s linear infinite}.spinner--sm{width:16px;height:16px;border-width:2px}.spinner--md{width:32px;height:32px;border-width:3px}.spinner--lg{width:48px;height:48px;border-width:4px}.spinner-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:var(--glass-bg);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100}.inline-spinner{display:inline-block;margin-left:var(--spacing-sm)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);gap:var(--spacing-md)}.loading-container p{color:var(--color-text-muted);font-size:var(--font-sm)}.login-page,.join-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100%;padding:48px 16px;animation:fadeIn .3s ease-out}.login-card,.join-card{width:100%;max-width:420px;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:40px 32px;box-shadow:var(--shadow-xl);transition:var(--theme-transition)}.login-title,.join-title{font-size:var(--font-2xl);font-weight:700;line-height:1.2;text-align:center;color:var(--color-text);margin:0 0 8px}.login-subtitle,.join-subtitle{font-size:var(--font-base);color:var(--color-text-muted);text-align:center;margin-bottom:32px}.login-form,.join-form{display:flex;flex-direction:column;gap:20px}.login-error,.join-error{margin-top:4px;padding:12px;background:var(--color-error-bg);border-radius:var(--radius-md);color:var(--color-error);font-size:var(--font-sm);text-align:center}.login-footer,.join-footer{margin-top:24px;text-align:center;font-size:var(--font-sm);color:var(--color-text-muted)}.login-footer a,.join-footer a{color:var(--color-text);font-weight:600;text-decoration:underline;margin-left:4px}.login-footer a:hover,.join-footer a:hover{text-decoration:underline}@media(max-width:420px){.login-card,.join-card{padding:32px 20px}.login-title,.join-title{font-size:var(--font-xl)}}.api-history-page{max-width:1200px;min-width:600px;min-height:400px;margin:0 auto;padding:24px;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);transition:var(--theme-transition);animation:fadeIn .3s ease-out}.api-history-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.api-history-header-left h1{font-size:var(--font-xl);font-weight:700;color:var(--color-text);margin-bottom:4px}.api-history-header-left p{font-size:var(--font-sm);color:var(--color-text-muted)}.api-history-header button{padding:8px 16px;font-size:var(--font-base);border:none;border-radius:var(--radius-md);background:var(--color-primary);color:#fff;cursor:pointer;transition:all var(--transition-fast)}.api-history-header button:hover:not(:disabled){background:var(--color-primary-hover)}.api-history-header button:disabled{opacity:.6;cursor:not-allowed}.api-history-filters{display:flex;justify-content:space-between;margin-bottom:20px;align-items:center;flex-wrap:wrap;gap:16px}.api-history-filters .filter-group{display:flex;align-items:center;gap:8px}.api-history-filters .filter-group-right{margin-left:auto}.api-history-filters label{font-weight:500;color:var(--color-text-muted);font-size:var(--font-sm)}.api-history-filters input[type=text]{padding:8px 12px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-sm);width:200px;color:var(--color-text);background:var(--color-bg-secondary);transition:all var(--transition-fast)}.api-history-filters input[type=text]::placeholder{color:var(--color-text-placeholder)}.api-history-filters input[type=text]:hover{border-color:var(--color-border-hover)}.api-history-filters input[type=text]:focus{outline:none;border-color:var(--color-primary);background:var(--color-bg-card);box-shadow:0 0 0 2px var(--color-primary-bg)}.api-history-filters .filter-group button.search-btn{padding:8px 16px;background:var(--color-bg-secondary);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-base);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.api-history-filters .filter-group button.search-btn:hover{background:var(--color-bg-tertiary);border-color:var(--color-border-hover)}.api-history-table-container{position:relative;overflow-x:auto;min-height:480px}.table-loading-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:var(--glass-bg);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10;min-height:300px}.api-history-table{width:100%;border-collapse:collapse;table-layout:fixed}.api-history-table tbody tr:not(.skeleton-row){animation:fadeInOpacity .3s ease-out}.api-history-table th,.api-history-table td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--color-border);font-size:var(--font-base)}.api-history-table th{background:var(--color-bg-secondary);font-weight:600;color:var(--color-text-muted);font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.5px}.api-history-table th:nth-child(1),.api-history-table td:nth-child(1){width:80px}.api-history-table th:nth-child(2),.api-history-table td:nth-child(2){width:80px}.api-history-table th:nth-child(3),.api-history-table td:nth-child(3){width:auto;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.api-history-table th:nth-child(4),.api-history-table td:nth-child(4){width:140px}.api-history-table th:nth-child(5),.api-history-table td:nth-child(5){width:90px}.api-history-table th:nth-child(6),.api-history-table td:nth-child(6){width:180px}.api-history-table tbody tr{transition:background-color var(--transition-fast)}.api-history-table tbody tr:hover{background:var(--color-bg-secondary)}.api-history-table tbody tr:last-child td{border-bottom:none}.api-history-table .no-data{text-align:center;padding:48px;color:var(--color-text-muted);font-size:var(--font-base)}.status-ok{display:inline-flex;padding:4px 10px;border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:600;background:var(--color-success-bg);color:var(--color-success)}.status-error{display:inline-flex;padding:4px 10px;border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:600;background:var(--color-error-bg);color:var(--color-error)}.method-badge{display:inline-flex;padding:4px 8px;border-radius:var(--radius-md);font-size:var(--font-xs);font-weight:600;font-family:var(--font-mono);background:var(--color-bg-tertiary);color:var(--color-text-secondary)}.elapsed-time{display:inline-flex;padding:4px 8px;border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:500;font-family:var(--font-mono);background:var(--color-bg-tertiary);color:var(--color-text-secondary)}.user-page{max-width:800px;margin:0 auto;animation:fadeIn .3s ease-out}.user-page__header{margin-bottom:32px}.user-page__header h1{font-size:var(--font-2xl);font-weight:700;color:var(--color-text);margin-bottom:4px}.user-page__subtitle{font-size:var(--font-base);color:var(--color-text-muted)}.user-page__content{display:flex;flex-direction:column;gap:24px}.user-page__error{text-align:center;padding:48px;color:var(--color-text-muted)}.user-page__skeleton-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden}.user-page__skeleton-body{padding:16px 32px 32px;display:flex;flex-direction:column;gap:12px}.user-page__skeleton-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:16px}.user-page__security{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:24px;transition:var(--theme-transition)}.security-header{display:flex;align-items:center;gap:10px;margin-bottom:20px;color:var(--color-text)}.security-header h2{font-size:var(--font-lg);font-weight:600;margin:0}.security-options{display:flex;flex-direction:column;gap:12px}.security-option{display:flex;align-items:center;gap:16px;padding:16px 20px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-align:left;width:100%}.security-option:hover:not(:disabled){background:var(--color-bg-tertiary);border-color:var(--color-border-hover)}.security-option:disabled{cursor:not-allowed;opacity:.6}.security-option__icon{width:44px;height:44px;border-radius:var(--radius-lg);background:var(--color-bg-tertiary);color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.security-option__content{flex:1;min-width:0}.security-option__title{display:block;font-size:var(--font-base);font-weight:600;color:var(--color-text);margin-bottom:2px}.security-option__desc{display:block;font-size:var(--font-sm);color:var(--color-text-muted)}.security-option__action{font-size:var(--font-sm);font-weight:500;color:var(--color-text-secondary);flex-shrink:0}.security-option__action.disabled{color:var(--color-text-muted)}@media(max-width:600px){.user-page__skeleton-grid{grid-template-columns:1fr}.security-option{flex-direction:column;align-items:flex-start;gap:12px}.security-option__action{align-self:flex-end}}.dashboard-page{max-width:1200px;margin:0 auto;animation:fadeIn .3s ease-out}.dashboard-header{margin-bottom:32px}.dashboard-header h1{font-size:var(--font-2xl);font-weight:700;color:var(--color-text);margin-bottom:4px}.dashboard-subtitle{font-size:var(--font-base);color:var(--color-text-muted)}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:32px}@media(max-width:900px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.stats-grid{grid-template-columns:1fr}}.recent-calls-section{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden;transition:var(--theme-transition)}.section-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--color-border)}.section-header h2{font-size:var(--font-lg);font-weight:600;color:var(--color-text);margin:0}.view-all-link{display:flex;align-items:center;gap:6px;font-size:var(--font-base);color:var(--color-text-secondary);font-weight:500;transition:all var(--transition-fast)}.view-all-link:hover{gap:10px}.recent-calls-table-wrapper{overflow-x:auto}.recent-calls-table{width:100%;border-collapse:collapse}.recent-calls-table th,.recent-calls-table td{padding:16px 24px;text-align:left;font-size:var(--font-base)}.recent-calls-table th{background:var(--color-bg-secondary);font-weight:600;color:var(--color-text-muted);font-size:11px;text-transform:uppercase;letter-spacing:.8px}.recent-calls-table tbody tr{border-bottom:1px solid var(--color-border);transition:background-color var(--transition-fast)}.recent-calls-table tbody tr:hover{background:var(--color-bg-secondary)}.recent-calls-table tbody tr:last-child{border-bottom:none}.status-badge{display:inline-flex;padding:4px 12px;border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:600}.status-badge.success{background:var(--color-success-bg);color:var(--color-success)}.status-badge.warning{background:var(--color-warning-bg);color:var(--color-warning)}.status-badge.error{background:var(--color-error-bg);color:var(--color-error)}.method-cell{color:var(--color-text-secondary);font-weight:500}.path-cell{color:var(--color-text);font-family:SF Mono,Consolas,monospace;font-size:var(--font-sm)}.latency-cell,.time-cell{color:var(--color-text-muted)}.empty-cell{text-align:center;padding:48px 24px!important;color:var(--color-text-muted)}.theme-toggle{display:flex;align-items:center;justify-content:center;background:none;border:none;padding:8px;cursor:pointer;border-radius:var(--radius-lg);transition:background-color var(--transition-fast)}.theme-toggle:hover{background:var(--color-bg-secondary)}.theme-toggle__track{position:relative;width:52px;height:28px;background:var(--color-bg-tertiary);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:space-between;padding:0 6px;transition:background-color var(--transition-normal)}[data-theme=dark] .theme-toggle__track{background:var(--color-bg-tertiary)}.theme-toggle__icon{position:relative;z-index:1;transition:opacity var(--transition-normal),color var(--transition-normal)}.theme-toggle__icon--sun{color:var(--color-warning);opacity:1}.theme-toggle__icon--moon{color:var(--color-text-muted);opacity:.4}[data-theme=dark] .theme-toggle__icon--sun{opacity:.4}[data-theme=dark] .theme-toggle__icon--moon{opacity:1;color:var(--color-text)}.theme-toggle__thumb{position:absolute;top:2px;left:2px;width:24px;height:24px;background:var(--color-bg-card);border-radius:var(--radius-full);box-shadow:var(--shadow-md);transition:left var(--transition-normal),background-color var(--transition-normal)}.theme-toggle__thumb.light{left:2px}.theme-toggle__thumb.dark{left:26px}.locale-toggle{display:flex;align-items:center;justify-content:center;background:none;border:none;padding:8px;cursor:pointer;border-radius:var(--radius-lg);transition:background-color var(--transition-fast)}.locale-toggle:hover{background:var(--color-bg-secondary)}.locale-toggle__track{position:relative;width:52px;height:28px;background:var(--color-bg-tertiary);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:space-between;padding:0 6px;transition:background-color var(--transition-normal)}.locale-toggle__label{position:relative;z-index:1;font-size:11px;font-weight:600;transition:opacity var(--transition-normal),color var(--transition-normal);opacity:.4;color:var(--color-text-muted)}.locale-toggle__label.active{opacity:1;color:var(--color-text)}.locale-toggle__label--ko{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.locale-toggle__label--en{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:10px}.locale-toggle__thumb{position:absolute;top:2px;left:2px;width:24px;height:24px;background:var(--color-bg-card);border-radius:var(--radius-full);box-shadow:var(--shadow-md);transition:left var(--transition-normal),background-color var(--transition-normal)}.locale-toggle__thumb.ko{left:2px}.locale-toggle__thumb.en{left:26px}.toast-container{position:fixed;top:68px;right:20px;display:flex;flex-direction:column;z-index:70}.toast{--base-opacity: 1;display:flex;align-items:center;gap:12px;padding:14px 18px;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:300px;max-width:400px;opacity:var(--base-opacity);transform:scale(calc(.9 + var(--base-opacity) * .1));transition:opacity .3s ease,transform .3s ease,margin .3s ease,max-height .3s ease;margin-bottom:10px;overflow:hidden;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.toast-enter{animation:slideIn .3s cubic-bezier(.4,0,.2,1) forwards}@keyframes slideIn{0%{opacity:0;transform:translate(30px) scale(.95);max-height:0;margin-bottom:0;padding-top:0;padding-bottom:0}to{opacity:var(--base-opacity);transform:translate(0) scale(calc(.9 + var(--base-opacity) * .1));max-height:100px;margin-bottom:10px;padding-top:14px;padding-bottom:14px}}.toast-exit{animation:slideOut .3s cubic-bezier(.4,0,.2,1) forwards}@keyframes slideOut{0%{opacity:var(--base-opacity);transform:translate(0) scale(calc(.9 + var(--base-opacity) * .1));max-height:100px;margin-bottom:10px}to{opacity:0;transform:translate(30px) scale(.95);max-height:0;margin-bottom:0;padding-top:0;padding-bottom:0}}.toast-info{background-color:var(--color-primary-bg);border:1px solid var(--color-primary);color:var(--color-primary)}.toast-success{background-color:var(--color-success-bg);border:1px solid var(--color-success);color:var(--color-success)}.toast-error{background-color:var(--color-error-bg);border:1px solid var(--color-error);color:var(--color-error)}.toast-icon{display:flex;align-items:center;flex-shrink:0}.toast-message{flex:1;font-size:var(--font-base);font-weight:500}.toast-close{display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;padding:4px;border-radius:var(--radius-sm);opacity:.7;transition:opacity var(--transition-fast),background-color var(--transition-fast);color:inherit}.toast-close:hover{opacity:1;background-color:#0000001a}[data-theme=dark] .toast-close:hover{background-color:#ffffff1a}
