:root{--bg-primary: #0C0A0B;--bg-surface: #141012;--bg-elevated: #1C181A;--bg-hover: #221E20;--accent-wine: #7B2D3E;--accent-wine-light: #9B3D51;--accent-wine-dim: rgba(123, 45, 62, .15);--accent-gold: #C4A35A;--accent-gold-dim: rgba(196, 163, 90, .15);--text-primary: #F2E8D9;--text-secondary: #A89880;--text-muted: #5C4F47;--border: rgba(242, 232, 217, .08);--border-strong: rgba(242, 232, 217, .15);--font-display: "Cormorant Garamond", Georgia, serif;--font-body: "DM Sans", system-ui, sans-serif;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--transition: .2s cubic-bezier(.4, 0, .2, 1)}[data-theme=light]{--bg-primary: #FAF6F0;--bg-surface: #F2EBE0;--bg-elevated: #E8DDD0;--bg-hover: #DDD0C0;--text-primary: #1A1210;--text-secondary: #5A4A3A;--text-muted: #8A7A6A;--border: rgba(26, 18, 16, .1);--border-strong: rgba(26, 18, 16, .2)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font-body);font-weight:400;background-color:var(--bg-primary);color:var(--text-primary);min-height:100dvh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100dvh;display:flex;flex-direction:column}h1,h2,h3{font-family:var(--font-display);font-weight:400;letter-spacing:.01em;line-height:1.2}h1{font-size:clamp(2rem,6vw,3rem)}h2{font-size:clamp(1.4rem,4vw,1.8rem)}h3{font-size:clamp(1.1rem,3vw,1.3rem)}p{line-height:1.65;font-size:.9375rem}.loading-screen{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);flex-direction:column;gap:1rem}.loading-logo{display:flex;flex-direction:column;align-items:center;gap:.75rem;animation:fadeIn .6s ease}.loading-icon{font-size:2.5rem;animation:pulse 2s ease-in-out infinite}.loading-text{font-family:var(--font-display);font-size:1.5rem;font-weight:300;letter-spacing:.12em;color:var(--text-secondary);text-transform:uppercase}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:6px;font-family:var(--font-body);font-size:.875rem;font-weight:500;letter-spacing:.04em;cursor:pointer;border:none;transition:var(--transition);text-decoration:none;white-space:nowrap;-webkit-tap-highlight-color:transparent}.btn-primary{background:var(--accent-wine);color:var(--text-primary)}.btn-primary:hover{background:var(--accent-wine-light)}.btn-primary:active{transform:scale(.98)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-strong)}.btn-secondary:hover{background:var(--bg-hover)}.btn-ghost{background:transparent;color:var(--text-secondary);padding:.5rem .75rem}.btn-ghost:hover{color:var(--text-primary);background:var(--bg-hover)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-full{width:100%}.input{width:100%;padding:.875rem 1rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-family:var(--font-body);font-size:1rem;transition:var(--transition);-webkit-appearance:none}.input:focus{outline:none;border-color:var(--accent-wine);box-shadow:0 0 0 3px var(--accent-wine-dim)}.input::placeholder{color:var(--text-muted)}textarea.input{resize:vertical;min-height:100px;line-height:1.65}.label{display:block;font-size:.8rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:.5rem}.form-group{display:flex;flex-direction:column;gap:.25rem;margin-bottom:1.25rem}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:10px;padding:1.25rem}.card-elevated{background:var(--bg-elevated)}.stars{display:flex;gap:.2rem}.star{font-size:1.1rem;cursor:pointer;transition:transform .1s;-webkit-tap-highlight-color:transparent}.star:active{transform:scale(1.3)}.star.filled{color:var(--accent-gold)}.star.empty{color:var(--text-muted)}.divider{height:1px;background:var(--border);margin:1.5rem 0}.divider-text{display:flex;align-items:center;gap:1rem;color:var(--text-muted);font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;margin:1.5rem 0}.divider-text:before,.divider-text:after{content:"";flex:1;height:1px;background:var(--border)}.toast{position:fixed;bottom:calc(80px + var(--safe-bottom));left:50%;transform:translate(-50%) translateY(20px);background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:8px;padding:.75rem 1.25rem;font-size:.875rem;color:var(--text-primary);z-index:1000;opacity:0;transition:all .3s ease;white-space:nowrap;box-shadow:0 8px 32px #0006}.toast.visible{opacity:1;transform:translate(-50%) translateY(0)}.toast.success{border-color:var(--accent-gold)}.toast.error{border-color:var(--accent-wine)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.animate-in{animation:slideUp .4s ease forwards}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:2px}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.text-gold{color:var(--accent-gold)}.text-wine{color:var(--accent-wine-light)}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.font-display{font-family:var(--font-display)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.w-full{width:100%}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mb-4{margin-bottom:1rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b8;z-index:200;display:flex;align-items:flex-end;justify-content:center;padding:0;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);animation:fadeIn .2s ease}.modal-content{background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:18px 18px 0 0;padding:1.5rem 1.25rem calc(1.5rem + var(--safe-bottom));width:100%;max-width:600px;max-height:90dvh;overflow-y:auto;animation:slideUp .28s cubic-bezier(.4,0,.2,1);-webkit-overflow-scrolling:touch}.modal-overlay.modal-overlay--center{align-items:center;padding:1rem}.modal-overlay--center .modal-content,.modal-content.modal-small{border-radius:14px;max-width:360px;padding:1.5rem}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.modal-header h2{font-size:clamp(1.2rem,4vw,1.5rem)}.modal-close{background:var(--bg-hover);border:none;color:var(--text-secondary);width:2rem;height:2rem;border-radius:50%;font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:var(--transition)}.modal-close:hover{background:var(--border-strong);color:var(--text-primary)}.modal-actions{display:flex;gap:.75rem;margin-top:1.25rem}.modal-actions .btn-secondary,.modal-actions .btn-danger{flex:1}.modal-content input[type=text],.modal-content input[type=number],.modal-content input[type=email],.modal-content textarea{width:100%;padding:.75rem .875rem;background:var(--bg-primary);border:1px solid var(--border-strong);border-radius:6px;color:var(--text-primary);font-family:var(--font-body);font-size:.9375rem;transition:var(--transition);-webkit-appearance:none}.modal-content input[type=text]:focus,.modal-content input[type=number]:focus,.modal-content input[type=email]:focus,.modal-content textarea:focus{outline:none;border-color:var(--accent-wine);box-shadow:0 0 0 3px var(--accent-wine-dim)}.modal-content input::placeholder,.modal-content textarea::placeholder{color:var(--text-muted)}.modal-content textarea{resize:vertical;min-height:72px;line-height:1.65}.modal-content label{display:block;font-size:.75rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:.4rem}.modal-content .form-group{margin-bottom:0}.btn-danger{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.25rem;background:#7f1d1d;color:var(--text-primary);border:1px solid rgba(239,68,68,.35);border-radius:6px;font-family:var(--font-body);font-size:.875rem;font-weight:500;letter-spacing:.04em;cursor:pointer;transition:var(--transition)}.btn-danger:hover{background:#991b1b}.form-error{font-size:.8rem;color:#f87171;padding:.5rem .75rem;background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:6px}.spinner-inline{display:inline-block;width:12px;height:12px;border:2px solid rgba(242,232,217,.3);border-top-color:var(--text-primary);border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle;margin-left:.4rem}.loading-state,.empty-state{text-align:center;color:var(--text-secondary);padding:3rem 1rem;font-size:.9rem;line-height:1.7}.try-next-toggle,.source-toggle{display:flex;gap:.5rem;margin-bottom:1.25rem}.toggle-tab{flex:1;padding:.5rem 1rem;border-radius:6px;border:1px solid var(--border-strong);background:transparent;color:var(--text-secondary);font-family:var(--font-body);font-size:.8rem;font-weight:500;letter-spacing:.04em;cursor:pointer;transition:var(--transition);-webkit-tap-highlight-color:transparent}.toggle-tab.active{background:var(--accent-wine);border-color:var(--accent-wine);color:var(--text-primary)}.try-next-list{display:flex;flex-direction:column;gap:.875rem}.try-next-card{background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:12px;padding:1rem 1.1rem;display:flex;flex-direction:column;gap:.6rem}.try-next-card.card-tried{opacity:.6;border-style:dashed}.card-top{display:flex;flex-direction:column;gap:.3rem}.card-title-row{display:flex;justify-content:space-between;align-items:flex-start}.source-badge{display:inline-block;font-size:.68rem;font-weight:600;padding:.18rem .5rem;border-radius:20px;letter-spacing:.04em;text-transform:uppercase}.badge-friend{background:#8b5cf61f;color:#b8a4f8}.badge-self{background:var(--accent-wine-dim);color:var(--accent-wine-light)}.delete-btn{background:none;border:none;color:var(--text-muted);font-size:.8rem;cursor:pointer;padding:.15rem .35rem;line-height:1;opacity:.5;transition:var(--transition);-webkit-tap-highlight-color:transparent}.delete-btn:hover{opacity:1;color:#f87171}.wine-name{margin:0;font-family:var(--font-display);font-size:1.15rem;font-weight:400;color:var(--text-primary);line-height:1.3}.wine-sub{font-size:.78rem;color:var(--text-secondary);letter-spacing:.02em}.recommended-by{font-size:.75rem;color:var(--text-muted);font-style:italic}.estimated-price{font-size:.8rem;font-weight:600;color:var(--accent-gold)}.expand-btn{background:none;border:none;color:var(--text-muted);font-size:.75rem;cursor:pointer;padding:.15rem 0;text-align:left;letter-spacing:.03em;transition:color .15s;-webkit-tap-highlight-color:transparent}.expand-btn:hover{color:var(--text-secondary)}.card-details{display:flex;flex-direction:column;gap:.6rem;padding-top:.5rem;border-top:1px solid var(--border)}.detail-block{display:flex;flex-direction:column;gap:.2rem}.detail-label{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted)}.detail-text{margin:0;font-size:.875rem;color:var(--text-primary);line-height:1.55}.verdict-block{background:#7b2d3e12;border:1px solid var(--accent-wine-dim);border-radius:8px;padding:.5rem .75rem}.btn-tried{margin-top:.25rem;padding:.55rem 1rem;background:transparent;border:1px solid var(--accent-wine-light);color:var(--accent-wine-light);border-radius:6px;font-family:var(--font-body);font-size:.875rem;font-weight:500;letter-spacing:.03em;cursor:pointer;text-align:center;transition:var(--transition);-webkit-tap-highlight-color:transparent}.btn-tried:hover{background:var(--accent-wine);border-color:var(--accent-wine);color:var(--text-primary)}.tried-badge{font-size:.75rem;color:var(--accent-gold);font-weight:600;padding-top:.15rem;letter-spacing:.03em}.add-form{display:flex;flex-direction:column;gap:.875rem;margin-top:.75rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.verdict-hint{font-size:.78rem;color:var(--text-muted);text-align:center;margin-top:-.25rem;font-style:italic}.rating-wine-name{font-family:var(--font-display);font-size:1.25rem;font-weight:400;color:var(--text-primary);margin-bottom:.1rem;line-height:1.3}.rating-wine-sub{font-size:.82rem;color:var(--text-secondary);margin-bottom:.5rem}.star-selector{display:flex;gap:.35rem;margin:.75rem 0 .35rem}.star-btn{font-size:2.1rem;background:none;border:none;cursor:pointer;color:var(--text-muted);padding:0;line-height:1;transition:color .1s,transform .12s;-webkit-tap-highlight-color:transparent}.star-btn.active{color:var(--accent-gold)}.star-btn:hover{transform:scale(1.2)}.star-label{font-size:.78rem;color:var(--text-secondary);min-height:1.2em;margin-bottom:.5rem;font-style:italic}.camera-controls{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem .25rem}.image-mode-toggle{display:flex;gap:.35rem;flex:1}.camera-btn{padding:.4rem .55rem;border-radius:6px;border:1px solid var(--border-strong);background:var(--bg-elevated);font-size:1.1rem;cursor:pointer;flex-shrink:0;transition:var(--transition);line-height:1;-webkit-tap-highlight-color:transparent}.camera-btn:hover{background:var(--bg-hover)}.camera-btn:disabled{opacity:.4;cursor:not-allowed}.image-preview-container{display:flex;align-items:center;gap:.6rem;padding:.5rem .75rem;background:var(--bg-surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.image-preview{width:44px;height:44px;object-fit:cover;border-radius:6px;border:1px solid var(--border-strong);flex-shrink:0}.image-preview-clear{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.85rem;padding:.1rem .3rem;opacity:.6;flex-shrink:0;transition:var(--transition);-webkit-tap-highlight-color:transparent}.image-preview-clear:hover{opacity:1;color:#f87171}.image-preview-label{font-size:.72rem;color:var(--text-secondary);font-style:italic;flex:1;line-height:1.4}
