:root{--color-bg: #f5f5f5;--color-surface: #ffffff;--color-text: #1a1a1a;--color-text-muted: #555555;--color-accent: #333333;--color-border: #e0e0e0;--color-focus: #333333;--font-sans: "DM Sans", system-ui, sans-serif;--font-serif: "Source Serif 4", Georgia, serif;--text-base: 18px;--text-sm: .9rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--line-height: 1.6;--line-height-tight: 1.4;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--max-width: 900px;--radius: 10px;--radius-sm: 8px;--focus-ring: 2px solid var(--color-focus);--focus-offset: 2px}*,*:before,*:after{box-sizing:border-box}html{font-size:var(--text-base);line-height:var(--line-height);-webkit-font-smoothing:antialiased}body{margin:0;font-family:var(--font-sans);color:var(--color-text);background-color:var(--color-bg);min-height:100vh}:focus-visible{outline:var(--focus-ring);outline-offset:var(--focus-offset)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}a{color:var(--color-accent);text-decoration:underline;text-underline-offset:2px}a:hover{text-decoration-thickness:2px}h1,h2,h3{font-family:var(--font-serif);font-weight:600;line-height:var(--line-height-tight)}h1{font-size:var(--text-2xl)}h2{font-size:var(--text-xl)}h3{font-size:var(--text-lg)}.shell{min-height:100vh;display:flex;flex-direction:column;align-items:center}.shell__main{width:100%;max-width:var(--max-width);padding:var(--space-lg);flex:1}.skip-link{position:absolute;top:var(--space-sm);left:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:500;color:var(--color-text);z-index:100;text-decoration:none;transform:translateY(-120%);transition:transform .2s}.skip-link:focus{transform:translateY(0)}.top-bar{width:100%;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border);background:var(--color-surface)}.top-bar__inner{width:100%;max-width:var(--max-width);margin:0 auto;display:flex;justify-content:space-between;align-items:center}.top-bar__logo{display:flex;align-items:center;gap:var(--space-sm);font-family:var(--font-serif);font-weight:600;font-size:var(--text-lg);color:var(--color-text);text-decoration:none}.top-bar__logo-img{height:32px;width:auto}.top-bar__logo:hover{text-decoration:underline}.top-bar__actions{display:flex;align-items:center;gap:var(--space-lg)}.top-bar__demo{font-size:var(--text-sm);color:var(--color-text-muted);text-decoration:none}.top-bar__demo:hover{color:var(--color-text);text-decoration:underline}.top-bar__settings{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;color:var(--color-text-muted);text-decoration:none;border-radius:var(--radius-sm)}.top-bar__settings:hover{color:var(--color-text)}.theme-pill{display:flex;align-items:center;background:var(--color-bg);border:1px solid var(--color-border);border-radius:999px;padding:2px;gap:0}.theme-pill__option{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border:none;border-radius:999px;cursor:pointer;background:transparent;color:var(--color-text-muted);transition:background-color .2s ease,color .2s ease}.theme-pill__option:hover{color:var(--color-text)}.theme-pill__option--active{background:var(--color-surface);color:var(--color-text);box-shadow:0 1px 3px #0000001a}body.theme-dark .theme-pill__option--active{box-shadow:0 1px 3px #0000004d}.help-fab{position:fixed;bottom:var(--space-lg);right:var(--space-lg);width:40px;height:40px;padding:0;display:flex;align-items:center;justify-content:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:50%;cursor:pointer;color:var(--color-text-muted);box-shadow:0 1px 4px #00000014;z-index:40}.help-fab:hover{color:var(--color-text);box-shadow:0 2px 6px #0000001a}.help-fab__icon{font-size:1.25rem;font-weight:600;font-family:var(--font-sans);line-height:1}.search-results-toolbar{display:flex;flex-wrap:wrap;gap:var(--space-md);align-items:center;margin-bottom:var(--space-xl);padding:var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius)}.search-results-toolbar__sort{display:flex;align-items:center;gap:var(--space-sm)}.search-results-toolbar__sort label{font-size:var(--text-sm);font-weight:500;color:var(--color-text-muted)}.search-results-toolbar select{padding:var(--space-xs) var(--space-xl) var(--space-xs) var(--space-sm);font-size:var(--text-sm);line-height:1.4;font-family:inherit;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-text);cursor:pointer}.search-results-toolbar select:focus{outline:var(--focus-ring);outline-offset:var(--focus-offset)}.search-results__compare-btn{font-size:var(--text-sm);line-height:1.4;color:var(--color-text);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-xs) var(--space-md);cursor:pointer;font-family:inherit}.search-results__compare-btn:hover{border-color:var(--color-text-muted)}.search-results__compare-btn--active{color:var(--color-text);font-weight:500;border-color:var(--color-accent)}.product-list{list-style:none;padding:0;margin:0;display:grid;gap:var(--space-lg)}.product-card{padding:var(--space-lg);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius)}.product-card__row{display:flex;align-items:flex-start;gap:var(--space-lg)}.product-card__thumb{flex-shrink:0}.product-card__thumb img{width:80px;height:80px;object-fit:contain;border-radius:var(--radius-sm);background:transparent}.product-card__content{flex:1;min-width:0}.product-card__title{margin:0 0 var(--space-sm)}.product-card__meta{color:var(--color-text-muted);font-size:var(--text-sm);margin-bottom:var(--space-md)}.product-card__link{display:inline-block;padding:var(--space-sm) var(--space-md);background:var(--color-accent);color:var(--color-surface);border-radius:var(--radius-sm);text-decoration:none;font-weight:500}.product-card__link:hover{opacity:.9}.product-card--compare-mode{cursor:pointer}.product-card--compare-mode:hover{border-color:var(--color-text-muted)}.product-card--selected{border:3px solid var(--color-accent);box-shadow:0 0 0 2px var(--color-accent)}.section-card{padding:var(--space-lg);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);margin-bottom:var(--space-lg)}.passport-body{font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.6}.passport-body strong{color:var(--color-text);font-weight:600}.passport-body__subtitle{font-size:var(--text-base);font-weight:600;color:var(--color-text);margin:0 0 var(--space-sm)}.passport-body__list{margin:0;padding-left:var(--space-lg);font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.6}.passport-body__list li{margin-bottom:var(--space-xs)}.section-card__header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-md);margin-bottom:var(--space-md)}.section-card__title{margin:0}.stat-pill{display:inline-block;padding:var(--space-xs) var(--space-sm);background:var(--color-bg);border-radius:var(--radius-sm);font-size:var(--text-sm);color:var(--color-text-muted)}.toggle{display:flex;align-items:center;gap:var(--space-sm)}.toggle__label{font-size:var(--text-sm);font-weight:500}.toggle__input{width:44px;height:24px;accent-color:var(--color-accent)}.tts-controls{display:flex;flex-wrap:wrap;gap:var(--space-sm);align-items:center}.tts-controls__btn{padding:var(--space-sm) var(--space-md);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:500;cursor:pointer;font-family:inherit;color:var(--color-text)}.tts-controls__btn:hover{background:var(--color-border)}.tts-controls__btn:disabled{opacity:.5;cursor:not-allowed}.tts-controls__speed{display:flex;align-items:center;gap:var(--space-sm)}.tts-controls__speed label{font-size:var(--text-sm)}.loading-spinner{width:36px;height:36px;border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:loading-spin .7s linear infinite}@keyframes loading-spin{to{transform:rotate(360deg)}}.passport-loading{min-height:120px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-xl)}.passport-loading p{margin:0;color:var(--color-text-muted)}.section-card--loading{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);padding:var(--space-xl)}.section-card--loading .loading-spinner{flex-shrink:0}.passport-header{margin-bottom:var(--space-xl)}.passport-header__back{display:inline-block;margin-bottom:var(--space-md);font-size:var(--text-sm)}.passport-header__title{margin:0 0 var(--space-md)}.passport-header__stats{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-lg)}.read-section-btn{margin-top:var(--space-sm);padding:var(--space-xs) var(--space-sm);font-size:var(--text-sm);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;font-family:inherit;color:var(--color-accent)}.read-section-btn:hover{background:var(--color-bg)}.sustainable-badge{display:inline-block;padding:var(--space-xs) var(--space-sm);background:#e8f5e9;color:#2e7d32;border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:500}.error-card{padding:var(--space-xl);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);text-align:center}.error-card__message{margin-bottom:var(--space-md)}.tts-banner{padding:var(--space-md);background:#fff3e0;border:1px solid #ffcc80;border-radius:var(--radius-sm);font-size:var(--text-sm);margin-bottom:var(--space-lg)}.landing-header{text-align:center;margin-bottom:var(--space-xl);padding:var(--space-xl) 0}.landing-header h1{font-family:var(--font-serif);font-size:3rem;margin:0 0 var(--space-md);color:var(--color-text)}.tagline{font-size:var(--text-lg);color:var(--color-text-muted);margin:0}.url-input-section{max-width:600px;margin:0 auto var(--space-xl);padding:var(--space-xl);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius)}.search-section .form-row{display:flex;gap:var(--space-xl);margin-bottom:var(--space-md);padding:0}.search-section .form-row .form-group:first-child{flex:0 0 auto;min-width:140px}.search-section .form-row .form-group:last-child{flex:1;min-width:200px}.url-input-section h2{margin-top:0}.url-form{margin-top:var(--space-lg)}.form-group{margin-bottom:var(--space-md)}.form-group label{display:block;margin-bottom:var(--space-xs);font-weight:500;font-size:var(--text-sm)}.form-row{display:flex;flex-wrap:wrap;gap:var(--space-md);margin-bottom:var(--space-md)}.form-row .form-group--flex{flex:1;min-width:180px}.form-group input[type=url],.form-group input[type=text],.form-group select{width:100%;padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--text-base);font-family:inherit;background:var(--color-bg)}.form-group select{padding-right:var(--space-xl)}.form-group input[type=url]:focus,.form-group input[type=text]:focus,.form-group select:focus{outline:2px solid var(--color-accent);outline-offset:2px}.form-group input[type=url]:disabled,.form-group input[type=text]:disabled,.form-group select:disabled{opacity:.6;cursor:not-allowed}.form-group select{cursor:pointer;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.btn-primary{width:100%;padding:var(--space-md);background:var(--color-accent);color:var(--color-surface);border:none;border-radius:var(--radius-sm);font-size:var(--text-base);font-weight:500;font-family:inherit;cursor:pointer}.btn-primary:hover:not(:disabled){opacity:.9}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.error-message{margin-top:var(--space-md);padding:var(--space-md);background:#ffebee;border:1px solid #ef5350;border-radius:var(--radius-sm);color:#c62828;font-size:var(--text-sm)}.loading-message{margin-top:var(--space-md);padding:var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-size:var(--text-sm);text-align:center;display:flex;align-items:center;justify-content:center;gap:var(--space-md)}.demo-section{margin:var(--space-xl) 0}.demo-section h2{margin-bottom:var(--space-md)}.about-section{max-width:700px;margin:var(--space-xl) auto;padding:var(--space-xl);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius)}.about-section h2{margin-top:0}.about-section ul{padding-left:var(--space-lg)}.about-section li{margin-bottom:var(--space-sm)}.sustainability-overview{display:flex;align-items:baseline;gap:var(--space-sm);flex-wrap:wrap;margin-bottom:var(--space-xl);padding-bottom:var(--space-xl);border-bottom:1px solid var(--color-border)}.sustainability-overview__label{font-size:var(--text-base);font-weight:600;color:var(--color-text)}.sustainability-overview__score{font-size:var(--text-base);font-weight:600;color:var(--color-text);font-variant-numeric:tabular-nums}.sustainability-category{margin-bottom:var(--space-lg);padding-bottom:var(--space-lg);border-bottom:1px solid var(--color-border)}.sustainability-category:last-of-type{border-bottom:none;margin-bottom:0;padding-bottom:0}.sustainability-category__header{display:flex;justify-content:space-between;align-items:baseline;gap:var(--space-md);margin-bottom:var(--space-sm)}.sustainability-category__title{font-size:var(--text-base);font-weight:600;margin:0}.sustainability-category__score{font-size:var(--text-sm);color:var(--color-text-muted);font-variant-numeric:tabular-nums}.sustainability-category__details{margin:0;padding-left:var(--space-lg);font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.6}.sustainability-category__details li{margin-bottom:var(--space-xs)}.sustainability-badges{margin-top:var(--space-lg);padding-top:var(--space-lg);border-top:1px solid var(--color-border)}.sustainability-badges__title{font-size:var(--text-base);font-weight:600;margin:0 0 var(--space-sm)}.compare-product-chips{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-lg)}.compare-product-chip{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--text-sm)}.compare-product-chip__name{font-weight:500}.compare-remove-btn{padding:var(--space-xs) var(--space-sm);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--text-xs);cursor:pointer;font-family:inherit;color:var(--color-text-muted)}.compare-remove-btn:hover{color:var(--color-text);border-color:var(--color-text-muted)}.compare-clear-btn{padding:var(--space-xs) var(--space-sm);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--text-xs);cursor:pointer;font-family:inherit;color:var(--color-text-muted)}.compare-clear-btn:hover{color:var(--color-text);border-color:var(--color-text-muted)}.compare-add-btn{padding:var(--space-xs) var(--space-sm);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--text-sm);cursor:pointer;font-family:inherit;color:var(--color-text-muted)}.compare-add-btn:hover:not(:disabled){color:var(--color-text);border-color:var(--color-text-muted)}.compare-add-btn:disabled{opacity:.6;cursor:not-allowed}.compare-bar{position:sticky;top:0;z-index:30;width:100%;padding:var(--space-sm) var(--space-lg);background:var(--color-surface);border-bottom:1px solid var(--color-border)}.compare-bar__inner{width:100%;max-width:var(--max-width);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:var(--space-lg)}.compare-bar__count{font-size:var(--text-sm);color:var(--color-text-muted)}.compare-bar__actions{display:flex;align-items:center;gap:var(--space-sm)}.compare-bar__btn{padding:var(--space-xs) var(--space-md);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:500;cursor:pointer;font-family:inherit}.compare-bar__btn--primary{background:var(--color-accent);color:var(--color-surface);border:none}.compare-bar__btn--primary:hover:not(:disabled){opacity:.9}.compare-bar__btn--primary:disabled{opacity:.5;cursor:not-allowed}.compare-bar__btn--secondary{background:transparent;color:var(--color-text-muted);border:1px solid var(--color-border)}.compare-bar__btn--secondary:hover{color:var(--color-text);border-color:var(--color-text-muted)}.compare-select-btn{padding:var(--space-xs) var(--space-sm);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--text-sm);color:var(--color-text-muted);cursor:pointer;font-family:inherit}.compare-select-btn:hover:not(:disabled){color:var(--color-text);border-color:var(--color-text-muted)}.compare-select-btn[aria-pressed=true]{background:var(--color-accent);color:var(--color-surface);border-color:var(--color-accent)}.compare-select-btn:disabled{opacity:.6;cursor:not-allowed}.tts-captions{position:fixed;bottom:0;left:0;right:0;max-height:25vh;overflow-y:auto;padding:var(--space-md) var(--space-lg);background:var(--color-surface);border-top:1px solid var(--color-border);z-index:50}.tts-captions__content{max-width:var(--max-width);margin:0 auto;font-size:var(--text-base);line-height:1.6;color:var(--color-text-muted)}.tts-captions__sentence{transition:background-color .15s ease,color .15s ease}.tts-captions__sentence--active{background:var(--color-accent);color:var(--color-surface);padding:.1em .2em;border-radius:var(--radius-sm)}.help-modal{max-width:min(680px,92vw);max-height:85vh;padding:0;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);box-shadow:0 4px 24px #00000026}.help-modal::backdrop{background:#0006}.help-modal__inner{padding:var(--space-xl);overflow-y:auto;max-height:85vh}.help-modal__title{margin:0 0 var(--space-lg);font-size:var(--text-xl)}.help-modal__content{font-size:var(--text-base);line-height:1.6;margin-bottom:var(--space-lg)}.help-modal__content ul{margin:0;padding-left:var(--space-lg)}.help-modal__content li{margin-bottom:var(--space-sm)}.help-modal__shortcuts-box{margin-top:var(--space-lg);padding:var(--space-md);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm)}.help-modal__shortcuts-title{margin:0 0 var(--space-sm);font-size:var(--text-base);font-weight:600}.help-modal__shortcuts{margin:0;display:grid;grid-template-columns:auto 1fr;gap:var(--space-xs) var(--space-md);align-items:baseline}.help-modal__shortcuts dt{margin:0;font-weight:600;font-family:var(--font-mono, monospace)}.help-modal__shortcuts dd{margin:0;color:var(--color-text-muted)}.help-modal__actions{display:flex;justify-content:flex-end}.help-modal__close{padding:var(--space-sm) var(--space-md);background:var(--color-accent);color:var(--color-surface);border:none;border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:500;cursor:pointer;font-family:inherit}.help-modal__close:hover{opacity:.9}body.low-vision{--color-bg: #f0f0f0;--color-surface: #ffffff;--color-text: #000000;--color-text-muted: #333333;--color-accent: #000000;--color-border: #999999;--text-base: 20px;--text-sm: 1rem;--text-lg: 1.25rem;--text-xl: 1.5rem;--text-2xl: 1.75rem;--line-height: 1.7}body.low-vision .section-card,body.low-vision .product-card{border-width:2px}body.low-vision a{font-weight:500}body.theme-dark{--color-bg: #1a1816;--color-surface: #2c2825;--color-text: #f5f3ef;--color-text-muted: #b8b2a8;--color-accent: #d4c4a8;--color-border: #4a4540;--color-focus: #d4c4a8;--color-error: #e88}body.theme-dark.low-vision{--color-bg: #1a1816;--color-surface: #2c2825;--color-text: #f5f3ef;--color-text-muted: #b8b2a8;--color-accent: #d4c4a8;--color-border: #5c554d}body.theme-dark .help-fab{background:#ffffff1f;border-color:#fff3}@font-face{font-family:OpenDyslexic;src:url(https://unpkg.com/open-dyslexic@1.0.3/woff/OpenDyslexic-Regular.woff) format("woff");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:OpenDyslexic;src:url(https://unpkg.com/open-dyslexic@1.0.3/woff/OpenDyslexic-Bold.woff) format("woff");font-weight:700;font-style:normal;font-display:swap}body.preferences-dyslexia-font{--font-sans: "OpenDyslexic", "Comic Sans MS", sans-serif;--font-serif: "OpenDyslexic", "Comic Sans MS", serif}body.preferences-font-small{--text-base: 16px;--text-sm: .875rem;--text-lg: 1.0625rem;--text-xl: 1.1875rem;--text-2xl: 1.375rem}body.preferences-font-medium{--text-base: 18px;--text-sm: .9rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem}body.preferences-font-large{--text-base: 20px;--text-sm: .95rem;--text-lg: 1.1875rem;--text-xl: 1.3125rem;--text-2xl: 1.625rem}@media (prefers-reduced-motion: reduce){body:not(.preferences-reduced-motion-off) *,body:not(.preferences-reduced-motion-off) *:before,body:not(.preferences-reduced-motion-off) *:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}body.preferences-reduced-motion-on *,body.preferences-reduced-motion-on *:before,body.preferences-reduced-motion-on *:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}body.preferences-highlight-focus :focus-visible{outline-width:3px;outline-offset:3px}
