:root{--bordeaux: #6e1423;--bordeaux-700: #4f0d18;--bordeaux-300: #a93b4a;--cream: #f7f1e5;--cream-200: #ece2cb;--ink: #1a0f10;--muted: #6b5e5a;--line: rgba(26, 15, 16, .08);--surface: #fffaf0;--surface-elev: #ffffff;--danger: #b3261e;--ok: #2e7d4f;--radius-sm: 8px;--radius: 16px;--radius-lg: 24px;--shadow-card: 0 1px 2px rgba(26, 15, 16, .04), 0 8px 24px -12px rgba(26, 15, 16, .18);--shadow-pop: 0 12px 32px -8px rgba(26, 15, 16, .25);--tap: 44px;--font-body: ui-rounded, -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", system-ui, sans-serif;--font-display: "Fraunces", "Iowan Old Style", "Palatino Linotype", Georgia, serif}@media(prefers-color-scheme:dark){:root{--cream: #1a1012;--cream-200: #241719;--ink: #f4ebd9;--muted: #b6a89f;--line: rgba(244, 235, 217, .1);--surface: #1f1416;--surface-elev: #2a1c1f;--bordeaux: #c14f5e;--bordeaux-300: #d97a89}}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--font-body);color:var(--ink);background:var(--cream);-webkit-font-smoothing:antialiased;min-height:100dvh}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button,.btn{font:inherit;cursor:pointer;border:0;border-radius:999px;padding:14px 22px;background:var(--bordeaux);color:#fff8ee;min-height:var(--tap);font-weight:600;letter-spacing:.01em;transition:transform .08s ease,background .15s ease}button:active,.btn:active{transform:scale(.97)}button.ghost,.btn.ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}button.danger{background:var(--danger)}input,textarea,select{font:inherit;width:100%;padding:14px 16px;border-radius:var(--radius-sm);border:1px solid var(--line);background:var(--surface-elev);color:var(--ink);min-height:var(--tap)}input:focus,textarea:focus,select:focus{outline:2px solid var(--bordeaux-300);outline-offset:1px}label{display:block;font-size:13px;color:var(--muted);margin-bottom:6px;font-weight:500}.field{margin-bottom:14px}.row{display:grid;gap:12px;grid-template-columns:1fr 1fr}.app{max-width:720px;margin:0 auto;padding:16px 16px calc(96px + env(safe-area-inset-bottom)) 16px}.app-header{display:flex;align-items:baseline;justify-content:space-between;padding:8px 4px 18px}.app-header h1{font-family:var(--font-display);font-weight:600;font-size:28px;margin:0;letter-spacing:-.01em}.app-header .sub{font-size:13px;color:var(--muted)}.card{background:var(--surface-elev);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-card);border:1px solid var(--line)}.wine-grid{display:grid;gap:12px;grid-template-columns:1fr}@media(min-width:520px){.wine-grid{grid-template-columns:1fr 1fr}}.wine-card{display:flex;gap:14px;background:var(--surface-elev);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow-card);border:1px solid var(--line);position:relative;overflow:hidden}.wine-card .thumb{width:64px;height:88px;border-radius:10px;background:linear-gradient(135deg,var(--bordeaux-300),var(--bordeaux-700));flex-shrink:0;object-fit:cover;position:relative}.wine-card .body{min-width:0;flex:1}.wine-card .producer{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.wine-card .name{font-family:var(--font-display);font-size:18px;font-weight:600;line-height:1.2;margin:2px 0 4px}.wine-card .meta{font-size:13px;color:var(--muted);display:flex;gap:8px;flex-wrap:wrap}.wine-card .badge{position:absolute;top:10px;right:12px;font-size:11px;font-weight:700;letter-spacing:.05em;background:var(--cream-200);color:var(--ink);padding:4px 8px;border-radius:999px}.empty{text-align:center;padding:48px 16px;color:var(--muted)}.empty h2{font-family:var(--font-display);color:var(--ink);margin:0 0 8px}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:color-mix(in srgb,var(--surface-elev) 92%,transparent);backdrop-filter:saturate(140%) blur(12px);-webkit-backdrop-filter:saturate(140%) blur(12px);border-top:1px solid var(--line);padding:8px 8px calc(8px + env(safe-area-inset-bottom));display:grid;grid-template-columns:repeat(4,1fr);z-index:50}.bottom-nav a{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;font-size:11px;color:var(--muted);border-radius:12px;min-height:56px;justify-content:center}.bottom-nav a[aria-current=page]{color:var(--bordeaux)}.bottom-nav a svg{width:22px;height:22px}.bottom-nav .fab{background:var(--bordeaux);color:#fff;border-radius:999px;margin:-22px 4px 0;height:56px;box-shadow:var(--shadow-pop)}.bottom-nav .fab svg{width:26px;height:26px}.note{background:var(--surface-elev);border-radius:var(--radius);padding:14px 16px;border:1px solid var(--line);box-shadow:var(--shadow-card)}.note .head{display:flex;justify-content:space-between;align-items:baseline}.note h3{margin:0;font-family:var(--font-display);font-size:16px}.note .date{font-size:12px;color:var(--muted)}.note .rating{display:inline-block;background:var(--bordeaux);color:#fff;border-radius:999px;padding:2px 10px;font-size:12px;font-weight:700}.note .body{margin-top:8px;font-size:14px;line-height:1.5}.note .orphan{margin-top:8px;font-size:12px;color:var(--muted);display:inline-flex;gap:6px;align-items:center}.section-title{font-family:var(--font-display);font-size:20px;margin:24px 0 12px}.stat-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:16px}.stat{background:var(--surface-elev);border:1px solid var(--line);border-radius:var(--radius);padding:10px 12px}.stat .label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.stat .value{font-family:var(--font-display);font-size:20px}.filter-bar{display:flex;gap:8px;overflow-x:auto;padding-bottom:12px}.chip{border:1px solid var(--line);background:var(--surface-elev);color:var(--ink);padding:8px 14px;border-radius:999px;font-size:13px;white-space:nowrap}.chip[aria-pressed=true]{background:var(--bordeaux);color:#fff;border-color:var(--bordeaux)}.detail-hero{position:relative;border-radius:var(--radius-lg);overflow:hidden;background:linear-gradient(160deg,var(--bordeaux),var(--bordeaux-700));color:#fff;padding:24px 20px;margin-bottom:16px}.detail-hero h2{font-family:var(--font-display);font-size:26px;margin:6px 0 4px;font-weight:600;line-height:1.15}.detail-hero .producer{font-size:13px;opacity:.85;text-transform:uppercase;letter-spacing:.08em}.detail-hero .meta{font-size:14px;opacity:.9;margin-top:8px}.detail-hero img.label{position:absolute;right:16px;top:16px;bottom:16px;width:90px;object-fit:cover;border-radius:10px;box-shadow:var(--shadow-pop)}.kv{display:grid;grid-template-columns:max-content 1fr;gap:6px 16px;font-size:14px}.kv dt{color:var(--muted)}.kv dd{margin:0}.actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}.login-wrap{min-height:100dvh;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at top,color-mix(in srgb,var(--bordeaux) 18%,var(--cream)),var(--cream) 70%)}.login-card{width:min(380px,100%);background:var(--surface-elev);border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow-pop);border:1px solid var(--line)}.login-card h1{font-family:var(--font-display);margin:0 0 6px;font-size:32px}.login-card p{color:var(--muted);margin:0 0 18px;font-size:14px}.toast{margin-top:12px;padding:10px 14px;border-radius:12px;background:color-mix(in srgb,var(--danger) 18%,transparent);color:var(--danger);font-size:13px}.skeleton-camera{border:2px dashed var(--line);border-radius:var(--radius-lg);aspect-ratio:3/4;display:grid;place-items:center;color:var(--muted);background:var(--surface-elev);position:relative;overflow:hidden}.skeleton-camera img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.spinner{width:22px;height:22px;border:3px solid var(--line);border-top-color:var(--bordeaux);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){*{animation-duration:1ms!important;transition:none!important}}
