#root{max-width:1200px;margin:0 auto;padding:0;text-align:center;width:100%}.app-container{display:flex;flex-direction:column;min-height:100vh;width:100%;position:relative}.container{max-width:1000px;margin:0 auto;padding:var(--space-4);flex:1;display:flex;flex-direction:column;width:100%}.main-content-container{flex:1;width:100%}.main-content{flex:1;width:100%;margin-bottom:var(--space-8)}.header{margin-bottom:var(--space-10);text-align:center}.header-content{background:var(--graphite);border-radius:var(--radius-xl);padding:var(--space-12) var(--space-8);box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.06);position:relative;overflow:hidden}.header-content:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary))}.header h1{font-size:var(--font-4xl);font-weight:700;color:var(--ash-text);margin-bottom:var(--space-4);letter-spacing:-.03em;line-height:1.15}.header p{color:var(--ash-text-muted);max-width:600px;margin:0 auto;line-height:1.7;font-size:var(--font-lg)}.demo-video-promo{margin-top:var(--space-6);padding:var(--space-3) var(--space-5);background:#5b6cff14;border-radius:var(--radius-lg);border:1px solid rgba(91,108,255,.15);display:inline-flex;align-items:center;gap:var(--space-2);color:var(--ash-text-muted);font-size:var(--font-sm);transition:all var(--transition)}.demo-video-promo:hover{background:#5b6cff1f;border-color:#5b6cff40}.demo-video-promo svg{color:var(--accent-primary)}.demo-video-promo a{color:var(--accent-primary);font-weight:600}.upload-container{background:var(--graphite);padding:var(--space-8);border-radius:var(--radius-xl);box-shadow:var(--shadow);margin-bottom:var(--space-8);border:1px solid rgba(255,255,255,.06)}.upload-label{display:block;color:var(--ash-text);font-size:var(--font-lg);font-weight:600;margin-bottom:var(--space-4);text-align:left}.upload-label:after{content:"";display:block;width:40px;height:2px;background:var(--accent-primary);margin-top:var(--space-2);border-radius:2px}.upload-area{border:2px dashed var(--graphite-lighter);border-radius:var(--radius-xl);padding:var(--space-12);text-align:center;cursor:pointer;transition:all var(--transition);background:var(--graphite-light);position:relative;display:flex;align-items:center;justify-content:center;min-height:280px}.upload-area:hover{border-color:var(--accent-primary);background:#5b6cff0a;box-shadow:0 0 0 4px var(--accent-primary-glow)}.upload-area.drag-active{border-color:var(--accent-primary);background:#5b6cff14;transform:scale(1.01);box-shadow:0 0 0 4px var(--accent-primary-glow),var(--shadow-lg)}.upload-area img{max-height:280px;margin:0 auto;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}.upload-text{color:var(--ash-text);font-size:var(--font-lg);font-weight:500}.upload-text-secondary{color:var(--ash-text-muted);font-size:var(--font-sm);margin-top:var(--space-2)}.button-container{display:flex;justify-content:center;gap:var(--space-3);margin-top:var(--space-6)}.action-button{padding:var(--space-3) var(--space-6);background:var(--accent-primary);color:#fff;border:none;border-radius:var(--radius-lg);cursor:pointer;font-weight:600;font-size:var(--font-base);transition:all var(--transition);box-shadow:var(--shadow-sm),0 0 0 0 var(--accent-primary-glow);display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2)}.action-button:hover{background:var(--accent-primary-hover);transform:translateY(-2px);box-shadow:var(--shadow),var(--shadow-glow)}.action-button:active{transform:translateY(0)}.restart-button{padding:var(--space-2) var(--space-4);background:transparent;color:var(--ash-text-muted);border:1px solid var(--graphite-lighter);border-radius:var(--radius);font-size:var(--font-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.restart-button:hover{background:var(--graphite-light);border-color:var(--ash-text-dim);color:var(--ash-text)}.error-message{background:#ef44441a;color:#fca5a5;padding:var(--space-3) var(--space-4);border-radius:var(--radius);margin:var(--space-4) 0;border-left:3px solid var(--accent-error);text-align:left;font-size:var(--font-sm)}.info-message{background:#5b6cff1a;color:var(--accent-primary);padding:var(--space-3) var(--space-4);border-radius:var(--radius);margin:var(--space-4) 0;border-left:3px solid var(--accent-primary);text-align:left;font-size:var(--font-sm)}.loading-container{display:flex;flex-direction:column;align-items:center;margin:var(--space-8) 0;padding:var(--space-8)}.loading-spinner{display:flex;justify-content:center;margin-bottom:var(--space-4)}.loading-text{color:var(--ash-text-muted);font-size:var(--font-base)}.loading-subtext{margin-top:var(--space-2);color:var(--ash-text-dim);font-size:var(--font-sm)}.spinner{animation:spin 1s linear infinite;border-radius:50%;height:48px;width:48px;border:3px solid var(--graphite-lighter);border-top-color:var(--accent-primary)}.demo-notice{margin-top:var(--space-2);color:var(--ash-text-dim);font-size:var(--font-sm);text-align:center}.progress-container{width:100%;max-width:300px;height:4px;background:var(--graphite-lighter);border-radius:2px;margin:var(--space-4) auto;overflow:hidden}.progress-bar{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary));border-radius:2px;transition:width .5s ease}.books-list{margin-top:var(--space-8);background:var(--graphite);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.06)}.books-list h2{font-size:var(--font-xl);font-weight:600;margin-bottom:var(--space-4);color:var(--ash-text);text-align:left;padding-bottom:var(--space-3);border-bottom:1px solid var(--graphite-lighter)}.book-summary{background:var(--graphite-light);border-radius:var(--radius-lg);padding:var(--space-5);margin-bottom:var(--space-6);border-left:3px solid var(--accent-secondary)}.summary-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-4);text-align:left;margin-top:var(--space-3)}.summary-stats p{display:flex;align-items:center;font-size:var(--font-sm);color:var(--ash-text);padding:var(--space-3);background:var(--graphite);border-radius:var(--radius)}.summary-stats p strong{margin-right:var(--space-2);color:var(--accent-primary)}.book-items{list-style:none;padding:0;display:grid;gap:var(--space-3)}.book-item{padding:var(--space-4);background:var(--graphite-light);border-radius:var(--radius-lg);border-left:3px solid var(--accent-primary);text-align:left;transition:all var(--transition-fast)}.book-item:hover{background:var(--graphite-lighter);transform:translate(4px)}.book-title{color:var(--ash-text);font-weight:600;font-size:var(--font-base);margin-bottom:var(--space-1)}.book-author{color:var(--ash-text-muted);font-size:var(--font-sm);font-style:italic}.book-genre{color:var(--accent-secondary);margin-top:var(--space-2);font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.05em;font-weight:500}.book-summary-text{color:var(--ash-text-muted);margin-top:var(--space-3);font-size:var(--font-sm);line-height:1.6;padding:var(--space-3);background:var(--graphite);border-radius:var(--radius)}.backend-status{position:fixed;bottom:var(--space-4);right:var(--space-4);display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-2xl);background:var(--graphite);box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.06);z-index:100;font-size:var(--font-xs)}.status-indicator{width:8px;height:8px;border-radius:50%}.backend-status.online .status-indicator{background:var(--accent-success);box-shadow:0 0 8px var(--accent-success)}.backend-status.offline .status-indicator{background:var(--accent-error)}.backend-status span{color:var(--ash-text-muted);font-weight:500}.dark-mode-toggle{position:fixed;top:var(--space-4);right:var(--space-4);width:40px;height:40px;border-radius:50%;background:var(--graphite);color:var(--ash-text);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.06);z-index:100;transition:all var(--transition-fast)}.dark-mode-toggle:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);background:var(--graphite-light)}.footer-wrapper{background:var(--graphite);border-top:1px solid rgba(255,255,255,.06);margin-top:var(--space-16);min-height:280px;contain:layout style}.footer-container{max-width:1200px;margin:0 auto;padding:var(--space-12) var(--space-6);display:grid;grid-template-columns:1.5fr 2fr;gap:var(--space-12)}.footer-brand{display:flex;flex-direction:column;gap:var(--space-4)}.footer-logo{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-lg);font-weight:700;color:var(--ash-text)}.footer-logo svg{color:var(--accent-primary)}.footer-tld{color:#8b9aff}.footer-tagline{color:var(--ash-text-muted);font-size:var(--font-sm);line-height:1.6;max-width:280px;margin:0}.footer-support{margin-top:var(--space-2)}.footer-links-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-8)}.footer-column h4{font-size:var(--font-sm);font-weight:600;color:var(--ash-text);margin-bottom:var(--space-4);text-transform:uppercase;letter-spacing:.05em}.footer-column ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-3)}.footer-column a{color:var(--ash-text-muted);font-size:var(--font-sm);text-decoration:none;transition:color var(--transition-fast);display:inline-flex;align-items:center;gap:var(--space-1)}.footer-column a:hover{color:var(--ash-text)}.footer-column a svg{opacity:.5}.footer-bottom-bar{border-top:1px solid rgba(255,255,255,.06);padding:var(--space-4) var(--space-6);text-align:center}.footer-bottom-bar p{color:var(--ash-text-dim);font-size:var(--font-xs);margin:0}@media (max-width: 768px){.footer-container{grid-template-columns:1fr;gap:var(--space-8);padding:var(--space-8) var(--space-4)}.footer-brand{text-align:center;align-items:center}.footer-tagline{text-align:center;max-width:100%}.footer-links-grid{grid-template-columns:repeat(3,1fr);gap:var(--space-4);text-align:center}.footer-column ul{align-items:center}}@media (max-width: 480px){.footer-links-grid{grid-template-columns:1fr;gap:var(--space-6)}}.about-container,.methodology-container{background:var(--graphite);border-radius:var(--radius-xl);padding:var(--space-8);box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.06);text-align:left;max-width:900px;margin:0 auto var(--space-8) auto}.about-header,.methodology-header{text-align:center;margin-bottom:var(--space-8)}.about-header h1,.methodology-header h1{color:var(--ash-text);font-size:var(--font-3xl);margin-bottom:var(--space-2)}.methodology-subtitle{color:var(--ash-text-muted);font-size:var(--font-lg)}.about-section,.methodology-section{margin-bottom:var(--space-8)}.about-section h2,.methodology-section h2{color:var(--ash-text);margin-bottom:var(--space-4);font-size:var(--font-xl);padding-bottom:var(--space-2);border-bottom:1px solid var(--graphite-lighter)}.about-section p,.methodology-section p{color:var(--ash-text-muted);line-height:1.7;margin-bottom:var(--space-4)}.feature-list{list-style:none;padding:0;margin-top:var(--space-4)}.feature-list li{margin-bottom:var(--space-3);padding-left:var(--space-6);position:relative;color:var(--ash-text-muted)}.feature-list li:before{content:"✓";position:absolute;left:0;color:var(--accent-secondary);font-weight:700}.methodology-steps{display:flex;flex-direction:column;gap:var(--space-4);margin-bottom:var(--space-8)}.step-card{background:var(--graphite-light);border-radius:var(--radius-lg);padding:var(--space-5);padding-left:calc(var(--space-5) + 48px);position:relative;border:1px solid rgba(255,255,255,.04)}.step-number{position:absolute;left:var(--space-5);top:var(--space-5);width:32px;height:32px;background:var(--accent-primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--font-sm)}.step-card h3{color:var(--ash-text);margin-bottom:var(--space-2)}.step-card p{color:var(--ash-text-muted);font-size:var(--font-sm);margin:0}.values-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-4);margin-top:var(--space-6)}.value-card{background:var(--graphite-light);padding:var(--space-5);border-radius:var(--radius-lg);border-left:3px solid var(--accent-secondary)}.value-card h3{color:var(--ash-text);margin-bottom:var(--space-2);font-size:var(--font-base)}.value-card p{color:var(--ash-text-muted);font-size:var(--font-sm);margin:0}.page-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:50vh;width:100%}.page-loading .loading-spinner{width:40px;height:40px;border:3px solid var(--graphite-lighter);border-radius:50%;border-top-color:var(--accent-primary);animation:spin 1s linear infinite;margin-bottom:var(--space-4)}.page-loading p{color:var(--ash-text-muted);font-size:var(--font-sm)}@media (max-width: 768px){.container{padding:var(--space-3)}.header-content{padding:var(--space-8) var(--space-4)}.header h1{font-size:var(--font-3xl)}.header p{font-size:var(--font-base)}.upload-container{padding:var(--space-4)}.upload-area{padding:var(--space-8);min-height:200px}.upload-area img{max-height:200px}.backend-status{bottom:var(--space-2);right:var(--space-2);padding:var(--space-1) var(--space-3);font-size:10px}.dark-mode-toggle{top:var(--space-2);right:var(--space-2);width:36px;height:36px}.about-container,.methodology-container{padding:var(--space-4);margin:0 var(--space-2) var(--space-4) var(--space-2)}.books-list{padding:var(--space-4)}.summary-stats{grid-template-columns:1fr}.footer-content{grid-template-columns:1fr;gap:var(--space-6)}}@media (max-width: 480px){.header h1{font-size:var(--font-2xl)}.button-container{flex-direction:column}.action-button{width:100%}.demo-video-promo{flex-direction:column;text-align:center}}.navbar{position:sticky;top:0;z-index:50;background:#0f1115cc;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.06);transition:all var(--transition)}.navbar-scrolled{background:#0f1115f2;box-shadow:var(--shadow-lg)}.navbar-container{max-width:1200px;margin:0 auto;padding:0 var(--space-4)}.navbar-content{display:flex;align-items:center;justify-content:space-between;height:64px}.navbar-brand{display:flex;align-items:center;gap:var(--space-2);text-decoration:none;transition:all var(--transition-fast)}.navbar-brand:hover{transform:translateY(-1px)}.brand-icon{width:24px;height:24px;color:var(--accent-primary)}.brand-text{font-size:var(--font-lg);font-weight:700;color:var(--ash-text);letter-spacing:-.02em}.brand-tld{color:var(--accent-primary)}.navbar-links-desktop{display:none;align-items:center;gap:var(--space-1)}@media (min-width: 768px){.navbar-links-desktop{display:flex}}.nav-link{position:relative;padding:var(--space-2) var(--space-3);font-size:var(--font-sm);font-weight:500;color:var(--ash-text-muted);text-decoration:none;border-radius:var(--radius);transition:all var(--transition-fast)}.nav-link:hover{color:var(--ash-text);background:#ffffff0a}.nav-link-active{color:var(--ash-text);background:#5b6cff1a}.nav-link-active:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:16px;height:2px;background:var(--accent-primary);border-radius:1px}.navbar-actions{display:flex;align-items:center;gap:var(--space-3);min-width:100px;min-height:40px}.auth-skeleton{width:80px;height:36px;background:var(--graphite-light);border-radius:var(--radius);animation:shimmer 1.5s infinite}.sign-in-btn{display:none;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--font-sm);font-weight:600;color:#fff;background:var(--accent-primary);border-radius:var(--radius);text-decoration:none;transition:all var(--transition);box-shadow:0 0 0 0 var(--accent-primary-glow)}@media (min-width: 768px){.sign-in-btn{display:flex}}.sign-in-btn:hover{background:var(--accent-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-sm),var(--shadow-glow);color:#fff}.sign-in-icon{width:16px;height:16px}.mobile-menu-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:transparent;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);color:var(--ash-text);cursor:pointer;transition:all var(--transition-fast)}@media (min-width: 768px){.mobile-menu-btn{display:none}}.mobile-menu-btn:hover{background:#ffffff0a;border-color:#ffffff1f}.mobile-menu-btn svg{width:20px;height:20px}.navbar-mobile{display:none;padding:var(--space-4);border-top:1px solid rgba(255,255,255,.06);background:#0f1115fa}.navbar-mobile-open{display:block}@media (min-width: 768px){.navbar-mobile{display:none!important}}.mobile-links{display:flex;flex-direction:column;gap:var(--space-1)}.mobile-link{display:block;padding:var(--space-3) var(--space-4);font-size:var(--font-base);font-weight:500;color:var(--ash-text-muted);text-decoration:none;border-radius:var(--radius);transition:all var(--transition-fast)}.mobile-link:hover{color:var(--ash-text);background:#ffffff0a}.mobile-link-active{color:var(--ash-text);background:#5b6cff1a;border-left:3px solid var(--accent-primary)}.mobile-auth{margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid rgba(255,255,255,.06)}.mobile-sign-in-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%;padding:var(--space-3) var(--space-4);font-size:var(--font-base);font-weight:600;color:#fff;background:var(--accent-primary);border-radius:var(--radius);text-decoration:none;transition:all var(--transition)}.mobile-sign-in-btn:hover{background:var(--accent-primary-hover);color:#fff}.mobile-sign-in-btn svg{width:18px;height:18px}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media (min-width: 640px){.container{max-width:640px}}@media (min-width: 768px){.container{max-width:768px}}@media (min-width: 1024px){.container{max-width:1024px}}@media (min-width: 1280px){.container{max-width:1280px}}@media (min-width: 1536px){.container{max-width:1536px}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.visible{visibility:visible}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.bottom-4{bottom:1rem}.right-0{right:0}.right-4{right:1rem}.isolate{isolation:isolate}.z-50{z-index:50}.z-\[100\]{z-index:100}.mx-auto{margin-left:auto;margin-right:auto}.my-1{margin-top:.25rem;margin-bottom:.25rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-1{margin-left:.25rem}.ml-2{margin-left:.5rem}.ml-4{margin-left:1rem}.mr-1{margin-right:.25rem}.mr-2{margin-right:.5rem}.mr-4{margin-right:1rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.line-clamp-3{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}.h-12{height:3rem}.h-16{height:4rem}.h-2{height:.5rem}.h-24{height:6rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-8{height:2rem}.h-screen{height:100vh}.max-h-0{max-height:0px}.max-h-\[5000px\]{max-height:5000px}.min-h-screen{min-height:100vh}.w-12{width:3rem}.w-16{width:4rem}.w-2{width:.5rem}.w-24{width:6rem}.w-4{width:1rem}.w-48{width:12rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-8{width:2rem}.w-full{width:100%}.max-w-3xl{max-width:48rem}.max-w-4xl{max-width:56rem}.max-w-5xl{max-width:64rem}.max-w-\[150px\]{max-width:150px}.max-w-md{max-width:28rem}.flex-1{flex:1 1 0%}.flex-shrink-0{flex-shrink:0}.rotate-180{--tw-rotate: 180deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.scale-100{--tw-scale-x: 1;--tw-scale-y: 1;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-pointer{cursor:pointer}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-col{flex-direction:column}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.space-x-1>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(.25rem * var(--tw-space-x-reverse));margin-left:calc(.25rem * calc(1 - var(--tw-space-x-reverse)))}.space-x-3>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(.75rem * var(--tw-space-x-reverse));margin-left:calc(.75rem * calc(1 - var(--tw-space-x-reverse)))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.space-y-8>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(2rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(2rem * var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-pre-wrap{white-space:pre-wrap}.break-words{overflow-wrap:break-word}.rounded{border-radius:.25rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.border{border-width:1px}.border-b-2{border-bottom-width:2px}.border-t{border-top-width:1px}.border-gray-100{--tw-border-opacity: 1;border-color:rgb(243 244 246 / var(--tw-border-opacity, 1))}.border-gray-200{--tw-border-opacity: 1;border-color:rgb(229 231 235 / var(--tw-border-opacity, 1))}.border-gray-300{--tw-border-opacity: 1;border-color:rgb(209 213 219 / var(--tw-border-opacity, 1))}.border-indigo-100{--tw-border-opacity: 1;border-color:rgb(224 231 255 / var(--tw-border-opacity, 1))}.border-indigo-200{--tw-border-opacity: 1;border-color:rgb(199 210 254 / var(--tw-border-opacity, 1))}.border-indigo-600{--tw-border-opacity: 1;border-color:rgb(79 70 229 / var(--tw-border-opacity, 1))}.border-red-400{--tw-border-opacity: 1;border-color:rgb(248 113 113 / var(--tw-border-opacity, 1))}.border-transparent{border-color:transparent}.border-yellow-400{--tw-border-opacity: 1;border-color:rgb(250 204 21 / var(--tw-border-opacity, 1))}.bg-\[\#FFDD00\]\/80{background-color:#fd0c}.bg-gray-100{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))}.bg-gray-50{--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity, 1))}.bg-gray-600{--tw-bg-opacity: 1;background-color:rgb(75 85 99 / var(--tw-bg-opacity, 1))}.bg-green-400{--tw-bg-opacity: 1;background-color:rgb(74 222 128 / var(--tw-bg-opacity, 1))}.bg-indigo-100{--tw-bg-opacity: 1;background-color:rgb(224 231 255 / var(--tw-bg-opacity, 1))}.bg-indigo-600{--tw-bg-opacity: 1;background-color:rgb(79 70 229 / var(--tw-bg-opacity, 1))}.bg-red-100{--tw-bg-opacity: 1;background-color:rgb(254 226 226 / var(--tw-bg-opacity, 1))}.bg-red-400{--tw-bg-opacity: 1;background-color:rgb(248 113 113 / var(--tw-bg-opacity, 1))}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.bg-yellow-100{--tw-bg-opacity: 1;background-color:rgb(254 249 195 / var(--tw-bg-opacity, 1))}.bg-opacity-20{--tw-bg-opacity: .2}.bg-opacity-50{--tw-bg-opacity: .5}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.from-indigo-500{--tw-gradient-from: #6366f1 var(--tw-gradient-from-position);--tw-gradient-to: rgb(99 102 241 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-indigo-600{--tw-gradient-from: #4f46e5 var(--tw-gradient-from-position);--tw-gradient-to: rgb(79 70 229 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.to-cyan-500{--tw-gradient-to: #06b6d4 var(--tw-gradient-to-position)}.to-indigo-700{--tw-gradient-to: #4338ca var(--tw-gradient-to-position)}.bg-clip-text{-webkit-background-clip:text;background-clip:text}.object-cover{-o-object-fit:cover;object-fit:cover}.p-2{padding:.5rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-8{padding-top:2rem;padding-bottom:2rem}.text-left{text-align:left}.text-center{text-align:center}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-extrabold{font-weight:800}.font-medium{font-weight:500}.font-semibold{font-weight:600}.text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.text-gray-600{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}.text-gray-700{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1))}.text-gray-800{--tw-text-opacity: 1;color:rgb(31 41 55 / var(--tw-text-opacity, 1))}.text-gray-900{--tw-text-opacity: 1;color:rgb(17 24 39 / var(--tw-text-opacity, 1))}.text-green-500{--tw-text-opacity: 1;color:rgb(34 197 94 / var(--tw-text-opacity, 1))}.text-indigo-100{--tw-text-opacity: 1;color:rgb(224 231 255 / var(--tw-text-opacity, 1))}.text-indigo-200{--tw-text-opacity: 1;color:rgb(199 210 254 / var(--tw-text-opacity, 1))}.text-indigo-500{--tw-text-opacity: 1;color:rgb(99 102 241 / var(--tw-text-opacity, 1))}.text-indigo-600{--tw-text-opacity: 1;color:rgb(79 70 229 / var(--tw-text-opacity, 1))}.text-indigo-700{--tw-text-opacity: 1;color:rgb(67 56 202 / var(--tw-text-opacity, 1))}.text-indigo-800{--tw-text-opacity: 1;color:rgb(55 48 163 / var(--tw-text-opacity, 1))}.text-indigo-900{--tw-text-opacity: 1;color:rgb(49 46 129 / var(--tw-text-opacity, 1))}.text-red-600{--tw-text-opacity: 1;color:rgb(220 38 38 / var(--tw-text-opacity, 1))}.text-red-700{--tw-text-opacity: 1;color:rgb(185 28 28 / var(--tw-text-opacity, 1))}.text-transparent{color:transparent}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.text-yellow-700{--tw-text-opacity: 1;color:rgb(161 98 7 / var(--tw-text-opacity, 1))}.underline{text-decoration-line:underline}.opacity-0{opacity:0}.opacity-100{opacity:1}.shadow-2xl{--tw-shadow: 0 25px 50px -12px rgb(0 0 0 / .25);--tw-shadow-colored: 0 25px 50px -12px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-md{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur-sm{--tw-backdrop-blur: blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-shadow{transition-property:box-shadow;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-150{transition-duration:.15s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}:root{--slate-dark: #0F1115;--graphite: #1C1F26;--graphite-light: #252931;--graphite-lighter: #2E333D;--ash-text: #E5E7EB;--ash-text-muted: #B8BCC4;--ash-text-dim: #8B9099;--accent-primary: #6B7AFF;--accent-primary-hover: #5B6CFF;--accent-primary-glow: rgba(107, 122, 255, .3);--accent-secondary: #5EDCC2;--accent-warning: #F2B705;--accent-success: #10B981;--accent-error: #EF4444;--primary-color: var(--accent-primary);--primary-hover: var(--accent-primary-hover);--accent-color: var(--accent-secondary);--secondary-color: var(--ash-text-muted);--dark-text: var(--ash-text);--light-text: var(--ash-text);--light-bg: var(--graphite);--dark-bg: var(--slate-dark);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .3);--shadow-sm: 0 2px 4px rgba(0, 0, 0, .3);--shadow: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .5);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .6);--shadow-glow: 0 0 20px var(--accent-primary-glow);--radius-sm: .375rem;--radius: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--border-radius: var(--radius);--border-radius-sm: var(--radius-sm);--transition-fast: .15s ease;--transition: .25s ease;--transition-slow: .4s ease;--font-xs: .75rem;--font-sm: .875rem;--font-base: 1rem;--font-lg: 1.125rem;--font-xl: 1.25rem;--font-2xl: 1.5rem;--font-3xl: 1.875rem;--font-4xl: 2.25rem;--font-5xl: 3rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--bg-overlay: linear-gradient(135deg, rgba(15, 17, 21, .92) 0%, rgba(28, 31, 38, .88) 100%)}.light-mode{--slate-dark: #F8FAFC;--graphite: #FFFFFF;--graphite-light: #F1F5F9;--graphite-lighter: #E2E8F0;--ash-text: #1E293B;--ash-text-muted: #64748B;--ash-text-dim: #94A3B8;--accent-primary-glow: rgba(91, 108, 255, .2);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .05);--shadow-sm: 0 2px 4px rgba(0, 0, 0, .08);--shadow: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12);--bg-overlay: linear-gradient(135deg, rgba(248, 250, 252, .95) 0%, rgba(241, 245, 249, .92) 100%)}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0;padding:0;min-height:100vh;box-sizing:border-box;color:var(--ash-text);background-color:var(--slate-dark);background-image:url(https://f8ad2fb8.smartbookshelf-assets.pages.dev/background.webp);background-size:cover;background-position:center;background-attachment:fixed;line-height:1.6;position:relative;content-visibility:auto;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:before{content:"";position:fixed;inset:0;background:var(--bg-overlay);z-index:-1;pointer-events:none}h1,h2,h3,h4,h5,h6{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.2;font-weight:600;color:var(--ash-text);letter-spacing:-.02em}h1{font-size:var(--font-4xl);font-weight:700}h2{font-size:var(--font-2xl)}h3{font-size:var(--font-xl)}h4{font-size:var(--font-lg)}p{color:var(--ash-text-muted);line-height:1.7}a{font-weight:500;color:var(--accent-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-primary-hover)}button{border-radius:var(--radius);border:1px solid transparent;padding:.625rem 1.25rem;font-size:var(--font-sm);font-weight:500;font-family:inherit;background-color:var(--graphite-light);color:var(--ash-text);cursor:pointer;transition:all var(--transition-fast)}button:hover{background-color:var(--graphite-lighter)}button:focus,button:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}.btn-primary{background:var(--accent-primary);color:#fff;border:none;font-weight:600;box-shadow:var(--shadow-sm),0 0 0 0 var(--accent-primary-glow);transition:all var(--transition)}.btn-primary:hover{background:var(--accent-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow),var(--shadow-glow)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:transparent;color:var(--ash-text);border:1px solid var(--graphite-lighter)}.btn-secondary:hover{background:var(--graphite-light);border-color:var(--ash-text-dim)}.card{background:var(--graphite);border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.06);box-shadow:var(--shadow-sm);transition:all var(--transition)}.card:hover{border-color:#ffffff1a;box-shadow:var(--shadow)}.card-elevated{background:var(--graphite-light)}.glass{background:#1c1f26cc;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.08)}input[type=text],input[type=email],input[type=password],textarea{background:var(--graphite);border:1px solid var(--graphite-lighter);border-radius:var(--radius);padding:.75rem 1rem;color:var(--ash-text);font-size:var(--font-base);transition:all var(--transition-fast)}input:focus,textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-glow)}input::-moz-placeholder,textarea::-moz-placeholder{color:var(--ash-text-dim)}input::placeholder,textarea::placeholder{color:var(--ash-text-dim)}input[type=file]{display:none}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--slate-dark)}::-webkit-scrollbar-thumb{background-color:var(--graphite-lighter);border-radius:4px}::-webkit-scrollbar-thumb:hover{background-color:var(--ash-text-dim)}.text-gradient{background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.text-muted{color:var(--ash-text-muted)}.text-dim{color:var(--ash-text-dim)}.accent{color:var(--accent-primary)}.glow{box-shadow:var(--shadow-glow)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.fade-in{animation:fadeIn .4s ease forwards}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-spin{animation:spin 1s linear infinite}.animate-float{animation:float 3s ease-in-out infinite}.skeleton{background:linear-gradient(90deg,var(--graphite) 0%,var(--graphite-light) 50%,var(--graphite) 100%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius)}@media (max-width: 768px){:root{--font-4xl: 1.875rem;--font-3xl: 1.5rem;--font-2xl: 1.25rem}body{background-attachment:scroll}}@media (max-width: 480px){:root{--font-4xl: 1.5rem;--font-3xl: 1.25rem}}@media print{body{background:#fff;color:#000}body:before{display:none}}*{box-sizing:border-box;margin:0;padding:0}img{max-width:100%;height:auto}::-moz-selection{background:var(--accent-primary);color:#fff}::selection{background:var(--accent-primary);color:#fff}.hover\:translate-y-\[-2px\]:hover{--tw-translate-y: -2px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:transform:hover{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:bg-\[\#FFDD00\]:hover{--tw-bg-opacity: 1;background-color:rgb(255 221 0 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-100:hover{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-50:hover{--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity, 1))}.hover\:bg-indigo-100:hover{--tw-bg-opacity: 1;background-color:rgb(224 231 255 / var(--tw-bg-opacity, 1))}.hover\:bg-indigo-200:hover{--tw-bg-opacity: 1;background-color:rgb(199 210 254 / var(--tw-bg-opacity, 1))}.hover\:bg-indigo-50:hover{--tw-bg-opacity: 1;background-color:rgb(238 242 255 / var(--tw-bg-opacity, 1))}.hover\:bg-indigo-700:hover{--tw-bg-opacity: 1;background-color:rgb(67 56 202 / var(--tw-bg-opacity, 1))}.hover\:bg-red-50:hover{--tw-bg-opacity: 1;background-color:rgb(254 242 242 / var(--tw-bg-opacity, 1))}.hover\:from-indigo-700:hover{--tw-gradient-from: #4338ca var(--tw-gradient-from-position);--tw-gradient-to: rgb(67 56 202 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.hover\:to-indigo-800:hover{--tw-gradient-to: #3730a3 var(--tw-gradient-to-position)}.hover\:text-gray-500:hover{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.hover\:text-gray-600:hover{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}.hover\:text-indigo-600:hover{--tw-text-opacity: 1;color:rgb(79 70 229 / var(--tw-text-opacity, 1))}.hover\:text-indigo-700:hover{--tw-text-opacity: 1;color:rgb(67 56 202 / var(--tw-text-opacity, 1))}.hover\:text-indigo-800:hover{--tw-text-opacity: 1;color:rgb(55 48 163 / var(--tw-text-opacity, 1))}.hover\:text-red-800:hover{--tw-text-opacity: 1;color:rgb(153 27 27 / var(--tw-text-opacity, 1))}.hover\:shadow:hover{--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.hover\:shadow-md:hover{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.focus\:border-indigo-500:focus{--tw-border-opacity: 1;border-color:rgb(99 102 241 / var(--tw-border-opacity, 1))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-indigo-500:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(99 102 241 / var(--tw-ring-opacity, 1))}.focus\:ring-offset-2:focus{--tw-ring-offset-width: 2px}.disabled\:opacity-50:disabled{opacity:.5}@media (min-width: 640px){.sm\:not-sr-only{position:static;width:auto;height:auto;padding:0;margin:0;overflow:visible;clip:auto;white-space:normal}.sm\:col-span-2{grid-column:span 2 / span 2}.sm\:inline{display:inline}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}}@media (min-width: 768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width: 1024px){.lg\:px-8{padding-left:2rem;padding-right:2rem}}
