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;--breakpoint-xs:480px;--breakpoint-sm:640px;--breakpoint-md:768px;--breakpoint-lg:1024px;--breakpoint-xl:1280px;--breakpoint-2xl:1536px;--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);--surface-primary:var(--color-background);--surface-secondary:var(--color-background-secondary);--surface-tertiary:var(--color-background-tertiary);--surface-elevated:var(--color-background-elevated);--text-primary:var(--color-text-primary);--text-secondary:var(--color-text-secondary);--text-tertiary:var(--color-text-tertiary);--text-quaternary:var(--color-text-muted);--border-primary:var(--color-border);--border-secondary:var(--color-border-light);--accent-color:var(--color-accent);--accent-color-hover:var(--color-accent-hover);--accent-color-10:var(--color-accent-lighter);--backdrop-overlay:#00000080}[data-theme=dark]{--color-background:#1c1c1e;--color-background-secondary:#2c2c2e;--color-background-tertiary:#252527;--color-background-elevated:#2c2c2e;--color-background-glass:#1c1c1eb3;--color-sidebar:#262628f2;--color-text-primary:#fff;--color-text-secondary:#a1a1a6;--color-text-tertiary:#6c6c70;--color-text-inverted:#1d1d1f;--color-text-muted:#8e8e93;--color-accent:#0a84ff;--color-accent-hover:#409cff;--color-accent-active:#06c;--color-accent-light:#0a84ff33;--color-accent-lighter:#0a84ff1a;--color-success:#30d158;--color-success-light:#30d15833;--color-warning:#ff9f0a;--color-warning-light:#ff9f0a33;--color-error:#ff453a;--color-error-light:#ff453a33;--color-info:#64d2ff;--color-info-light:#64d2ff33;--gradient-accent:linear-gradient(135deg,#0a84ff,#06c);--gradient-accent-light:linear-gradient(135deg,#64d2ff,#0a84ff);--gradient-subtle:linear-gradient(180deg,#2c2c2e00,#26262880);--gradient-card:linear-gradient(135deg,#2c2c2e,#252527);--gradient-radial:radial-gradient(circle at top left,#0a84ff26 0%,#0000 50%);--gradient-mesh:linear-gradient(105deg,#0a84ff1a,#0000 40%),linear-gradient(225deg,#64d2ff1a,#0000 40%);--color-border:#38383a;--color-border-light:#2c2c2e;--color-border-dark:#48484a;--shadow-sm:0 1px 3px #0000004d,0 1px 2px #0003;--shadow-md:0 2px 8px #0006,0 4px 6px #0003;--shadow-lg:0 4px 16px #0006,0 8px 24px #0000004d;--shadow-xl:0 8px 32px #00000080,0 16px 48px #0000004d;--shadow-glow:0 0 0 3px #0a84ff4d,0 0 20px #0a84ff33;--shadow-inset:inset 0 2px 4px #0000004d;--shadow-button:0 1px 2px #0003,0 0 0 1px #ffffff0d;--shadow-card:0 1px 3px #0000004d,0 2px 8px #0003;--shadow-hover:0 4px 12px #0006,0 8px 24px #0000004d;--shadow-focus:0 0 0 3px #0a84ff66,0 0 0 6px #0a84ff33}[data-contrast=high]{--color-text-primary:#000;--color-text-secondary:#333;--color-border:#000;--color-accent:#0050aa}[data-theme=dark][data-contrast=high]{--color-text-primary:#fff;--color-text-secondary:#e5e5e5;--color-border:#fff;--color-accent:#5ac8fa}[data-accent=purple]{--color-accent:#5856d6;--color-accent-hover:#4a48c0;--color-accent-active:#3e3ca0;--color-accent-light:#ebe9ff;--color-accent-lighter:#f5f4ff;--gradient-accent:linear-gradient(135deg,#5856d6,#4a48c0)}[data-accent=green]{--color-accent:#34c759;--color-accent-hover:#28a745;--color-accent-active:#1e8635;--color-accent-light:#e8f8ec;--color-accent-lighter:#f3fcf5;--gradient-accent:linear-gradient(135deg,#34c759,#28a745)}[data-accent=orange]{--color-accent:#ff9500;--color-accent-hover:#e68600;--color-accent-active:#c70;--color-accent-light:#fff4e5;--color-accent-lighter:#fffaf0;--gradient-accent:linear-gradient(135deg,#ff9500,#e68600)}[data-theme=dark][data-accent=purple]{--color-accent:#bf5af2;--color-accent-hover:#d06bff;--color-accent-active:#a040d0;--color-accent-light:#bf5af233;--color-accent-lighter:#bf5af21a}[data-theme=dark][data-accent=green]{--color-accent:#30d158;--color-accent-hover:#40e968;--color-accent-active:#20b040;--color-accent-light:#30d15833;--color-accent-lighter:#30d1581a}[data-theme=dark][data-accent=orange]{--color-accent:#ff9f0a;--color-accent-hover:#ffb340;--color-accent-active:#e68600;--color-accent-light:#ff9f0a33;--color-accent-lighter:#ff9f0a1a}[data-font-size=small]{--font-size-xs:10px;--font-size-sm:12px;--font-size-base:14px;--font-size-md:16px;--font-size-lg:20px;--font-size-xl:26px;--font-size-2xl:32px}[data-font-size=large]{--font-size-xs:12px;--font-size-sm:14px;--font-size-base:16px;--font-size-md:18px;--font-size-lg:24px;--font-size-xl:30px;--font-size-2xl:36px}[data-compact=true]{--spacing-xs:2px;--spacing-sm:4px;--spacing-md:8px;--spacing-base:12px;--spacing-lg:16px;--spacing-xl:20px;--spacing-2xl:24px;--spacing-3xl:32px;--spacing-4xl:48px}[data-sidebar=right]{--sidebar-position:right}[data-sidebar=left]{--sidebar-position:left}@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{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,.main-content{background:var(--color-background);display:flex;overflow:hidden;position:relative}.main-content{flex:1 1;flex-direction:column;margin-left:var(--sidebar-width);min-height:100vh;transition:margin-left var(--transition-smooth)}[data-sidebar=right] .main-content{margin-left:0;margin-right:var(--sidebar-width)}[data-sidebar=right] .sidebar{border-left:1px solid var(--color-border);border-right:none;left:auto;right:0}.app-content{flex:1 1;overflow-x:hidden;overflow-y:auto}.app-login{align-items:center;background:var(--gradient-mesh),var(--color-background);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);font-size:var(--font-size-base);padding:var(--spacing-md) var(--spacing-base) var(--spacing-md) var(--spacing-3xl);transition:all var(--transition-base)}.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}.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){.main-content{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}}.toast{align-items:center;animation:slideIn .3s ease-out;background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm);max-width:500px;min-width:300px;padding:var(--spacing-md);transition:all .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.toast.removing{animation:slideOut .3s ease-out forwards}@keyframes slideOut{0%{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(100%)}}.toast-success{background:var(--color-success-light);border-color:var(--color-success)}.toast-success .toast-icon{color:var(--color-success)}.toast-error{background:var(--color-error-light);border-color:var(--color-error)}.toast-error .toast-icon{color:var(--color-error)}.toast-warning{background:var(--color-warning-light);border-color:var(--color-warning)}.toast-warning .toast-icon{color:var(--color-warning)}.toast-info{background:var(--color-info-light);border-color:var(--color-info)}.toast-info .toast-icon{color:var(--color-info)}.toast-icon{align-items:center;display:flex;flex-shrink:0;justify-content:center}.toast-message{color:var(--color-text-primary);flex:1 1;font-size:var(--font-size-sm);line-height:1.5;word-break:break-word}.toast-close{align-items:center;background:#0000;border:none;border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;display:flex;flex-shrink:0;height:24px;justify-content:center;padding:0;transition:all var(--transition-fast);width:24px}.toast-close:hover{background:var(--color-background-secondary);color:var(--color-text-primary)}@media (max-width:768px){.toast{margin-right:var(--spacing-md);max-width:calc(100vw - var(--spacing-lg)*2);min-width:250px}.toast,.toast-message{font-size:var(--font-size-xs)}}.toast-container{pointer-events:none;position:fixed;right:var(--spacing-lg);top:var(--spacing-lg);z-index:var(--z-tooltip)}.toast-container>*{pointer-events:auto}@media (max-width:768px){.toast-container{left:var(--spacing-md);right:var(--spacing-md);top:var(--spacing-md)}}.chat-history{background:var(--color-sidebar);display:flex;flex-direction:column;height:100%;overflow:hidden}.chat-history-header{background:#0000;border-bottom:1px solid var(--color-border);padding:var(--spacing-sm) var(--spacing-base)}.chat-history-header h3{color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);letter-spacing:.06em;margin:0;text-transform:uppercase}.chat-history-search{border-bottom:1px solid var(--color-border);padding:var(--spacing-sm) var(--spacing-base)}.search-input-wrapper{align-items:center;background:var(--color-background-secondary);border:1px solid #0000;border-radius:var(--radius-md);display:flex;position:relative;transition:all var(--transition-fast)}.search-input-wrapper.focused{border-color:var(--color-accent);box-shadow:0 0 0 3px rgba(var(--color-accent-rgb),.1)}.search-icon{color:var(--color-text-tertiary);left:var(--spacing-sm);pointer-events:none;position:absolute}.search-input{background:#0000;border:none;color:var(--color-text-primary);font-size:var(--font-size-sm);outline:none;padding:var(--spacing-sm) var(--spacing-lg);padding-left:calc(var(--spacing-sm) + 20px);width:100%}.search-input::placeholder{color:var(--color-text-tertiary)}.search-clear{align-items:center;background:var(--color-background);border:none;border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;display:flex;height:20px;justify-content:center;padding:0;position:absolute;right:var(--spacing-sm);transition:all var(--transition-fast);width:20px}.search-clear:hover{background:var(--color-background-hover);color:var(--color-text-primary)}.search-results-count{color:var(--color-text-secondary);font-size:var(--font-size-xs);margin-top:var(--spacing-xs);text-align:center}.search-highlight{background:var(--color-warning-light);border-radius:2px;color:var(--color-text-primary);font-weight:var(--font-weight-medium);padding:0 2px}.chat-history-item.active .search-highlight{background:#ffffff4d;color:var(--color-text-inverted)}.chat-history-empty.search-empty{animation:fadeIn var(--transition-medium)}.chat-history-list{flex:1 1;overflow-y:auto;padding:var(--spacing-sm) 0;scroll-behavior:smooth}.chat-history-loading{align-items:center;color:var(--color-text-secondary);display:flex;flex-direction:column;gap:var(--spacing-md);justify-content:center;padding:var(--spacing-xl)}.spinner{animation:spin .8s linear infinite;border:2px solid var(--color-border);border-top-color:var(--color-accent);height:24px;width:24px}.chat-history-error{color:var(--color-error);font-size:var(--font-size-sm);padding:var(--spacing-md);text-align:center}.chat-history-empty{align-items:center;color:var(--color-text-secondary);display:flex;flex-direction:column;gap:var(--spacing-sm);justify-content:center;padding:var(--spacing-xl);text-align:center}.chat-history-empty svg{color:var(--color-text-tertiary)}.chat-history-empty p{font-size:var(--font-size-md);font-weight:var(--font-weight-medium);margin:0}.chat-history-empty span{color:var(--color-text-tertiary);font-size:var(--font-size-sm)}.chat-history-item{align-items:flex-start;border-radius:var(--radius-md);cursor:pointer;display:flex;justify-content:space-between;margin:0 var(--spacing-sm) var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-base);position:relative;transition:all var(--transition-fast)}.chat-history-item:hover{background:var(--color-background-secondary);transform:translateX(4px)}.chat-history-item.active{background:var(--gradient-accent);box-shadow:var(--shadow-md)}.chat-history-item.active,.chat-history-item.active .chat-history-item-footer span,.chat-history-item.active .chat-history-item-summary,.chat-history-item.active .chat-history-item-title,.chat-history-item.active svg{color:var(--color-text-inverted)}.chat-history-item-content{flex:1 1;min-width:0}.chat-history-item-header{align-items:center;display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.chat-history-item-header svg{color:var(--color-text-secondary);flex-shrink:0}.chat-history-item-title{color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-history-item-summary{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:var(--color-text-secondary);display:-webkit-box;font-size:var(--font-size-xs);line-height:1.4;margin:0;overflow:hidden}.chat-history-item-footer{align-items:center;display:flex;gap:var(--spacing-xs);margin-top:var(--spacing-xs)}.chat-history-item-footer span,.chat-history-item-footer svg{color:var(--color-text-tertiary)}.chat-history-item-footer span{font-size:var(--font-size-xs)}.chat-history-item-actions{position:relative}.chat-history-menu-btn{align-items:center;background:#0000;border:none;border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;display:none;height:28px;justify-content:center;transition:all var(--transition-fast);width:28px}.chat-history-item.active .chat-history-menu-btn,.chat-history-item:hover .chat-history-menu-btn{display:flex}.chat-history-menu-btn:hover{background:var(--color-background);color:var(--color-text-primary)}.chat-history-item.active .chat-history-menu-btn{color:var(--color-text-inverted)}.chat-history-item.active .chat-history-menu-btn:hover{background:#fff3}.chat-history-menu{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);margin-top:var(--spacing-xs);min-width:120px;overflow:hidden;position:absolute;right:0;top:100%;z-index:var(--z-dropdown)}.chat-history-menu-item{align-items:center;background:none;border:none;color:var(--color-text-primary);cursor:pointer;display:flex;font-size:var(--font-size-sm);gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);transition:all var(--transition-fast);width:100%}.chat-history-menu-item:hover{background:var(--color-background-secondary)}.chat-history-menu-item.delete{color:var(--color-error)}.chat-history-menu-item.delete:hover{background:var(--color-error-light)}.chat-history-edit-wrapper{align-items:center;display:flex;flex:1 1;gap:var(--spacing-xs);min-width:0}.chat-history-edit-input{background:var(--color-background);border:1px solid var(--color-accent);border-radius:var(--radius-sm);color:var(--color-text-primary);flex:1 1;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);min-width:0;outline:none;padding:var(--spacing-xs) var(--spacing-sm);transition:all var(--transition-fast)}.chat-history-edit-input:focus{box-shadow:0 0 0 2px rgba(var(--color-accent-rgb),.2)}.chat-history-edit-input:disabled{cursor:not-allowed;opacity:.6}.chat-history-item.active .chat-history-edit-input{background:#ffffffe6;color:var(--color-text-primary)}.chat-history-edit-actions{display:flex;gap:var(--spacing-xs)}.chat-history-edit-btn{align-items:center;background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;display:flex;height:24px;justify-content:center;padding:0;transition:all var(--transition-fast);width:24px}.chat-history-edit-btn:hover:not(:disabled){transform:scale(1.1)}.chat-history-edit-btn:disabled{cursor:not-allowed;opacity:.5}.chat-history-edit-btn.save{border-color:var(--color-success);color:var(--color-success)}.chat-history-edit-btn.save:hover:not(:disabled){background:var(--color-success);color:var(--color-text-inverted)}.chat-history-edit-btn.cancel{color:var(--color-text-secondary)}.chat-history-edit-btn.cancel:hover:not(:disabled){background:var(--color-background-secondary);color:var(--color-text-primary)}.chat-history-item.active .chat-history-edit-btn{background:#ffffffe6}.mini-spinner{animation:spin .6s linear infinite;border:2px solid var(--color-border);border-radius:50%;border-top-color:var(--color-success);height:12px;width:12px}.chat-history-load-more{border-top:1px solid var(--color-border);padding:var(--spacing-md) var(--spacing-base)}.load-more-btn{align-items:center;background:var(--color-background-secondary);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);font-weight:var(--font-weight-medium);gap:var(--spacing-sm);justify-content:center;padding:var(--spacing-sm) var(--spacing-md);transition:all var(--transition-fast);width:100%}.load-more-btn:hover:not(:disabled){background:var(--color-background-hover);border-color:var(--color-accent);box-shadow:var(--shadow-sm);color:var(--color-text-primary);transform:translateY(-1px)}.load-more-btn:disabled{cursor:not-allowed;opacity:.6}.load-more-btn .conversation-count{color:var(--color-text-tertiary);font-size:var(--font-size-xs);font-weight:var(--font-weight-normal)}.spinner-small{animation:spin .8s linear infinite;border:2px solid var(--color-border);border-radius:50%;border-top-color:var(--color-accent);height:16px;width:16px}.chat-history-list::-webkit-scrollbar{width:6px}.chat-history-list::-webkit-scrollbar-track{background:#0000}.chat-history-list::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.chat-history-list::-webkit-scrollbar-thumb:hover{background:var(--color-border-dark)}@media (max-width:768px){.chat-history{margin:var(--spacing-sm) 0}.chat-history-header{padding:var(--spacing-sm) var(--spacing-base)}.chat-history-search{padding:var(--spacing-xs) var(--spacing-sm)}.search-input{padding:var(--spacing-xs) var(--spacing-md);padding-left:calc(var(--spacing-xs) + 20px)}.chat-history-edit-input,.search-input,.search-input::placeholder{font-size:var(--font-size-xs)}.chat-history-edit-input{padding:var(--spacing-xs)}.chat-history-edit-btn{height:20px;width:20px}.chat-history-load-more{padding:var(--spacing-sm)}.load-more-btn{font-size:var(--font-size-xs);padding:var(--spacing-xs) var(--spacing-sm)}}.sidebar{backdrop-filter:var(--backdrop-blur-heavy) saturate(180%);-webkit-backdrop-filter:var(--backdrop-blur-heavy) saturate(180%);background:var(--color-sidebar);border-right:1px solid var(--color-border);box-shadow:var(--shadow-md);display:flex;flex-direction:column;height:100vh;left:0;overflow:hidden;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) var(--spacing-md)}.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-nav{background:#0000;max-height:40vh;overflow-y:auto;padding:var(--spacing-base) 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-new-chat{padding:var(--spacing-sm) var(--spacing-base)}.sidebar-new-chat-btn{align-items:center;background:var(--gradient-accent);border:none;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);color:var(--color-text-inverted);cursor:pointer;display: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-md);transition:all var(--transition-fast);width:100%}.sidebar-new-chat-btn:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.sidebar-new-chat-btn:active{box-shadow:var(--shadow-sm);transform:translateY(0)}.sidebar-chat-history{border-bottom:1px solid var(--color-border);display:flex;flex:1 1;flex-direction:column;min-height:200px;overflow:hidden}.sidebar-chat-history,.sidebar-footer{border-top:1px solid var(--color-border)}.sidebar-footer{background:var(--color-sidebar);padding:var(--spacing-base)}.user-info{border-left:1px solid var(--color-border);gap:var(--spacing-sm);margin-left:auto;padding-left: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{display:flex;flex-direction:column}.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{align-items:center;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 (min-height:700px){.sidebar-nav{max-height:35vh}.sidebar-chat-history{min-height:250px}}@media (min-height:900px){.sidebar-nav{max-height:40vh}.sidebar-chat-history{min-height:300px}}@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-nav{max-height:30vh}.sidebar-chat-history{min-height:150px}.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:var(--z-base)}.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:var(--z-base)}.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:var(--z-base)}.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:var(--z-base)}.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)}.theme-toggle-btn{right:var(--spacing-base);top:var(--spacing-base);z-index:var(--z-tooltip)}[data-theme=dark] .login-container{background:#1c1c1efa}[data-theme=dark] .theme-toggle-btn{background:#2c2c2ef2;box-shadow:0 2px 16px #00000080}.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:var(--z-dropdown)}.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)}}.theme-toggle-btn{-webkit-tap-highlight-color:transparent;align-items:center;backdrop-filter:var(--backdrop-blur);-webkit-backdrop-filter:var(--backdrop-blur);background:var(--color-background-glass);border:1px solid var(--color-border);border-radius:var(--radius-full);box-shadow:0 2px 8px #0000001a;color:var(--color-text-secondary);cursor:pointer;display:flex;height:44px;justify-content:center;position:absolute;right:var(--spacing-xl);top:var(--spacing-xl);touch-action:manipulation;transition:all var(--transition-fast);width:44px;z-index:var(--z-dropdown)}.theme-toggle-btn:hover{background:var(--color-background);border-color:var(--color-accent);box-shadow:var(--shadow-md);color:var(--color-accent);transform:scale(1.1)}.theme-toggle-btn:active{transform:scale(.95)}[data-theme=dark] .api-key-login{background:var(--gradient-mesh),var(--color-background)}[data-theme=dark] .theme-toggle-btn{background:#2c2c2ee6;border-color:#fff3;box-shadow:0 2px 12px #0000004d}[data-theme=dark] .login-container{box-shadow:var(--shadow-xl),0 0 0 1px var(--color-border)}[data-theme=dark] .mode-btn{background:var(--color-background-secondary);border-color:var(--color-border);color:var(--color-text-secondary)}[data-theme=dark] .mode-btn:hover{background:var(--color-accent-lighter);border-color:var(--color-accent);color:var(--color-accent)}[data-theme=dark] .mode-btn.active{background:var(--gradient-accent);border-color:var(--color-accent);color:#fff}[data-theme=dark] .form-group input{background:var(--color-background-secondary);border-color:var(--color-border);color:var(--color-text-primary)}[data-theme=dark] .form-group input:focus{background:var(--color-background-tertiary);border-color:var(--color-accent)}[data-theme=dark] .error-message{background:var(--color-error-light);border-color:var(--color-error);color:var(--color-error)}[data-theme=dark] .login-btn{background:var(--gradient-accent);color:#fff}[data-theme=dark] .login-footer{background:var(--color-background-tertiary);border-top-color:var(--color-border)}.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:640px){.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:var(--z-modal)}.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:640px){.loading-spinner-container{padding:20px}}.settings-modal-overlay{align-items:center;animation:fadeIn .2s ease-out;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:var(--backdrop-overlay);display:flex;inset:0;justify-content:center;position:fixed;z-index:var(--z-modal)}.settings-modal{animation:slideUp .3s ease-out;background:var(--surface-primary);border-radius:16px;box-shadow:var(--shadow-xl);display:flex;flex-direction:column;height:600px;max-height:80vh;max-width:90vw;width:680px}.settings-header{align-items:center;border-bottom:1px solid var(--border-primary);display:flex;justify-content:space-between;padding:24px}.settings-header h2{color:var(--text-primary);font-size:20px;font-weight:600;margin:0}.close-button{align-items:center;background:var(--surface-secondary);border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .2s;width:32px}.close-button:hover{background:var(--surface-tertiary);color:var(--text-primary)}.settings-content{display:flex;flex:1 1;overflow:hidden}.settings-tabs{border-right:1px solid var(--border-primary);display:flex;flex-direction:column;gap:4px;padding:16px;width:180px}.settings-tab{align-items:center;background:#0000;border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:12px;padding:10px 16px;text-align:left;transition:all .2s}.settings-tab:hover{background:var(--surface-secondary);color:var(--text-primary)}.settings-tab.active{background:var(--accent-color);color:#fff}.settings-panel{flex:1 1;overflow-y:auto;padding:24px}.settings-section h3{color:var(--text-primary);font-size:16px;font-weight:600;margin:0 0 20px}.setting-item{margin-bottom:24px}.setting-item label{color:var(--text-primary);display:block;font-size:14px;font-weight:500;margin-bottom:8px}.setting-item input[type=checkbox]{margin-right:8px}.setting-item select{background:var(--surface-secondary);border:1px solid var(--border-primary);border-radius:8px;color:var(--text-primary);cursor:pointer;font-size:14px;padding:8px 12px;transition:all .2s;width:100%}.setting-item select:hover{border-color:var(--border-secondary)}.setting-item select:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px var(--accent-color-10);outline:none}.setting-description{color:var(--text-tertiary);font-size:12px;line-height:1.5;margin-top:4px}.theme-option,.theme-selector{display:flex;gap:8px}.theme-option{align-items:center;background:var(--surface-secondary);border:1px solid var(--border-primary);border-radius:8px;color:var(--text-secondary);cursor:pointer;flex:1 1;font-size:14px;font-weight:500;justify-content:center;padding:12px 16px;transition:all .2s}.theme-option:hover{background:var(--surface-tertiary);border-color:var(--border-secondary);color:var(--text-primary)}.theme-option.active{background:var(--accent-color);border-color:var(--accent-color);color:#fff}.color-selector{display:flex;gap:8px}.color-option{align-items:center;border:3px solid #0000;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:40px;justify-content:center;transition:all .2s;width:40px}.color-option.blue{background:#007aff}.color-option.purple{background:#5856d6}.color-option.green{background:#34c759}.color-option.orange{background:#ff9500}.color-option:hover{transform:scale(1.1)}.color-option.active{border-color:var(--text-primary)}.danger-button,.secondary-button{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s}.secondary-button{background:var(--surface-secondary);color:var(--text-primary)}.secondary-button:hover{background:var(--surface-tertiary)}.danger-button{background:#ff3b30;color:#fff}.danger-button:hover{background:#ff453a}.last-cleared{color:var(--text-quaternary);display:block;font-size:11px;margin-top:4px}.settings-footer{border-top:1px solid var(--border-primary);display:flex;gap:8px;justify-content:flex-end;padding:16px 24px}.primary-button{background:var(--accent-color);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:8px 24px;transition:all .2s}.primary-button:hover{background:var(--accent-color-hover)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.settings-modal{border-radius:0;height:100%;margin:0;max-height:100%;max-width:100%;width:100%}.settings-tabs{-webkit-overflow-scrolling:touch;border-bottom:1px solid var(--border-primary);border-right:none;flex-direction:row;gap:8px;overflow-x:auto;padding:8px;width:100%}.settings-tab{flex-shrink:0;white-space:nowrap}.settings-content{flex-direction:column}.settings-panel{padding:16px}.color-selector,.theme-selector{flex-wrap:wrap}.danger-button,.primary-button,.secondary-button,.setting-item input[type=checkbox],.setting-item select,.theme-option{min-height:44px}[data-theme=dark] .settings-modal{background:var(--color-background)}}
/*# sourceMappingURL=main.235e8b1c.css.map*/