.topbar{height:var(--topbar-height);background:var(--color-topbar-bg);padding:0 var(--spacing-lg);z-index:100;justify-content:space-between;align-items:center;display:flex;position:fixed;top:0;left:0;right:0}.topbar-brand{align-items:center;gap:var(--spacing-md);display:flex}.topbar-menu-btn{padding:var(--spacing-xs);width:32px;height:32px;color:var(--color-text-inverse);border-radius:var(--radius-sm);transition:background var(--transition-fast);justify-content:center;align-items:center;display:flex}.topbar-menu-btn:hover{background:#ffffff1a}.topbar-menu-btn svg{width:18px;height:18px}.topbar-logo{width:24px;height:24px;color:var(--color-text-inverse);justify-content:center;align-items:center;display:flex}.topbar-logo svg{width:20px;height:20px}.topbar-title{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-text-inverse);letter-spacing:.3px}.topbar-actions{align-items:center;gap:var(--spacing-sm);display:flex}.topbar-btn{align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-md);color:var(--color-text-inverse);font-size:var(--font-size-sm);border-radius:var(--radius-sm);transition:background var(--transition-fast);display:flex}.topbar-btn:hover{background:#ffffff1a}.topbar-btn svg{width:16px;height:16px}.topbar-theme-btn{padding:var(--spacing-xs);justify-content:center;align-items:center;width:32px;height:32px;display:flex}.topbar-theme-btn svg{width:18px;height:18px}.sidebar{top:var(--topbar-height);width:var(--sidebar-width);background:var(--color-sidebar-bg);border-right:1px solid var(--color-border-light);z-index:90;transition:width var(--transition-normal);flex-direction:column;display:flex;position:fixed;bottom:0;left:0;overflow:hidden auto}.sidebar-collapsed{width:var(--sidebar-collapsed-width)}.sidebar-user{align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg) var(--spacing-base) var(--spacing-base);border-bottom:1px solid var(--color-divider);cursor:pointer;transition:background var(--transition-fast);display:flex;position:relative}.sidebar-user:hover,.sidebar-user.menu-open{background:var(--color-sidebar-hover)}.sidebar-collapsed .sidebar-user{padding:var(--spacing-lg) var(--spacing-sm) var(--spacing-base);cursor:default;justify-content:center}.sidebar-collapsed .sidebar-user:hover{background:0 0}.sidebar-avatar-lg{background:var(--color-primary);width:44px;height:44px;color:var(--color-text-inverse);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-user-info{min-width:0}.sidebar-user-name{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.sidebar-user-email{font-size:var(--font-size-xs);color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.sidebar-user-benefits{margin-top:var(--spacing-xs);font-size:var(--font-size-xs);color:var(--color-primary)}.sidebar-user-benefits:hover{text-decoration:underline}.sidebar-user-chevron{color:var(--color-text-tertiary);transition:transform var(--transition-fast);margin-left:auto}.sidebar-user-chevron svg{width:16px;height:16px}.sidebar-user.menu-open .sidebar-user-chevron{transform:rotate(180deg)}.sidebar-user-menu{top:calc(100% + 4px);left:var(--spacing-base);right:var(--spacing-base);background:var(--color-card-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;position:absolute;overflow:hidden}.sidebar-user-menu-item{align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-base);width:100%;color:var(--color-text-secondary);font-size:var(--font-size-base);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast);background:0 0;border:none;display:flex}.sidebar-user-menu-item:hover{background:var(--color-sidebar-hover);color:var(--color-danger)}.sidebar-user-menu-item svg{flex-shrink:0;width:16px;height:16px}.sidebar-nav{padding:var(--spacing-sm) 0;flex:1}.sidebar-section-label{padding:var(--spacing-base) var(--spacing-base) var(--spacing-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.5px}.sidebar-item{align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-base);margin:0 var(--spacing-sm);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-size-base);font-weight:var(--font-weight-regular);cursor:pointer;width:calc(100% - var(--spacing-base));transition:background var(--transition-fast);background:0 0;border:none;min-height:36px;line-height:1;display:flex;position:relative}.sidebar-collapsed .sidebar-item{padding:var(--spacing-sm);margin:0 var(--spacing-xs);width:calc(100% - var(--spacing-xs) * 2);justify-content:center}.sidebar-item:hover{background:var(--color-sidebar-hover)}.sidebar-item.active{background:var(--color-sidebar-active);color:var(--color-primary);font-weight:var(--font-weight-medium)}.sidebar-item.active:before{content:"";left:calc(-1 * var(--spacing-sm));background:var(--color-primary);border-radius:0 2px 2px 0;width:3px;height:20px;position:absolute;top:50%;transform:translateY(-50%)}.sidebar-item svg{width:18px;height:18px;color:inherit;opacity:.75;flex-shrink:0}.sidebar-item.active svg{opacity:1}.footer{margin-left:var(--sidebar-width);padding:var(--spacing-lg) var(--spacing-lg);background:var(--color-card-bg);border-top:1px solid var(--color-border-light);transition:margin-left var(--transition-normal)}.layout-sidebar-collapsed .footer{margin-left:var(--sidebar-collapsed-width)}.footer-content{justify-content:space-between;align-items:center;gap:var(--spacing-md);flex-wrap:wrap;max-width:960px;margin:0 auto;display:flex}:is(.layout-content-wide~.footer .footer-content,.layout-main:has(.layout-content-wide)~.footer .footer-content){max-width:1200px}.footer-left{align-items:center;gap:var(--spacing-sm);display:flex}.footer-brand{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.footer-divider{color:var(--color-text-tertiary);font-size:var(--font-size-sm)}.footer-copyright{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.footer-right{align-items:center;gap:var(--spacing-lg);display:flex}.footer-link{font-size:var(--font-size-sm);color:var(--color-text-secondary);transition:color var(--transition-fast);text-decoration:none}.footer-link:hover{color:var(--color-primary);text-decoration:underline}@media (width<=768px){.footer{padding:var(--spacing-md) var(--spacing-base);margin-left:0}.footer-content{text-align:center;gap:var(--spacing-sm);flex-direction:column}.footer-left,.footer-right{justify-content:center}.footer-right{gap:var(--spacing-md)}}.layout{flex-direction:column;min-height:100vh;display:flex}.layout-main{margin-left:var(--sidebar-width);padding-top:var(--topbar-height);min-height:calc(100vh - var(--topbar-height));transition:margin-left var(--transition-normal);flex:1}.layout-sidebar-collapsed .layout-main{margin-left:var(--sidebar-collapsed-width)}.layout-content{max-width:960px;padding:var(--spacing-xl) var(--spacing-lg);min-height:calc(100vh - var(--topbar-height));margin:0 auto}.layout-content-wide{max-width:1200px;padding:var(--spacing-xl) var(--spacing-lg);min-height:calc(100vh - var(--topbar-height));margin:0 auto}.toast-container{top:calc(var(--topbar-height) + var(--spacing-base));z-index:9999;gap:var(--spacing-sm);pointer-events:none;width:100%;max-width:480px;padding:0 var(--spacing-base);flex-direction:column;display:flex;position:fixed;left:50%;transform:translate(-50%)}.toast-item{pointer-events:auto;background:var(--color-card-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);flex-direction:column;animation:.3s ease-out toastSlideDown;display:flex;overflow:hidden}.toast-item.toast-exit{animation:.25s ease-in forwards toastSlideUp}@keyframes toastSlideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes toastSlideUp{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-20px)}}.toast-content{align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-base);min-height:40px;display:flex}.toast-icon{flex-shrink:0;width:18px;height:18px;margin-top:1px}.toast-icon-success{color:var(--color-success)}.toast-icon-error{color:var(--color-danger)}.toast-icon-warning{color:var(--color-warning)}.toast-icon-info{color:var(--color-primary)}.toast-message{font-size:var(--font-size-sm);color:var(--color-text-primary);word-break:break-word;flex:1;line-height:1.5}.toast-close{width:22px;height:22px;color:var(--color-text-tertiary);cursor:pointer;border-radius:var(--radius-sm);transition:color var(--transition-fast), background var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;margin-top:-2px;margin-right:-4px;display:flex}.toast-close:hover{color:var(--color-text-primary);background:var(--color-sidebar-hover)}.toast-close svg{width:14px;height:14px}.toast-detail-section{border-top:1px solid var(--color-border-light);margin-top:var(--spacing-xs)}.toast-detail-toggle{padding:var(--spacing-sm) var(--spacing-base) var(--spacing-sm) calc(var(--spacing-base) + 26px);font-size:var(--font-size-xs);color:var(--color-text-tertiary);cursor:pointer;transition:color var(--transition-fast);-webkit-user-select:none;user-select:none}.toast-detail-toggle:hover{color:var(--color-primary);text-decoration:underline}.toast-detail-header{padding:var(--spacing-xs) var(--spacing-base) var(--spacing-xs) calc(var(--spacing-base) + 26px);background:var(--color-sidebar-bg);justify-content:space-between;align-items:center;display:flex}.toast-detail-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);font-weight:500}.toast-copy-btn{font-size:var(--font-size-xs);color:var(--color-text-tertiary);background:var(--color-card-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);align-items:center;gap:4px;padding:4px 8px;display:flex}.toast-copy-btn:hover{color:var(--color-primary);border-color:var(--color-primary)}.toast-copy-btn-copied{color:var(--color-success);border-color:var(--color-success)}.toast-copy-btn svg{width:12px;height:12px}.toast-detail-content{padding:var(--spacing-sm) var(--spacing-base) var(--spacing-sm) calc(var(--spacing-base) + 26px);font-size:var(--font-size-xs);color:var(--color-text-secondary);white-space:pre-wrap;word-break:break-word;background:var(--color-page-bg);max-height:200px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;line-height:1.6;overflow-y:auto}.toast-progress{background:var(--color-border-light);height:3px;position:relative;overflow:hidden}.toast-progress-bar{height:100%;transition:width .1s linear}.toast-progress-success{background:var(--color-success)}.toast-progress-error{background:var(--color-danger)}.toast-progress-warning{background:var(--color-warning)}.toast-progress-info{background:var(--color-primary)}.btn{justify-content:center;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-base);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);white-space:nowrap;cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast);border:none;min-height:32px;line-height:1;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn svg{width:16px;height:16px}.btn-primary{background:var(--color-primary);color:var(--color-text-inverse)}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn-secondary{color:var(--color-primary);border:1px solid var(--color-border);background:0 0}.btn-secondary:hover:not(:disabled){background:var(--color-primary-light);border-color:var(--color-primary-border)}.btn-text{color:var(--color-primary);padding:var(--spacing-xs) var(--spacing-sm);background:0 0}.btn-text:hover:not(:disabled){background:var(--color-primary-light)}.btn-danger{color:var(--color-danger);border:1px solid var(--color-border);background:0 0}.btn-danger:hover:not(:disabled){background:var(--color-danger-light);border-color:var(--color-danger)}.btn-sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-xs);min-height:26px}.btn-lg{padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-base);min-height:40px}.btn-full{width:100%}.form-group{margin-bottom:var(--spacing-base)}.form-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--spacing-xs);display:block}.form-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-base);color:var(--color-text-primary);background:var(--color-card-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;min-height:36px;display:block}.form-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}.form-input::placeholder{color:var(--color-text-tertiary)}.form-input.error{border-color:var(--color-danger)}.form-input.error:focus{box-shadow:0 0 0 2px var(--color-danger-light)}.form-error{font-size:var(--font-size-xs);color:var(--color-danger);margin-top:var(--spacing-xs)}.form-hint{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:var(--spacing-xs)}.form-select{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-base);color:var(--color-text-primary);background:var(--color-card-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;appearance:auto;outline:none;min-height:36px;display:block}.form-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}.form-textarea{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-base);color:var(--color-text-primary);background:var(--color-card-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);resize:vertical;min-height:80px;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;display:block}.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}.form-checkbox{align-items:flex-start;gap:var(--spacing-sm);cursor:pointer;display:flex}.form-checkbox input[type=checkbox]{accent-color:var(--color-primary);cursor:pointer;width:16px;height:16px;margin-top:2px}.form-checkbox-label{font-size:var(--font-size-sm);color:var(--color-text-primary)}.auth-page{background:var(--color-page-bg);min-height:100vh;padding:var(--spacing-lg);justify-content:center;align-items:center;display:flex}.auth-container{width:100%;max-width:440px}.auth-logo{align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xl);justify-content:center;display:flex}.auth-logo svg{width:28px;height:28px;color:var(--color-primary)}.auth-logo-text{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.auth-card{background:var(--color-card-bg);border-radius:var(--radius-lg);padding:var(--spacing-xl);border:1px solid var(--color-border-light)}.auth-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.auth-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-lg)}.auth-error{background:var(--color-danger-light);color:var(--color-danger);padding:var(--spacing-md);border-radius:var(--radius-sm);font-size:var(--font-size-sm);margin-bottom:var(--spacing-base);line-height:var(--line-height-base)}.auth-success{background:var(--color-success-light);color:var(--color-success);padding:var(--spacing-md);border-radius:var(--radius-sm);font-size:var(--font-size-sm);margin-bottom:var(--spacing-base);line-height:var(--line-height-base)}.auth-footer{margin-top:var(--spacing-lg);font-size:var(--font-size-sm);color:var(--color-text-secondary);text-align:center}.auth-footer a{color:var(--color-primary);font-weight:var(--font-weight-medium)}.auth-footer a:hover{text-decoration:underline}.auth-links{margin-top:var(--spacing-base);font-size:var(--font-size-sm);justify-content:space-between;align-items:center;display:flex}.auth-links a{color:var(--color-primary)}.auth-links a:hover{text-decoration:underline}.auth-global-footer{padding:var(--spacing-md) var(--spacing-lg);background:var(--color-card-bg);border-top:1px solid var(--color-border-light);z-index:50;position:fixed;bottom:0;left:0;right:0}.auth-global-footer-content{justify-content:center;align-items:center;gap:var(--spacing-md);max-width:1200px;font-size:var(--font-size-sm);color:var(--color-text-secondary);flex-wrap:wrap;margin:0 auto;display:flex}.auth-global-footer-brand{font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.auth-global-footer-divider{color:var(--color-text-tertiary)}.auth-global-footer-links{align-items:center;gap:var(--spacing-lg);display:flex}.auth-global-footer-link{color:var(--color-text-secondary);transition:color var(--transition-fast);text-decoration:none}.auth-global-footer-link:hover{color:var(--color-primary);text-decoration:underline}@media (width<=768px){.auth-global-footer{padding:var(--spacing-sm) var(--spacing-base)}.auth-global-footer-content{gap:var(--spacing-xs);text-align:center;flex-direction:column}.auth-global-footer-divider{display:none}.auth-global-footer-links{gap:var(--spacing-md)}}.legal-page{background:var(--color-page-bg);min-height:100vh;padding:var(--spacing-lg);flex-direction:column;justify-content:center;align-items:center;padding-bottom:80px;display:flex}.legal-container{width:100%;max-width:800px}.legal-header{margin-bottom:var(--spacing-lg)}.legal-back-link{align-items:center;gap:var(--spacing-sm);color:var(--color-text-secondary);font-size:var(--font-size-sm);transition:color var(--transition-fast);text-decoration:none;display:inline-flex}.legal-back-link:hover{color:var(--color-primary)}.legal-back-link svg{flex-shrink:0}.legal-card{background:var(--color-card-bg);border-radius:var(--radius-lg);padding:var(--spacing-xl);border:1px solid var(--color-border-light)}.legal-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.legal-date{font-size:var(--font-size-sm);color:var(--color-text-tertiary);margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--color-border-light)}.legal-content{color:var(--color-text-primary);line-height:var(--line-height-relaxed)}.legal-section{margin-bottom:var(--spacing-xl)}.legal-section:last-child{margin-bottom:0}.legal-section h2{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-md)}.legal-section p{font-size:var(--font-size-base);color:var(--color-text-secondary);margin-bottom:var(--spacing-md);line-height:var(--line-height-relaxed)}.legal-section ul{margin:0;padding-left:0;list-style:none}.legal-section ul li{padding-left:var(--spacing-lg);margin-bottom:var(--spacing-sm);font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:var(--line-height-relaxed);position:relative}.legal-section ul li:before{content:"•";left:var(--spacing-sm);color:var(--color-primary);font-weight:700;position:absolute}.legal-section ul li strong{color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.help-hero{text-align:center;padding:var(--spacing-lg) 0;margin-bottom:var(--spacing-xl)}.help-hero svg{color:var(--color-primary);margin-bottom:var(--spacing-md)}.help-hero .legal-title{margin-bottom:var(--spacing-sm)}.help-hero .legal-date{border-bottom:none;margin-bottom:0;padding-bottom:0}.help-categories{margin-bottom:var(--spacing-xl)}.help-category{border:1px solid var(--color-border-light);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);background:var(--color-page-bg);overflow:hidden}.help-category:last-child{margin-bottom:0}.help-category-header{width:100%;padding:var(--spacing-md) var(--spacing-lg);cursor:pointer;transition:background-color var(--transition-fast);background:0 0;border:none;justify-content:space-between;align-items:center;display:flex}.help-category-header:hover{background:var(--color-border-light)}.help-category-info{align-items:center;gap:var(--spacing-md);display:flex}.help-category-info svg{color:var(--color-primary);flex-shrink:0}.help-category-title{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.help-category-arrow{color:var(--color-text-tertiary);transition:transform var(--transition-normal);flex-shrink:0}.help-category-arrow.rotated{transform:rotate(180deg)}.help-questions{border-top:1px solid var(--color-border-light)}.help-question{border-bottom:1px solid var(--color-border-light)}.help-question:last-child{border-bottom:none}.help-question-header{width:100%;padding:var(--spacing-md) var(--spacing-lg);cursor:pointer;text-align:left;font-size:var(--font-size-sm);color:var(--color-text-primary);transition:background-color var(--transition-fast);background:0 0;border:none;justify-content:space-between;align-items:center;display:flex}.help-question-header:hover{background:var(--color-border-light)}.help-question-arrow{color:var(--color-text-tertiary);transition:transform var(--transition-normal);flex-shrink:0}.help-question-arrow.rotated{transform:rotate(180deg)}.help-answer{padding:0 var(--spacing-lg) var(--spacing-lg);padding-left:calc(var(--spacing-lg) + 24px)}.help-answer p{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-relaxed);margin:0}.help-contact{text-align:center;padding:var(--spacing-xl);background:var(--color-page-bg);border-radius:var(--radius-md)}.help-contact h2{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.help-contact p{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-lg)}.help-contact-button{padding:var(--spacing-sm) var(--spacing-lg);background:var(--color-primary);color:var(--color-text-inverse);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);transition:background-color var(--transition-fast);justify-content:center;align-items:center;text-decoration:none;display:inline-flex}.help-contact-button:hover{background:var(--color-primary-hover)}@media (width<=768px){.legal-page{padding:var(--spacing-base);padding-bottom:80px}.legal-card{padding:var(--spacing-lg)}.legal-title{font-size:var(--font-size-xl)}.legal-section h2{font-size:var(--font-size-base)}.legal-section p,.legal-section ul li{font-size:var(--font-size-sm)}.help-category-header{padding:var(--spacing-md)}.help-question-header{padding:var(--spacing-sm) var(--spacing-md)}.help-answer{padding:var(--spacing-sm) var(--spacing-md);padding-left:calc(var(--spacing-md) + 24px)}}.card{background:var(--color-card-bg);border-radius:var(--radius-lg);border:1px solid var(--color-border-light);margin-bottom:var(--spacing-base)}.card-header{padding:var(--spacing-lg) var(--spacing-lg) 0;justify-content:space-between;align-items:center;display:flex}.card-header-left{align-items:center;gap:var(--spacing-md);display:flex}.card-icon{width:36px;height:36px;color:var(--color-text-secondary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.card-icon svg{width:22px;height:22px}.card-icon.accent{color:var(--color-primary)}.card-title{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.card-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--spacing-xs)}.card-body{padding:var(--spacing-lg)}.card-body-top{padding:var(--spacing-lg) var(--spacing-lg) 0}.card-body-bottom{padding:0 var(--spacing-lg) var(--spacing-lg)}.card-footer{padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--color-divider);justify-content:flex-end;align-items:center;gap:var(--spacing-sm);display:flex}.card-row{padding:var(--spacing-md) 0;border-bottom:1px solid var(--color-divider);justify-content:space-between;align-items:center;display:flex}.card-row:last-child{border-bottom:none}.card-row-left{flex:1;min-width:0}.card-row-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.card-row-value{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--spacing-xs)}.card-row-right{align-items:center;gap:var(--spacing-sm);flex-shrink:0;display:flex}.page-header{margin-bottom:var(--spacing-xl);justify-content:space-between;align-items:center;display:flex}.page-title{font-size:var(--font-size-xxl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.page-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--spacing-xs)}.page-actions{align-items:center;gap:var(--spacing-sm);display:flex}.section-header{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:var(--spacing-xxl) 0 var(--spacing-base)}.section-header:first-child{margin-top:0}.info-grid{gap:var(--spacing-base);grid-template-columns:1fr 1fr;display:grid}@media (width<=768px){.info-grid{grid-template-columns:1fr}}.info-item{padding:var(--spacing-base);border:1px solid var(--color-border-light);border-radius:var(--radius-md)}.info-item-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);font-weight:var(--font-weight-medium);text-transform:uppercase;letter-spacing:.3px;margin-bottom:var(--spacing-xs)}.info-item-value{font-size:var(--font-size-md);color:var(--color-text-primary);font-weight:var(--font-weight-regular)}.info-item-hint{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:var(--spacing-xs)}.empty-state{text-align:center;padding:var(--spacing-xxxl) var(--spacing-lg);color:var(--color-text-secondary)}.empty-state svg{width:48px;height:48px;margin-bottom:var(--spacing-base);color:var(--color-text-tertiary)}.empty-state-title{font-size:var(--font-size-md);font-weight:var(--font-weight-medium);margin-bottom:var(--spacing-sm)}.empty-state-desc{font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.loading-state{padding:var(--spacing-xxxl);color:var(--color-text-secondary);font-size:var(--font-size-base);justify-content:center;align-items:center;display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-tertiary{color:var(--color-text-tertiary)}.mt-sm{margin-top:var(--spacing-sm)}.mt-base{margin-top:var(--spacing-base)}.mt-lg{margin-top:var(--spacing-lg)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-base{margin-bottom:var(--spacing-base)}.mb-lg{margin-bottom:var(--spacing-lg)}.ml-sm{margin-left:var(--spacing-sm)}.flex-row{align-items:center;gap:var(--spacing-sm);display:flex}.status-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.status-dot.active{background:var(--color-success)}.status-dot.inactive{background:var(--color-text-tertiary)}.status-dot.warning{background:var(--color-warning)}.modal-overlay{z-index:200;padding:var(--spacing-lg);background:#00000059;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--color-card-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:480px;max-height:90vh;overflow-y:auto}.modal-header{padding:var(--spacing-lg) var(--spacing-lg) 0;justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.modal-close{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--color-text-secondary);transition:background var(--transition-fast), color var(--transition-fast);justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--color-sidebar-hover);color:var(--color-text-primary)}.modal-close svg{width:16px;height:16px}.modal-body{padding:var(--spacing-lg)}.modal-footer{padding:0 var(--spacing-lg) var(--spacing-lg);justify-content:flex-end;gap:var(--spacing-sm);display:flex}.table-wrapper{overflow-x:auto}.table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm)}.table th,.table td{text-align:left;padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--color-divider);vertical-align:middle}.table th{font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;background:var(--color-sidebar-bg)}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:var(--color-sidebar-hover)}.table .text-muted{color:var(--color-text-tertiary)}.table .text-sm{font-size:var(--font-size-xs)}.table-actions{align-items:center;gap:var(--spacing-xs);display:flex}.badge{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border-radius:10px;padding:2px 8px;line-height:1.5;display:inline-block}.badge-success{background:var(--color-success-light);color:var(--color-success)}.badge-danger{background:var(--color-danger-light);color:var(--color-danger)}.badge-warning{background:var(--color-warning-light);color:var(--color-warning)}.badge-neutral{background:var(--color-sidebar-hover);color:var(--color-text-secondary)}.admin-toolbar{justify-content:space-between;align-items:center;gap:var(--spacing-base);margin-bottom:var(--spacing-base);flex-wrap:wrap;display:flex}.admin-toolbar-left{align-items:center;gap:var(--spacing-sm);flex-wrap:wrap;display:flex}.admin-toolbar-right{align-items:center;gap:var(--spacing-sm);display:flex}.admin-search{width:240px}.admin-form-grid{gap:var(--spacing-base);grid-template-columns:1fr 1fr;display:grid}@media (width<=600px){.admin-form-grid{grid-template-columns:1fr}}.admin-perm-tree{padding:var(--spacing-sm) 0}.admin-perm-group{margin-bottom:var(--spacing-base)}.admin-perm-group-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-xs);border-bottom:1px solid var(--color-divider)}.admin-perm-items{gap:var(--spacing-xs);grid-template-columns:1fr 1fr;display:grid}@media (width<=600px){.admin-perm-items{grid-template-columns:1fr}}.admin-config-section{margin-bottom:var(--spacing-lg)}.admin-config-section:last-child{margin-bottom:0}.admin-config-section-title{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-base);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-divider)}.pagination{justify-content:center;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-base) 0;display:flex}.pagination-info{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.config-value{font-family:monospace;font-size:var(--font-size-sm);background:var(--color-sidebar-bg);border-radius:var(--radius-sm);word-break:break-all;padding:2px 8px}.oauth-loading{text-align:center;padding:var(--spacing-xl);color:var(--color-text-secondary);font-size:var(--font-size-sm)}.oauth-container{width:100%;max-width:480px}.oauth-error-state{text-align:center;padding:var(--spacing-lg) 0}.oauth-consent-card{background:var(--color-card-bg);border-radius:var(--radius-lg);padding:var(--spacing-xl);border:1px solid var(--color-border-light)}.oauth-consent-header{text-align:center;margin-bottom:var(--spacing-lg)}.oauth-consent-icon{width:48px;height:48px;margin:0 auto var(--spacing-base);color:var(--color-primary);background:var(--color-primary-light);border-radius:50%;justify-content:center;align-items:center;display:flex}.oauth-consent-icon svg{width:24px;height:24px}.oauth-consent-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.oauth-consent-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-base)}.oauth-consent-subtitle strong{color:var(--color-text-primary);font-weight:var(--font-weight-semibold)}.oauth-scopes{margin-bottom:var(--spacing-lg)}.oauth-scopes-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--spacing-md)}.oauth-scopes-list{border:1px solid var(--color-border-light);border-radius:var(--radius-md);margin:0;padding:0;list-style:none;overflow:hidden}.oauth-scope-item{align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-base);border-bottom:1px solid var(--color-divider);display:flex}.oauth-scope-item:last-child{border-bottom:none}.oauth-scope-check{width:20px;height:20px;color:var(--color-success);flex-shrink:0;justify-content:center;align-items:center;margin-top:1px;display:flex}.oauth-scope-check svg{width:16px;height:16px}.oauth-scope-info{flex-direction:column;gap:2px;min-width:0;display:flex}.oauth-scope-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.oauth-scope-desc{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.oauth-privacy-notice{align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--color-primary-light);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);font-size:var(--font-size-xs);color:var(--color-text-secondary);line-height:var(--line-height-relaxed);display:flex}.oauth-privacy-icon{width:16px;height:16px;color:var(--color-primary);flex-shrink:0;justify-content:center;align-items:center;margin-top:1px;display:flex}.oauth-privacy-icon svg{width:14px;height:14px}.oauth-user-info{text-align:center;font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--color-divider)}.oauth-user-info strong{color:var(--color-text-secondary)}.oauth-consent-actions{gap:var(--spacing-sm);display:flex}.oauth-consent-actions .btn{flex:1}.oauth-scope-selector,.oauth-scope-group{margin-bottom:var(--spacing-base)}.oauth-scope-group-header{margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-xs);border-bottom:1px solid var(--color-divider);justify-content:space-between;align-items:center;display:flex}.oauth-scope-group-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.oauth-scope-group-toggle{font-size:var(--font-size-xs);color:var(--color-primary);cursor:pointer;background:0 0;border:none;padding:0}.oauth-scope-group-toggle:hover{text-decoration:underline}.oauth-scope-items{gap:var(--spacing-xs);grid-template-columns:1fr 1fr;display:grid}@media (width<=600px){.oauth-scope-items{grid-template-columns:1fr}}.oauth-scope-checkbox{align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-xs) 0;cursor:pointer;display:flex}.oauth-scope-checkbox input[type=checkbox]{accent-color:var(--color-primary);cursor:pointer;flex-shrink:0;width:16px;height:16px;margin-top:2px}.oauth-scope-checkbox-info{flex-direction:column;gap:1px;min-width:0;display:flex}.oauth-scope-checkbox-label{font-size:var(--font-size-sm);color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.oauth-scope-checkbox-value{font-size:var(--font-size-xs);color:var(--color-text-tertiary);font-family:monospace}.oauth-scope-preview{margin-top:var(--spacing-md);padding:var(--spacing-md);background:var(--color-sidebar-bg);border-radius:var(--radius-sm);font-size:var(--font-size-xs);color:var(--color-text-secondary);word-break:break-all}.oauth-scope-preview-label{font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--spacing-xs);display:block}:root{--color-primary:#2b5c4f;--color-primary-hover:#1e453a;--color-primary-light:#e8f0ed;--color-primary-border:#b8d4ca;--color-topbar-bg:#1b1b1b;--color-page-bg:#f3f3f3;--color-card-bg:#fff;--color-sidebar-bg:#f7f7f7;--color-sidebar-hover:#ebebeb;--color-sidebar-active:#e8f0ed;--color-text-primary:#1b1b1b;--color-text-secondary:#616161;--color-text-tertiary:#a0a0a0;--color-text-inverse:#fff;--color-border:#e0e0e0;--color-border-light:#eee;--color-divider:#e8e8e8;--color-danger:#c62828;--color-danger-hover:#b71c1c;--color-danger-light:#fce8e8;--color-success:#2e7d32;--color-success-light:#e8f5e9;--color-warning:#e65100;--color-warning-light:#fff3e0;--font-family:"Segoe UI", "PingFang SC", "Microsoft YaHei", "Helvetica Neue", Arial, sans-serif;--font-size-xs:12px;--font-size-sm:13px;--font-size-base:14px;--font-size-md:15px;--font-size-lg:18px;--font-size-xl:22px;--font-size-xxl:28px;--font-weight-regular:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--line-height-tight:1.3;--line-height-base:1.5;--line-height-relaxed:1.7;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:12px;--spacing-base:16px;--spacing-lg:24px;--spacing-xl:32px;--spacing-xxl:40px;--spacing-xxxl:48px;--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--shadow-sm:0 1px 2px #0000000a;--shadow-md:0 2px 8px #0000000f;--shadow-lg:0 4px 16px #00000014;--sidebar-width:250px;--sidebar-collapsed-width:60px;--topbar-height:48px;--transition-fast:.15s ease;--transition-normal:.25s ease;--transition-base:.2s ease;--transition-slow:.3s ease}[data-theme=dark]{--color-primary:#4a9b85;--color-primary-hover:#5ab396;--color-primary-light:#1a3d34;--color-primary-border:#2d5a4d;--color-topbar-bg:#0d0d0d;--color-page-bg:#1a1a1a;--color-card-bg:#242424;--color-sidebar-bg:#1e1e1e;--color-sidebar-hover:#2a2a2a;--color-sidebar-active:#1a3d34;--color-text-primary:#f0f0f0;--color-text-secondary:#a0a0a0;--color-text-tertiary:#707070;--color-text-inverse:#fff;--color-border:#3a3a3a;--color-border-light:#2e2e2e;--color-divider:#333;--color-danger:#ef5350;--color-danger-hover:#e57373;--color-danger-light:#3d1f1f;--color-success:#66bb6a;--color-success-light:#1e3d1f;--color-warning:#ffa726;--color-warning-light:#3d2e1f;--shadow-sm:0 1px 2px #0003;--shadow-md:0 2px 8px #0000004d;--shadow-lg:0 4px 16px #0006}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:14px}body{font-family:var(--font-family);font-size:var(--font-size-base);font-weight:var(--font-weight-regular);line-height:var(--line-height-base);color:var(--color-text-primary);background-color:var(--color-page-bg);min-height:100vh;transition:background-color var(--transition-base), color var(--transition-base)}a{color:var(--color-primary);transition:color var(--transition-fast);text-decoration:none}a:hover{text-decoration:underline}ul,ol{list-style:none}img{max-width:100%;display:block}input,button,select,textarea{font-family:inherit;font-size:inherit;transition:background-color var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast)}button{cursor:pointer;background:0 0;border:none}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight)}h1{font-size:var(--font-size-xxl)}h2{font-size:var(--font-size-xl)}h3{font-size:var(--font-size-lg)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}
