body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--color-background:#fff;--color-background-secondary:#f5f5f7;--color-background-tertiary:#fafafa;--color-background-elevated:#fff;--color-background-glass:#ffffffb3;--color-sidebar:#f6f6f8f2;--color-text-primary:#1d1d1f;--color-text-secondary:#6e6e73;--color-text-tertiary:#b3b3b8;--color-text-inverted:#fff;--color-text-muted:#9a9a9f;--color-accent:#007aff;--color-accent-hover:#0051d5;--color-accent-active:#0040a0;--color-accent-light:#e5f2ff;--color-accent-lighter:#f0f7ff;--color-success:#34c759;--color-success-light:#e8f8ec;--color-warning:#ff9500;--color-warning-light:#fff4e5;--color-error:#ff3b30;--color-error-light:#ffebe9;--color-info:#5ac8fa;--color-info-light:#e8f7ff;--gradient-accent:linear-gradient(135deg,#007aff,#0051d5);--gradient-accent-light:linear-gradient(135deg,#5ac8fa,#007aff);--gradient-success:linear-gradient(135deg,#34c759,#28a745);--gradient-warning:linear-gradient(135deg,#ff9500,#f70);--gradient-error:linear-gradient(135deg,#ff3b30,#dc3545);--gradient-subtle:linear-gradient(180deg,#fff0,#f5f5f780);--gradient-card:linear-gradient(135deg,#fff,#fafafa);--gradient-radial:radial-gradient(circle at top left,#007aff1a 0%,#0000 50%);--gradient-mesh:linear-gradient(105deg,#007aff0d,#0000 40%),linear-gradient(225deg,#5ac8fa0d,#0000 40%);--color-border:#e5e5e7;--color-border-light:#f0f0f2;--color-border-dark:#c7c7cc;--shadow-sm:0 1px 3px #0000000f,0 1px 2px #0000000a;--shadow-md:0 2px 8px #00000014,0 4px 6px #0000000a;--shadow-lg:0 4px 16px #00000014,0 8px 24px #0000000a;--shadow-xl:0 8px 32px #00000014,0 16px 48px #0000000f;--shadow-glow:0 0 0 3px #007aff33,0 0 20px #007aff1a;--shadow-inset:inset 0 2px 4px #0000000f;--shadow-button:0 1px 2px #0000000d,0 0 0 1px #0000000d;--shadow-card:0 1px 3px #0000000a,0 2px 8px #0000000a,0 4px 16px #00000005;--shadow-hover:0 4px 12px #00000014,0 8px 24px #0000000a,0 12px 32px #00000005;--shadow-focus:0 0 0 3px #007aff4d,0 0 0 6px #007aff1a;--font-family:-apple-system,BlinkMacSystemFont,"SF Pro Display","SF Pro Text","Helvetica Neue",Helvetica,Arial,sans-serif;--font-family-mono:"SF Mono",Monaco,"Cascadia Code","Roboto Mono",Consolas,monospace;--font-size-xs:11px;--font-size-sm:13px;--font-size-base:15px;--font-size-md:17px;--font-size-lg:22px;--font-size-xl:28px;--font-size-2xl:34px;--font-weight-regular:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--line-height-tight:1.2;--line-height-base:1.5;--line-height-relaxed:1.75;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:12px;--spacing-base:16px;--spacing-lg:20px;--spacing-xl:24px;--spacing-2xl:32px;--spacing-3xl:48px;--spacing-4xl:64px;--radius-sm:4px;--radius-md:6px;--radius-base:8px;--radius-lg:10px;--radius-xl:12px;--radius-2xl:16px;--radius-full:9999px;--sidebar-width:256px;--header-height:52px;--content-max-width:1200px;--transition-fast:150ms cubic-bezier(0.4,0,0.2,1);--transition-base:200ms cubic-bezier(0.4,0,0.2,1);--transition-slow:300ms cubic-bezier(0.4,0,0.2,1);--transition-spring:300ms cubic-bezier(0.68,-0.55,0.265,1.55);--transition-bounce:600ms cubic-bezier(0.68,-0.55,0.265,1.55);--transition-smooth:400ms cubic-bezier(0.23,1,0.32,1);--z-base:1;--z-dropdown:10;--z-sticky:20;--z-overlay:30;--z-modal:40;--z-tooltip:50;--backdrop-blur:blur(20px);--backdrop-blur-heavy:blur(40px)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{0%{transform:translateX(100%)}to{transform:translateX(0)}}@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%}to{background-position:200%}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes typingDots{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-6px)}}.transition-all{transition:all var(--transition-base)}.transition-fast{transition:all var(--transition-fast)}.transition-slow{transition:all var(--transition-slow)}.transition-spring{transition:all var(--transition-spring)}.transition-opacity{transition:opacity var(--transition-base)}.transition-transform{transition:transform var(--transition-base)}.transition-colors{transition:background-color var(--transition-base),color var(--transition-base),border-color var(--transition-base)}.hover-lift{transition:transform var(--transition-base),box-shadow var(--transition-base)}.hover-lift:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.hover-glow{transition:box-shadow var(--transition-base)}.hover-glow:hover{box-shadow:var(--shadow-glow)}.hover-scale{transition:transform var(--transition-base)}.hover-scale:hover{transform:scale(1.02)}.hover-scale:active{transform:scale(.98)}.skeleton{animation:shimmer 1.5s infinite;background:linear-gradient(90deg,var(--color-background-secondary) 25%,var(--color-background-tertiary) 50%,var(--color-background-secondary) 75%);background-size:200% 100%}.fade-enter{animation:fadeIn var(--transition-base) ease-out}.fade-enter-up{animation:fadeInUp var(--transition-base) ease-out}.fade-enter-down{animation:fadeInDown var(--transition-base) ease-out}.slide-left{animation:slideInLeft var(--transition-base) ease-out}.slide-right{animation:slideInRight var(--transition-base) ease-out}.scale-in{animation:scaleIn var(--transition-base) ease-out}.typing-dots{display:flex;gap:4px}.typing-dots span{animation:typingDots 1.4s infinite;background:var(--color-text-secondary);border-radius:50%;height:8px;width:8px}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}.spinner{animation:spin .8s linear infinite;border:2px solid var(--color-border);border-top-color:var(--color-accent);height:20px;width:20px}.pulse{animation:pulse 2s infinite}.bounce{animation:bounce 1s infinite}@keyframes ripple{to{opacity:0;transform:scale(4)}}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{opacity:1;transform:scale(1.05)}70%{transform:scale(.9)}to{transform:scale(1)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes gradientShift{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}@keyframes checkmark{0%{stroke-dashoffset:100}to{stroke-dashoffset:0}}@keyframes shake{0%,to{transform:translateX(0)}10%,30%,50%,70%,90%{transform:translateX(-5px)}20%,40%,60%,80%{transform:translateX(5px)}}@keyframes typingDotsEnhanced{0%,60%,to{opacity:.3;transform:scale(.8) translateY(0)}30%{opacity:1;transform:scale(1) translateY(-10px)}}.ripple-button{overflow:hidden;position:relative}.ripple-button:before{background:#ffffff80;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .6s,height .6s;width:0}.ripple-button:active:before{height:300px;width:300px}.hover-lift-shadow{transition:all var(--transition-base)}.hover-lift-shadow:hover{box-shadow:var(--shadow-xl);transform:translateY(-4px)}.skeleton-enhanced{background:var(--color-background-secondary);overflow:hidden;position:relative}.skeleton-enhanced:after{animation:shimmer 2s infinite;background:linear-gradient(90deg,#fff0,#fff3 20%,#ffffff80 60%,#fff0);bottom:0;content:"";left:0;position:absolute;right:0;top:0;transform:translateX(-100%)}@keyframes focusRing{0%{box-shadow:0 0 0 0 #007aff66}to{box-shadow:0 0 0 4px #007aff00}}.focus-ring:focus{animation:focusRing .4s ease-out;box-shadow:var(--shadow-glow);outline:none}*{box-sizing:border-box;margin:0;padding:0}.sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:15px}body{background:var(--color-background);color:var(--color-text-primary);font-family:var(--font-family);font-size:var(--font-size-base);line-height:var(--line-height-base);overflow:hidden}.app{height:100vh}.app,.app-main{background:var(--color-background);display:flex;overflow:hidden;position:relative}.app-main{flex:1 1;flex-direction:column;margin-left:var(--sidebar-width);transition:margin-left var(--transition-smooth)}.app-content{flex:1 1;overflow-x:hidden;overflow-y:auto}.app-login{align-items:center;background:linear-gradient(135deg,var(--color-background-secondary) 0,var(--color-background) 50%,var(--color-background-secondary) 100%);display:flex;justify-content:center;min-height:100vh;overflow:hidden;position:relative}.app-login:after,.app-login:before{background:var(--gradient-accent);border-radius:50%;content:"";filter:blur(100px);opacity:.1;position:absolute}.app-login:before{animation:float 20s ease-in-out infinite;height:600px;right:-300px;top:-300px;width:600px}.app-login:after{animation:float 25s ease-in-out infinite reverse;bottom:-400px;height:800px;left:-400px;width:800px}.page-header{background:var(--gradient-subtle);border-bottom:2px solid var(--color-border);overflow:hidden;padding:var(--spacing-3xl) var(--spacing-3xl) var(--spacing-2xl);position:relative}.page-header:after{background:var(--gradient-accent);bottom:0;content:"";height:2px;left:0;position:absolute;right:0;transform:scaleX(0);transition:transform var(--transition-slow)}.page-header:hover:after{transform:scaleX(1)}.page-header h1{align-items:center;animation:fadeInDown var(--transition-base);color:var(--color-text-primary);display:inline-flex;font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);gap:var(--spacing-md);margin-bottom:var(--spacing-sm)}.page-header h1:before{content:"🏗️";filter:saturate(.8);font-size:var(--font-size-xl)}.page-subtitle{color:var(--color-text-secondary);font-size:var(--font-size-md)}.standards-page{background:var(--color-background-secondary);min-height:100vh}.standards-toolbar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--color-background);border-bottom:1px solid var(--color-border);box-shadow:0 2px 4px #00000005;display:flex;gap:var(--spacing-base);padding:var(--spacing-xl) var(--spacing-3xl);position:-webkit-sticky;position:sticky;top:0;z-index:var(--z-sticky)}.search-box{flex:1 1;max-width:400px}.search-input{background:var(--color-background);border:2px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-inset);color:var(--color-text-primary);font-size:var(--font-size-base);padding:var(--spacing-md) var(--spacing-base) var(--spacing-md) var(--spacing-3xl);transition:all var(--transition-base);width:100%}.search-box{position:relative}.search-box:before{content:"🔍";font-size:var(--font-size-base);left:var(--spacing-base);opacity:.5;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.search-input:focus{background:var(--color-background);border-color:var(--color-accent);box-shadow:var(--shadow-glow);outline:none}.search-input::placeholder{color:var(--color-text-tertiary)}.category-filter{min-width:200px}.filter-select{-webkit-appearance:none;appearance:none;background:var(--color-background);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg width='14' height='8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='m1 1 6 6 6-6' stroke='%236E6E73' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right var(--spacing-base) center;background-repeat:no-repeat;border:2px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-primary);cursor:pointer;font-size:var(--font-size-base);padding:var(--spacing-md) var(--spacing-base);padding-right:var(--spacing-3xl);transition:all var(--transition-base);width:100%}.filter-select:hover{border-color:var(--color-accent);box-shadow:var(--shadow-sm)}.filter-select:focus{border-color:var(--color-accent);box-shadow:var(--shadow-glow);outline:none}.documents-grid{grid-gap:var(--spacing-xl);animation:fadeIn var(--transition-base);display:grid;gap:var(--spacing-xl);grid-template-columns:repeat(auto-fill,minmax(300px,1fr));padding:var(--spacing-3xl)}.documents-grid .document-card:first-child{animation-delay:.05s}.documents-grid .document-card:nth-child(2){animation-delay:.1s}.documents-grid .document-card:nth-child(3){animation-delay:.15s}.documents-grid .document-card:nth-child(4){animation-delay:.2s}.documents-grid .document-card:nth-child(5){animation-delay:.25s}.documents-grid .document-card:nth-child(6){animation-delay:.3s}.document-card{align-items:center;animation:fadeInUp var(--transition-base);animation-fill-mode:both;background:var(--gradient-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);cursor:pointer;display:flex;flex-direction:column;overflow:hidden;padding:var(--spacing-2xl);position:relative;text-align:center;transition:all var(--transition-base)}.document-card:before{background:var(--gradient-accent);content:"";height:3px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transform-origin:left;transition:transform var(--transition-base)}.document-card:after{background:radial-gradient(circle,var(--color-accent-lighter) 0,#0000 70%);content:"";height:200%;left:-50%;opacity:0;pointer-events:none;position:absolute;top:-50%;transition:opacity var(--transition-base);width:200%}.document-card:hover{border-color:var(--color-accent);box-shadow:0 20px 40px #0000001a;transform:translateY(-8px) scale(1.02)}.document-card:hover:before{transform:scaleX(1)}.document-card:hover:after{opacity:.1}.document-card:active{transform:translateY(-4px) scale(1.01)}.document-icon{filter:drop-shadow(0 4px 8px rgba(0,0,0,.1));font-size:56px;margin-bottom:var(--spacing-base);transition:transform var(--transition-base)}.document-card:hover .document-icon{transform:scale(1.1) rotate(5deg)}.document-card h3{color:var(--color-text-primary);font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);margin-bottom:var(--spacing-sm);transition:color var(--transition-fast)}.document-card:hover h3{color:var(--color-accent)}.document-category{background:var(--color-accent-lighter);border:1px solid var(--color-accent);border-radius:var(--radius-full);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);margin-bottom:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md)}.document-size{color:var(--color-text-tertiary);font-size:var(--font-size-xs)}.empty-state,.loading-state{align-items:center;color:var(--color-text-secondary);display:flex;flex-direction:column;grid-column:1/-1;justify-content:center;padding:var(--spacing-4xl)}.empty-state p,.loading-state p{margin-top:var(--spacing-base)}button{background:none;border:none;font-family:inherit;outline:none}.btn,button{cursor:pointer}.btn{align-items:center;border-radius:var(--radius-md);display:inline-flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:var(--spacing-sm);justify-content:center;padding:var(--spacing-sm) var(--spacing-base);transition:all var(--transition-base)}.btn-primary{background:var(--gradient-accent);box-shadow:var(--shadow-button);color:var(--color-text-inverted);overflow:hidden;position:relative}.btn-primary:hover{box-shadow:var(--shadow-md),var(--shadow-glow);transform:translateY(-2px)}.btn-primary:before{background:#fff3;content:"";height:100%;left:-100%;position:absolute;top:50%;transform:skewX(-45deg) translateY(-50%);transition:left .6s;width:100%}.btn-primary:hover:before{left:100%}.btn-primary:active{background:var(--color-accent-active);transform:translateY(0)}.btn-secondary{background:var(--color-background);border:2px solid var(--color-border);box-shadow:var(--shadow-button);color:var(--color-accent);overflow:hidden;position:relative}.btn-secondary:hover{background:var(--color-accent-lighter);border-color:var(--color-accent);box-shadow:var(--shadow-sm);transform:translateY(-1px)}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-border-dark)}.fade-in{animation:fadeIn var(--transition-base)}.slide-up{animation:fadeInUp var(--transition-base)}.document-skeleton{align-items:center;animation:pulse 1.5s ease-in-out infinite;background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-xl);display:flex;flex-direction:column;padding:var(--spacing-2xl)}.skeleton-icon{background:var(--color-background-secondary);border-radius:var(--radius-lg);height:56px;margin-bottom:var(--spacing-base);overflow:hidden;position:relative;width:56px}.skeleton-title{height:20px;margin-bottom:var(--spacing-sm);width:80%}.skeleton-subtitle,.skeleton-title{background:var(--color-background-secondary);border-radius:var(--radius-sm)}.skeleton-subtitle{height:16px;margin-bottom:var(--spacing-xs);width:60%}.skeleton-meta{background:var(--color-background-secondary);border-radius:var(--radius-sm);height:14px;width:40%}.fab{align-items:center;background:var(--gradient-accent);border-radius:var(--radius-full);bottom:var(--spacing-2xl);box-shadow:var(--shadow-lg);color:var(--color-text-inverted);cursor:pointer;display:flex;height:56px;justify-content:center;position:fixed;right:var(--spacing-2xl);transition:all var(--transition-base);width:56px;z-index:var(--z-sticky)}.fab:hover{box-shadow:var(--shadow-xl),var(--shadow-glow);transform:scale(1.1) rotate(90deg)}.fab:active{transform:scale(.95)}@media (max-width:768px){.app-main{margin-left:0}.documents-grid,.page-header,.standards-toolbar{padding-left:var(--spacing-base);padding-right:var(--spacing-base)}.documents-grid{gap:var(--spacing-base);grid-template-columns:1fr}.standards-toolbar{flex-direction:column;position:static}.search-box{max-width:none}.document-card{padding:var(--spacing-xl)}.fab{bottom:var(--spacing-xl);height:48px;right:var(--spacing-xl);width:48px}}.mobile-logout-btn{align-items:center;background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-lg);bottom:var(--spacing-base);box-shadow:var(--shadow-lg);color:var(--color-text-secondary);cursor:pointer;display:none;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:var(--spacing-sm);left:var(--spacing-base);padding:var(--spacing-sm) var(--spacing-base);position:fixed;transition:all var(--transition-fast);z-index:calc(var(--z-sticky) + 1)}.mobile-logout-btn:hover{background:var(--color-error-light);border-color:var(--color-error);box-shadow:var(--shadow-xl);color:var(--color-error);transform:translateY(-2px)}.mobile-logout-btn svg{height:18px;width:18px}@media (max-width:768px){.mobile-logout-btn{display:flex}}.sidebar{backdrop-filter:var(--backdrop-blur-heavy) saturate(180%);-webkit-backdrop-filter:var(--backdrop-blur-heavy) saturate(180%);background:#ffffffd9;border-right:1px solid #0000001a;box-shadow:2px 0 20px #0000000d,inset -1px 0 0 #ffffff80;display:flex;flex-direction:column;height:100vh;left:0;position:fixed;top:0;transition:transform var(--transition-smooth);width:var(--sidebar-width);z-index:var(--z-sticky)}.sidebar-header{border-bottom:1px solid var(--color-border);padding:var(--spacing-lg) var(--spacing-base)}.app-logo{align-items:center;cursor:pointer;display:flex;gap:var(--spacing-md);transition:transform var(--transition-base)}.app-logo:hover{transform:scale(1.02)}.logo-icon{align-items:center;background:var(--gradient-accent);border-radius:var(--radius-md);box-shadow:var(--shadow-md);color:#fff;display:flex;height:40px;justify-content:center;overflow:hidden;position:relative;width:40px}.logo-icon:after{background:linear-gradient(45deg,#0000 30%,#ffffff4d 50%,#0000 70%);content:"";height:200%;left:-50%;position:absolute;top:-50%;transform:rotate(45deg) translateX(-100%);transition:transform .6s;width:200%}.app-logo:hover .logo-icon:after{transform:rotate(45deg) translateX(100%)}.app-logo h1{color:var(--color-text-primary);font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);margin:0}.sidebar-search{padding:var(--spacing-base)}.search-trigger{align-items:center;background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;display:flex;font-size:var(--font-size-sm);gap:var(--spacing-sm);overflow:hidden;padding:var(--spacing-sm) var(--spacing-md);position:relative;transition:all var(--transition-base);width:100%}.search-trigger:hover{background:var(--color-accent-lighter);border-color:var(--color-accent);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.search-trigger:active{box-shadow:none;transform:translateY(0)}.search-trigger kbd{background:var(--color-background-secondary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-family:var(--font-family-mono);font-size:var(--font-size-xs);margin-left:auto;padding:2px 6px}.sidebar-nav{flex:1 1;overflow-y:auto;padding:var(--spacing-sm) 0}.nav-section{margin-bottom:var(--spacing-base)}.section-header{align-items:center;background:none;border:none;color:var(--color-text-secondary);cursor:pointer;display:flex;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);justify-content:space-between;letter-spacing:.06em;padding:var(--spacing-sm) var(--spacing-base);text-transform:uppercase;transition:var(--transition-fast);width:100%}.section-header:hover{color:var(--color-text-primary)}.nav-items{padding:var(--spacing-xs) 0}.nav-item{align-items:center;border-radius:var(--radius-md);color:var(--color-text-primary);display:flex;font-size:var(--font-size-sm);gap:var(--spacing-md);margin:0 var(--spacing-sm) var(--spacing-xs);overflow:hidden;padding:var(--spacing-sm) var(--spacing-base);position:relative;text-decoration:none;transition:all var(--transition-fast)}.nav-item:hover{background:var(--color-background-secondary);transform:translateX(4px)}.nav-item:before{background:var(--gradient-accent);bottom:0;content:"";left:0;position:absolute;top:0;transform:scaleY(0);transition:transform var(--transition-fast);width:3px}.nav-item:hover:before{transform:scaleY(1)}.nav-item.active{background:var(--gradient-accent);box-shadow:var(--shadow-md);color:var(--color-text-inverted);transform:translateX(2px)}.nav-item.active:before{background:#fff;opacity:.3;transform:scaleY(1)}.nav-item.active svg{color:var(--color-text-inverted)}.nav-item svg{color:var(--color-text-secondary);transition:var(--transition-fast)}.sidebar-footer{background:var(--color-background);border-top:1px solid var(--color-border);padding:var(--spacing-base)}.user-info{gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.user-avatar,.user-info{align-items:center;display:flex}.user-avatar{background:var(--gradient-accent);border:2px solid var(--color-accent);border-radius:50%;box-shadow:var(--shadow-sm);color:var(--color-text-inverted);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);height:36px;justify-content:center;transition:all var(--transition-fast);width:36px}.user-info:hover .user-avatar{box-shadow:var(--shadow-md);transform:scale(1.1)}.user-details{flex:1 1}.user-name{color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);line-height:1.2}.user-role{color:var(--color-text-secondary);font-size:var(--font-size-xs)}.sidebar-actions{display:flex;gap:var(--spacing-sm)}.sidebar-action{align-items:center;background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;display:flex;height:36px;justify-content:center;overflow:hidden;position:relative;transition:all var(--transition-fast);width:36px}.sidebar-action:hover{background:var(--color-accent-lighter);border-color:var(--color-accent);box-shadow:var(--shadow-sm);color:var(--color-accent);transform:translateY(-2px)}.sidebar-action:active{box-shadow:none;transform:translateY(0)}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-track{background:#0000}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:var(--color-border-dark)}.mobile-menu-toggle{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-full);box-shadow:var(--shadow-lg);cursor:pointer;display:none;height:44px;left:var(--spacing-base);position:fixed;top:var(--spacing-base);transition:all var(--transition-fast);width:44px;z-index:calc(var(--z-sticky) + 1)}.mobile-menu-toggle:hover{background:var(--color-accent-lighter);border-color:var(--color-accent);transform:scale(1.1)}@media (max-width:768px){.mobile-menu-toggle{align-items:center;display:flex;justify-content:center}.sidebar{box-shadow:0 0 50px #0003;transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.sidebar-overlay{background:#0000004d;bottom:0;display:none;left:0;opacity:0;position:fixed;right:0;top:0;transition:opacity var(--transition-base);z-index:calc(var(--z-sticky) - 1)}.sidebar-overlay.active{display:block;opacity:1}}.api-key-login{align-items:center;background:linear-gradient(135deg,var(--color-background-secondary) 0,var(--color-background) 50%,var(--color-background-secondary) 100%);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:var(--spacing-xl);position:relative}.api-key-login:after,.api-key-login:before{background:var(--gradient-accent);border-radius:50%;content:"";filter:blur(100px);opacity:.1;pointer-events:none;position:absolute;z-index:0}.api-key-login:before{animation:float 20s ease-in-out infinite;height:600px;right:-300px;top:-300px;width:600px}.api-key-login:after{animation:float 25s ease-in-out infinite reverse;bottom:-400px;height:800px;left:-400px;width:800px}.login-container{animation:bounceIn var(--transition-bounce);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);background:#fffffff2;border-radius:var(--radius-2xl);box-shadow:0 20px 60px #0000001a,0 0 0 1px var(--color-border),inset 0 0 0 1px #ffffff80;max-width:420px;width:100%;z-index:1}.login-container,.login-header{overflow:hidden;position:relative}.login-header{background:var(--gradient-accent);color:var(--color-text-inverted);padding:var(--spacing-3xl) var(--spacing-2xl) var(--spacing-xl);text-align:center}.login-header:after{animation:gradientShift 10s linear infinite;background:linear-gradient(45deg,#ffffff1a 25%,#0000 0,#0000 75%,#ffffff1a 0);background-size:30px 30px;bottom:0;content:"";left:0;opacity:.2;position:absolute;right:0;top:0}.login-header h1{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);margin:0 0 var(--spacing-sm);position:relative;text-shadow:0 2px 10px #0000001a;z-index:1}.login-header p{font-size:var(--font-size-base);margin:0;opacity:.9}.login-mode-toggle{padding:0 var(--spacing-xl);transform:translateY(-50%)}.login-mode-toggle,.mode-btn{display:flex;gap:var(--spacing-sm)}.mode-btn{-webkit-tap-highlight-color:transparent;align-items:center;-webkit-appearance:none;appearance:none;background:var(--color-background);border:2px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-button);color:var(--color-text-secondary);cursor:pointer;flex:1 1;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);justify-content:center;min-height:44px;overflow:hidden;padding:var(--spacing-md) var(--spacing-base);position:relative;touch-action:manipulation;transition:all var(--transition-base);-webkit-user-select:none;user-select:none;z-index:5}.mode-btn:hover{background:var(--color-accent-lighter);border-color:var(--color-accent);box-shadow:var(--shadow-md);color:var(--color-accent);transform:translateY(-2px)}.mode-btn:before{background:var(--color-accent-light);border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .6s,height .6s;width:0}.mode-btn:active:before{height:200px;width:200px}.mode-btn.active{background:var(--gradient-accent);border-color:var(--color-accent);box-shadow:var(--shadow-md),var(--shadow-glow);transform:translateY(-1px)}.mode-btn.active,.mode-btn.active svg{color:var(--color-text-inverted)}.login-form{padding:var(--spacing-xl) var(--spacing-2xl) var(--spacing-2xl)}.form-group{margin-bottom:var(--spacing-xl)}.form-group label{align-items:center;color:var(--color-text-primary);display:flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.form-group label svg{color:var(--color-text-secondary)}.form-group input{-webkit-tap-highlight-color:transparent;-webkit-appearance:none;appearance:none;background:var(--color-background);border:2px solid var(--color-border);border-radius:var(--radius-base);box-shadow:var(--shadow-inset);color:var(--color-text-primary);font-family:var(--font-family-mono);font-size:var(--font-size-base);min-height:44px;padding:var(--spacing-md) var(--spacing-base);transition:all var(--transition-base);width:100%}.form-group input:focus{background:var(--color-background);border-color:var(--color-accent);box-shadow:var(--shadow-glow),var(--shadow-md);outline:none;transform:scale(1.01)}.form-group input::placeholder{color:var(--color-text-tertiary);font-family:var(--font-family)}.form-group input:disabled{cursor:not-allowed;opacity:.6}.form-group small{color:var(--color-text-secondary);display:block;font-size:var(--font-size-xs);margin-top:var(--spacing-xs)}.error-message{animation:shake .5s ease-in-out;background:var(--color-error-light);border:1px solid var(--color-error);border-radius:var(--radius-md);color:var(--color-error);font-size:var(--font-size-sm);margin-bottom:var(--spacing-base);padding:var(--spacing-md) var(--spacing-base) var(--spacing-md) var(--spacing-3xl);position:relative}.error-message:before{content:"⚠️";font-size:var(--font-size-lg);left:var(--spacing-base);position:absolute;top:50%;transform:translateY(-50%)}.login-btn{-webkit-tap-highlight-color:transparent;align-items:center;-webkit-appearance:none;appearance:none;background:var(--gradient-accent);border:none;border-radius:var(--radius-base);box-shadow:var(--shadow-md);color:var(--color-text-inverted);cursor:pointer;display:flex;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);gap:var(--spacing-sm);justify-content:center;letter-spacing:.05em;min-height:48px;overflow:hidden;padding:var(--spacing-md) var(--spacing-lg);position:relative;text-transform:uppercase;touch-action:manipulation;transition:all var(--transition-base);-webkit-user-select:none;user-select:none;width:100%}.login-btn:hover:not(:disabled){box-shadow:var(--shadow-lg),var(--shadow-glow);transform:translateY(-2px)}.login-btn:before{background:#fff3;content:"";height:100%;left:-100%;position:absolute;top:50%;transform:skewX(-45deg) translateY(-50%);transition:left .6s;width:100%}.login-btn:hover:before{left:100%}.login-btn:active:not(:disabled){background:var(--color-accent-active);transform:translateY(0)}.login-btn:disabled{cursor:not-allowed;opacity:.6}.login-footer{background:var(--gradient-subtle);border-top:1px solid var(--color-border);padding:var(--spacing-xl);position:relative;text-align:center}.login-footer p{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin:0}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.login-btn:disabled svg{animation:rotate 1s linear infinite}@keyframes successPulse{0%{box-shadow:0 0 0 0 var(--color-success)}to{box-shadow:0 0 0 10px #34c75900}}.login-success{animation:successPulse .5s ease-out}.login-btn.loading{color:#0000}.login-btn.loading:after{animation:spin .8s linear infinite;border:2px solid var(--color-text-inverted);border-radius:50%;border-top:2px solid #0000;content:"";height:20px;left:50%;margin-left:-10px;margin-top:-10px;position:absolute;top:50%;width:20px}@media (max-width:768px){.api-key-login{min-height:100vh;min-height:100dvh;padding:var(--spacing-base)}.login-container{border-radius:var(--radius-lg);margin:0;max-width:100%;transform:translateZ(0)}.login-header{padding:var(--spacing-2xl) var(--spacing-base) var(--spacing-lg)}.login-form{padding:var(--spacing-lg) var(--spacing-base) var(--spacing-base)}.form-group input{font-size:16px!important;padding:var(--spacing-lg) var(--spacing-base);position:relative;-webkit-user-select:text;user-select:text;z-index:10}.login-btn{font-size:var(--font-size-lg);min-height:56px;padding:var(--spacing-lg)}.mode-btn{font-size:var(--font-size-base);min-height:48px;padding:var(--spacing-lg) var(--spacing-sm)}}@supports (-webkit-touch-callout:none){.form-group input{-webkit-appearance:none;border-radius:0}.login-btn{-webkit-appearance:none;border-radius:var(--radius-base)}}.error-boundary{align-items:center;background-color:#f5f5f5;display:flex;justify-content:center;min-height:100vh;padding:20px}.error-container{background:#fff;border-radius:8px;box-shadow:0 4px 6px #0000001a;max-width:500px;padding:40px;text-align:center;width:100%}.error-icon{font-size:48px;margin-bottom:20px}.error-boundary h1{color:#333;font-size:24px;font-weight:600;margin-bottom:16px}.error-message{color:#666;font-size:16px;line-height:1.6;margin-bottom:30px}.error-details{background:#f8f8f8;border:1px solid #e0e0e0;border-radius:4px;margin-bottom:24px;padding:16px;text-align:left}.error-details summary{color:#666;cursor:pointer;font-size:14px;margin-bottom:12px}.error-details pre{word-wrap:break-word;color:#d73a49;font-size:12px;margin:8px 0;overflow-x:auto;white-space:pre-wrap}.error-actions{display:flex;gap:12px;justify-content:center}.error-actions button{border:none;border-radius:4px;cursor:pointer;font-size:16px;padding:10px 24px;transition:all .2s ease}.btn-primary{background-color:#007bff;color:#fff}.btn-primary:hover{background-color:#0056b3}.btn-secondary{background-color:#f0f0f0;color:#333}.btn-secondary:hover{background-color:#e0e0e0}@media (max-width:600px){.error-container{padding:24px}.error-actions{flex-direction:column;width:100%}.error-actions button{width:100%}}.loading-spinner-container{align-items:center;display:flex;justify-content:center;min-height:200px;padding:40px}.loading-spinner-container.fullscreen{background-color:#ffffffe6;bottom:0;left:0;min-height:100vh;position:fixed;right:0;top:0;z-index:9999}.loading-spinner{text-align:center}.spinner{animation:spin 1s linear infinite;border:3px solid #f3f3f3;border-radius:50%;border-top-color:#007bff;display:inline-block;height:40px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-message{color:#666;font-size:14px;font-weight:500;margin-top:16px}@media (max-width:600px){.loading-spinner-container{padding:20px}}
/*# sourceMappingURL=main.5c09a8db.css.map*/