:root{--primary-50: #f0f9ff;--primary-100: #e0f2fe;--primary-200: #bae6fd;--primary-300: #7dd3fc;--primary-400: #38bdf8;--primary-500: #0ea5e9;--primary-600: #0284c7;--primary-700: #0369a1;--primary-800: #075985;--primary-900: #0c4a6e;--accent: var(--primary-500);--accent-hover: var(--primary-600);--accent-primary: var(--primary-500);--accent-secondary: var(--primary-600);--accent-color: var(--primary-500);--primary-color: var(--primary-500);--primary: var(--primary-500);--primary-hover: var(--primary-600);--success: #16a34a;--warning: #ca8a04;--error: #dc2626;--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--bg-elevated: #ffffff;--bg-card: #ffffff;--bg-input: #ffffff;--text-primary: #0f172a;--text-secondary: #475569;--text-tertiary: #94a3b8;--text-muted: #cbd5e1;--border-color: #e2e8f0;--border-hover: #cbd5e1;--border-focus: var(--primary-500);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--container-max: 1200px;--container-padding: 1.5rem;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--transition-fast: .15s ease;--transition-normal: .25s ease;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "SF Mono", "Fira Code", "Consolas", monospace}@media (prefers-color-scheme: dark){:root:not([data-theme=light]){--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--bg-elevated: #1e293b;--bg-card: #1e293b;--bg-input: #1e293b;--text-primary: #f1f5f9;--text-secondary: #cbd5e1;--text-tertiary: #94a3b8;--text-muted: #64748b;--border-color: #334155;--border-hover: #475569;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .3), 0 2px 4px -1px rgba(0, 0, 0, .2);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .3), 0 4px 6px -2px rgba(0, 0, 0, .2)}}[data-theme=dark]{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--bg-elevated: #1e293b;--bg-card: #1e293b;--bg-input: #1e293b;--text-primary: #f1f5f9;--text-secondary: #cbd5e1;--text-tertiary: #94a3b8;--text-muted: #64748b;--border-color: #334155;--border-hover: #475569;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .3), 0 2px 4px -1px rgba(0, 0, 0, .2);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .3), 0 4px 6px -2px rgba(0, 0, 0, .2)}[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--bg-elevated: #ffffff;--bg-card: #ffffff;--bg-input: #ffffff;--text-primary: #0f172a;--text-secondary: #475569;--text-tertiary: #94a3b8;--text-muted: #cbd5e1;--border-color: #e2e8f0;--border-hover: #cbd5e1;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{font-family:var(--font-sans);font-size:1rem;line-height:1.6;color:var(--text-primary);background-color:var(--bg-secondary);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color var(--transition-normal),color var(--transition-normal)}#root{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{color:var(--text-primary);font-weight:600;line-height:1.3;letter-spacing:-.02em}h1{font-size:clamp(1.5rem,4vw,2rem)}h2{font-size:clamp(1.25rem,3vw,1.5rem)}h3{font-size:clamp(1.125rem,2.5vw,1.25rem)}p{color:var(--text-secondary)}a{color:var(--primary-500);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-600)}input,textarea,select{font-family:inherit;font-size:.9375rem;color:var(--text-primary);background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:.75rem 1rem;transition:all var(--transition-fast);width:100%}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #0ea5e926}input::placeholder,textarea::placeholder{color:var(--text-tertiary)}select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .75rem center;background-size:1.25rem;padding-right:2.5rem}button{font-family:inherit;font-size:.875rem;font-weight:500;cursor:pointer;border:none;border-radius:var(--radius-md);padding:.75rem 1.5rem;transition:all var(--transition-fast)}button:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--primary-700);color:#fff;font-weight:600}.btn-primary:hover:not(:disabled){background-color:var(--primary-800)}.btn-secondary{background-color:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background-color:var(--bg-secondary);border-color:var(--border-hover)}.btn-small{padding:.5rem 1rem;font-size:.8125rem}.btn-pdf{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem .875rem;background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);font-weight:600;font-size:.8125rem;text-decoration:none;cursor:pointer;transition:all var(--transition-fast)}.btn-pdf:hover{background:#ef444433;border-color:#ef444480}.container{width:100%;max-width:var(--container-max);margin:0 auto;padding:0 var(--container-padding)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}::selection{background:var(--primary-200);color:var(--primary-900)}[data-theme=dark] ::selection{background:var(--primary-700);color:var(--primary-100)}.app-header{background-color:var(--bg-primary);border-bottom:1px solid var(--border-color);padding:.5rem 0;position:sticky;top:0;z-index:200;transition:background-color var(--transition-normal),border-color var(--transition-normal)}.app-header .container{display:flex;justify-content:space-between;align-items:center;gap:1rem}.app-logo{display:flex;align-items:center;gap:.75rem;text-decoration:none;color:inherit;cursor:pointer}.app-logo:hover{opacity:.9}.header-branding{display:flex;align-items:center;gap:.75rem}.header-role-badge{padding:.125rem .375rem;font-size:.5625rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:#fff;border-radius:3px;white-space:nowrap}.header-role-badge.role-superadmin{background:linear-gradient(135deg,#dc2626,#b91c1c)}.header-role-badge.role-admin{background:linear-gradient(135deg,#8b5cf6,#6366f1)}.app-logo .logo-icon{width:36px;height:36px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e3a5f,#2d5a87);border-radius:8px;color:#fff}.app-title{display:flex;flex-direction:column;gap:0}.app-title-row{display:flex;align-items:center;gap:.5rem}.app-title h1{font-size:1.375rem;font-weight:700;margin:0;color:var(--text-primary);letter-spacing:.02em}.app-title h1 .domain-suffix{color:var(--accent, #0ea5e9)}.app-subtitle{font-size:.625rem;font-weight:400;color:var(--text-tertiary);line-height:1.2}@media (min-width: 480px){.app-logo .logo-icon{width:40px;height:40px}.app-title h1{font-size:1.5rem}.app-subtitle{font-size:.75rem}}@media (min-width: 768px){.app-logo .logo-icon{width:44px;height:44px}.app-title h1{font-size:1.75rem}.app-subtitle{font-size:.8125rem}}.theme-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.theme-toggle:hover{background-color:var(--bg-secondary);border-color:var(--border-hover)}.theme-toggle svg{width:18px;height:18px;color:var(--text-secondary)}.header-actions{display:flex;align-items:center;gap:.5rem}.header-login-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#0369a1;color:#fff;font-weight:600;border:none;border-radius:6px;font-size:.875rem;font-weight:500;text-decoration:none;cursor:pointer;transition:background-color .2s,transform .1s}.header-login-btn:hover{background:#075985;color:#fff;transform:translateY(-1px)}.header-login-btn,.header-login-btn:link,.header-login-btn:visited{color:#fff}.header-login-btn:active{transform:translateY(0)}.desktop-nav{display:none;align-items:center;gap:.5rem}@media (min-width: 768px){.desktop-nav{display:flex}}.desktop-user-menu{position:relative;display:none}@media (min-width: 768px){.desktop-user-menu{display:block}}.user-menu-btn{position:relative;display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:linear-gradient(135deg,#1e3a5f,#2d5a87);border:2px solid var(--border-color);border-radius:50%;color:#fff;cursor:pointer;transition:all var(--transition-fast);box-shadow:0 2px 8px #0000001a}.user-menu-btn:hover{border-color:var(--accent-primary);transform:scale(1.05);box-shadow:0 4px 12px #00000026}.user-initials{font-size:.875rem;font-weight:700;letter-spacing:.05em}.user-role-badge{position:absolute;top:-6px;right:-8px;padding:.125rem .375rem;font-size:.5625rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#8b5cf6,#6366f1);border-radius:3px;line-height:1;white-space:nowrap}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:260px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 4px 12px #00000026;z-index:300;overflow:hidden}.user-dropdown-header{padding:.75rem 1rem;font-size:.8125rem;color:var(--text-secondary);border-bottom:1px solid var(--border-color);display:flex;flex-direction:column;align-items:flex-start;gap:.25rem}.user-dropdown-header .user-name{font-weight:500;color:var(--text-primary);word-break:break-all}.user-dropdown-header .user-role-tag{padding:.125rem .375rem;font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#fff;background:linear-gradient(135deg,#8b5cf6,#6366f1);border-radius:3px}.user-dropdown-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.75rem 1rem;font-size:.875rem;color:var(--text-primary);background:transparent;border:none;cursor:pointer;text-align:left;transition:background .15s}.user-dropdown-item:hover{background:var(--bg-secondary)}.user-dropdown-item.logout{color:#dc2626}.user-dropdown-item.logout:hover{background:#fef2f2}[data-theme=dark] .user-dropdown-item.logout:hover{background:#dc26261a}.user-dropdown-divider,.mobile-menu-divider{height:1px;background:var(--border-color);margin:.5rem 0}.mobile-menu-section-title{font-size:.75rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;padding:.5rem 1rem .25rem}.header-link{color:var(--text-secondary);text-decoration:none;font-size:.875rem;padding:.5rem .75rem;border-radius:var(--radius-md);transition:all var(--transition-fast)}.header-link:hover{color:var(--text-primary);background:var(--bg-secondary)}.nav-beta-badge{display:inline-block;margin-left:.25rem;padding:.125rem .375rem;font-size:.5625rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#fff;background:linear-gradient(135deg,#8b5cf6,#6366f1);border-radius:3px;vertical-align:middle}.desktop-only{display:none}@media (min-width: 768px){.desktop-only{display:inline-flex}}.mobile-menu-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:transparent;border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast)}.mobile-menu-btn:hover{background:var(--bg-secondary)}@media (min-width: 768px){.mobile-menu-btn{display:none}}.mobile-menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.mobile-menu{position:absolute;top:0;right:0;width:280px;max-width:85vw;height:100vh;background:var(--bg-primary);box-shadow:-4px 0 20px #00000026;display:flex;flex-direction:column;animation:slideIn .2s ease}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.mobile-menu-header{padding:1rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:.5rem}.mobile-menu-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:transparent;border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;margin-left:auto;transition:all var(--transition-fast)}.mobile-menu-close:hover{background:var(--bg-secondary);color:var(--text-primary)}.mobile-menu-user{font-size:.875rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.dev-badge{font-size:.65rem;padding:2px 6px;background:#fef3c7;color:#92400e;border-radius:4px;font-weight:600}.mobile-menu-link{display:flex;align-items:center;gap:.75rem;padding:1rem;color:var(--text-primary);text-decoration:none;font-size:.9375rem;border:none;background:transparent;width:100%;text-align:left;cursor:pointer;transition:background .15s}.mobile-menu-link:hover{background:var(--bg-secondary)}.mobile-menu-link.logout{color:#dc2626;margin-top:auto;border-top:1px solid var(--border-color)}.mobile-menu-link svg{color:var(--text-tertiary);flex-shrink:0}.mobile-menu-link.logout svg{color:#dc2626}main{flex:1;width:100%;max-width:var(--container-max);margin:0 auto;padding:1rem var(--container-padding);display:flex;flex-direction:column;gap:1rem}main>*{width:100%;max-width:900px;margin:0 auto}main:has(.admin-page){max-width:100%;padding:1rem}main>.admin-page{max-width:100%}.app-footer{background-color:var(--bg-secondary);border-top:1px solid var(--border-color);margin-top:auto;transition:background-color var(--transition-normal),border-color var(--transition-normal)}.footer-content{display:flex;flex-direction:column;gap:1.5rem;padding:2rem 0}@media (min-width: 640px){.footer-content{flex-direction:row;justify-content:space-between;align-items:flex-start;padding:2.5rem 0}}.footer-brand{display:flex;flex-direction:column;gap:.5rem;text-decoration:none;color:inherit;transition:opacity .15s}.footer-brand:hover{opacity:.85}.footer-logo{display:flex;align-items:center;gap:.75rem;font-weight:700;font-size:1.25rem;color:var(--text-primary);letter-spacing:.02em}.footer-logo .domain-suffix,.footer-section h4 .domain-suffix,.footer-bottom .domain-suffix{color:var(--accent, #0ea5e9)}.footer-logo .footer-logo-icon{width:32px;height:32px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e3a5f,#2d5a87);border-radius:8px;color:#fff}@media (min-width: 640px){.footer-logo{font-size:1.5rem}.footer-logo .footer-logo-icon{width:38px;height:38px}}.footer-tagline{font-size:.8125rem;color:var(--text-tertiary);margin:0}@media (min-width: 640px){.footer-tagline{font-size:.875rem}}.footer-links{display:flex;gap:2rem}@media (max-width: 639px){.footer-links{gap:1.5rem}}.footer-section{display:flex;flex-direction:column;gap:.5rem}.footer-section h4{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin:0 0 .25rem}.footer-section a{font-size:.8125rem;color:var(--text-tertiary);text-decoration:none;transition:color .15s}.footer-section a:hover{color:var(--primary-500)}.footer-bottom{border-top:1px solid var(--border-color);padding:1rem;text-align:center}@media (min-width: 640px){.footer-bottom{padding:1rem var(--container-padding)}}.footer-bottom p{font-size:.75rem;color:var(--text-tertiary);margin:0}.footer-bottom a{color:var(--primary-500);text-decoration:none}.footer-bottom a:hover{text-decoration:underline}.footer-privacy{font-size:.6875rem!important;opacity:.7;margin-top:.25rem!important}@media (max-width: 479px){.app-header{padding:.25rem 0}.app-header .container{padding:0 .5rem}.app-logo{gap:.5rem}.app-logo .logo-icon{width:28px;height:28px}.app-logo svg{width:24px;height:24px}.app-title h1{font-size:.8125rem}.app-subtitle{display:none}.header-actions{gap:.375rem}.header-link{font-size:.75rem;padding:.375rem .5rem}.theme-toggle{width:32px;height:32px}.theme-toggle svg{width:16px;height:16px}.mobile-menu-btn{width:32px;height:32px}main{padding:.5rem;gap:.5rem}.footer-content{padding:.75rem 0;gap:.75rem}.footer-links,.footer-tagline{display:none}.footer-logo{font-size:1rem}.footer-logo .footer-logo-icon{width:24px;height:24px}.footer-bottom{padding:.5rem}.footer-bottom p{font-size:.65rem;padding:0}.footer-privacy{display:none}}@media (min-width: 640px){.app-header{padding:.625rem 0}.app-logo svg{width:32px;height:32px}.app-title h1{font-size:1.125rem}main{padding:1.25rem var(--container-padding);gap:1.25rem}}.document-viewer-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem}.document-viewer-content{background-color:var(--bg-primary);border-radius:var(--radius-lg);width:100%;max-width:900px;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 25px 50px -12px #00000040}.document-viewer-content .close-button{position:sticky;top:0;float:right;margin:1rem;padding:.5rem 1rem;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;font-size:.875rem;color:var(--text-primary);z-index:10}.document-viewer-content .close-button:hover{background-color:var(--bg-secondary)}.document-viewer-content>div:last-child{padding:1.5rem;padding-top:0;color:var(--text-primary);line-height:1.7;font-size:.9375rem}.document-viewer-content p{margin-bottom:1rem;text-align:justify}.document-viewer-content strong{font-weight:600}.auth-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:1rem;color:var(--text-secondary)}.auth-loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--accent-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-loading p{font-size:.875rem;margin:0}.page-nav-hint{text-align:center;padding:.5rem 1rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.page-nav-hint a{display:inline-flex;align-items:center;gap:.375rem;color:var(--accent-color);text-decoration:none;font-size:.8125rem;font-weight:500;transition:opacity var(--transition-fast)}.page-nav-hint a:hover{opacity:.8;text-decoration:underline}.page-nav-hint .nav-beta-badge{font-size:.625rem;padding:.125rem .375rem;background:var(--accent-color);color:#fff;border-radius:3px;font-weight:600;text-transform:uppercase}.offline-indicator{display:flex;align-items:center;gap:.25rem;padding:.25rem .5rem;font-size:.6875rem;font-weight:500;color:var(--text-tertiary);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);white-space:nowrap;animation:fade-in-slide .3s ease-out}.offline-indicator svg{flex-shrink:0;opacity:.7}@keyframes fade-in-slide{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 479px){.offline-indicator{padding:.125rem .375rem;font-size:.625rem}.offline-indicator svg{width:12px;height:12px}}.cold-start-indicator{display:flex;align-items:center;gap:.25rem;padding:.25rem .5rem;font-size:.6875rem;font-weight:500;color:#92400e;background:#fef3c7;border:1px solid #f59e0b;border-radius:var(--radius-sm);white-space:nowrap;animation:fade-in-slide .3s ease-out}[data-theme=dark] .cold-start-indicator{color:#fbbf24;background:#f59e0b26;border-color:#f59e0b66}.cold-start-spinner{flex-shrink:0;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 479px){.cold-start-indicator{padding:.125rem .375rem;font-size:.625rem}.cold-start-indicator svg{width:12px;height:12px}}.landing-page{min-height:100vh;background:var(--bg-primary);color:var(--text-primary)}.landing-hero{padding:6rem 1.5rem 4rem;background:linear-gradient(135deg,#0ea5e90f,#0ea5e905);border-bottom:1px solid var(--border-color)}.landing-hero-inner{max-width:760px;margin:0 auto;text-align:center}.landing-logo{display:inline-flex;align-items:center;justify-content:center;width:80px;height:80px;margin-bottom:1.25rem;border-radius:16px;background:#0ea5e9;color:#fff;box-shadow:0 10px 30px #0ea5e940}.landing-title{font-size:3rem;font-weight:800;letter-spacing:-.02em;line-height:1.1;margin-bottom:1rem;background:linear-gradient(135deg,#0c4a6e,#0ea5e9);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.landing-subtitle{font-size:1.125rem;color:var(--text-secondary);line-height:1.6;margin-bottom:2rem;max-width:620px;margin-left:auto;margin-right:auto}.landing-auth-error{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1rem;margin-bottom:1.25rem;background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:8px;color:#ef4444;font-size:.875rem}.landing-auth-error-close{background:none;border:none;color:#ef4444;cursor:pointer;font-size:1.25rem;line-height:1;padding:0}.landing-cta-group{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;margin-top:.5rem}.landing-cta{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.75rem;border-radius:8px;font-size:.9375rem;font-weight:500;cursor:pointer;border:1px solid transparent;transition:all .15s;text-decoration:none}.landing-cta-primary{background:#0369a1;color:#fff;font-weight:600}.landing-cta-primary:hover{background:#075985;transform:translateY(-1px);box-shadow:0 6px 20px #0ea5e94d}.landing-cta-secondary{background:transparent;color:var(--text-primary);border-color:var(--border-color)}.landing-cta-secondary:hover{border-color:#0ea5e9;color:#0ea5e9}.landing-features{padding:4rem 1.5rem;max-width:1100px;margin:0 auto}.section-title{font-size:1.75rem;font-weight:700;text-align:center;margin-bottom:2.5rem;color:var(--text-primary)}.landing-features-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.landing-feature-card{padding:1.5rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;transition:all .15s}.landing-feature-card:hover{border-color:#0ea5e9;transform:translateY(-2px);box-shadow:0 8px 24px #0ea5e914}.landing-feature-icon{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;margin-bottom:1rem;border-radius:10px;background:#0ea5e91a;color:#0ea5e9}.landing-feature-card h3{font-size:1rem;font-weight:600;margin-bottom:.5rem;color:var(--text-primary)}.landing-feature-card p{font-size:.875rem;color:var(--text-secondary);line-height:1.5}.landing-about{padding:4rem 1.5rem 6rem;border-top:1px solid var(--border-color);background:var(--bg-secondary)}.landing-about-inner{max-width:720px;margin:0 auto;text-align:center}.landing-about p{font-size:.9375rem;color:var(--text-secondary);line-height:1.7;margin-bottom:1rem}.landing-about code{padding:.125rem .375rem;background:var(--bg-tertiary);border-radius:4px;font-size:.8125rem;font-family:ui-monospace,SFMono-Regular,monospace;color:var(--text-primary)}.landing-cross-sell{padding:2rem 1.5rem 4rem;background:var(--bg-primary);border-top:1px solid var(--border-color)}.landing-cross-sell-inner{max-width:920px;margin:0 auto;display:flex;align-items:center;gap:1.25rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem 1.75rem}.landing-cross-sell-icon{flex:0 0 auto;color:var(--accent, #0ea5e9);display:flex;align-items:center}.landing-cross-sell-content{flex:1 1 auto;min-width:0}.landing-cross-sell-content h3{margin:0 0 .25rem;font-size:1rem;font-weight:600;color:var(--text-primary)}.landing-cross-sell-content p{margin:0;font-size:.875rem;line-height:1.5;color:var(--text-secondary)}.landing-cross-sell .landing-cta{flex:0 0 auto;white-space:nowrap;text-decoration:none}@media (max-width: 640px){.landing-cross-sell-inner{flex-direction:column;align-items:flex-start;text-align:left}}.arteclaw-link{color:#0ea5e9;text-decoration:none;font-weight:500}.arteclaw-link:hover{text-decoration:underline}.landing-disclaimer{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-color);font-size:.8125rem;color:var(--text-tertiary);font-style:italic}@media (max-width: 640px){.landing-hero{padding:3.5rem 1rem 3rem}.landing-title{font-size:2.25rem}.landing-subtitle{font-size:1rem}.landing-features{padding:3rem 1rem}.landing-features-grid{grid-template-columns:1fr}.landing-cta{width:100%}.landing-cta-group{flex-direction:column}}@media (prefers-color-scheme: dark){.landing-hero{background:linear-gradient(135deg,#0ea5e91f,#0ea5e908)}}.favorites-page{max-width:900px;margin:0 auto;padding:2rem 1rem}.favorites-header{margin-bottom:2rem}.back-link{display:inline-block;color:var(--primary-500);text-decoration:none;margin-bottom:1rem;font-size:.875rem}.back-link:hover{text-decoration:underline}.favorites-header h2{margin:0;font-size:1.5rem;color:var(--text-primary)}.favorites-subtitle{margin:.5rem 0 0;color:var(--text-secondary);font-size:.875rem}.favorites-loading{text-align:center;padding:3rem;color:var(--text-secondary)}.favorites-empty{text-align:center;padding:3rem;background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.favorites-empty p{color:var(--text-secondary);margin:.5rem 0}.favorites-empty .btn-primary{margin-top:1.5rem;display:inline-block;padding:.75rem 1.5rem;background:var(--primary-500);color:#fff;border-radius:var(--radius-md);text-decoration:none}.favorites-actions{margin-bottom:1.5rem}.batch-progress-bar{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:1rem}.progress-text{font-size:.875rem;color:var(--text-secondary);margin-bottom:.5rem}.progress-bar{height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(135deg,#8b5cf6,#6366f1);transition:width .3s ease}.favorites-list{display:flex;flex-direction:column;gap:1rem}.favorite-item{display:flex;flex-direction:column;gap:1rem;padding:1rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.favorite-item:hover{border-color:var(--border-hover);box-shadow:var(--shadow-sm)}.favorite-content{flex:1}.favorite-title{font-weight:500;font-size:1rem;color:var(--text-primary);display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.favorite-metadata{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:.5rem;font-size:.8125rem}.favorite-metadata .meta-item{color:var(--text-secondary);display:flex;align-items:center;gap:.25rem}.favorite-metadata .doc-type{background:linear-gradient(135deg,#6366f126,#8b5cf626);color:#a5b4fc;padding:.2rem .6rem;border-radius:4px;font-weight:600;font-size:.75rem;letter-spacing:.025em}.favorite-metadata .date{color:var(--text-tertiary)}.favorite-metadata .court{color:var(--text-secondary)}.favorite-id{font-size:.7rem;color:var(--text-tertiary);margin-top:.5rem;opacity:.7;font-family:monospace}.favorite-summary{font-size:.875rem;color:var(--text-secondary);margin-top:.5rem;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.favorite-actions{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.btn-remove{background:none;border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-tertiary);padding:.375rem .75rem;cursor:pointer;transition:all .2s ease}.btn-remove:hover{border-color:#ef4444;color:#ef4444;background:#ef44441a}@media (min-width: 640px){.favorite-item{flex-direction:row;align-items:center}.favorite-actions{flex-shrink:0}}.favorites-page .modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.favorites-page .modal-content{background:var(--bg-card);border-radius:12px;max-width:600px;width:100%;max-height:80vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 40px #0006}.favorites-page .modal-content.pdf-viewer-modal{max-width:95vw;width:95vw;max-height:95vh;height:95vh}.favorites-page .pdf-viewer-modal .modal-header{flex-shrink:0}.favorites-page .pdf-viewer-modal .modal-header-actions{display:flex;align-items:center;gap:.75rem}.favorites-page .pdf-viewer-modal .btn-download-small{background:#6366f126;color:#a5b4fc;padding:.4rem .8rem;border-radius:6px;font-size:.8rem;text-decoration:none;transition:all .2s ease}.favorites-page .pdf-viewer-modal .btn-download-small:hover{background:#6366f140}.favorites-page .pdf-viewer-modal .pdf-body{flex:1;padding:0;overflow:hidden}.favorites-page .pdf-viewer-modal .pdf-iframe-full{width:100%;height:100%;border:none}.favorites-page .modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color)}.favorites-page .modal-header h3{margin:0;font-size:1.25rem}.favorites-page .modal-close{background:none;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;padding:.25rem}.favorites-page .modal-body{padding:1.5rem;overflow-y:auto}.favorites-page .summary-text{line-height:1.7;color:var(--text-primary);white-space:pre-wrap}.favorites-page .summary-meta{margin-top:1.5rem;display:flex;gap:.5rem;flex-wrap:wrap}.favorites-page .meta-tag{background:#6366f133;color:#a5b4fc;padding:.25rem .75rem;border-radius:20px;font-size:.8rem}.favorites-page .meta-tag.source-full{background:#10b98133;color:#34d399;font-weight:600}.favorites-page .attachments-section{margin-top:1rem;padding:1rem;background:#f973160d;border:1px solid rgba(249,115,22,.2);border-radius:8px}.favorites-page .attachment-link{display:block;padding:.5rem;color:var(--primary-500);text-decoration:none}.favorites-page .attachment-link:hover{text-decoration:underline}
