/*wAIno*/:root{--bg:#0a090c;--bg-elevated:#141216;--bg-hover:#1c191f;--border:#2a252e;--border-light:#3a3540;--text:#f0ece6;--text-muted:#9e98a3;--text-dim:#6a6470;--accent:#d4634d;--accent-light:#e87e68;--accent-dark:#a84a38;--gold:#d4a843;--gold-light:#e8c060;--success:#5cb85c;--warning:#d4a843;--error:#c45a5a;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:40px;--space-2xl:64px;--font:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,system-ui,sans-serif;--font-mono:'SF Mono',Menlo,Monaco,'Courier New',monospace;--radius:12px;--radius-sm:8px;--ease:cubic-bezier(0.22,1,0.36,1);--duration-fast:0.18s;--duration-mid:0.35s;--glow-accent:0 0 0 2px rgba(212,99,77,0.35);--glow-gold:0 0 0 2px rgba(212,168,67,0.35);}[data-theme="light"]{--bg:#f7f5f2;--bg-elevated:#ffffff;--bg-hover:#ede9e4;--border:#d9d4ce;--border-light:#c4beb6;--text:#1c1914;--text-muted:#5c5750;--text-dim:#918b83;--accent:#c4523d;--accent-light:#d66a52;--accent-dark:#a23b29;--gold:#c49a30;--gold-light:#dcb045;--success:#3a9e3a;--warning:#c49a30;--error:#b84a4a;--glow-accent:0 0 0 2px rgba(196,82,61,0.25);--glow-gold:0 0 0 2px rgba(196,154,48,0.25);}[data-theme="light"] .logo-caps,[data-theme="light"] .header-logo .logo-caps,[data-theme="light"] .section-title,[data-theme="light"] .result-item .result-title,[data-theme="light"] .card-title,[data-theme="light"] .note-card h4{color:#1c1914;}.theme-toggle{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:8px;border-radius:var(--radius-sm);transition:all var(--duration-fast) var(--ease);display:flex;align-items:center;justify-content:center;}.theme-toggle:hover{color:var(--text);background:var(--bg-hover);}.theme-toggle svg{width:20px;height:20px;}body,.page,.view,.header,.sidebar,.footer,.modal-content,.form-section,.card,.result-item,.note-card,.search-suggestions,.nav-link{transition:background-color var(--duration-mid) var(--ease),border-color var(--duration-mid) var(--ease),color var(--duration-fast) var(--ease);}.icon,.icon-lg,.icon-star,.icon-star-sm{display:inline-block;vertical-align:middle;flex-shrink:0;}.icon{width:var(--icon-md);height:var(--icon-md);}.icon,.icon-lg,.icon-star,.icon-star-sm{stroke:currentColor;stroke-width:2.5;fill:none;stroke-linecap:round;stroke-linejoin:round;}.icon-lg{width:var(--icon-lg);height:var(--icon-lg);stroke-width:2;}.icon-star{width:1.4rem;height:1.4rem;stroke-width:1.8;fill:none;}.icon-star-sm{width:1rem;height:1rem;stroke-width:1.8;fill:none;}.icon-composer,.icon-profile-lg{width:100%;height:100%;stroke:currentColor;stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round;opacity:0.7;}.nav-link .icon{margin-right:6px;opacity:0.85;}.card-icon .icon-lg{color:var(--accent);opacity:0.9;}.star-rating label .icon-star,.star-rating label .icon-star-sm{stroke:var(--border);transition:stroke var(--duration-fast);}.star-rating label:hover .icon-star,.star-rating label:hover ~ label .icon-star,.star-rating input:checked ~ label .icon-star,.star-rating label:hover .icon-star-sm,.star-rating label:hover ~ label .icon-star-sm,.star-rating input:checked ~ label .icon-star-sm{stroke:var(--gold);fill:rgba(212,168,67,0.15);}*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}html{scroll-behavior:smooth;}body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;}button,input,textarea,select{font-family:inherit;font-size:inherit;color:inherit;}::selection{background:rgba(212,99,77,0.35);color:var(--text);}::-webkit-scrollbar{width:8px;}::-webkit-scrollbar-track{background:var(--bg);}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px;}::-webkit-scrollbar-thumb:hover{background:var(--border-light);}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:10px 20px;border-radius:var(--radius-sm);border:1.5px solid transparent;font-weight:600;font-size:0.92rem;cursor:pointer;transition:all var(--duration-fast) var(--ease);white-space:nowrap;background:transparent;}.btn:disabled{opacity:0.5;cursor:not-allowed;}.btn-primary{background:var(--accent);color:var(--bg);border-color:var(--accent);}.btn-primary:hover{background:var(--accent-light);border-color:var(--accent-light);transform:translateY(-1px);box-shadow:var(--glow-accent);}.btn-ghost{border-color:var(--border-light);color:var(--text);}.btn-ghost:hover{border-color:var(--accent);color:var(--accent);background:rgba(212,99,77,0.08);box-shadow:inset 0 0 12px rgba(212,99,77,0.15),0 0 20px rgba(212,99,77,0.1);}.btn-follow{border-color:var(--accent);color:var(--accent);background:transparent;}.btn-follow:hover{background:rgba(212,99,77,0.12);}.btn-follow-active{border-color:var(--border-light);color:var(--text-muted);background:var(--bg-hover);}.btn-follow-active:hover{border-color:var(--error);color:var(--error);background:rgba(196,90,90,0.1);}.btn-text{padding:6px 8px;color:var(--text-muted);text-decoration:underline;text-underline-offset:3px;}.btn-text:hover{color:var(--accent);}.btn-sm{padding:6px 14px;font-size:0.82rem;}.btn-lg{padding:14px 32px;font-size:1rem;}.main-nav{position:fixed;top:0;left:0;right:0;z-index:500;height:56px;background:rgba(10,9,12,0.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border);transition:transform var(--duration-normal) var(--ease);}.nav-inner{max-width:1100px;height:100%;margin:0 auto;padding:0 var(--space-md);display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);}.nav-logo{background:none;border:none;font-size:1.25rem;font-weight:700;color:var(--accent);cursor:pointer;letter-spacing:-0.5px;padding:0;transition:opacity var(--duration-fast);}.nav-logo:hover{opacity:0.75;}.nav-links{display:flex;gap:4px;flex:1;justify-content:center;}.nav-link{background:none;border:none;padding:8px 14px;font-size:0.82rem;font-weight:500;color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--duration-fast) var(--ease);}.nav-link:hover,.nav-link.active{color:var(--text);background:var(--bg-hover);}.nav-user{display:flex;align-items:center;gap:var(--space-sm);}.nav-username{font-size:0.82rem;color:var(--text-muted);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:6px;flex-direction:column;gap:4px;margin-right:4px;}.nav-toggle span{display:block;width:20px;height:2px;background:var(--text);border-radius:1px;transition:all var(--duration-fast);}.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(6px) rotate(45deg);}.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0;}.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-6px) rotate(-45deg);}.view{display:none;opacity:0;transform:translateY(20px) scale(0.98);}.view.active{display:block;animation:viewEnter 0.4s var(--ease) forwards;}@keyframes viewEnter{from{opacity:0;transform:translateY(20px) scale(0.98);}to{opacity:1;transform:translateY(0) scale(1);}}.view > div:first-child{padding-top:56px;}body:not([data-view="dashboard"]) .main-nav{display:none !important;}body:not([data-view="dashboard"]) .page-header{position:fixed;top:0;left:0;right:0;z-index:100;}body:not([data-view="dashboard"]) .page-body{padding-top:calc(56px + var(--space-lg));}body[data-view="dashboard"] .page-body{padding-top:var(--space-lg);}@media (max-width:640px){body:not([data-view="dashboard"]) .page-body{padding-bottom:72px;}body[data-view="dashboard"] .page-body{padding-bottom:72px;}}.dashboard-bg{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-xl) var(--space-md);position:relative;overflow:hidden;}.dashboard-bg::before,.dashboard-bg::after{content:'';position:absolute;border-radius:50%;filter:blur(80px);opacity:0.15;animation:blobDrift 20s ease-in-out infinite alternate;pointer-events:none;}.dashboard-bg::before{width:500px;height:500px;background:radial-gradient(circle,rgba(212,99,77,0.4) 0%,transparent 70%);top:-100px;left:-100px;animation-delay:0s;}.dashboard-bg::after{width:400px;height:400px;background:radial-gradient(circle,rgba(160,40,60,0.35) 0%,transparent 70%);bottom:-80px;right:-80px;animation-delay:-10s;animation-duration:25s;}.dashboard-inner::before{content:'';position:absolute;width:350px;height:350px;border-radius:50%;filter:blur(70px);opacity:0.1;background:radial-gradient(circle,rgba(212,168,67,0.3) 0%,transparent 70%);top:40%;left:50%;transform:translateX(-50%);animation:blobDrift 18s ease-in-out infinite alternate-reverse;pointer-events:none;}@keyframes blobDrift{0%{transform:translate(0,0) scale(1);}33%{transform:translate(40px,-30px) scale(1.08);}66%{transform:translate(-20px,50px) scale(0.95);}100%{transform:translate(30px,20px) scale(1.05);}}.dashboard-inner{max-width:900px;width:100%;text-align:center;position:relative;z-index:1;}.dashboard-hero{margin-bottom:var(--space-2xl);}.hero-logo{font-size:clamp(3.5rem,8vw,6rem);font-weight:800;letter-spacing:-2px;color:var(--accent);line-height:1;text-shadow:0 0 60px rgba(212,99,77,0.2);animation:textGlowPulse 3s ease-in-out infinite alternate;}@keyframes textGlowPulse{0%{text-shadow:0 0 20px rgba(212,99,77,0.3),0 0 40px rgba(212,99,77,0.1);}50%{text-shadow:0 0 40px rgba(212,99,77,0.5),0 0 80px rgba(212,99,77,0.2),0 0 120px rgba(212,99,77,0.08);}100%{text-shadow:0 0 30px rgba(212,99,77,0.4),0 0 60px rgba(212,99,77,0.15);}}.hero-tagline{font-size:clamp(1.1rem,2.5vw,1.5rem);font-weight:300;color:var(--text-muted);margin-top:var(--space-sm);letter-spacing:1px;}.hero-sub{font-size:0.88rem;color:var(--text-dim);margin-top:var(--space-lg);line-height:1.7;max-width:480px;margin-left:auto;margin-right:auto;}.hero-actions{margin-top:var(--space-xl);display:flex;gap:var(--space-md);justify-content:center;flex-wrap:wrap;}.hero-meta{margin-top:var(--space-xl);font-size:0.75rem;color:var(--text-dim);letter-spacing:0.5px;}.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md);margin-bottom:var(--space-xl);}.dash-card{background:rgba(20,18,22,0.7);border:1px solid rgba(255,255,255,0.06);border-radius:var(--radius);padding:var(--space-lg);text-align:left;cursor:pointer;transition:all var(--duration-normal) var(--ease);display:block;width:100%;text-align:left;color:inherit;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);}.dash-card:hover{border-color:rgba(212,99,77,0.3);transform:translateY(-6px) scale(1.01);box-shadow:var(--glow-accent);background:rgba(20,18,22,0.85);}.dash-card:active{transform:translateY(-2px) scale(0.99);transition-duration:var(--duration-fast);}.card-icon{font-size:2rem;margin-bottom:var(--space-sm);opacity:0.85;}.dash-card h3{font-size:1.05rem;font-weight:600;color:var(--text);margin-bottom:var(--space-sm);}.dash-card p{font-size:0.8rem;color:var(--text-muted);line-height:1.55;margin-bottom:var(--space-md);}.card-cta{font-size:0.78rem;font-weight:600;color:var(--accent);letter-spacing:0.3px;}.dashboard-footer{padding:var(--space-lg) 0;font-size:0.78rem;color:var(--text-dim);display:flex;gap:var(--space-md);justify-content:center;align-items:center;flex-wrap:wrap;}.dashboard-footer a{color:var(--text-muted);text-decoration:none;transition:color var(--duration-fast);}.dashboard-footer a:hover{color:var(--accent);}.page-header{position:sticky;top:0;z-index:100;background:rgba(10,9,12,0.85);backdrop-filter:blur(20px) saturate(1.2);-webkit-backdrop-filter:blur(20px) saturate(1.2);border-bottom:1px solid rgba(255,255,255,0.06);height:56px;padding:0 var(--space-md);display:flex;align-items:center;gap:var(--space-md);}.page-header .back-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:6px;border-radius:var(--radius-sm);transition:all var(--duration-fast);display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;}.page-header .back-btn svg{width:20px;height:20px;stroke:currentColor;stroke-width:2.5;fill:none;stroke-linecap:round;stroke-linejoin:round;}.page-header .back-btn:hover{color:var(--accent);background:rgba(212,99,77,0.08);box-shadow:0 0 12px rgba(212,99,77,0.15);}.page-header h2{flex:1;font-size:1.15rem;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}.page-header-actions{display:flex;gap:var(--space-sm);}.page-body{max-width:720px;margin:0 auto;padding:var(--space-lg) var(--space-md) var(--space-2xl);}.section-title{font-size:0.85rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:var(--space-md);margin-top:var(--space-xl);}.search-bar-wrap{margin-bottom:var(--space-xl);}.search-bar{display:flex;gap:var(--space-sm);margin-bottom:var(--space-sm);}.search-bar input{flex:1;padding:12px 16px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--bg-elevated);color:var(--text);font-size:0.92rem;transition:border-color var(--duration-fast);}.search-bar input:focus{outline:none;border-color:var(--accent);}.search-bar input::placeholder{color:var(--text-dim);}.search-filters{display:flex;gap:var(--space-sm);}.search-filters select,.search-filters input{flex:1;padding:9px 12px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--bg-elevated);color:var(--text);font-size:0.8rem;}.search-filters select:focus,.search-filters input:focus{outline:none;border-color:var(--accent);}.results-welcome{text-align:center;padding:var(--space-xl) var(--space-md);background:rgba(20,18,22,0.6);border-radius:var(--radius);border:1px solid rgba(255,255,255,0.06);margin-bottom:var(--space-lg);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);}.results-welcome h3{color:var(--accent);margin-bottom:var(--space-sm);}.results-welcome p{color:var(--text-muted);font-size:0.85rem;margin-bottom:var(--space-md);}.results-list{display:flex;flex-direction:column;gap:var(--space-md);}.result-item{background:rgba(20,18,22,0.6);border:1px solid rgba(255,255,255,0.06);border-radius:var(--radius);padding:var(--space-lg);transition:all var(--duration-fast) var(--ease);text-align:left;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);}.result-item:hover{border-color:rgba(255,255,255,0.12);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.3);background:rgba(20,18,22,0.75);}.result-header-row{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-sm);flex-wrap:wrap;}.result-badge{font-size:0.65rem;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;padding:3px 8px;border-radius:4px;}.result-badge.knowledge{background:rgba(212,99,77,0.15);color:var(--accent);}.result-badge.tasting{background:rgba(212,175,67,0.15);color:var(--gold);}.result-title{font-size:1rem;font-weight:600;color:var(--text);margin-bottom:var(--space-sm);line-height:1.35;}.result-content{font-size:0.85rem;color:var(--text-muted);line-height:1.6;margin-bottom:var(--space-sm);}.result-meta-row{display:flex;align-items:center;gap:var(--space-sm);font-size:0.75rem;color:var(--text-dim);flex-wrap:wrap;}.result-actions-row{display:flex;gap:var(--space-sm);margin-top:var(--space-sm);padding-top:var(--space-sm);border-top:1px solid var(--border);}.upvote-btn{background:none;border:1.5px solid var(--border);color:var(--text-dim);padding:5px 12px;border-radius:6px;font-size:0.78rem;cursor:pointer;display:inline-flex;align-items:center;gap:5px;transition:all var(--duration-fast);}.upvote-btn:hover{border-color:var(--accent);color:var(--accent);}.upvote-btn.upvoted{border-color:var(--gold);color:var(--gold);background:rgba(212,168,67,0.08);}.result-content.expandable{cursor:pointer;position:relative;}.result-content.collapsed::after{content:'… Show more';color:var(--accent);margin-left:4px;cursor:pointer;font-weight:500;}.result-content.expanded::after{content:none;}.slider-group{margin-bottom:24px;}.slider-group:last-child{margin-bottom:0;}.slider-header{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,0.06);}.slider-cat{font-size:14px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:0.8px;display:flex;align-items:center;gap:6px;}.slider-cat svg{width:18px;height:18px;stroke:var(--accent);fill:none;}.slider-row{display:flex;align-items:center;gap:12px;padding:8px 0;}.slider-label-left,.slider-label-right{font-size:12px;font-weight:600;min-width:110px;max-width:110px;flex-shrink:0;}.slider-label-left{color:var(--text-dim);text-align:right;}.slider-label-right{color:var(--accent-warm);text-align:left;}.slider-wrap{flex:1;display:flex;align-items:center;gap:8px;min-width:0;}.wine-slider{-webkit-appearance:none;appearance:none;width:100%;height:6px;background:rgba(255,255,255,0.08);border-radius:3px;outline:none;cursor:pointer;}.wine-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px rgba(212,99,77,0.5);cursor:pointer;transition:transform 0.15s,box-shadow 0.15s;}.wine-slider::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 0 16px rgba(212,99,77,0.7);}.wine-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--accent);border:none;box-shadow:0 0 10px rgba(212,99,77,0.5);cursor:pointer;}.slider-val{font-size:13px;font-weight:700;color:var(--accent);min-width:18px;text-align:center;}.slider-summary{background:rgba(20,18,22,0.6);border:1px solid rgba(255,255,255,0.06);border-radius:12px;padding:14px 18px;margin-top:20px;}.slider-summary .summary-cat{font-size:13px;color:var(--text-dim);padding:4px 0;}.slider-summary .summary-cat strong{color:var(--text);font-weight:600;}.slider-summary .summary-cat span{color:var(--accent);font-weight:500;}.photo-upload-group{display:flex;flex-direction:column;}.photo-upload-wrap{display:flex;flex-direction:column;gap:10px;}.photo-preview{position:relative;min-height:180px;border:2px dashed var(--border-light);border-radius:var(--radius-sm);background:rgba(255,255,255,0.02);cursor:pointer;transition:border-color 0.2s,background 0.2s;overflow:hidden;}.photo-preview:hover{border-color:var(--accent);background:rgba(212,99,77,0.04);}.photo-preview.has-image{border-style:solid;border-color:var(--accent);}.photo-preview img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-sm);}.photo-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:32px 16px;color:var(--text-dim);}.photo-placeholder svg{width:44px;height:44px;stroke:var(--text-dim);fill:none;}.photo-placeholder p{font-size:14px;font-weight:500;color:var(--text-muted);margin:0;}.photo-hint{font-size:11px;color:var(--text-dim);}.photo-clear-btn{align-self:flex-start;padding:6px 14px;font-size:12px;font-weight:500;color:var(--error);background:transparent;border:1px solid rgba(196,90,90,0.3);border-radius:6px;cursor:pointer;transition:background 0.2s;}.photo-clear-btn:hover{background:rgba(196,90,90,0.1);}.score-badge{display:inline-flex;align-items:center;gap:4px;background:rgba(20,18,22,0.6);border:1px solid rgba(255,255,255,0.06);border-radius:10px;padding:4px 8px;font-size:12px;color:var(--text-dim);}.score-badge .sb-fill{width:6px;height:6px;border-radius:1px;background:var(--text-dim);}.score-badge .sb-fill.on{background:var(--accent);box-shadow:0 0 4px rgba(212,99,77,0.4);}.score-badge .sb-val{color:var(--accent);font-weight:700;}.score-pill{display:inline-flex;align-items:center;gap:4px;background:linear-gradient(135deg,rgba(212,99,77,0.2),rgba(212,99,77,0.05));border:1px solid rgba(212,99,77,0.3);border-radius:20px;padding:2px 10px;font-size:14px;font-weight:700;color:var(--accent);box-shadow:0 0 8px rgba(212,99,77,0.1);}.profile-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;}.profile-tag{font-size:11px;font-weight:600;padding:3px 10px;border-radius:12px;border:1px solid rgba(255,255,255,0.08);}.tag-low{background:rgba(129,140,248,0.12);color:#818cf8;border-color:rgba(129,140,248,0.25);}.tag-high{background:rgba(212,99,77,0.15);color:var(--accent);border-color:rgba(212,99,77,0.3);}.tasting-form-wrap{margin-bottom:var(--space-xl);}.form-section{background:rgba(20,18,22,0.6);border:1px solid rgba(255,255,255,0.06);border-radius:var(--radius);padding:var(--space-lg);margin-bottom:var(--space-lg);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);}.form-section h3{font-size:0.9rem;font-weight:600;color:var(--text);margin-bottom:var(--space-lg);padding-bottom:var(--space-sm);border-bottom:1px solid var(--border);}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-md);margin-bottom:var(--space-md);}.form-group{margin-bottom:var(--space-md);}.form-group:last-child{margin-bottom:0;}.form-group label{display:block;font-size:0.78rem;font-weight:600;color:var(--text-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:0.5px;}.form-group .req{color:var(--accent);}.form-group input[type="text"],.form-group input[type="email"],.form-group input[type="password"],.form-group textarea,.form-group select{width:100%;padding:11px 14px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--bg);color:var(--text);font-size:0.9rem;transition:border-color var(--duration-fast);}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--accent);}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-dim);}.form-group textarea{resize:vertical;min-height:90px;}.rating-group{display:flex;flex-direction:column;gap:8px;}.star-rating{display:flex;gap:3px;align-items:center;}.star-rating .star{width:24px;height:24px;cursor:pointer;transition:transform 0.15s,fill 0.15s;fill:none;stroke:var(--border);stroke-width:1.5;}.star-rating .star:hover{transform:scale(1.15);}.star-rating .star.filled{fill:var(--gold);stroke:var(--gold);filter:drop-shadow(0 0 4px rgba(212,168,67,0.4));}.star-rating .star.hovered{fill:rgba(212,168,67,0.5);stroke:var(--gold);}.rating-display{font-size:14px;font-weight:600;color:var(--gold);min-height:20px;letter-spacing:0.5px;}.checkbox-group{margin-top:8px;}.check-toggle{display:flex;align-items:center;gap:var(--space-sm);cursor:pointer;font-weight:400;text-transform:none;color:var(--text-muted);width:fit-content;}.check-toggle{display:flex;align-items:center;gap:var(--space-sm);cursor:pointer;font-weight:400;text-transform:none;color:var(--text-muted);}.check-toggle input{display:none;}.check-slider{width:40px;height:22px;background:var(--border);border-radius:11px;position:relative;transition:background var(--duration-fast);flex-shrink:0;}.check-slider::before{content:'';position:absolute;top:2px;left:2px;width:18px;height:18px;background:var(--text);border-radius:50%;transition:transform var(--duration-fast) var(--ease);}.check-toggle input:checked ~ .check-slider{background:rgba(212,99,77,0.5);}.check-toggle input:checked ~ .check-slider::before{transform:translateX(18px);background:var(--accent);}.social-body{max-width:100%;}.social-layout{display:grid;grid-template-columns:1fr 280px;gap:24px;max-width:1020px;margin:0 auto;align-items:start;}@media (max-width:860px){.social-layout{grid-template-columns:1fr;}.social-sidebar{display:none;}}.social-main{min-width:0;}.social-sidebar{position:sticky;top:72px;display:flex;flex-direction:column;gap:16px;}.sidebar-card{background:rgba(20,18,22,0.6);border:1px solid rgba(255,255,255,0.06);border-radius:var(--radius);padding:var(--space-md);backdrop-filter:blur(8px);}.sidebar-card h4{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;color:var(--text-dim);margin-bottom:10px;display:flex;align-items:center;gap:6px;}.sidebar-tags{gap:6px;padding:0;}.sidebar-users{display:flex;flex-direction:column;gap:8px;}.feed-badge{font-size:0.65rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-dim);border:1px solid var(--border);padding:3px 10px;border-radius:20px;white-space:nowrap;}.composer-card{background:rgba(20,18,22,0.6);border:1px solid rgba(255,255,255,0.06);border-radius:var(--radius);padding:var(--space-lg);margin-bottom:var(--space-lg);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);}.composer-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md);}.composer-avatar{width:32px;height:32px;border-radius:50%;background:var(--border);display:flex;align-items:center;justify-content:center;font-size:0.85rem;}.composer-name{font-size:0.85rem;font-weight:600;color:var(--text);}.composer-card textarea{width:100%;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text);padding:12px 14px;font-size:0.9rem;resize:vertical;min-height:80px;transition:border-color var(--duration-fast);}.composer-card textarea:focus{outline:none;border-color:var(--accent);}.composer-card textarea::placeholder{color:var(--text-dim);}.composer-tools{display:flex;gap:var(--space-sm);margin-top:var(--space-md);align-items:center;flex-wrap:wrap;}.file-label{display:inline-flex;align-items:center;gap:4px;padding:7px 12px;border-radius:var(--radius-sm);border:1.5px solid var(--border);font-size:0.8rem;color:var(--text-muted);cursor:pointer;transition:all var(--duration-fast);}.file-label:hover{border-color:var(--accent);color:var(--accent);}.composer-tools select,.composer-tools input[type="text"]{padding:7px 10px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--bg);color:var(--text);font-size:0.8rem;min-width:100px;}.image-preview{margin-top:var(--space-sm);}.image-preview img{max-width:100%;max-height:200px;border-radius:var(--radius-sm);border:1px solid var(--border);}.feed{display:flex;flex-direction:column;gap:var(--space-md);}.post-card{background:rgba(20,18,22,0.6);border:1px solid rgba(255,255,255,0.06);border-radius:var(--radius);padding:var(--space-lg);transition:all var(--duration-fast);text-align:left;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);}.post-card:hover{border-color:rgba(255,255,255,0.12);box-shadow:0 8px 24px rgba(0,0,0,0.3);background:rgba(20,18,22,0.75);}.post-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-sm);}.post-avatar{width:36px;height:36px;border-radius:50%;background:var(--border);display:flex;align-items:center;justify-content:center;font-size:0.9rem;overflow:hidden;}.post-avatar img{width:100%;height:100%;object-fit:cover;}.post-author-name{font-size:0.85rem;font-weight:600;color:var(--text);}.post-meta{font-size:0.72rem;color:var(--text-dim);}.post-content{font-size:0.9rem;color:var(--text);line-height:1.6;margin-bottom:var(--space-sm);white-space:pre-wrap;word-break:break-word;}.post-image{margin-bottom:var(--space-sm);}.post-image img{max-width:100%;border-radius:var(--radius-sm);border:1px solid var(--border);}.post-tasting-link{display:block;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:var(--space-sm) var(--space-md);margin-bottom:var(--space-sm);font-size:0.8rem;color:var(--text-muted);cursor:pointer;transition:border-color var(--duration-fast);}.post-tasting-link:hover{border-color:var(--accent);}.post-tasting-link strong{color:var(--text);}.post-hashtags{display:flex;gap:var(--space-xs);flex-wrap:wrap;margin-bottom:var(--space-sm);}.post-hashtag{font-size:0.75rem;color:var(--accent);cursor:pointer;}.post-hashtag::before{content:'#';}.post-hashtag:hover{text-decoration:underline;}.post-actions{display:flex;gap:var(--space-md);padding-top:var(--space-sm);border-top:1px solid var(--border);}.post-action-btn{background:none;border:none;color:var(--text-dim);font-size:0.82rem;cursor:pointer;display:inline-flex;align-items:center;gap:5px;padding:4px 0;transition:color var(--duration-fast);}.post-action-btn:hover{color:var(--text);}.post-action-btn.liked{color:#e06c75;}.hashtag-cloud{display:flex;flex-wrap:wrap;gap:8px;padding:8px 0;}.hashtag-chip{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border-radius:20px;background:rgba(20,18,22,0.5);border:1px solid rgba(255,255,255,0.06);font-size:14px;color:var(--accent);cursor:pointer;transition:all 0.2s;}.hashtag-chip:hover{background:rgba(212,99,77,0.15);border-color:rgba(212,99,77,0.3);box-shadow:var(--glow-accent);transform:translateY(-1px);}.hashtag-chip .count{font-size:11px;color:var(--text-dim);background:rgba(255,255,255,0.06);padding:1px 5px;border-radius:8px;}.user-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;}.user-card{background:rgba(20,18,22,0.6);border:1px solid rgba(255,255,255,0.06);border-radius:12px;padding:14px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;transition:all 0.2s;}.user-card:hover{border-color:rgba(255,255,255,0.1);background:rgba(20,18,22,0.75);box-shadow:var(--glow-wine);}.user-card .avatar{width:56px;height:56px;border-radius:50%;background:rgba(212,99,77,0.15);display:flex;align-items:center;justify-content:center;color:var(--accent);}.user-card .name{font-weight:600;font-size:15px;color:var(--text);}.user-card .bio{font-size:13px;color:var(--text-dim);line-height:1.3;}.user-card .stats{font-size:12px;color:var(--text-dim);}.user-card .follow-btn{margin-top:4px;}.event-card{background:rgba(20,18,22,0.6);border:1px solid rgba(255,255,255,0.06);border-radius:12px;padding:14px 16px;display:flex;flex-direction:column;gap:8px;transition:all 0.2s;}.event-card:hover{border-color:rgba(255,255,255,0.1);background:rgba(20,18,22,0.75);box-shadow:var(--glow-wine);}.event-card .event-type{display:inline-block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;padding:2px 8px;border-radius:6px;background:rgba(212,99,77,0.15);color:var(--accent);align-self:flex-start;}.event-card .event-title{font-weight:700;font-size:16px;color:var(--text);}.event-card .event-meta{font-size:13px;color:var(--text-dim);display:flex;gap:12px;flex-wrap:wrap;}.event-card .event-desc{font-size:14px;color:var(--text-secondary);line-height:1.4;}.event-card .event-actions{display:flex;gap:8px;margin-top:4px;}.profile-card{background:rgba(20,18,22,0.6);border:1px solid rgba(255,255,255,0.06);border-radius:var(--radius);padding:var(--space-xl);text-align:center;margin-bottom:var(--space-lg);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:all var(--duration-fast);}.profile-card:hover{border-color:rgba(255,255,255,0.12);box-shadow:0 8px 24px rgba(0,0,0,0.3);}.profile-avatar{width:72px;height:72px;border-radius:50%;background:var(--border);margin:0 auto var(--space-md);display:flex;align-items:center;justify-content:center;font-size:2rem;overflow:hidden;}.profile-avatar img{width:100%;height:100%;object-fit:cover;}.profile-card h3{font-size:1.2rem;font-weight:600;color:var(--text);margin-bottom:4px;}.profile-card .bio{font-size:0.85rem;color:var(--text-muted);margin-top:8px;}.profile-meta{margin-top:var(--space-md);font-size:0.78rem;color:var(--text-dim);display:flex;gap:var(--space-md);justify-content:center;}.profile-tabs{display:flex;gap:2px;margin-bottom:var(--space-lg);border-bottom:1px solid var(--border);}.profile-tab{padding:10px 18px;background:none;border:none;border-bottom:2px solid transparent;font-size:0.82rem;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all var(--duration-fast);}.profile-tab:hover{color:var(--text);}.profile-tab.active{color:var(--accent);border-bottom-color:var(--accent);background:rgba(212,99,77,0.05);}.archive-search-wrap{margin-bottom:var(--space-lg);}.archive-search-wrap input{width:100%;padding:11px 14px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--bg-elevated);color:var(--text);font-size:0.9rem;}.archive-search-wrap input:focus{outline:none;border-color:var(--accent);}.modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.7);backdrop-filter:blur(6px);z-index:1000;align-items:center;justify-content:center;padding:var(--space-md);opacity:0;transition:opacity var(--duration-normal) var(--ease);}.modal.active{display:flex;opacity:1;}.modal-box{background:rgba(20,18,22,0.9);border:1px solid rgba(255,255,255,0.08);border-radius:var(--radius);width:100%;max-width:460px;max-height:90vh;overflow-y:auto;padding:var(--space-xl);position:relative;transform:scale(0.96);transition:transform var(--duration-normal) var(--ease);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 24px 64px rgba(0,0,0,0.5),var(--glow-wine);}.modal.active .modal-box{transform:scale(1);}.modal-close{position:absolute;top:var(--space-md);right:var(--space-md);width:32px;height:32px;border-radius:50%;border:none;background:var(--bg-hover);color:var(--text-muted);font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--duration-fast);}.modal-close:hover{background:var(--accent);color:var(--bg);}.modal h3{font-size:1.2rem;font-weight:700;color:var(--text);margin-bottom:var(--space-lg);}.auth-form .form-group{margin-bottom:var(--space-md);}.form-actions{display:flex;gap:var(--space-md);align-items:center;margin-top:var(--space-lg);}.form-error{color:var(--error);font-size:0.8rem;margin-top:6px;min-height:0;}.info-body{font-size:0.88rem;color:var(--text-muted);line-height:1.65;}.info-body strong{color:var(--text);}#toast-container{position:fixed;bottom:24px;right:24px;z-index:2000;display:flex;flex-direction:column;gap:var(--space-sm);pointer-events:none;}.toast{background:rgba(20,18,22,0.85);border:1px solid rgba(255,255,255,0.06);border-radius:var(--radius-sm);padding:12px 18px;font-size:0.85rem;color:var(--text);box-shadow:0 8px 24px rgba(0,0,0,0.4);animation:toastSlideIn var(--duration-normal) var(--ease) forwards;pointer-events:auto;max-width:320px;display:flex;align-items:center;gap:var(--space-sm);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-left:3px solid var(--text-muted);}.toast.success{border-color:rgba(255,255,255,0.06);border-left-color:rgba(92,184,92,0.6);box-shadow:0 8px 24px rgba(0,0,0,0.4),0 0 20px rgba(92,184,92,0.15);}.toast.error{border-color:rgba(255,255,255,0.06);border-left-color:rgba(196,90,90,0.6);box-shadow:0 8px 24px rgba(0,0,0,0.4),0 0 20px rgba(196,90,90,0.15);}.toast.warning{border-color:rgba(255,255,255,0.06);border-left-color:rgba(212,168,67,0.6);box-shadow:0 8px 24px rgba(0,0,0,0.4),0 0 20px rgba(212,168,67,0.15);}.toast.info{border-color:rgba(255,255,255,0.06);border-left-color:rgba(212,99,77,0.6);box-shadow:0 8px 24px rgba(0,0,0,0.4),0 0 20px rgba(212,99,77,0.15);}@keyframes toastSlideIn{from{opacity:0;transform:translateX(40px) scale(0.95);}to{opacity:1;transform:translateX(0) scale(1);}}.toast.out{animation:toastSlideOut var(--duration-fast) var(--ease) forwards;}@keyframes toastSlideOut{from{opacity:1;transform:translateX(0) scale(1);}to{opacity:0;transform:translateX(40px) scale(0.95);}}.empty-state{text-align:center;padding:var(--space-2xl) var(--space-md);color:var(--text-dim);font-size:0.9rem;display:flex;flex-direction:column;align-items:center;gap:var(--space-md);}.empty-state .empty-icon{font-size:2.5rem;opacity:0.3;margin-bottom:var(--space-sm);}.empty-state .empty-title{color:var(--text-muted);font-size:1rem;font-weight:600;}.empty-state .empty-cta{margin-top:var(--space-sm);}.loading-dots{display:inline-flex;gap:4px;}.loading-dots span{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:dotBounce 1.2s infinite ease-in-out;}.loading-dots span:nth-child(2){animation-delay:0.15s;}.loading-dots span:nth-child(3){animation-delay:0.3s;}@keyframes dotBounce{0%,80%,100%{transform:scale(0.5);opacity:0.4;}40%{transform:scale(1);opacity:1;}}.field-hint{font-size:0.75rem;color:var(--text-dim);margin-top:4px;display:flex;align-items:center;gap:4px;}.field-hint::before{content:'💡';font-size:0.7rem;}.field-error{font-size:0.75rem;color:var(--error);margin-top:4px;display:flex;align-items:center;gap:4px;}.field-error::before{content:'⚠️';font-size:0.7rem;}.toast,.skeleton,.result-item,.card-entrance,.view{will-change:transform,opacity;}.toast.out,.skeleton{will-change:auto;}@media (max-width:640px){.page-header{height:52px;}.view > div:first-child{padding-top:52px;}.nav-links{display:none;}.nav-logo{font-size:1rem;}.nav-toggle{display:flex;}.nav-links.open{display:flex;position:absolute;top:56px;left:0;right:0;background:rgba(10,9,12,0.98);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);flex-direction:column;padding:4px 0 12px;z-index:499;}.nav-links.open .nav-link{width:100%;text-align:left;padding:12px 20px;border-radius:0;}.hero-logo{font-size:3.5rem;}.hero-actions{flex-direction:column;}.btn-lg{width:100%;max-width:280px;margin:0 auto;}.card-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-sm);}.dash-card{padding:var(--space-md);text-align:center;}.dash-card h3{font-size:0.9rem;margin-bottom:var(--space-xs);}.dash-card p{font-size:0.75rem;max-width:100%;margin-left:auto;margin-right:auto;margin-bottom:var(--space-sm);line-height:1.4;}.card-icon{font-size:1.5rem;margin-bottom:var(--space-xs);}.card-cta{font-size:0.72rem;}.form-row{grid-template-columns:1fr;}.form-actions{flex-direction:column;}.form-actions .btn{width:100%;}.slider-row{gap:8px;padding:6px 0;}.slider-label-left,.slider-label-right{font-size:10px;min-width:72px;max-width:72px;}.slider-val{font-size:11px;min-width:14px;}.wine-slider{height:5px;}.wine-slider::-webkit-slider-thumb{width:16px;height:16px;}.photo-preview{min-height:160px;}.photo-placeholder svg{width:36px;height:36px;}.photo-placeholder p{font-size:13px;}.composer-tools{flex-wrap:wrap;}.composer-tools select{flex:1;min-width:120px;}#toast-container{left:var(--space-md);right:var(--space-md);bottom:16px;}.toast{max-width:none;}}@media (max-width:480px){.page-body{padding:var(--space-md) var(--space-sm) var(--space-xl);}.result-item{padding:var(--space-md);}.card-grid{grid-template-columns:1fr;}.dash-card{padding:var(--space-md);}}.hidden{display:none !important;}.sr-only{position:absolute;width:1px;height:1px;padding:0;border:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;}button:focus-visible,a:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:2px solid var(--accent);outline-offset:2px;}.skeleton{background:linear-gradient(90deg,var(--bg-hover) 25%,var(--border) 50%,var(--bg-hover) 75%);background-size:200% 100%;animation:skeletonShimmer 1.2s ease-in-out infinite;border-radius:var(--radius-sm);}.skeleton-text{height:14px;margin-bottom:8px;}.skeleton-title{height:20px;width:70%;margin-bottom:12px;}.skeleton-badge{height:18px;width:80px;}.skeleton-meta{height:12px;width:50%;}@keyframes skeletonShimmer{0%{background-position:200% 0;}100%{background-position:-200% 0;}}.stagger-in > *{opacity:0;transform:translateY(12px);animation:staggerIn var(--duration-normal) var(--ease) forwards;}.stagger-in > *:nth-child(1){animation-delay:0ms;}.stagger-in > *:nth-child(2){animation-delay:60ms;}.stagger-in > *:nth-child(3){animation-delay:120ms;}.stagger-in > *:nth-child(4){animation-delay:180ms;}.stagger-in > *:nth-child(5){animation-delay:240ms;}.stagger-in > *:nth-child(6){animation-delay:300ms;}.stagger-in > *:nth-child(7){animation-delay:360ms;}.stagger-in > *:nth-child(8){animation-delay:420ms;}.stagger-in > *:nth-child(9){animation-delay:480ms;}.stagger-in > *:nth-child(10){animation-delay:540ms;}@keyframes staggerIn{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:translateY(0);}}.nav-notify{position:relative;background:none;border:none;font-size:1.1rem;cursor:pointer;padding:4px;line-height:1;}.notify-badge{position:absolute;top:-2px;right:-4px;background:var(--error);color:#fff;font-size:0.6rem;font-weight:700;padding:1px 5px;border-radius:8px;min-width:16px;text-align:center;animation:badgePop var(--duration-fast) var(--ease);}@keyframes badgePop{0%{transform:scale(0);}80%{transform:scale(1.2);}100%{transform:scale(1);}}.dm-convo-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;cursor:pointer;transition:background 0.15s;border-bottom:1px solid rgba(255,255,255,0.04);}.dm-convo-item:hover{background:rgba(255,255,255,0.04);}.dm-convo-item.active{background:rgba(212,99,77,0.1);border-color:rgba(212,99,77,0.15);}.dm-convo-item .avatar{width:36px;height:36px;border-radius:50%;background:rgba(212,99,77,0.15);display:flex;align-items:center;justify-content:center;color:var(--accent);flex-shrink:0;}.dm-convo-item .info{flex:1;min-width:0;}.dm-convo-item .name{font-weight:600;font-size:14px;color:var(--text);}.dm-convo-item .preview{font-size:12px;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}.dm-convo-item .unread-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);flex-shrink:0;box-shadow:0 0 6px rgba(212,99,77,0.6);}.dm-msg{padding:6px 0;border-bottom:1px solid rgba(255,255,255,0.03);}.dm-msg .msg-author{font-weight:600;font-size:12px;color:var(--accent);}.dm-msg .msg-time{font-size:11px;color:var(--text-dim);margin-left:6px;}.dm-msg .msg-text{font-size:14px;color:var(--text);margin-top:2px;word-break:break-word;}.dm-msg.toast{background:rgba(212,99,77,0.08);border-radius:8px;padding:8px 10px;text-align:center;}.dm-msg.toast .msg-text{color:var(--accent);font-weight:600;font-style:italic;display:flex;align-items:center;justify-content:center;gap:6px;}.notification-panel{position:fixed;top:56px;right:16px;width:320px;max-height:420px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 16px 48px rgba(0,0,0,0.5);z-index:600;overflow:hidden;display:flex;flex-direction:column;animation:panelIn var(--duration-normal) var(--ease);}@keyframes panelIn{from{opacity:0;transform:translateY(-8px);}to{opacity:1;transform:translateY(0);}}.notification-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border);}.notification-header h4{font-size:0.9rem;font-weight:600;}.notification-list{overflow-y:auto;padding:var(--space-sm) 0;}.notification-item{padding:var(--space-sm) var(--space-lg);font-size:0.82rem;border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--duration-fast);}.notification-item:hover{background:var(--bg-hover);}.notification-item.unread{border-left:3px solid var(--accent);}.notification-item .notify-time{font-size:0.7rem;color:var(--text-dim);margin-top:2px;}.btn{transition:transform 0.2s var(--ease),box-shadow 0.2s var(--ease),background 0.2s;position:relative;overflow:hidden;}.btn::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at center,rgba(212,99,77,0.15) 0%,transparent 70%);opacity:0;transition:opacity 0.3s;pointer-events:none;}.btn:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 4px 20px rgba(212,99,77,0.15);}.btn:hover::after{opacity:1;}.btn:active{transform:translateY(0) scale(0.98);box-shadow:0 2px 8px rgba(212,99,77,0.1);}.btn-primary{position:relative;}.btn-primary::before{content:'';position:absolute;inset:-2px;border-radius:inherit;background:linear-gradient(135deg,var(--accent),var(--accent-light));opacity:0;filter:blur(8px);transition:opacity 0.3s;z-index:-1;}.btn-primary:hover::before{opacity:0.4;}@keyframes cardFadeUp{from{opacity:0;transform:translateY(24px);}to{opacity:1;transform:translateY(0);}}.card-entrance{animation:cardFadeUp 0.5s var(--ease) both;}.results-list .result-item:nth-child(1){animation-delay:0.05s;}.results-list .result-item:nth-child(2){animation-delay:0.10s;}.results-list .result-item:nth-child(3){animation-delay:0.15s;}.results-list .result-item:nth-child(4){animation-delay:0.20s;}.results-list .result-item:nth-child(5){animation-delay:0.25s;}.results-list .result-item:nth-child(6){animation-delay:0.30s;}.results-list .result-item:nth-child(7){animation-delay:0.35s;}.results-list .result-item:nth-child(8){animation-delay:0.40s;}.results-list .result-item:nth-child(9){animation-delay:0.45s;}.results-list .result-item:nth-child(10){animation-delay:0.50s;}@keyframes starPop{0%{transform:scale(1);}50%{transform:scale(1.4);}100%{transform:scale(1);}}.star-rating .star.filled{animation:starPop 0.3s var(--ease);}@keyframes sliderGlow{0%{box-shadow:0 0 0 0 rgba(212,99,77,0.4);}50%{box-shadow:0 0 0 8px rgba(212,99,77,0);}100%{box-shadow:0 0 0 0 rgba(212,99,77,0);}}.wine-slider:active::-webkit-slider-thumb{animation:sliderGlow 1s ease-out infinite;}.toast{animation:toastSlideIn 0.35s var(--ease) both;}@keyframes toastSlideIn{from{opacity:0;transform:translateX(40px);}to{opacity:1;transform:translateX(0);}}.toast.out{animation:toastSlideOut 0.3s var(--ease) both;}@keyframes toastSlideOut{from{opacity:1;transform:translateX(0);}to{opacity:0;transform:translateX(40px);}}@keyframes shimmer{0%{background-position:-200% 0;}100%{background-position:200% 0;}}.skeleton{background:linear-gradient(
    90deg,var(--bg-elevated) 25%,var(--bg-hover) 50%,var(--bg-elevated) 75%
  );background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:6px;}.skeleton-text{height:14px;margin:8px 0;border-radius:4px;}.skeleton-title{height:20px;width:60%;margin:12px 0 8px;}.skeleton-avatar{width:40px;height:40px;border-radius:50%;}.glass-card{background:rgba(20,18,22,0.65);backdrop-filter:blur(16px) saturate(1.2);-webkit-backdrop-filter:blur(16px) saturate(1.2);border:1px solid rgba(255,255,255,0.06);box-shadow:0 8px 32px rgba(0,0,0,0.3),inset 0 1px 0 rgba(255,255,255,0.04);}@keyframes wineSpin{0%{transform:rotate(0deg);}25%{transform:rotate(15deg);}75%{transform:rotate(-15deg);}100%{transform:rotate(0deg);}}.wine-spinner{width:40px;height:40px;animation:wineSpin 1.2s ease-in-out infinite;}.wine-spinner svg{width:100%;height:100%;stroke:var(--accent);fill:none;stroke-width:1.5;}.backdrop-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.6);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:998;opacity:0;transition:opacity 0.3s;pointer-events:none;}.backdrop-overlay.active{opacity:1;pointer-events:all;}.dashboard-card{transition:transform 0.3s var(--ease),box-shadow 0.3s var(--ease);}.dashboard-card:hover{transform:translateY(-4px) scale(1.01);box-shadow:0 12px 40px rgba(0,0,0,0.4),0 0 20px rgba(212,99,77,0.08);}.nav-link{position:relative;transition:color 0.2s;}.nav-link::after{content:'';position:absolute;bottom:-2px;left:50%;width:0;height:2px;background:var(--accent);transition:width 0.25s var(--ease),left 0.25s var(--ease);border-radius:1px;}.nav-link:hover::after{width:100%;left:0;}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{box-shadow:0 0 0 3px rgba(212,99,77,0.15);transition:box-shadow 0.2s,border-color 0.2s;}@keyframes scorePulse{0%{box-shadow:0 0 0 0 rgba(212,99,77,0.3);}70%{box-shadow:0 0 0 6px rgba(212,99,77,0);}100%{box-shadow:0 0 0 0 rgba(212,99,77,0);}}.score-pill{animation:scorePulse 2s ease-in-out infinite;}.page-header{transition:box-shadow 0.3s,background 0.3s;}.page-header.scrolled{background:rgba(10,9,12,0.95);backdrop-filter:blur(12px);box-shadow:0 2px 20px rgba(0,0,0,0.3);}.breadcrumb{display:flex;align-items:center;gap:4px;font-size:0.7rem;color:var(--text-dim);margin-bottom:4px;opacity:0;transform:translateY(-4px);transition:opacity 0.3s,transform 0.3s;}.breadcrumb.show{opacity:1;transform:translateY(0);}.breadcrumb a{color:var(--text-dim);text-decoration:none;transition:color 0.2s;}.breadcrumb a:hover{color:var(--accent);}.breadcrumb .sep{color:var(--border-light);margin:0 2px;}.breadcrumb .current{color:var(--text-muted);font-weight:500;}.back-btn{transition:transform 0.2s,background 0.2s;}.back-btn:hover{transform:translateX(-3px);background:var(--bg-hover);}.empty-state{text-align:center;padding:40px 20px;color:var(--text-dim);}.empty-state-icon{width:48px;height:48px;margin:0 auto 16px;opacity:0.4;}.bottom-nav{display:none;}@media (max-width:640px){.bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;align-items:center;height:56px;background:rgba(10,9,12,0.92);backdrop-filter:blur(16px);border-top:1px solid var(--border);z-index:999;padding-bottom:env(safe-area-inset-bottom);}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;color:var(--text-dim);font-size:0.65rem;padding:6px 12px;border:none;background:none;cursor:pointer;transition:color 0.2s;}.bottom-nav-item.active{color:var(--accent);}.bottom-nav-item svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2;}}.splash-screen{position:fixed;inset:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:9999;transition:opacity 0.6s var(--ease),visibility 0.6s;}.splash-screen.done{opacity:0;visibility:hidden;pointer-events:none;}.splash-content{display:flex;flex-direction:column;align-items:center;gap:16px;animation:splashFadeIn 0.8s var(--ease) both;}@keyframes splashFadeIn{from{opacity:0;transform:translateY(30px);}to{opacity:1;transform:translateY(0);}}.splash-logo{width:64px;height:64px;background:linear-gradient(135deg,var(--accent),var(--accent-light));border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 32px rgba(212,99,77,0.3);animation:splashPulse 2s ease-in-out infinite;}@keyframes splashPulse{0%,100%{box-shadow:0 8px 32px rgba(212,99,77,0.3);}50%{box-shadow:0 8px 48px rgba(212,99,77,0.5);}}.splash-logo svg{width:32px;height:32px;stroke:#fff;fill:none;stroke-width:1.5;}.splash-title{font-size:2.5rem;font-weight:700;letter-spacing:-1px;background:linear-gradient(135deg,var(--accent),var(--accent-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0;}.splash-tagline{font-size:0.9rem;color:var(--text-muted);margin:0;letter-spacing:1px;text-transform:uppercase;}.splash-loader{width:120px;height:3px;background:var(--bg-elevated);border-radius:3px;overflow:hidden;margin-top:8px;}.splash-loader-bar{width:0%;height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-light));border-radius:3px;animation:splashLoad 2s ease-in-out forwards;}@keyframes splashLoad{0%{width:0%;}50%{width:70%;}100%{width:100%;}}::-webkit-scrollbar{width:8px;}::-webkit-scrollbar-track{background:var(--bg);border-radius:4px;}::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.12);border-radius:4px;transition:background 0.2s;}::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,0.22);}*{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,0.12) var(--bg);}.sound-toggle{position:fixed;bottom:72px;right:16px;width:36px;height:36px;border-radius:50%;background:var(--bg-elevated);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:997;color:var(--text-muted);transition:all 0.2s;font-size:0.8rem;}.sound-toggle:hover{color:var(--accent);border-color:var(--accent);}.sound-toggle.on{color:var(--accent);background:rgba(212,99,77,0.1);}@media (min-width:641px){.sound-toggle{bottom:16px;}}.favicon-badge canvas{display:none;}.view.exit{animation:viewExit 0.3s var(--ease) forwards;}@keyframes viewExit{from{opacity:1;transform:translateY(0) scale(1);}to{opacity:0;transform:translateY(-10px) scale(0.98);}}.note-card-actions{display:flex;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,0.08);flex-wrap:wrap;}.note-card-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;border:1px solid rgba(255,255,255,0.12);background:rgba(255,255,255,0.06);color:#a0a0a0;transition:all 0.2s ease;}.note-card-btn:hover{background:rgba(255,255,255,0.12);color:#fff;border-color:rgba(255,255,255,0.2);}.note-card-btn.edit:hover{border-color:#c9a227;color:#c9a227;}.note-card-btn.share:hover{border-color:#4a9eff;color:#4a9eff;}.note-card-btn.delete:hover{border-color:#ff6b6b;color:#ff6b6b;}.privacy-toggle-label{display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-size:13px;color:#a0a0a0;user-select:none;}.privacy-toggle-label .toggle-slider{width:36px;height:20px;background:#555;border-radius:10px;position:relative;transition:background 0.2s;}.privacy-toggle-label .toggle-slider::after{content:'';width:16px;height:16px;background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;transition:left 0.2s;}.privacy-toggle-label input:checked + .toggle-slider{background:#c9a227;}.privacy-toggle-label input:checked + .toggle-slider::after{left:18px;}.scroll-to-top{position:fixed;bottom:80px;right:16px;width:44px;height:44px;border-radius:50%;background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transform:translateY(16px);transition:all 0.3s var(--ease);z-index:1000;box-shadow:0 4px 16px rgba(0,0,0,0.4);}.scroll-to-top.visible{opacity:1;transform:translateY(0);}.scroll-to-top:hover{border-color:var(--accent);color:var(--accent);box-shadow:var(--glow-accent);}.scroll-to-top svg{width:20px;height:20px;stroke:currentColor;stroke-width:2.5;fill:none;}@media (min-width:769px){.scroll-to-top{display:none;}}.empty-state-enhanced{text-align:center;padding:var(--space-2xl) var(--space-lg);}.empty-state-icon{width:80px;height:80px;margin:0 auto var(--space-lg);color:var(--text-dim);opacity:0.5;}.empty-state-title{font-size:1.3rem;font-weight:600;color:var(--text-muted);margin-bottom:var(--space-sm);}.empty-state-desc{font-size:0.92rem;color:var(--text-dim);max-width:320px;margin:0 auto var(--space-lg);line-height:1.5;}.empty-state-cta{margin-top:var(--space-md);}.quick-mode-toggle{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-lg);padding:var(--space-sm) var(--space-md);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color var(--duration-fast) var(--ease);}.quick-mode-toggle:hover{border-color:var(--accent);}.quick-mode-toggle input{appearance:none;width:18px;height:18px;border:2px solid var(--border-light);border-radius:4px;cursor:pointer;position:relative;transition:all var(--duration-fast) var(--ease);}.quick-mode-toggle input:checked{background:var(--accent);border-color:var(--accent);}.quick-mode-toggle input:checked::after{content:'';position:absolute;left:5px;top:2px;width:4px;height:9px;border:solid var(--text);border-width:0 2px 2px 0;transform:rotate(45deg);}.quick-mode-toggle label{font-weight:600;font-size:0.9rem;color:var(--text-muted);cursor:pointer;}.form-section.quick-hidden{display:none !important;}.form-section.quick-visible{display:block !important;}.search-bar{position:relative;}.search-suggestions{position:absolute;top:100%;left:0;right:0;z-index:10;list-style:none;margin:4px 0 0;padding:0;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:0 8px 32px rgba(0,0,0,0.4);overflow:hidden;}.search-suggestions li{padding:10px 14px;cursor:pointer;display:flex;align-items:center;gap:10px;transition:background 0.15s var(--ease);font-size:0.9rem;color:var(--text-muted);}.search-suggestions li:hover,.search-suggestions li.active{background:var(--bg-hover);color:var(--text);}.search-suggestions li .sugg-type{font-size:0.7rem;text-transform:uppercase;letter-spacing:0.05em;color:var(--accent);background:rgba(212,99,77,0.1);padding:2px 6px;border-radius:4px;white-space:nowrap;}.search-suggestions li .sugg-count{margin-left:auto;font-size:0.75rem;color:var(--text-dim);}.feed-tabs{display:flex;gap:4px;margin-bottom:var(--space-md);border-bottom:1px solid var(--border);padding-bottom:var(--space-sm);}.feed-tab{background:transparent;border:none;color:var(--text-muted);font-size:0.9rem;font-weight:500;padding:8px 16px;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--duration-fast) var(--ease);position:relative;}.feed-tab:hover{color:var(--text);background:var(--bg-hover);}.feed-tab.active{color:var(--accent);font-weight:600;}.feed-tab.active::after{content:'';position:absolute;bottom:-9px;left:16px;right:16px;height:2px;background:var(--accent);border-radius:2px;}.rec-reason{display:inline-flex;align-items:center;gap:6px;font-size:0.78rem;color:var(--accent);background:rgba(212,99,77,0.08);padding:4px 10px;border-radius:12px;margin-bottom:8px;}.pwa-install-banner{position:fixed;bottom:0;left:0;right:0;background:var(--bg-card);border-top:1px solid var(--border);padding:var(--space-sm) var(--space-md);z-index:var(--z-toast);box-shadow:0 -4px 16px rgba(0,0,0,0.1);animation:slideUp var(--duration-normal) var(--ease);}.pwa-install-content{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);max-width:var(--max-width);margin:0 auto;}.pwa-install-content span{font-size:0.9rem;color:var(--text);}.pwa-install-actions{display:flex;gap:8px;flex-shrink:0;}@keyframes slideUp{from{transform:translateY(100%);}to{transform:translateY(0);}}.magic-separator{display:flex;align-items:center;gap:12px;margin:var(--space-md) 0;color:var(--text-dim);font-size:0.85rem;}.magic-separator::before,.magic-separator::after{content:'';flex:1;height:1px;background:var(--border);}.magic-hint{font-size:0.78rem;color:var(--text-dim);text-align:center;margin-top:var(--space-xs);}.guest-banner{background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius);padding:var(--space-sm) var(--space-md);margin-bottom:var(--space-md);text-align:center;color:var(--text-dim);font-size:0.88rem;}.guest-banner .btn{margin-left:var(--space-sm);padding:6px 14px;font-size:0.82rem;}