:root{--fg:15 15 18;--muted:100 100 110;--bg:250 250 252;--surface:255 255 255;--border:220 220 228;--input-bg:255 255 255;--accent:99 102 241;--on-accent:255 255 255;--chip-bg:238 238 246;--chip-fg:70 70 85;--ok:22 163 74;--err:220 38 38;font-family:SF Pro Text,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.45;color:rgb(var(--fg));background:rgb(var(--bg));font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}@media (prefers-color-scheme:dark){:root{--fg:245 245 248;--muted:160 160 175;--bg:18 18 22;--surface:28 28 34;--border:55 55 65;--input-bg:22 22 28;--chip-bg:45 45 55;--chip-fg:200 200 210}}body,html{min-height:100dvh}body{margin:0}*{box-sizing:border-box}.app{max-width:42rem;margin:0 auto;padding:1.25rem 1rem 2.5rem;text-align:left}.hero{margin-bottom:2rem}.eyebrow{font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;color:rgb(var(--muted)/.95);margin:0 0 .5rem}.hero h1{font-size:1.75rem;line-height:1.15;letter-spacing:-.02em;margin:0 0 .75rem;color:rgb(var(--fg))}.lede{margin:0;color:rgb(var(--muted));line-height:1.5;font-size:.95rem}.section h2{font-size:1.1rem;margin:0 0 1rem;color:rgb(var(--fg))}.grid{list-style:none;margin:0;padding:0;display:grid;grid-gap:.75rem;gap:.75rem}@media (min-width:520px){.grid{grid-template-columns:1fr 1fr}}.card{width:100%;text-align:left;border:1px solid rgb(var(--border));border-radius:12px;padding:1rem 1rem .9rem;background:rgb(var(--surface));color:inherit;font:inherit;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease}.card:hover{border-color:rgb(var(--accent)/.45)}.card--active{border-color:rgb(var(--accent));box-shadow:0 0 0 1px rgb(var(--accent)/.35)}.card__price{font-size:.8rem;color:rgb(var(--accent))}.card__price,.card__title{display:block;font-weight:600;margin-bottom:.35rem}.card__title{font-size:1rem;color:rgb(var(--fg))}.card__blurb{display:block;font-size:.85rem;color:rgb(var(--muted));line-height:1.45;margin-bottom:.65rem}.card__tags{display:flex;flex-wrap:wrap;gap:.35rem}.tag{font-size:.7rem;padding:.2rem .45rem;border-radius:6px;background:rgb(var(--chip-bg));color:rgb(var(--chip-fg))}.section--form{margin-top:2.25rem;padding-top:1.5rem;border-top:1px solid rgb(var(--border))}.selected-line{margin:0 0 1rem;font-size:.9rem;color:rgb(var(--muted))}.selected-line strong{color:rgb(var(--fg))}.hint{margin:0 0 1rem;color:rgb(var(--muted));font-size:.9rem}.form{gap:1rem}.field,.form{display:flex;flex-direction:column}.field{gap:.35rem;font-size:.85rem}.field span{color:rgb(var(--muted))}.field input,.field select,.field textarea{font:inherit;font-size:1rem;padding:.6rem .65rem;border-radius:10px;border:1px solid rgb(var(--border));background:rgb(var(--input-bg));color:rgb(var(--fg))}.field textarea{resize:vertical;min-height:5rem}.file-hint{margin:0;font-size:.8rem;color:rgb(var(--muted));line-height:1.45}.submit{font:inherit;font-size:1rem;font-weight:600;padding:.85rem 1rem;border:none;border-radius:12px;background:rgb(var(--accent));color:rgb(var(--on-accent));cursor:pointer;margin-top:.25rem}.submit:disabled{opacity:.45;cursor:not-allowed}.feedback{margin:0;font-size:.9rem;line-height:1.45}.feedback--ok{color:rgb(var(--ok))}.feedback--err{color:rgb(var(--err))}.foot{margin-top:2.5rem;padding-top:1.25rem;border-top:1px solid rgb(var(--border))}.foot p{margin:0;font-size:.75rem;color:rgb(var(--muted));line-height:1.5}.foot a{color:rgb(var(--accent));text-decoration:none}.foot a:hover{text-decoration:underline}.site-header{position:-webkit-sticky;position:sticky;top:0;z-index:10;border-bottom:1px solid rgb(var(--border));background:rgb(var(--bg)/.92);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.site-header__inner{max-width:72rem;margin:0 auto;padding:.65rem 1rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.site-header__brand{font-weight:700;font-size:1rem;color:rgb(var(--fg));text-decoration:none;letter-spacing:-.02em}.site-header__brand:hover{color:rgb(var(--accent))}.site-header__nav{display:flex;gap:1rem;font-size:.9rem}.site-header__nav a{color:rgb(var(--muted));text-decoration:none}.site-header__nav a:hover{color:rgb(var(--accent))}.app--catalog{max-width:72rem}.catalog{padding-bottom:2rem}.catalog__hero{margin-bottom:1.25rem}.catalog__hero h1{font-size:1.6rem;letter-spacing:-.02em;margin:0 0 .5rem}.catalog__lede{margin:0;font-size:.9rem;color:rgb(var(--muted));line-height:1.5;max-width:40rem}.catalog__lede code{font-size:.8em;padding:.1rem .25rem;border-radius:4px;background:rgb(var(--chip-bg))}.catalog__toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:.6rem 1rem;margin-bottom:1.25rem;padding:.75rem 0;border-bottom:1px solid rgb(var(--border))}.catalog__toolbar-label{font-size:.8rem;color:rgb(var(--muted))}.catalog__chips{display:flex;flex-wrap:wrap;gap:.4rem}.catalog__chip{font:inherit;font-size:.8rem;padding:.35rem .65rem;border-radius:999px;border:1px solid rgb(var(--border));background:rgb(var(--surface));color:rgb(var(--fg));cursor:pointer}.catalog__chip--active{border-color:rgb(var(--accent));background:rgb(var(--accent)/.1);color:rgb(var(--accent))}.catalog__refresh{font:inherit;font-size:.8rem;margin-left:auto;padding:.35rem .65rem;border-radius:8px;border:1px solid rgb(var(--border));background:rgb(var(--surface));color:rgb(var(--muted));cursor:pointer}.catalog__refresh:hover{border-color:rgb(var(--accent)/.45);color:rgb(var(--fg))}.catalog__state{margin:1.5rem 0;color:rgb(var(--muted));font-size:.95rem}.catalog__banner{margin:0 0 1rem;padding:.65rem .85rem;border-radius:10px;background:rgb(var(--chip-bg));color:rgb(var(--chip-fg));font-size:.85rem;line-height:1.45}.catalog__grid{list-style:none;margin:0;padding:0;display:grid;grid-gap:1rem;gap:1rem;grid-template-columns:1fr}@media (min-width:560px){.catalog__grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:960px){.catalog__grid{grid-template-columns:repeat(3,1fr)}}.product-card{border:1px solid rgb(var(--border));border-radius:14px;overflow:hidden;background:rgb(var(--surface));height:100%;display:flex;flex-direction:column}.product-card--link{text-decoration:none;color:inherit;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease}.product-card--link:hover{border-color:rgb(var(--accent)/.45);box-shadow:0 8px 24px rgb(var(--fg)/.06);transform:translateY(-1px)}.product-card__media{aspect-ratio:4/3;background:rgb(var(--chip-bg))}.product-card__img{width:100%;height:100%;object-fit:cover;display:block}.product-card__placeholder{width:100%;height:100%;background:linear-gradient(135deg,rgb(var(--chip-bg)),rgb(var(--border)/.35))}.product-card__body{padding:.9rem 1rem 1rem;display:flex;flex-direction:column;gap:.35rem;flex:1 1}.product-card__price{margin:0;font-size:.85rem;font-weight:600;color:rgb(var(--accent))}.product-card__title{margin:0;font-size:1rem;font-weight:600;color:rgb(var(--fg));line-height:1.3}.product-card__desc{margin:0;font-size:.8rem;color:rgb(var(--muted));line-height:1.45;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3;overflow:hidden}.product-card__tags{margin-top:auto;padding-top:.5rem;display:flex;flex-wrap:wrap;gap:.35rem}.product-details{padding-bottom:2rem}.product-details__crumbs{display:flex;flex-wrap:wrap;gap:.45rem;margin-bottom:1.25rem;font-size:.85rem;color:rgb(var(--muted))}.product-details__crumbs a{color:rgb(var(--accent));text-decoration:none}.product-details__crumbs a:hover{text-decoration:underline}.product-details__layout{display:grid;grid-gap:1.5rem;gap:1.5rem}@media (min-width:880px){.product-details__layout{grid-template-columns:minmax(0,1.1fr) minmax(20rem,.9fr);align-items:start}}.product-details__gallery,.product-details__summary{border:1px solid rgb(var(--border));border-radius:18px;background:rgb(var(--surface));padding:1rem}.product-details__hero{aspect-ratio:4/3;border-radius:14px;overflow:hidden;background:rgb(var(--chip-bg))}.product-details__hero-img,.product-details__thumb-img{width:100%;height:100%;object-fit:cover;display:block}.product-details__hero-placeholder{width:100%;height:100%;background:linear-gradient(135deg,rgb(var(--chip-bg)),rgb(var(--border)/.35))}.product-details__thumbs{display:grid;grid-template-columns:repeat(auto-fit,minmax(4.5rem,1fr));grid-gap:.65rem;gap:.65rem;margin-top:.85rem}.product-details__thumb{aspect-ratio:1;border-radius:12px;overflow:hidden;border:1px solid rgb(var(--border));background:rgb(var(--chip-bg));padding:0;cursor:pointer}.product-details__thumb--active{border-color:rgb(var(--accent));box-shadow:0 0 0 1px rgb(var(--accent)/.25)}.product-details__summary h1{margin:0 0 .5rem;font-size:clamp(1.7rem,4vw,2.35rem);line-height:1.1;letter-spacing:-.03em}.product-details__price{margin:0 0 1rem;font-size:1.1rem;font-weight:700;color:rgb(var(--accent))}.product-details__description{margin:0 0 1.25rem;color:rgb(var(--fg));line-height:1.6}.product-details__description--muted{color:rgb(var(--muted))}.product-details__meta{display:grid;grid-gap:1rem;gap:1rem}.product-details__meta h2{margin:0 0 .6rem;font-size:.95rem}.product-details__tags{display:flex;flex-wrap:wrap;gap:.4rem}.product-details__bullets{margin:0;padding-left:1.1rem;color:rgb(var(--muted));font-size:.92rem}.product-details__bullets li+li{margin-top:.45rem}.product-details__actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.5rem}.product-details__action{min-width:11rem;font:inherit;font-weight:600;padding:.85rem 1rem;border-radius:12px;border:1px solid rgb(var(--accent));background:rgb(var(--accent));color:rgb(var(--on-accent));opacity:.72;cursor:not-allowed}.product-details__action--ghost{background:transparent;color:rgb(var(--accent))}.product-details__hint{margin:.85rem 0 0;font-size:.85rem;color:rgb(var(--muted));line-height:1.5}