.donate-backdrop{-webkit-backdrop-filter:blur(4px);z-index:1000;background:#0000008c;justify-content:center;align-items:center;padding:1rem;animation:.18s donate-fade-in;display:flex;position:fixed;inset:0}@keyframes donate-fade-in{0%{opacity:0}to{opacity:1}}.donate-modal{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:1.25rem;width:100%;max-width:480px;max-height:90vh;animation:.22s donate-slide-up;overflow-y:auto;box-shadow:0 24px 64px #0000004d}@keyframes donate-slide-up{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.donate-header{justify-content:space-between;align-items:flex-start;gap:1rem;padding:1.5rem 1.5rem 0;display:flex}.donate-kicker{color:color-mix(in srgb, var(--primary) 80%, var(--text-secondary));text-transform:uppercase;letter-spacing:.06em;align-items:center;gap:.35rem;margin-bottom:.4rem;font-size:.75rem;font-weight:600;display:inline-flex}.donate-header-copy h2{color:var(--text-primary);margin:0;font-size:1.2rem;font-weight:700}.donate-close{border:1px solid var(--border-default);background:var(--bg-secondary);width:2rem;height:2rem;color:var(--text-secondary);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,color .15s;display:inline-flex}.donate-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.donate-form{flex-direction:column;gap:1rem;padding:1.25rem 1.5rem 1.5rem;display:flex}.donate-section-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.82rem;font-weight:600}.donate-presets{grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:.5rem;display:grid}.donate-preset-btn{border:1.5px solid var(--border-default);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;text-align:center;border-radius:.6rem;padding:.55rem .5rem;font-size:.9rem;font-weight:600;transition:border-color .15s,background .15s,color .15s}.donate-preset-btn:hover{border-color:var(--primary);color:var(--primary);background:color-mix(in srgb, var(--primary) 8%, var(--bg-elevated))}.donate-preset-btn.is-selected{border-color:var(--primary);background:color-mix(in srgb, var(--primary) 12%, var(--bg-elevated));color:var(--primary-700,var(--primary))}.donate-custom-row{flex-direction:column;gap:.4rem;display:flex}.donate-input-wrap{align-items:center;display:flex;position:relative}.donate-input{border:1.5px solid var(--border-default);background:var(--bg-secondary);width:100%;color:var(--text-primary);appearance:textfield;border-radius:.65rem;outline:none;padding:.65rem 2.5rem .65rem .85rem;font-size:1rem;transition:border-color .15s}.donate-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.donate-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.donate-input:focus{border-color:var(--primary)}.donate-input.is-error{border-color:#ef4444}.donate-input:disabled{opacity:.45;cursor:not-allowed}.donate-input-suffix{color:var(--text-secondary);pointer-events:none;font-size:.9rem;font-weight:600;position:absolute;right:.75rem}.donate-open-toggle{cursor:pointer;color:var(--text-secondary);align-items:center;gap:.55rem;font-size:.875rem;display:flex}.donate-open-toggle input{accent-color:var(--primary);cursor:pointer;flex-shrink:0;width:1rem;height:1rem}.donate-error{color:#ef4444;margin:0;font-size:.825rem}.donate-btn-primary{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:.75rem;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.25rem;font-size:.95rem;font-weight:700;transition:opacity .15s,transform .15s;display:inline-flex}.donate-btn-primary:hover{opacity:.9;transform:translateY(-1px)}.donate-btn-primary:disabled{opacity:.55;cursor:not-allowed;transform:none}.donate-generate-btn{width:100%}.donate-qr-section{flex-direction:column;align-items:center;gap:1rem;padding:1.25rem 1.5rem 1.5rem;display:flex}.donate-qr-card{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:1rem;flex-direction:column;align-items:center;gap:.5rem;width:100%;padding:1.5rem;display:flex}.donate-qr-img{width:220px;height:220px;image-rendering:pixelated;border-radius:.5rem;display:block}.donate-qr-receiver{color:var(--text-secondary);margin:0;font-size:.85rem}.donate-qr-amount{color:var(--text-primary);margin:0;font-size:2rem;font-weight:800;line-height:1.1}.donate-qr-amount span{color:var(--text-secondary);font-size:1rem;font-weight:600}.donate-qr-amount-open{color:var(--text-secondary);margin:0;font-size:.9rem;font-style:italic}.donate-qr-instruction{color:var(--text-secondary);text-align:center;margin:.5rem 0 0;font-size:.875rem}.donate-qr-note{color:var(--text-tertiary);text-align:center;margin:0;font-size:.75rem}.donate-qr-actions{flex-wrap:wrap;justify-content:center;gap:.5rem;display:flex}.donate-btn-icon{border:1.5px solid var(--border-default);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;border-radius:.6rem;align-items:center;gap:.4rem;padding:.55rem .9rem;font-size:.83rem;font-weight:600;transition:border-color .15s,background .15s;display:inline-flex}.donate-btn-icon:hover{border-color:var(--primary);background:color-mix(in srgb, var(--primary) 8%, var(--bg-elevated));color:var(--primary)}.donate-btn-ghost{color:var(--text-secondary)}.donate-btn-secondary{border:1.5px solid var(--border-default);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;border-radius:.65rem;align-items:center;gap:.45rem;padding:.6rem 1rem;font-size:.875rem;font-weight:600;transition:border-color .15s;display:inline-flex}.donate-btn-secondary:hover{border-color:var(--primary)}.donate-polling-hint{color:var(--text-tertiary);align-items:center;gap:.45rem;font-size:.78rem;display:flex}.donate-spinner{animation:1s linear infinite donate-spin}@keyframes donate-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.donate-expired{text-align:center;flex-direction:column;align-items:center;gap:1rem;padding:1.5rem;display:flex}.donate-expired p{color:var(--text-secondary);font-size:.9rem}.donate-thankyou{text-align:center;flex-direction:column;align-items:center;gap:.75rem;padding:2rem 1.5rem;display:flex}.donate-thankyou-icon{color:#22c55e}.donate-thankyou h3{color:var(--text-primary);margin:0;font-size:1.3rem;font-weight:700}.donate-thankyou p{color:var(--text-secondary);margin:0;font-size:.9rem}@media (width<=540px){.donate-modal{border-radius:1rem 1rem 0 0;align-self:flex-end;max-width:100%;max-height:95vh}.donate-backdrop{align-items:flex-end;padding:0}.donate-qr-img{width:200px;height:200px}}.app-wrapper{flex-direction:column;min-height:100vh;display:flex}.coffee-support-backdrop{z-index:1200;background:color-mix(in srgb, var(--bg-primary) 68%, transparent);-webkit-backdrop-filter:blur(6px);place-items:center;padding:clamp(1rem,3vw,1.5rem);display:grid;position:fixed;inset:0}.coffee-support-modal{border:1px solid color-mix(in srgb, var(--primary) 20%, var(--border-strong));background:var(--bg-elevated);width:min(100%,33rem);box-shadow:0 8px 32px rgba(var(--primary-rgb), .12), 0 24px 60px #0000002e, var(--shadow-xl);border-radius:1.75rem;animation:.46s cubic-bezier(.16,1,.3,1) coffee-support-rise;position:relative;overflow:hidden}.coffee-support-modal:before{content:"";background:linear-gradient(170deg, color-mix(in srgb, var(--primary) 12%, transparent) 0%, color-mix(in srgb, var(--primary) 5%, transparent) 30%, transparent 55%);pointer-events:none;position:absolute;inset:0}.coffee-support-close{z-index:2;width:2.5rem;height:2.5rem;color:var(--text-secondary);background:var(--bg-secondary);border:1px solid var(--border-default);transition:transform var(--transition-fast), color var(--transition-fast), background-color var(--transition-fast);border-radius:999px;justify-content:center;align-items:center;display:inline-flex;position:absolute;top:1rem;right:1rem}.coffee-support-close:hover{color:var(--text-primary);background:color-mix(in srgb, var(--bg-secondary) 88%, var(--primary-50));transform:translateY(-1px)}.coffee-support-art,.coffee-support-copy,.coffee-support-actions,.coffee-support-note{z-index:1;position:relative}.coffee-support-art{background:radial-gradient(ellipse 70% 80% at 50% 20%, color-mix(in srgb, var(--primary) 10%, transparent), transparent 70%);place-items:center;min-height:9rem;padding:1.6rem 1.5rem .6rem;display:grid;position:relative}.coffee-support-art-ring{border:1.5px solid color-mix(in srgb, var(--primary) 28%, var(--border-default));border-radius:999px;animation:3s ease-in-out infinite coffee-support-ring-pulse;position:absolute}.coffee-support-art-ring--one{width:10rem;height:10rem}.coffee-support-art-ring--two{opacity:.55;width:7rem;height:7rem;animation-delay:.8s}.coffee-support-mascot{width:4.75rem;height:4.75rem;color:var(--primary-700);background:linear-gradient(145deg, color-mix(in srgb, var(--primary-50) 90%, var(--bg-elevated)), color-mix(in srgb, var(--primary-100,var(--primary-50)) 60%, var(--bg-elevated)));border:1.5px solid color-mix(in srgb, var(--primary) 30%, var(--border-default));box-shadow:0 4px 16px rgba(var(--primary-rgb), .14), var(--shadow-sm);border-radius:1.4rem;justify-content:center;align-items:center;animation:3.2s ease-in-out infinite coffee-support-float;display:inline-flex;position:relative}.coffee-support-mascot-heart{color:#fff;background:linear-gradient(135deg, var(--primary), color-mix(in srgb, var(--primary) 80%, #f43f5e));width:1.75rem;height:1.75rem;box-shadow:0 .3rem .9rem rgba(var(--primary-rgb), .3);border-radius:999px;justify-content:center;align-items:center;animation:1.8s ease-in-out infinite coffee-support-heartbeat;display:inline-flex;position:absolute;top:-.5rem;right:-.35rem}.coffee-support-star{color:color-mix(in srgb, var(--primary) 70%, var(--text-tertiary));animation:2.6s ease-in-out infinite coffee-support-wiggle;position:absolute}.coffee-support-star--left{top:2.25rem;left:calc(50% - 4.8rem)}.coffee-support-star--right{animation-delay:.45s;top:4.2rem;right:calc(50% - 5.2rem)}.coffee-support-copy{text-align:center;padding:0 1.4rem .75rem}.coffee-support-kicker{background:color-mix(in srgb, var(--primary-50) 74%, var(--bg-secondary));color:var(--primary-700);border:1px solid color-mix(in srgb, var(--primary) 18%, var(--border-default));letter-spacing:.04em;border-radius:999px;align-items:center;gap:.4rem;padding:.45rem .85rem;font-size:.75rem;font-weight:700;display:inline-flex}.coffee-support-copy h2{font-family:var(--font-heading,sans-serif);letter-spacing:-.04em;color:var(--text-primary);margin:.85rem 0 .45rem;font-size:clamp(1.55rem,3vw,2rem);line-height:1.08}.coffee-support-copy p{color:color-mix(in srgb, var(--text-primary) 78%, var(--text-secondary));margin:0;font-size:.94rem;line-height:1.55}.coffee-support-plea{flex-wrap:wrap;justify-content:center;gap:.55rem;margin-top:1rem;display:flex}.coffee-support-plea span{min-height:2.1rem;color:color-mix(in srgb, var(--primary) 80%, var(--text-primary));background:color-mix(in srgb, var(--primary) 8%, var(--bg-secondary));border:1px solid color-mix(in srgb, var(--primary) 18%, var(--border-default));border-radius:999px;align-items:center;padding:.4rem .9rem;font-size:.81rem;font-weight:600;display:inline-flex}.coffee-support-actions{flex-wrap:wrap;gap:.75rem;padding:.6rem 1.4rem 0;display:flex}.coffee-support-modal--no-note .coffee-support-actions{padding-bottom:1.3rem}.coffee-support-actions .btn{flex:13rem;min-height:3rem}.coffee-support-primary.btn.btn-primary{box-shadow:var(--shadow-sm)}.coffee-support-primary.btn.btn-primary:hover:not(:disabled){box-shadow:var(--shadow-md);transform:translateY(-1px)}.coffee-support-promptpay.btn.btn-secondary{box-shadow:var(--shadow-sm)}.coffee-support-promptpay.btn.btn-secondary:hover:not(:disabled){box-shadow:var(--shadow-md);transform:translateY(-1px)}.coffee-support-secondary.btn{background:0 0}.coffee-support-dismiss-today{cursor:pointer;color:var(--text-tertiary);-webkit-user-select:none;user-select:none;align-items:center;gap:.5rem;padding:.4rem .2rem;font-size:.82rem;font-weight:600;transition:color .15s;display:flex}.coffee-support-dismiss-today:hover{color:var(--text-secondary)}.coffee-support-dismiss-today input[type=checkbox]{width:1rem;height:1rem;accent-color:var(--primary);cursor:pointer;flex-shrink:0}.coffee-support-note{text-align:center;color:var(--text-secondary);margin:0;padding:.9rem 1.4rem 1.3rem;font-size:.82rem;line-height:1.5}@keyframes coffee-support-rise{0%{opacity:0;transform:translateY(.6rem)scale(.985)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes coffee-support-float{0%,to{transform:translateY(0)rotate(-1deg)}50%{transform:translateY(-.45rem)rotate(1deg)}}@keyframes coffee-support-ring-pulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.06)}}@keyframes coffee-support-heartbeat{0%,to{transform:scale(1)}14%{transform:scale(1.22)}28%{transform:scale(1)}42%{transform:scale(1.14)}56%{transform:scale(1)}}@keyframes coffee-support-wiggle{0%,to{opacity:.75;transform:translateY(0)rotate(0)}50%{opacity:1;transform:translateY(-.2rem)rotate(12deg)}}.main-content{-webkit-overflow-scrolling:touch;flex:1;padding-bottom:5.5rem}.main-content--swipe{padding-bottom:0;position:relative}.mobile-swipe-pager{top:var(--header-height,80px);z-index:0;touch-action:pan-y;overscroll-behavior:none;position:fixed;bottom:0;left:0;right:0;overflow:hidden}.mobile-swipe-pager-track{will-change:transform;height:100%;display:flex}.mobile-swipe-pager.is-animating .mobile-swipe-pager-track{transition:transform .24s cubic-bezier(.22,1,.36,1)}.mobile-swipe-pager-slot{overscroll-behavior:contain;-webkit-overflow-scrolling:touch;background:var(--bg-primary);height:100%;padding-bottom:calc(64px + env(safe-area-inset-bottom,0));overflow:hidden auto}.mobile-swipe-pager.is-dragging .mobile-swipe-pager-slot:not(.is-active){pointer-events:none}.mobile-swipe-pager-slot-inner{min-height:100%}.mobile-swipe-pager-fallback{background:var(--bg-primary);min-height:100%}.header{z-index:1000;height:var(--header-height);background:var(--bg-glass-heavy);-webkit-backdrop-filter:blur(16px);transition:height .3s,background-color .3s,box-shadow .3s;position:sticky;top:0;overflow:visible!important}.header:after{content:"";background:linear-gradient(to bottom, var(--bg-glass-heavy), transparent);pointer-events:none;height:28px;position:absolute;top:100%;left:0;right:0}.header-scrolled{background:var(--bg-glass-heavy);box-shadow:var(--shadow-md);height:70px}.header-scrolled:after{display:none}.header-content{justify-content:space-between;align-items:center;gap:1rem;height:100%;display:flex}.visually-hidden{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.logo{font-family:var(--font-heading);letter-spacing:-.03em;color:var(--text-primary);flex-shrink:0;align-items:center;gap:.65rem;font-size:1.45rem;font-weight:800;text-decoration:none;display:flex}.logo-icon{background:var(--gradient-primary);color:#fff;width:38px;height:38px;box-shadow:0 4px 14px rgba(var(--primary-rgb), .42), 0 0 0 1px #ffffff26 inset;transition:box-shadow var(--transition-fast), rotate var(--transition-fast), scale var(--transition-fast);border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;display:flex;rotate:-6deg}.logo-icon-sm{border-radius:10px;width:30px;height:30px}.logo:hover .logo-icon{box-shadow:0 6px 22px rgba(var(--primary-rgb), .56), 0 0 0 1px #fff3 inset;rotate:6deg;scale:1.12}.logo-wordmark{letter-spacing:-.04em;color:var(--text-primary);font-weight:800;line-height:1}.logo-accent{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.text-accent{color:var(--text-accent)}.guest-actions-desktop{align-items:center;gap:.6rem;display:none}.guest-settings-panel{border:1px solid var(--border-default);background:var(--bg-elevated);z-index:200;border-radius:14px;flex-direction:column;gap:.25rem;min-width:220px;padding:.5rem;display:flex;box-shadow:0 8px 24px #0000001f}.guest-settings-row{border-radius:9px;justify-content:space-between;align-items:center;gap:.75rem;padding:.5rem .6rem;display:flex}.guest-settings-row:hover{background:color-mix(in srgb, var(--primary) 6%, var(--bg-secondary))}.guest-settings-label{color:var(--text-secondary);white-space:nowrap;align-items:center;gap:.4rem;font-size:.82rem;font-weight:500;display:flex}.guest-settings-link{color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--border-default);transition:transform var(--transition-fast), background-color var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast);border-radius:11px;justify-content:space-between;align-items:center;gap:.75rem;padding:.7rem .75rem;display:flex}.guest-settings-link:hover{color:var(--text-primary);background:color-mix(in srgb, var(--primary-50) 56%, var(--bg-secondary));border-color:color-mix(in srgb, var(--primary) 24%, var(--border-strong));transform:translateY(-1px)}.guest-settings-link-hint{letter-spacing:.03em;color:var(--primary-600);font-size:.74rem;font-weight:700}.guest-settings-link.is-disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.guest-icon-group{background:var(--bg-secondary,#ffffff14);border:1px solid var(--border-default,#ffffff26);border-radius:999px;align-items:center;gap:.15rem;padding:.25rem;display:inline-flex}.language-toggle{background:color-mix(in srgb, var(--bg-elevated) 96%, transparent);border:1px solid var(--border-default);box-shadow:var(--shadow-xs);border-radius:999px;align-items:center;gap:.3rem;padding:.25rem;display:inline-flex}.language-toggle-btn{min-width:2.3rem;min-height:2.15rem;color:var(--text-secondary);letter-spacing:.04em;transition:background-color var(--transition-fast), color var(--transition-fast), transform var(--transition-fast);border-radius:999px;padding:.35rem .7rem;font-size:.8rem;font-weight:700}.language-toggle-btn:hover,.language-toggle-btn.active{color:var(--text-primary);background:linear-gradient(135deg,#ffd8e2eb,#ffecd2eb);transform:translateY(-1px)}.desktop-nav{flex-shrink:0;align-items:center;gap:.25rem;min-width:0;display:none}.header-search{flex:24rem;max-width:40rem;display:none;position:relative}.header-search-input{border:1px solid var(--border-default);background:color-mix(in srgb, var(--bg-secondary) 95%, white);width:100%;height:46px;color:var(--text-primary);box-shadow:var(--shadow-xs);border-radius:999px;padding:0 5.8rem 0 2.85rem;transition:border-color .2s,box-shadow .2s,background-color .2s}.header-search-input::placeholder{color:var(--text-tertiary)}.header-search-input:focus{outline:none}.header-search:focus-within .header-search-input,.header-search.is-active .header-search-input{border-color:color-mix(in srgb, var(--primary) 36%, var(--border-default));box-shadow:0 0 0 4px rgba(var(--primary-rgb), .1);background:color-mix(in srgb, var(--bg-elevated) 96%, white)}.header-search-icon,.header-search-clear,.header-search-submit{position:absolute;top:50%;transform:translateY(-50%)}@media (width<=640px){.coffee-support-backdrop{align-items:end;padding:.8rem}.coffee-support-modal{border-radius:1.65rem;width:100%}.coffee-support-art{min-height:10rem;padding-top:1.7rem}.coffee-support-copy,.coffee-support-actions{padding-inline:1rem}.coffee-support-modal--no-note .coffee-support-actions{padding-bottom:1rem}.coffee-support-actions .btn{flex-basis:100%}.coffee-support-note{padding-inline:1rem}}@media (prefers-reduced-motion:reduce){.coffee-support-modal,.coffee-support-star,.coffee-support-mascot,.coffee-support-mascot-heart,.coffee-support-art-ring{animation:none}}.header-search-icon{color:var(--text-tertiary);pointer-events:none;left:1rem}.header-search-clear,.drawer-search-clear{width:2rem;height:2rem;color:var(--text-secondary);border-radius:999px;justify-content:center;align-items:center;transition:background-color .2s,color .2s,transform .2s;display:inline-flex}.header-search-clear{right:3.2rem}.header-search-clear svg,.drawer-search-clear svg{flex-shrink:0;display:block}.header-search-clear:hover,.drawer-search-clear:hover{background:color-mix(in srgb, var(--primary) 10%, var(--bg-secondary));color:var(--text-primary)}.header-search-clear:hover{transform:translateY(-50%)scale(1.04)}.header-search-submit{color:#fff;background:var(--gradient-primary);width:38px;height:38px;box-shadow:0 8px 18px rgba(var(--primary-rgb), .22);border-radius:999px;justify-content:center;align-items:center;transition:transform .2s,box-shadow .2s;display:inline-flex;right:4px}.header-search-submit:hover{box-shadow:0 10px 22px rgba(var(--primary-rgb), .28);transform:translateY(-50%)scale(1.02)}.desktop-nav .nav-link{--link-color:var(--primary);--link-bg:rgba(var(--primary-rgb), .12)}.nav-link{color:var(--text-secondary);transition:color var(--transition-fast), background-color var(--transition-fast);border-radius:10px;justify-content:center;align-items:center;gap:.4rem;padding:.45rem .65rem;font-size:.82rem;font-weight:600;display:flex;position:relative}.nav-link svg{transition:transform var(--transition-fast), color var(--transition-fast);flex-shrink:0}.nav-link:hover{color:var(--link-color,var(--text-primary));background:var(--link-bg,color-mix(in srgb, var(--primary) 8%, var(--bg-secondary)))}.nav-link:hover svg{color:var(--link-color,var(--text-primary));transform:scale(1.15)}.nav-link.active{color:var(--link-color,var(--primary));background:var(--link-bg,color-mix(in srgb, var(--primary) 10%, var(--bg-secondary)));box-shadow:inset 0 0 0 1px rgba(var(--primary-rgb), .14)}.nav-link.active svg{color:var(--link-color,var(--primary));transform:scale(1.1)}.nav-link-label{white-space:nowrap;display:none}.nav-link.active:after{display:none}.header-actions{flex-shrink:0;align-items:center;gap:.75rem;display:flex}.user-dropdown-container{align-items:center;display:flex;position:relative}.theme-toggle,.mobile-menu-btn{background:var(--bg-secondary);border:1px solid var(--border-default);width:42px;height:42px;color:var(--text-primary);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;transition:all .2s;display:flex}.guest-pill-btn{width:34px;height:34px;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;transition:background-color .18s,color .18s;display:flex}.guest-pill-btn:hover{background:color-mix(in srgb, var(--primary) 12%, var(--bg-tertiary));color:var(--text-primary)}.adult-toggle-btn{color:color-mix(in srgb, var(--text-secondary) 90%, var(--ink-900))}.adult-toggle-btn:hover{color:var(--text-primary)}.adult-toggle-btn.is-active{color:var(--error,#e11d48)}.adult-toggle-btn-desktop{width:auto;min-width:68px;height:34px;color:var(--text-secondary);box-shadow:none;background:0 0;border:none;gap:.38rem;padding:0 .58rem 0 .48rem}.adult-toggle-btn-desktop:hover{background:color-mix(in srgb, var(--primary) 6%, var(--bg-tertiary));color:var(--text-primary)}.adult-toggle-btn-desktop.is-active{background:color-mix(in srgb, var(--error,#e11d48) 7%, transparent);color:var(--error,#e11d48)}.adult-toggle-desktop-label{letter-spacing:.02em;white-space:nowrap;font-size:.74rem;font-weight:700}.adult-toggle-state-dot{background:color-mix(in srgb, var(--text-tertiary) 82%, transparent);border-radius:999px;flex-shrink:0;width:.42rem;height:.42rem}.adult-toggle-state-dot.is-active{background:var(--error,#e11d48);box-shadow:0 0 0 3px color-mix(in srgb, var(--error,#e11d48) 14%, transparent)}.adult-mode-icon{--adult-mode-icon-size:18px;min-width:auto;height:auto;font-size:calc(var(--adult-mode-icon-size) * .68);letter-spacing:-.02em;font-variant-numeric:tabular-nums;box-sizing:border-box;background:0 0;border:none;border-radius:0;justify-content:center;align-items:center;padding:0;font-weight:800;line-height:1;transition:all .25s;display:inline-flex}.adult-mode-icon.is-active{box-shadow:none;background:0 0}.drawer-link.adult-toggle-btn,.dropdown-item.adult-toggle-btn{background:color-mix(in srgb, var(--bg-secondary) 72%, transparent);border:1px solid color-mix(in srgb, var(--border-default) 85%, transparent)}.drawer-link.adult-toggle-btn:hover,.dropdown-item.adult-toggle-btn:hover{background:color-mix(in srgb, var(--primary) 7%, var(--bg-secondary))}.drawer-link.adult-toggle-btn.is-active,.dropdown-item.adult-toggle-btn.is-active{background:color-mix(in srgb, var(--error,#e11d48) 10%, var(--bg-secondary));border-color:color-mix(in srgb, var(--error,#e11d48) 22%, transparent);color:var(--error,#e11d48)}.theme-toggle:hover{background:var(--bg-tertiary);transform:translateY(-2px)}.mobile-menu-btn.active,.mobile-menu-btn:hover{background:color-mix(in srgb, var(--accent-500) 12%, var(--bg-secondary));border-color:color-mix(in srgb, var(--accent-500) 20%, transparent)}.account-menu-btn{border:1px solid var(--border-default);background:var(--bg-secondary);border-radius:12px;width:44px;height:44px;padding:2px;transition:all .2s;overflow:hidden}.account-menu-btn:hover{border-color:var(--primary);transform:translateY(-2px)}.account-menu-btn.ring-active{border-color:color-mix(in srgb, var(--primary) 50%, transparent);box-shadow:0 0 0 4px rgba(var(--primary-rgb), .14)}.user-chip{border:1px solid var(--border-default);background:color-mix(in srgb, var(--bg-secondary) 92%, transparent);color:var(--text-primary);cursor:pointer;border-radius:999px;align-items:center;gap:.55rem;min-height:40px;padding:.3rem .7rem .3rem .3rem;transition:border-color .2s,background .2s,box-shadow .2s,transform .2s;display:flex}.user-chip:hover{border-color:color-mix(in srgb, var(--primary) 38%, var(--border-default));background:color-mix(in srgb, var(--primary) 6%, var(--bg-secondary));transform:translateY(-1px)}.user-chip.ring-active{border-color:color-mix(in srgb, var(--primary) 50%, transparent);box-shadow:0 0 0 4px rgba(var(--primary-rgb), .14)}.user-name{text-overflow:ellipsis;white-space:nowrap;max-width:110px;font-size:.86rem;font-weight:600;overflow:hidden}.dropdown-chevron{color:var(--text-tertiary);flex-shrink:0;transition:transform .22s cubic-bezier(.16,1,.3,1)}.dropdown-chevron.rotate{transform:rotate(180deg)}.role-badge{letter-spacing:.06em;text-transform:uppercase;background:linear-gradient(135deg, var(--primary-500), var(--primary-600));color:#fff;border-radius:999px;align-items:center;padding:.2rem .55rem;font-size:.7rem;font-weight:800;display:inline-flex}.desktop-only{display:none!important}.mobile-only{display:flex}.user-avatar{object-fit:cover;background:var(--gradient-primary);color:#fff;border-radius:10px;justify-content:center;align-items:center;width:100%;height:100%;font-weight:700;display:flex}.user-chip .user-avatar{border-radius:999px;flex-shrink:0;width:32px;min-width:32px;height:32px;font-size:.85rem}.user-dropdown-menu{background:var(--bg-elevated);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-strong);border-radius:var(--radius-lg);width:280px;box-shadow:var(--shadow-xl);z-index:9999;transform-origin:100% 0;flex-direction:column;gap:.25rem;padding:.75rem;animation:.2s ease-out scaleIn;display:flex;position:absolute;top:calc(100% + 8px);right:0}.drawer-search{background:color-mix(in srgb, var(--bg-secondary) 92%, transparent);border:1px solid var(--border-default);min-height:44px;box-shadow:var(--shadow-xs);border-radius:999px;grid-template-columns:auto minmax(0,1fr) auto auto;align-items:center;gap:.45rem;margin-bottom:.9rem;padding:.35rem .4rem .35rem .9rem;display:grid}.drawer-search-wrap{position:relative}.drawer-search:focus-within{border-color:color-mix(in srgb, var(--primary) 35%, var(--border-default));box-shadow:0 0 0 4px rgba(var(--primary-rgb), .1)}.drawer-search-icon{color:var(--text-tertiary)}.drawer-search-input{min-width:0;color:var(--text-primary);background:0 0;border:none;padding:.45rem 0}.drawer-search-input:focus{outline:none}.drawer-search-input::placeholder{color:var(--text-tertiary)}.drawer-search-submit{background:var(--gradient-primary);color:#fff;letter-spacing:.01em;border-radius:999px;min-height:36px;padding:.55rem .9rem;font-size:.82rem;font-weight:700;transition:transform .2s,box-shadow .2s}.drawer-search-submit:hover{box-shadow:0 10px 22px rgba(var(--primary-rgb), .28);transform:translateY(-1px)}.dropdown-header{border-bottom:1px solid var(--border-default);justify-content:space-between;align-items:flex-start;margin-bottom:.5rem;padding:.75rem .75rem 1rem;display:flex}.dropdown-profile{align-items:center;gap:1rem;display:flex}.dropdown-avatar{object-fit:cover;border-radius:12px;width:48px;height:48px}.dropdown-profile-copy{line-height:1.3}.dropdown-profile-copy strong{color:var(--text-primary);font-size:1rem;font-weight:600;display:block}.dropdown-profile-copy span{color:var(--text-tertiary);white-space:nowrap;text-overflow:ellipsis;max-width:150px;font-size:.8rem;display:block;overflow:hidden}.role-badge{background-color:var(--bg-tertiary);color:var(--text-secondary);text-transform:capitalize;border-radius:99px;padding:.25rem .6rem;font-size:.75rem;font-weight:600}.dropdown-divider{background-color:var(--border-default);height:1px;margin:.5rem .75rem}.dropdown-section{flex-direction:column;gap:.5rem;padding:0 .75rem;display:flex}.dropdown-group{justify-content:space-between;align-items:center;display:flex}.dropdown-label{color:var(--text-secondary);align-items:center;gap:.5rem;font-size:.875rem;font-weight:500;display:flex}.theme-toggle-btn{background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;transition:transform var(--transition-fast), border-color var(--transition-fast), background-color var(--transition-fast);padding:.5rem 1rem;font-weight:500}.theme-toggle-btn:hover{border-color:color-mix(in srgb, var(--primary) 30%, transparent);background:color-mix(in srgb, var(--primary-50) 55%, var(--bg-tertiary));transform:translateY(-1px)}.dropdown-item{border-radius:var(--radius-md);color:var(--text-secondary);transition:background-color var(--transition-fast), color var(--transition-fast), transform var(--transition-fast);align-items:center;gap:.75rem;width:100%;padding:.75rem;font-weight:500;display:flex}.dropdown-item svg{transition:transform var(--transition-fast), color var(--transition-fast);flex-shrink:0}.dropdown-item:hover{background:color-mix(in srgb, var(--primary) 7%, var(--bg-secondary));color:var(--text-primary);transform:translate(3px)}.dropdown-item:hover svg{color:var(--primary);transform:scale(1.15)}.dropdown-item-support{color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--border-default)}.dropdown-item-support:hover{background:color-mix(in srgb, var(--primary-50) 56%, var(--bg-secondary))}.dropdown-item-support:hover svg{color:var(--primary)}.dropdown-item-support.is-disabled{opacity:.5;cursor:not-allowed;transform:none}.dropdown-item-support.is-disabled:hover{background:var(--bg-secondary);color:var(--text-primary)}.dropdown-item.logout-item{color:#f43f5e}.dropdown-item.logout-item:hover{background:#f43f5e1a;transform:translate(3px)}.dropdown-item.logout-item:hover svg{color:#f43f5e}.theme-toggle:hover,.theme-toggle:focus-visible{background:color-mix(in srgb, var(--primary) 10%, var(--bg-tertiary));border-color:color-mix(in srgb, var(--primary) 20%, transparent)}.login-btn{background:var(--gradient-primary);color:#fff;letter-spacing:.01em;white-space:nowrap;box-shadow:0 4px 14px rgba(var(--primary-rgb), .25);transition:transform var(--transition-fast), box-shadow var(--transition-fast), filter var(--transition-fast);border-radius:999px;flex-shrink:0;padding:.55rem 1.2rem;font-size:.9rem;font-weight:700}.login-btn:hover{box-shadow:0 10px 26px rgba(var(--primary-rgb), .3);filter:brightness(1.04)saturate(1.06);transform:translateY(-2px)}.mobile-overlay{opacity:0;pointer-events:none;transition:opacity var(--transition-base);z-index:1050;background:#22171259;position:fixed;inset:0}.mobile-overlay.open{opacity:1;pointer-events:auto}.mobile-drawer{background:radial-gradient(circle at top right, color-mix(in srgb, var(--rose-100) 45%, transparent), transparent 24%), linear-gradient(180deg, color-mix(in srgb, var(--paper-tint) 96%, transparent), color-mix(in srgb, var(--bg-elevated) 99%, transparent));z-index:1100;width:min(300px,100vw - 3rem);box-shadow:var(--shadow-xl);flex-direction:column;gap:1.5rem;padding:2rem;transition:transform .4s cubic-bezier(.16,1,.3,1);display:flex;position:fixed;inset:0 0 0 auto;transform:translate(100%)}.mobile-drawer.open{transform:translate(0)}.drawer-header{justify-content:space-between;align-items:center;gap:1rem;display:flex}.drawer-title{font-family:var(--font-heading);align-items:center;gap:.65rem;font-size:1.1rem;font-weight:800;display:inline-flex}.drawer-close{background:color-mix(in srgb, var(--bg-secondary) 80%, transparent);border:1px solid var(--border-default);width:2.5rem;min-width:2.5rem;height:2.5rem;min-height:2.5rem;color:var(--text-primary);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;padding:0;line-height:1;display:inline-flex}.drawer-links{flex-direction:column;gap:.35rem;display:flex}.drawer-section-divider{letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary);align-items:center;gap:.6rem;padding:.75rem .25rem .25rem;font-size:.68rem;font-weight:700;display:flex}.drawer-section-divider:before,.drawer-section-divider:after{content:"";background:var(--border-default);flex:1;height:1px}.drawer-link{color:var(--text-secondary);border-radius:12px;align-items:center;gap:1rem;padding:1rem;font-size:1.125rem;font-weight:600;display:flex}.drawer-link:hover{background:color-mix(in srgb, var(--primary) 7%, var(--bg-secondary));color:var(--text-primary)}.drawer-link.active{background:linear-gradient(135deg, color-mix(in srgb, var(--primary) 10%, var(--bg-secondary)), color-mix(in srgb, var(--accent) 7%, var(--bg-secondary)));color:var(--text-primary);border:1px solid color-mix(in srgb, var(--primary) 18%, transparent)}.drawer-link.active svg{color:var(--primary)}.drawer-footer{border-top:1px solid var(--border-default);gap:.9rem;margin-top:auto;padding-top:1rem;display:grid}.drawer-user{background:color-mix(in srgb, var(--bg-secondary) 78%, transparent);border:1px solid var(--border-default);color:var(--text-primary);border-radius:1rem;align-items:center;gap:.85rem;padding:.95rem 1rem;font-weight:700;display:flex}.drawer-user .user-avatar{flex-shrink:0;width:2.5rem;height:2.5rem}.drawer-link.logout{color:var(--rose-600)}.drawer-link.logout:hover{background:#e11d4814}.drawer-link-support{color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--border-default)}.drawer-link-support:hover{background:color-mix(in srgb, var(--primary-50) 56%, var(--bg-secondary))}.drawer-link-support.is-disabled{opacity:.55;cursor:not-allowed}.bottom-nav{background:var(--bg-glass-heavy);-webkit-backdrop-filter:blur(14px);border-top:1px solid var(--border-default);z-index:900;height:60px;padding-bottom:env(safe-area-inset-bottom,0);justify-content:space-around;align-items:stretch;display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-nav-item{color:var(--text-tertiary);transition:color var(--transition-fast);flex-direction:column;flex:1 1 0;justify-content:center;align-items:center;gap:2px;min-width:0;padding:.35rem .25rem;display:flex;position:relative}.bottom-nav-icon{transition:transform var(--transition-fast);justify-content:center;align-items:center;display:flex}.bottom-nav-item:active .bottom-nav-icon{transform:scale(.92)}.bottom-nav-item.active,.bottom-nav-item.active .bottom-nav-icon{color:var(--text-primary)}.bottom-nav-label{letter-spacing:0;font-size:.62rem;font-weight:600;line-height:1}.bottom-nav-avatar{object-fit:cover;background:var(--gradient-primary);color:#fff;width:26px;height:26px;transition:border-color var(--transition-fast);border:2px solid #0000;border-radius:999px;justify-content:center;align-items:center;font-size:.78rem;font-weight:700;display:inline-flex}.bottom-nav-item-profile.active .bottom-nav-avatar{border-color:var(--text-primary)}.footer{background:var(--bg-secondary);border-top:1px solid var(--border-default);margin-top:4rem;padding:4rem 0 2rem}.footer-content{grid-template-columns:1fr;gap:3rem;display:grid}.footer-brand{gap:1rem;display:grid}.footer-desc{color:var(--text-secondary);max-width:400px;margin-top:.5rem}.footer-support-strip{border-top:1px solid var(--border-default);margin-top:3rem;padding:1.75rem 0}.footer-support-strip .container{justify-content:center;display:flex}.footer-support-strip-inner{flex-wrap:wrap;justify-content:center;align-items:center;gap:.75rem;display:flex}.footer-donate-btn{width:fit-content;color:color-mix(in srgb, #ec4899 70%, var(--primary));background:color-mix(in srgb, #ec4899 7%, var(--bg-elevated));border:1.5px solid color-mix(in srgb, #ec4899 22%, var(--border-default));cursor:pointer;border-radius:999px;align-items:center;gap:.75rem;padding:.7rem 1.25rem .7rem .75rem;font-family:inherit;transition:transform .22s,box-shadow .22s,background-color .22s,border-color .22s;display:inline-flex;box-shadow:0 2px 12px #ec48991a}.footer-donate-btn:hover{background:color-mix(in srgb, #ec4899 12%, var(--bg-elevated));border-color:color-mix(in srgb, #ec4899 40%, var(--border-default));transform:translateY(-2px);box-shadow:0 6px 20px #ec48992e}.footer-donate-btn .footer-support-icon{color:color-mix(in srgb, #ec4899 80%, var(--primary));background:color-mix(in srgb, #ec4899 14%, var(--bg-elevated));border-color:color-mix(in srgb, #ec4899 20%, var(--border-default))}.footer-donate-btn .footer-support-copy strong{color:color-mix(in srgb, #ec4899 80%, var(--primary))}.footer-donate-btn .footer-support-copy span{color:color-mix(in srgb, #ec4899 60%, var(--text-secondary))}.footer-donate-btn .footer-support-heart{color:#ec4899}.footer-support-link{width:fit-content;color:var(--primary-700,var(--primary));background:color-mix(in srgb, var(--primary) 7%, var(--bg-elevated));border:1.5px solid color-mix(in srgb, var(--primary) 22%, var(--border-default));box-shadow:0 2px 12px rgba(var(--primary-rgb), .1);border-radius:999px;align-items:center;gap:.75rem;padding:.7rem 1.25rem .7rem .75rem;text-decoration:none;transition:transform .22s,box-shadow .22s,background-color .22s,border-color .22s;display:inline-flex}.footer-support-link:hover{background:color-mix(in srgb, var(--primary) 12%, var(--bg-elevated));border-color:color-mix(in srgb, var(--primary) 40%, var(--border-default));box-shadow:0 6px 20px rgba(var(--primary-rgb), .18);transform:translateY(-2px)}.footer-support-link.is-disabled{opacity:.45;cursor:not-allowed;box-shadow:none;transform:none}.footer-support-icon{width:2rem;height:2rem;color:var(--primary-700,var(--primary));background:color-mix(in srgb, var(--primary) 14%, var(--bg-elevated));border:1px solid color-mix(in srgb, var(--primary) 20%, var(--border-default));border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.footer-support-copy{flex-direction:column;gap:.1rem;display:flex}.footer-support-copy strong{color:var(--primary-700,var(--primary));font-size:.88rem;font-weight:700;line-height:1.2}.footer-support-copy span{color:color-mix(in srgb, var(--primary) 60%, var(--text-secondary));font-size:.75rem;line-height:1.3}.footer-support-heart{color:color-mix(in srgb, var(--primary) 70%, #f43f5e);flex-shrink:0;margin-left:.1rem}.footer-links{grid-template-columns:repeat(2,1fr);gap:2rem;display:grid}.link-group h4{color:var(--text-primary);margin-bottom:1rem}.link-group a{color:var(--text-secondary);margin-bottom:.5rem;transition:color .2s;display:block}.link-group a:hover{color:var(--primary)}.footer-bottom{border-top:1px solid var(--border-default);text-align:center;color:var(--text-tertiary);margin-top:0;padding-top:1.5rem;font-size:.875rem}@media (width<=767px){.main-content{position:relative;overflow-x:clip}.main-content--swipe{overflow:hidden}.mobile-swipe-pager{top:60px;bottom:60px}.mobile-swipe-pager-slot{padding-bottom:env(safe-area-inset-bottom,0)}.header{background:color-mix(in srgb, var(--bg-primary) 94%, transparent);-webkit-backdrop-filter:none;height:60px;transition:background-color .2s,box-shadow .2s}.header:after{display:none}.header-scrolled{height:60px;box-shadow:0 8px 20px #2a1c1914}.footer{display:none}.main-content{padding-bottom:68px}.logo{gap:.45rem;font-size:1.15rem}.logo-icon{border-radius:9px;width:32px;height:32px}.logo-wordmark{font-size:1.1rem}.header-actions{gap:.5rem}.login-btn{border-radius:999px;padding:.45rem .9rem;font-size:.82rem}.guest-icon-group,.user-chip{display:none}.notif-bell-btn{width:36px;height:36px}.mobile-menu-btn{width:38px;height:38px}.user-dropdown-menu{max-width:calc(100vw - 2rem);right:.5rem}.bottom-nav{background:color-mix(in srgb, var(--bg-primary) 96%, transparent);-webkit-backdrop-filter:none;height:60px;padding-bottom:max(env(safe-area-inset-bottom,0px), 4px)}.bottom-nav-item{gap:2px;padding:.3rem .6rem}.bottom-nav-label{letter-spacing:-.01em;font-size:.6rem}}@media (width<=420px){.user-dropdown-menu{width:min(100vw - 1rem,18.5rem);padding:.6rem;right:0}.dropdown-profile{gap:.75rem;min-width:0}.dropdown-profile-copy{min-width:0}.dropdown-profile-copy strong,.dropdown-profile-copy span{white-space:normal;overflow-wrap:anywhere;max-width:100%}.drawer-search{grid-template-columns:auto minmax(0,1fr) auto;padding-inline:.75rem .35rem}.drawer-search-submit{min-height:32px;padding:.5rem .7rem;font-size:.76rem}}@media (width>=768px){.main-content{padding-bottom:0}.desktop-nav,.guest-actions-desktop{display:flex}.mobile-menu-btn,.mobile-overlay,.mobile-drawer,.bottom-nav{display:none}.footer-content{grid-template-columns:2fr 1fr}.desktop-only{display:initial!important}.mobile-only{display:none!important}}@media (width>=768px) and (width<=1099px){.header-search{flex:auto;max-width:14rem;display:block}.header-content{gap:.6rem}.desktop-nav{gap:.15rem}.header-actions{gap:.4rem}}@media (width>=1100px){.header-content{gap:1.25rem}.header-search{flex:auto;min-width:0;max-width:36rem;display:block}.desktop-nav{gap:.25rem}.nav-link-discover{display:none}}@media (width>=1280px){.desktop-nav{gap:.35rem}}@media (width>=1100px){.nav-link-label{display:inline}}@media (width>=1440px){.header-search{min-width:18rem}}.header-cmdk-btn{background:var(--bg-secondary);border:1px solid var(--border-default);color:var(--text-tertiary);letter-spacing:.04em;cursor:pointer;border-radius:8px;align-items:center;gap:.3rem;padding:.3rem .6rem;font-size:.72rem;font-weight:700;transition:background-color .15s,color .15s,border-color .15s;display:inline-flex}.header-cmdk-btn:hover{background:color-mix(in srgb, var(--primary) 8%, var(--bg-secondary));color:var(--text-secondary);border-color:color-mix(in srgb, var(--primary) 20%, var(--border-default))}.header-cmdk-hint{font-family:var(--font-mono,monospace);font-size:.7rem}.header-saved-btn{background:var(--bg-secondary);border:1px solid var(--border-default);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;transition:background-color .15s,color .15s,border-color .15s;display:flex;position:relative}.header-saved-btn:hover,.header-saved-btn.is-active{background:color-mix(in srgb, var(--primary) 10%, var(--bg-secondary));border-color:color-mix(in srgb, var(--primary) 22%, var(--border-default));color:var(--primary)}.header-saved-dot{background:var(--primary);pointer-events:none;border-radius:999px;width:6px;height:6px;position:absolute;top:5px;right:5px}.header-saved-panel{border:1px solid var(--border-strong);width:260px;box-shadow:var(--shadow-xl);background:var(--bg-elevated);z-index:9000;transform-origin:100% 0;border-radius:12px;animation:.18s ease-out scaleIn;overflow:hidden}.header-saved-panel-head{border-bottom:1px solid var(--border-default);color:var(--text-secondary);align-items:center;gap:.4rem;padding:.6rem .85rem;font-size:.78rem;display:flex}.header-saved-panel-head strong{color:var(--text-primary);font-weight:700}.header-saved-section-label{letter-spacing:.07em;text-transform:uppercase;color:var(--text-tertiary);pointer-events:none;align-items:center;gap:.3rem;padding:.45rem .85rem .2rem;font-size:.68rem;font-weight:700;display:flex}.header-saved-divider{background:var(--border-default);height:1px;margin:.35rem 0}.header-saved-item{width:100%;color:var(--text-secondary);text-align:left;cursor:pointer;background:0 0;border:none;align-items:center;gap:.5rem;padding:.5rem .85rem;font-size:.85rem;font-weight:500;transition:background-color .12s,color .12s;display:flex}.header-saved-item:hover{background:color-mix(in srgb, var(--primary) 7%, var(--bg-secondary));color:var(--text-primary)}.header-saved-item-label{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.header-saved-item-pill{background:color-mix(in srgb, var(--primary) 10%, var(--bg-tertiary));color:var(--primary);letter-spacing:.04em;border-radius:999px;flex-shrink:0;align-items:center;padding:.1rem .4rem;font-size:.66rem;font-weight:700;display:inline-flex}.header-saved-panel-footer{border-top:1px solid var(--border-default);padding:.4rem}.header-saved-panel-more{width:100%;color:var(--text-tertiary);text-align:center;cursor:pointer;background:0 0;border:none;border-radius:8px;padding:.45rem .6rem;font-size:.78rem;font-weight:600;transition:background-color .12s,color .12s;display:block}.header-saved-panel-more:hover{background:var(--bg-secondary);color:var(--primary)}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)translateY(-10px)}to{opacity:1;transform:scale(1)translateY(0)}}.notif-bell-btn{cursor:pointer;width:36px;height:36px;color:var(--text-secondary);background:0 0;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative}.notif-bell-btn:hover{background:var(--bg-elevated);color:var(--text-primary)}.notif-badge{background:var(--accent-500,#e55);color:#fff;text-align:center;pointer-events:none;border-radius:99px;min-width:16px;height:16px;padding:0 3px;font-size:.65rem;font-weight:700;line-height:16px;position:absolute;top:4px;right:4px}.notif-panel{border:1px solid var(--border-default);z-index:2000;background:var(--bg-elevated);border-radius:10px;width:min(300px,100vw - 2rem);max-height:400px;overflow-y:auto}.notif-panel-head{border-bottom:1px solid var(--border-default);padding:.65rem .9rem;font-size:.85rem}.notif-empty{color:var(--text-secondary);margin:0;padding:1rem .9rem;font-size:.85rem}.notif-list{margin:0;padding:0;list-style:none}.notif-item{color:var(--text-secondary);border-bottom:1px solid var(--border-default);padding:.6rem .9rem;font-size:.82rem}.notif-item:last-child{border-bottom:none}.notif-item.is-unread{color:var(--text-primary);background:color-mix(in srgb, var(--accent-500) 6%, transparent)}.notif-link{color:inherit;text-decoration:none;display:block}.notif-link:hover{text-underline-offset:2px;text-decoration:underline}.btn{border-radius:var(--radius-md);min-height:48px;font-family:var(--font-sans);letter-spacing:-.01em;transition:transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast), background-color var(--transition-fast), color var(--transition-fast), filter var(--transition-fast);cursor:pointer;border:1px solid #0000;justify-content:center;align-items:center;gap:.6rem;padding:.8rem 1.25rem;font-weight:600;line-height:1.1;text-decoration:none;display:inline-flex;position:relative;overflow:hidden}.btn:active{transform:scale(.96)}.btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none!important;transform:none!important}.btn-sm{border-radius:var(--radius-sm);min-height:40px;padding:.62rem .95rem;font-size:.875rem}.btn-md{min-height:46px;padding:.78rem 1.2rem;font-size:.95rem}.btn-lg{border-radius:var(--radius-lg);min-height:54px;padding:.95rem 1.5rem;font-size:1rem}.btn-primary{background:var(--gradient-primary);color:var(--text-inverse);box-shadow:0 10px 24px rgba(var(--primary-rgb), .26);border-color:rgba(var(--primary-rgb), .18)}.btn-primary:hover:not(:disabled){box-shadow:0 16px 32px rgba(var(--primary-rgb), .34);filter:brightness(1.04)saturate(1.06);transform:translateY(-2px)}.btn-primary:after{content:"";background:linear-gradient(90deg,#0000,#fff3,#0000);width:100%;height:100%;transition:all .5s;position:absolute;top:0;left:-100%}.btn-primary:hover:after{left:100%}.btn-secondary{background:linear-gradient(180deg, color-mix(in srgb, var(--paper-tint) 92%, transparent), color-mix(in srgb, var(--bg-elevated) 96%, transparent));border-color:var(--border-default);color:var(--text-primary);box-shadow:var(--shadow-sm)}.btn-secondary:hover:not(:disabled){background:color-mix(in srgb, var(--primary) 7%, var(--bg-elevated));border-color:color-mix(in srgb, var(--primary) 22%, transparent);box-shadow:var(--shadow-md);transform:translateY(-2px)}.btn-accent{background:linear-gradient(135deg, var(--accent-500), color-mix(in srgb, var(--primary-500) 45%, var(--accent-500)));color:var(--text-inverse);box-shadow:0 4px 12px #ec489940}.btn-accent:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 8px 24px #ec489959}.btn-outline{background:color-mix(in srgb, var(--bg-primary) 78%, transparent);border:1px solid var(--border-strong);color:var(--text-primary)}.btn-outline:hover:not(:disabled){border-color:color-mix(in srgb, var(--primary-500) 34%, transparent);color:var(--primary-700);background:color-mix(in srgb, var(--primary-50) 70%, transparent)}.btn-ghost{color:var(--text-secondary);background:0 0;border-color:#0000}.btn-ghost:hover:not(:disabled){background:color-mix(in srgb, var(--primary) 8%, var(--bg-secondary));border-color:color-mix(in srgb, var(--primary) 20%, transparent);color:var(--text-primary)}.btn-full{width:100%}.btn-slot{flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.btn-slot svg{width:1.05rem;height:1.05rem}.btn-text{align-items:center;display:inline-flex}.btn-icon{border-radius:var(--radius-full);width:44px;height:44px;min-height:44px;padding:0}.btn-sm.btn-icon{width:36px;height:36px;min-height:36px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:auto;-webkit-text-size-adjust:100%}body{min-height:100vh;font-family:var(--font-sans);color:var(--text-primary);background-color:var(--bg-primary);background-image:radial-gradient(circle at 10% 20%, var(--glow-1), transparent 40%), radial-gradient(circle at 90% 80%, var(--glow-2), transparent 40%), radial-gradient(circle at 50% 50%, var(--glow-3), transparent 60%);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior-y:auto;-webkit-overflow-scrolling:touch;line-height:1.6;transition:background-color .3s,color .3s}img,picture,video,canvas,svg{max-width:100%;display:block}input,button,textarea,select{font:inherit}input[type=search]::-webkit-search-decoration{appearance:none;display:none}input[type=search]::-webkit-search-cancel-button{appearance:none;display:none}input[type=search]::-webkit-search-results-button{appearance:none;display:none}input[type=search]::-webkit-search-results-decoration{appearance:none;display:none}input[type=search]::-ms-clear{display:none}input[type=search]::-ms-reveal{display:none}select{appearance:none;background-color:var(--bg-elevated);color:var(--text-primary);cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right .65rem center;background-repeat:no-repeat;background-size:.8rem}select option{background-color:var(--bg-elevated);color:var(--text-primary)}a{color:inherit;text-decoration:none}ul,ol{list-style:none}button{cursor:pointer;background:0 0;border:none}@media (width<=767px){html,body{scroll-behavior:auto}body{background-image:radial-gradient(circle at 14% 14%, var(--glow-1), transparent 32%), radial-gradient(circle at 86% 88%, var(--glow-2), transparent 30%)}}:root{--primary-rgb:236, 72, 153;--primary:rgb(var(--primary-rgb));--primary-hover:#be185d;--primary-50:#fdf2f8;--primary-100:#fce7f3;--primary-200:#fbcfe8;--primary-300:#f9a8d4;--primary-400:#f472b6;--primary-500:#ec4899;--primary-600:#db2777;--primary-700:#be185d;--primary-gradient:linear-gradient(135deg, #f43f5e 0%, #ec4899 60%, #f97316 100%);--accent-rgb:245, 158, 11;--accent:rgb(var(--accent-rgb));--accent-500:#f59e0b;--accent-600:#d97706;--accent-700:#b45309;--secondary:#8b5cf6;--secondary-600:#7c3aed;--success:#16a34a;--info:#3b82f6;--warning:#d97706;--error:#ef4444;--ink-900:#2a1c19;--paper-tint:#fff8f0;--peach-200:#fed7aa;--peach-400:#fb923c;--plum-500:#a855f7;--rose-100:#ffe4e6;--rose-600:#e11d48;--paper-shadow:#46322c;--muted:var(--text-tertiary);--danger:var(--error);--bg-primary:#fdfaf6;--bg-secondary:#f5ece3;--bg-tertiary:#ebe0d6;--bg-elevated:#fffcf8f7;--bg-glass:#fdfaf6c2;--bg-glass-heavy:#fdfaf6ed;--bg-overlay:#120a087a;--text-primary:#2a1c19;--text-secondary:#644e48;--text-tertiary:#967369;--text-inverse:#fff;--text-accent:var(--primary);--text-h:var(--text-primary);--border-default:#5a3c3221;--border-strong:#5a3c323d;--border:var(--border-default);--border-hover:#ec489957;--border-focus:var(--primary);--glow-1:#ec489924;--glow-2:#f59e0b1c;--glow-3:#fdfaf6;--accent-bg:#f59e0b17;--accent-border:#f59e0b42;--social-bg:#ffffffd1;--shadow-xs:0 1px 3px #2a1c1912;--shadow-sm:0 8px 22px #462c2417;--shadow-md:0 16px 34px #462c2421;--shadow-lg:0 24px 48px #38241c2b;--shadow-xl:0 34px 62px #2a1c1936;--shadow-2xl:0 48px 88px #2a1c1942;--shadow-glass:0 16px 40px #462c241c;--shadow:var(--shadow-sm);--shadow-glow:0 20px 44px #ec48993d;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--radius-sm:.375rem;--radius-md:.75rem;--radius-lg:1.25rem;--radius-xl:2rem;--radius-2xl:2.5rem;--radius-full:9999px;--transition-fast:.2s cubic-bezier(.16, 1, .3, 1);--transition-base:.3s cubic-bezier(.16, 1, .3, 1);--font-sans:"Plus Jakarta Sans", "Noto Sans Thai", sans-serif;--font-heading:"Plus Jakarta Sans", "Noto Sans Thai", sans-serif;--max-width:1400px;--header-height:80px;--gradient-primary:linear-gradient(135deg, #f43f5e 0%, #ec4899 55%, #f97316 100%);--gradient-accent:linear-gradient(135deg, #f59e0b 0%, #f97316 100%);--gradient-hero:linear-gradient(135deg, #f43f5e 0%, #8b5cf6 100%);--gradient-glass:linear-gradient(135deg, #ffffff2e, #ffffff0a);--gradient-surface:linear-gradient(180deg, var(--paper-tint) 0%, var(--bg-elevated) 100%)}[data-theme=dark]{--primary:#f472b6;--primary-rgb:244, 114, 182;--primary-50:#2a1522;--primary-100:#3a1c32;--primary-200:#56234a;--primary-300:#7a2d68;--primary-400:#c05ea8;--primary-500:#f472b6;--primary-600:#f9a8d4;--primary-700:#fce7f3;--accent:#fbbf24;--accent-rgb:251, 191, 36;--accent-500:#fbbf24;--accent-600:#fde68a;--accent-700:#fef9c3;--secondary:#c4b5fd;--secondary-600:#ddd6fe;--paper-tint:#1a1215;--ink-900:#ffeee4;--bg-primary:#120e0d;--bg-secondary:#1c1614;--bg-tertiary:#261d1a;--bg-elevated:#1c1614f0;--bg-glass:#120e0dcc;--bg-glass-heavy:#1c1614f5;--bg-overlay:#000000bf;--text-primary:#fef2ec;--text-secondary:#c8a89e;--text-tertiary:#916c64;--text-inverse:#0a0706;--text-accent:#f9a8d4;--border-default:#ffe6d712;--border-strong:#ffe6d721;--border:var(--border-default);--border-hover:#f472b652;--border-focus:#f472b6;--glow-1:#f472b633;--glow-2:#fbbf2426;--glow-3:#120e0d;--accent-bg:#fbbf241c;--accent-border:#fbbf2438;--social-bg:#261d1ae0;--shadow-xs:0 1px 3px #0000002e;--shadow-sm:0 8px 22px #00000038;--shadow-md:0 16px 34px #00000052;--shadow-lg:0 24px 48px #0000006b;--shadow-xl:0 34px 62px #00000080;--shadow-2xl:0 48px 88px #00000094;--shadow-glass:0 16px 40px #00000061;--shadow-glow:0 20px 44px #f472b647;--shadow:var(--shadow-sm);--paper-shadow:#000;--muted:var(--text-tertiary);--danger:var(--error)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--radius-full);transition:background .2s}::-webkit-scrollbar-thumb:hover{background:color-mix(in srgb, var(--primary) 40%, var(--text-tertiary))}h1,h2,h3,h4,h5,h6,.font-heading{font-family:var(--font-heading);letter-spacing:-.02em;font-weight:700;line-height:1.2}.container{width:100%;max-width:var(--max-width);margin:0 auto;padding-inline:clamp(1rem,5vw,4rem)}.section{padding-block:0}.glass,.glass-heavy,.glass-premium{background:var(--bg-glass);-webkit-backdrop-filter:blur(8px);border:1px solid var(--border-default);box-shadow:var(--shadow-glass);transition:transform .25s,box-shadow .25s,border-color .25s;position:relative;overflow:hidden}.glass-heavy,.glass-premium{background:var(--bg-glass-heavy);border:1px solid var(--border-strong)}.glass:before,.glass-heavy:before,.glass-premium:before{content:"";pointer-events:none;z-index:0;background:linear-gradient(135deg,#ffffff1f 0%,#ffffff08 100%);position:absolute;inset:0}[data-theme=dark] .glass:before,[data-theme=dark] .glass-heavy:before,[data-theme=dark] .glass-premium:before{background:linear-gradient(135deg,#ffc8b40a 0%,#ffc8b403 100%)}.glass>*,.glass-heavy>*,.glass-premium>*{z-index:1;position:relative}.text-success{color:var(--success)}:focus-visible{outline:2px solid var(--border-focus);outline-offset:4px}::selection{background:rgba(var(--primary-rgb), .2);color:var(--text-primary)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes glow{0%,to{box-shadow:0 0 5px rgba(var(--primary-rgb), .2)}50%{box-shadow:0 0 20px rgba(var(--primary-rgb), .4)}}.animate-fade-in{animation:.5s ease-out forwards fadeIn}.animate-fade-in-up{animation:.7s cubic-bezier(.16,1,.3,1) forwards fadeInUp}.animate-float{animation:4s ease-in-out infinite float}.animate-spin{animation:1s linear infinite spin}.stagger-children>*{opacity:0;animation:.8s cubic-bezier(.16,1,.3,1) forwards fadeInUp}.stagger-children>:first-child{animation-delay:.1s}.stagger-children>:nth-child(2){animation-delay:.2s}.stagger-children>:nth-child(3){animation-delay:.3s}.stagger-children>:nth-child(4){animation-delay:.4s}.stagger-children>:nth-child(5){animation-delay:.5s}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (width<=768px){.container{padding-inline:1.25rem}.section{padding-block:15px}.glass,.glass-premium{-webkit-backdrop-filter:blur(8px)}}@media (prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.error-state{border-radius:var(--radius-xl);border:1px solid color-mix(in srgb, var(--error,#ef4444) 28%, transparent);background:color-mix(in srgb, var(--error,#ef4444) 7%, var(--bg-secondary));color:var(--error,#ef4444);flex-direction:column;align-items:flex-start;gap:.75rem;padding:1.25rem 1.5rem;display:flex}.error-state-icon{font-size:1.5rem;line-height:1}.error-state-message{color:var(--text-primary);font-size:.9375rem;line-height:1.5}
