*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#eaefef;--bg-card:#fff;--bg-muted:#dde3e3;--border:#c8d1d1;--text:#25343f;--text-muted:#5a6b78;--primary:#ff9b51;--primary-hover:#e8852e;--primary-light:#fff1e3;--danger:#d04040;--success:#3a8a50;--shadow-sm:0 1px 3px #25343f14;--shadow:0 2px 8px #25343f1f;--shadow-lg:0 4px 20px #25343f26;--radius:12px;--radius-sm:8px;color:var(--text);background:var(--bg);font-family:system-ui,-apple-system,Segoe UI,sans-serif;font-size:16px;line-height:1.6;transition:background .2s,color .2s}[data-theme=dark]{--bg:#25343f;--bg-card:#2f4250;--bg-muted:#364a5a;--border:#44596b;--text:#eaefef;--text-muted:#9aaab5;--primary:#ff9b51;--primary-hover:#ffae73;--primary-light:#3a2818;--danger:#e05555;--success:#4aaa60;--shadow-sm:0 1px 3px #0000004d;--shadow:0 2px 8px #0006;--shadow-lg:0 4px 20px #00000080}body{min-height:100vh}#root{flex-direction:column;min-height:100vh;display:flex}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;border-radius:var(--radius-sm);border:none;padding:.5rem 1.1rem;font-family:inherit;font-size:.9rem;transition:background .15s,opacity .15s,transform .1s}button:active{transform:scale(.97)}button:disabled{opacity:.55;cursor:not-allowed}input,textarea,select{color:var(--text);background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-sm);outline:none;width:100%;padding:.6rem .85rem;font-family:inherit;font-size:.95rem;transition:border-color .15s}input:focus,textarea:focus,select:focus{border-color:var(--primary)}textarea{resize:vertical;min-height:100px}label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.35rem;font-size:.875rem;font-weight:600;display:block}.container{max-width:900px;margin:0 auto;padding:0 1.25rem}.container-wide{max-width:1100px;margin:0 auto;padding:0 1.25rem}.navbar{background:var(--bg-card);border-bottom:1.5px solid var(--border);z-index:100;box-shadow:var(--shadow-sm);position:sticky;top:0}.navbar-inner{justify-content:space-between;align-items:center;max-width:1100px;height:60px;margin:0 auto;padding:0 1.25rem;display:flex}.navbar-brand{color:var(--primary);align-items:center;gap:.5rem;font-size:1.25rem;font-weight:700;text-decoration:none;display:flex}.navbar-brand:hover{opacity:.85;text-decoration:none}.navbar-brand span{font-size:1.5rem}.navbar-links{flex-wrap:wrap;align-items:center;gap:.6rem;display:flex}.btn{border-radius:var(--radius-sm);align-items:center;gap:.35rem;padding:.5rem 1.1rem;font-weight:600;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-ghost{color:var(--text-muted);border:1.5px solid var(--border);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--bg-muted);color:var(--text)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#b83535}.btn-sm{padding:.3rem .75rem;font-size:.82rem}.btn-icon{color:var(--text-muted);border-radius:var(--radius-sm);background:0 0;border:none;padding:.3rem;font-size:1.1rem}.btn-icon:hover{background:var(--bg-muted);color:var(--text)}.dark-toggle{background:var(--bg-muted);border:1.5px solid var(--border);color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;padding:.3rem .5rem;font-size:1rem;line-height:1}.dark-toggle:hover{color:var(--text)}.page{flex:1;padding:2rem 0 3rem}.unverified-banner{color:#7a5800;background:#fff8e1;border-bottom:1.5px solid #ffe082;flex-wrap:wrap;justify-content:center;align-items:center;gap:.75rem;padding:.6rem 1.25rem;font-size:.875rem;display:flex}[data-theme=dark] .unverified-banner{color:#f0c040;background:#2a2000;border-color:#5a4000}.unverified-banner button{color:#fff;background:#f59e0b;border-radius:99px;padding:.2rem .65rem;font-size:.8rem;font-weight:600}.unverified-banner button:hover{background:#d97706}.card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.post-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);cursor:pointer;transition:border-color .15s,box-shadow .15s}.post-card:hover{border-color:var(--primary);box-shadow:var(--shadow)}.post-card-inner{color:inherit;align-items:flex-start;gap:1rem;padding:1rem 1.15rem;text-decoration:none;display:flex}.post-card-inner:hover{text-decoration:none}.post-card-content{flex-direction:column;flex:1;min-width:0;display:flex}.post-card-thumb{border-radius:var(--radius-sm);background:var(--bg-muted);flex-shrink:0;width:88px;height:72px;overflow:hidden}.post-card-thumb img{object-fit:cover;width:100%;height:100%}.post-card-tags{flex-wrap:wrap;gap:.3rem;margin-bottom:.4rem;display:flex}.tag{text-transform:uppercase;letter-spacing:.04em;background:var(--primary-light);color:var(--primary);border-radius:99px;padding:.1rem .45rem;font-size:.7rem;font-weight:600}.post-card-title{color:var(--text);margin-bottom:.3rem;font-size:1rem;font-weight:700;line-height:1.35}.post-card:hover .post-card-title{color:var(--primary)}.post-card-excerpt{color:var(--text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;flex:1;margin-bottom:.65rem;font-size:.86rem;line-height:1.5;display:-webkit-box;overflow:hidden}.post-card-footer{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.post-card-author{color:var(--text-muted);align-items:center;gap:.4rem;font-size:.82rem;text-decoration:none;display:flex}.post-card-author:hover{color:var(--primary);text-decoration:none}.avatar{background:var(--bg-muted);object-fit:cover;width:28px;height:28px;color:var(--primary);border:1.5px solid var(--border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.85rem;font-weight:700;display:flex}.avatar-lg{width:72px;height:72px;font-size:1.75rem}.post-metrics{color:var(--text-muted);gap:.75rem;font-size:.82rem;display:flex}.metric{align-items:center;gap:.2rem;display:flex}.home-layout{grid-template-columns:1fr 272px;align-items:start;gap:1.5rem;display:grid}.home-layout-3col{grid-template-columns:240px 1fr 280px}.home-feed{min-width:0}.left-sidebar{flex-direction:column;gap:.85rem;display:flex;position:sticky;top:76px}.left-profile-card{padding:.85rem}.left-profile-link{color:inherit;border-bottom:1px solid var(--border);align-items:center;gap:.65rem;margin-bottom:.6rem;padding-bottom:.75rem;text-decoration:none;display:flex}.left-profile-link:hover{text-decoration:none}.left-profile-info{flex:1;min-width:0}.left-profile-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.92rem;font-weight:700;overflow:hidden}.left-profile-email{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;overflow:hidden}.left-profile-stats{text-align:center;grid-template-columns:1fr 1fr;gap:.5rem;display:grid}.left-profile-stats>div{background:var(--bg-muted);border-radius:var(--radius-sm);flex-direction:column;padding:.4rem .25rem;display:flex}.left-profile-stats strong{color:var(--text);font-size:1rem;font-weight:800}.left-profile-stats span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.7rem}.left-nav{flex-direction:column;gap:.15rem;display:flex}.left-nav-item{color:var(--text);border-radius:var(--radius-sm);align-items:center;gap:.65rem;padding:.55rem .65rem;font-size:.88rem;font-weight:600;text-decoration:none;transition:background .12s,color .12s;display:flex}.left-nav-item:hover{background:var(--bg-muted);color:var(--primary);text-decoration:none}.left-nav-item svg{color:var(--text-muted);flex-shrink:0}.left-nav-item:hover svg{color:var(--primary)}.left-nav-cta{background:var(--primary-light);color:var(--primary);margin-top:.4rem}.left-nav-cta svg{color:var(--primary)}.left-nav-cta:hover{background:var(--primary);color:#fff}.left-nav-cta:hover svg{color:#fff}.trending-bakers{flex-direction:column;gap:.55rem;display:flex}.trending-baker{border-radius:var(--radius-sm);color:inherit;align-items:center;gap:.6rem;padding:.4rem .5rem;text-decoration:none;transition:background .12s;display:flex}.trending-baker:hover{background:var(--bg-muted);text-decoration:none}.trending-baker-info{flex:1;min-width:0}.trending-baker-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:700;overflow:hidden}.trending-baker-meta{color:var(--text-muted);align-items:center;gap:.25rem;font-size:.72rem;display:flex}.ad-slot{flex-direction:column;gap:.4rem;display:flex}.ad-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius);padding:1rem 1.1rem;position:relative;overflow:hidden}.ad-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);background:var(--bg-muted);border-radius:99px;align-items:center;gap:.25rem;margin-bottom:.65rem;padding:.15rem .5rem;font-size:.65rem;font-weight:700;display:inline-flex}.ad-icon{border-radius:8px;justify-content:center;align-items:center;width:38px;height:38px;margin-bottom:.65rem;display:flex}.ad-title{color:var(--text);margin-bottom:.3rem;font-size:.95rem;font-weight:800;line-height:1.25}.ad-body{color:var(--text-muted);margin-bottom:.75rem;font-size:.82rem;line-height:1.5}.ad-cta{color:var(--primary);align-items:center;gap:.3rem;font-size:.82rem;font-weight:700;text-decoration:none;display:inline-flex}.ad-cta:hover{text-decoration:underline}.ad-cta-disabled{color:var(--text-muted);cursor:default}.ad-cta-disabled:hover{text-decoration:none}.ad-meta{color:var(--text-muted);align-items:center;gap:.25rem;padding:0 .4rem;font-size:.66rem;display:flex}.showcase-section{flex-direction:column;gap:1.1rem;display:flex}.showcase-grid{grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:.85rem;display:grid}.showcase-item{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:box-shadow .15s,transform .15s;position:relative;overflow:hidden}.showcase-item:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.showcase-img{aspect-ratio:1;background:var(--bg-muted);width:100%;overflow:hidden}.showcase-img img{object-fit:cover;width:100%;height:100%;display:block}.showcase-title{color:var(--text);padding:.6rem .8rem .7rem;font-size:.88rem;font-weight:700;line-height:1.3}.showcase-remove{color:#fff;opacity:0;background:#000000a6;border:none;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;padding:0;transition:opacity .15s,background .15s;display:flex;position:absolute;top:.45rem;right:.45rem}.showcase-item:hover .showcase-remove{opacity:1}.showcase-remove:hover{background:var(--danger)}.showcase-add-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius);padding:1.25rem}.showcase-add-card h4{color:var(--text);margin-bottom:1rem;font-size:1rem;font-weight:700}.field-error{color:var(--danger);margin-top:.3rem;font-size:.78rem}.field-hint{color:var(--text-muted);margin-top:.3rem;font-size:.75rem}input[aria-invalid=true],textarea[aria-invalid=true],input[aria-invalid=true]:focus,textarea[aria-invalid=true]:focus,.upload-item-error{border-color:var(--danger)}.upload-status-rejected{color:var(--danger)}.upload-status-scanning{color:#5a8de8}.home-sidebar{flex-direction:column;gap:1rem;display:flex;position:sticky;top:76px}.sidebar-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:1rem 1.1rem}.sidebar-create-prompt{color:var(--text-muted);margin-bottom:.65rem;font-size:.88rem}.sidebar-join{text-align:center;flex-direction:column;align-items:center;display:flex}.sidebar-heading{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);align-items:center;gap:.4rem;margin-bottom:.75rem;font-size:.75rem;font-weight:700;display:flex}.sidebar-tags{flex-wrap:wrap;gap:.4rem;display:flex}.sidebar-tag-btn{background:var(--bg-muted);border:1.5px solid var(--border);color:var(--text-muted);border-radius:99px;padding:.2rem .65rem;font-size:.8rem;font-weight:600;transition:all .13s}.sidebar-tag-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.sidebar-tag-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.sidebar-about p{color:var(--text-muted);margin-bottom:.85rem;font-size:.84rem;line-height:1.55}.sidebar-rules{flex-direction:column;gap:.45rem;display:flex}.sidebar-rule{color:var(--text-muted);align-items:center;gap:.5rem;font-size:.82rem;display:flex}.sidebar-rule svg{color:var(--primary);flex-shrink:0}.sidebar-tag-count{opacity:.7;margin-left:.35rem;font-size:.7rem;font-weight:500;display:inline-block}.composer-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-bottom:.85rem;padding:.85rem 1rem .6rem}.composer-top{border-bottom:1px solid var(--border);align-items:center;gap:.75rem;margin-bottom:.4rem;padding-bottom:.65rem;display:flex}.composer-prompt{background:var(--bg-muted);height:40px;color:var(--text-muted);border-radius:99px;flex:1;align-items:center;padding:0 1rem;font-size:.92rem;text-decoration:none;transition:background .15s,color .15s;display:flex}.composer-prompt:hover{background:var(--border);color:var(--text);text-decoration:none}.composer-actions{gap:.25rem;display:flex}.composer-action{color:var(--text-muted);border-radius:var(--radius-sm);flex:1;justify-content:center;align-items:center;gap:.45rem;padding:.55rem .65rem;font-size:.85rem;font-weight:600;text-decoration:none;transition:background .12s,color .12s;display:flex}.composer-action:hover{background:var(--bg-muted);color:var(--text);text-decoration:none}.avatar-sm{width:24px;height:24px;font-size:.75rem}.feed-count-pill{background:var(--primary-light);color:var(--primary);border-radius:99px;margin-left:.2rem;padding:.05rem .45rem;font-size:.78rem;font-weight:600;display:inline-block}.feed-list{flex-direction:column;gap:.6rem;display:flex}.feed-tabs{border-bottom:2px solid var(--border);gap:0;margin-bottom:1.1rem;display:flex}.feed-tab{color:var(--text-muted);background:0 0;border:none;border-bottom:2px solid #0000;border-radius:0;align-items:center;gap:.35rem;margin-bottom:-2px;padding:.55rem 1.1rem;font-size:.88rem;font-weight:600;transition:color .15s,border-color .15s;display:flex}.feed-tab:hover{color:var(--text)}.feed-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.feed-tab:active{transform:none}.feed-controls{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:.75rem;display:flex}.feed-sort{gap:.35rem;display:flex}.sort-btn{background:var(--bg-card);border:1.5px solid var(--border);color:var(--text-muted);border-radius:99px;align-items:center;gap:.3rem;padding:.35rem .75rem;font-size:.82rem;font-weight:600;transition:all .13s;display:flex}.sort-btn:hover{background:var(--bg-muted);color:var(--text)}.sort-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.search-bar{background:var(--bg-card);border:1.5px solid var(--border);border-radius:99px;flex:1;align-items:center;gap:0;max-width:340px;padding:0 .75rem;transition:border-color .15s;display:flex}.search-bar:focus-within{border-color:var(--primary)}.search-icon{color:var(--text-muted);flex-shrink:0}.search-bar input{background:0 0;border:none;outline:none;flex:1;width:auto;padding:.45rem .5rem;font-size:.88rem}.search-clear{color:var(--text-muted);background:0 0;border:none;border-radius:50%;align-items:center;padding:.2rem;display:flex}.search-clear:hover{color:var(--text)}.active-filters{flex-wrap:wrap;gap:.4rem;margin-bottom:.65rem;display:flex}.active-filter-chip{background:var(--primary-light);border:1.5px solid var(--primary);color:var(--primary);border-radius:99px;align-items:center;gap:.3rem;padding:.2rem .65rem;font-size:.8rem;font-weight:600;display:inline-flex}.active-filter-chip:hover{background:var(--primary);color:#fff}.feed-count{color:var(--text-muted);margin-bottom:.85rem;font-size:.82rem}.filter-btn{background:var(--bg-card);border:1.5px solid var(--border);color:var(--text-muted);border-radius:99px;padding:.3rem .75rem;font-size:.83rem;font-weight:600}.filter-btn:hover:not(:disabled){background:var(--bg-muted);color:var(--text)}.filter-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.auth-page{flex:1;justify-content:center;align-items:center;padding:2rem 1rem;display:flex}.auth-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);width:100%;max-width:420px;padding:2.25rem}.auth-logo{text-align:center;margin-bottom:1.5rem;font-size:2.5rem}.auth-title{text-align:center;color:var(--text);margin-bottom:.35rem;font-size:1.6rem;font-weight:700}.auth-subtitle{text-align:center;color:var(--text-muted);margin-bottom:1.75rem;font-size:.9rem}.form-group{margin-bottom:1.1rem}.form-error{color:var(--danger);border-radius:var(--radius-sm);background:#fde8e8;border:1.5px solid #f5b8b8;margin-bottom:1rem;padding:.6rem .9rem;font-size:.88rem}.form-success{color:var(--success);border-radius:var(--radius-sm);background:#e8f5e9;border:1.5px solid #a5d6a7;margin-bottom:1rem;padding:.6rem .9rem;font-size:.88rem}[data-theme=dark] .form-error{background:#2a0a0a;border-color:#6a2020}[data-theme=dark] .form-success{background:#0a2a0a;border-color:#206020}.auth-footer{text-align:center;color:var(--text-muted);margin-top:1.25rem;font-size:.875rem}.post-detail{max-width:720px;margin:0 auto}.post-detail-hero{object-fit:cover;border-radius:var(--radius);width:100%;max-height:400px;margin-bottom:1.5rem}.post-detail-meta{flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1.25rem;display:flex}.post-detail-title{margin-bottom:.75rem;font-size:1.8rem;font-weight:800;line-height:1.25}.post-detail-content{color:var(--text);white-space:pre-wrap;margin-bottom:2rem;font-size:1rem;line-height:1.75}.interactions-bar{background:var(--bg-muted);border-radius:var(--radius);flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding:.85rem 1.1rem;display:flex}.sprinkle-btn{background:var(--bg-card);border:1.5px solid var(--border);color:var(--text-muted);border-radius:99px;align-items:center;gap:.4rem;padding:.45rem 1rem;font-size:.9rem;font-weight:600;transition:all .15s;display:flex}.sprinkle-btn:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.sprinkle-btn.active{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.cookie-rating{align-items:center;gap:.15rem;display:flex}.cookie-btn{opacity:1;background:0 0;border:none;border-radius:4px;padding:.2rem;font-size:1.25rem;transition:all .12s}.cookie-btn:hover{transform:scale(1.2)}.share-btn{background:var(--bg-card);border:1.5px solid var(--border);color:var(--text-muted);border-radius:99px;align-items:center;gap:.35rem;padding:.45rem .85rem;font-size:.85rem;font-weight:600;display:flex}.share-btn:hover{border-color:var(--primary);color:var(--primary)}.scaler-bar{color:var(--text-muted);align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:.85rem;display:flex}.scaler-btn{background:var(--bg-card);border:1.5px solid var(--border);color:var(--text-muted);border-radius:99px;padding:.2rem .55rem;font-size:.8rem;font-weight:700}.scaler-btn:hover{background:var(--bg-muted)}.scaler-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.recipe-box{background:var(--primary-light);border-radius:var(--radius);border:1.5px solid #f0d8a8;margin-bottom:1.75rem;padding:1.25rem 1.5rem}[data-theme=dark] .recipe-box{border-color:#4a3010}.recipe-box h3{color:var(--primary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem;font-size:1rem;font-weight:700}.ingredients-list{flex-direction:column;gap:.3rem;list-style:none;display:flex}.ingredients-list li{gap:.5rem;font-size:.9rem;display:flex}.ingredients-list li:before{content:"·";color:var(--primary);font-weight:700}.recipe-stats{flex-wrap:wrap;gap:1.5rem;margin-top:.75rem;display:flex}.recipe-stat{color:var(--text-muted);font-size:.85rem}.recipe-stat strong{color:var(--text)}.comments-section{margin-top:2rem}.comments-section h3{color:var(--text);margin-bottom:1.1rem;font-size:1.05rem;font-weight:700}.comment-form{align-items:flex-start;gap:.75rem;margin-bottom:1.5rem;display:flex}.comment-form textarea{resize:none;flex:1;min-height:60px}.comment-list{flex-direction:column;gap:.85rem;display:flex}.comment{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:.85rem 1rem}.comment-header{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.4rem;display:flex}.comment-author{color:var(--text);font-size:.85rem;font-weight:700;text-decoration:none}.comment-author:hover{color:var(--primary);text-decoration:none}.comment-date{color:var(--text-muted);font-size:.78rem}.comment-content{color:var(--text);font-size:.9rem;line-height:1.55}.comment-delete{color:var(--text-muted);background:0 0;border:none;border-radius:4px;margin-left:auto;padding:.15rem .4rem;font-size:.78rem}.comment-delete:hover{color:var(--danger);background:#fde8e8}.profile-header{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);align-items:flex-start;gap:1.5rem;margin-bottom:1.75rem;padding:1.5rem;display:flex}.profile-info h1{margin-bottom:.25rem;font-size:1.5rem;font-weight:800}.profile-bio{color:var(--text-muted);margin-bottom:.5rem;font-size:.9rem}.profile-stats{color:var(--text-muted);gap:1.25rem;margin-bottom:.75rem;font-size:.85rem;display:flex}.profile-stats strong{color:var(--text);font-weight:700}.follow-btn{background:var(--primary);color:#fff;border:1.5px solid var(--primary);border-radius:99px;align-items:center;gap:.35rem;padding:.4rem 1rem;font-size:.85rem;font-weight:600;transition:all .15s;display:inline-flex}.follow-btn:hover:not(:disabled){background:var(--primary-hover)}.follow-btn.following{background:var(--bg-card);color:var(--text-muted);border-color:var(--border)}.follow-btn.following:hover{color:var(--danger);border-color:var(--danger);background:#fde8e8}.profile-tabs{border-bottom:2px solid var(--border);gap:0;margin-bottom:1.5rem;display:flex}.profile-tab{color:var(--text-muted);background:0 0;border:none;border-bottom:2px solid #0000;border-radius:0;margin-bottom:-2px;padding:.6rem 1.25rem;font-size:.9rem;font-weight:600}.profile-tab:hover{color:var(--text)}.profile-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.profile-tab:active{transform:none}.bookmark-btn{background:var(--bg-card);border:1.5px solid var(--border);color:var(--text-muted);border-radius:99px;align-items:center;gap:.35rem;padding:.45rem .85rem;font-size:.85rem;font-weight:600;display:flex}.bookmark-btn:hover{border-color:var(--primary);color:var(--primary)}.bookmark-btn.active{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.create-page{max-width:700px;margin:0 auto;padding:2rem 1.25rem 3rem}.create-page h1{margin-bottom:1.5rem;font-size:1.75rem;font-weight:800}.ingredient-row{gap:.5rem;margin-bottom:.5rem;display:flex}.ingredient-row input{flex:1}.section-label{color:var(--text);border-bottom:2px solid var(--border);margin:1.25rem 0 .75rem;padding-bottom:.4rem;font-size:1rem;font-weight:700}.pagination{justify-content:center;align-items:center;gap:.5rem;margin-top:2rem;display:flex}.page-btn{background:var(--bg-card);border:1.5px solid var(--border);color:var(--text-muted);border-radius:var(--radius-sm);justify-content:center;align-items:center;width:36px;height:36px;padding:0;font-weight:600;display:flex}.page-btn:hover:not(:disabled){background:var(--bg-muted)}.page-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.empty-state{text-align:center;color:var(--text-muted);padding:3.5rem 1rem}.empty-state .icon{margin-bottom:.75rem;font-size:3.5rem;display:block}.empty-state h3{color:var(--text);margin-bottom:.4rem;font-size:1.15rem;font-weight:700}.empty-icon{color:var(--border);justify-content:center;margin-bottom:.75rem;display:flex}.spin{animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-wrap{justify-content:center;align-items:center;padding:3rem;display:flex}.input-icon-wrap{position:relative}.input-icon-wrap input{padding-left:2.4rem}.input-icon{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:.75rem;transform:translateY(-50%)}.hero-banner{background:linear-gradient(135deg, var(--primary-light) 0%, #fce8c6 100%);border-radius:var(--radius);border:1.5px solid #f0d8a8;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1.25rem;margin-bottom:1.5rem;padding:1.75rem 2rem;display:flex}[data-theme=dark] .hero-banner{background:linear-gradient(135deg,#2a1a08 0%,#1e1206 100%);border-color:#4a3010}.hero-banner-text{flex:1;min-width:200px}.hero-banner h1{color:var(--text);margin-bottom:.3rem;font-size:1.45rem;font-weight:800}.hero-banner p{color:var(--text-muted);font-size:.9rem}.hero-banner-cta{flex-shrink:0;gap:.65rem;display:flex}.hero-icon{color:var(--primary);margin-bottom:.4rem}.profile-badge{background:var(--primary-light);color:var(--primary);border:1px solid #f0d8a8;border-radius:99px;align-items:center;gap:.3rem;padding:.2rem .65rem;font-size:.78rem;font-weight:600;display:inline-flex}.profile-badge-skill{background:var(--bg-muted);color:var(--text-muted);border-color:var(--border)}.goal-tag{background:var(--bg-muted);color:var(--text-muted);border:1px solid var(--border);border-radius:99px;align-items:center;gap:.25rem;padding:.15rem .55rem;font-size:.75rem;font-weight:500;display:inline-flex}.achievements-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.85rem;display:grid}.achievement-badge{border-radius:var(--radius);border:1.5px solid var(--border);background:var(--bg-card);align-items:center;gap:.85rem;padding:.85rem 1rem;transition:box-shadow .15s;display:flex;position:relative}.achievement-badge.earned{background:var(--ach-bg,var(--primary-light));border-color:color-mix(in srgb, var(--ach-color,var(--primary)) 30%, transparent)}.achievement-badge.locked{opacity:.45;filter:grayscale()}.achievement-icon{background:var(--bg-muted);width:42px;height:42px;color:var(--text-muted);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.achievement-badge.earned .achievement-icon{background:color-mix(in srgb, var(--ach-color,var(--primary)) 15%, transparent);color:var(--ach-color,var(--primary))}.achievement-label{color:var(--text);font-size:.88rem;font-weight:700}.achievement-desc{color:var(--text-muted);margin-top:.1rem;font-size:.78rem}.achievement-earned-dot{background:var(--ach-color,var(--primary));border-radius:50%;width:8px;height:8px;position:absolute;top:.65rem;right:.65rem}.onboarding-page{background:var(--bg);flex-direction:column;flex:1;align-items:center;padding:0 1rem 3rem;display:flex}.onboarding-progress-wrap{width:100%;max-width:680px;margin-bottom:1.5rem;padding:1.5rem 0 0}.onboarding-progress-bar{background:var(--bg-muted);border-radius:99px;width:100%;height:8px;margin-bottom:.5rem;overflow:hidden}.onboarding-progress-fill{background:linear-gradient(90deg, var(--primary), #e8a030);border-radius:99px;height:100%;transition:width .5s cubic-bezier(.4,0,.2,1)}.onboarding-progress-label{color:var(--text-muted);justify-content:space-between;font-size:.82rem;font-weight:600;display:flex}.onboarding-pct{color:var(--primary)}.onboarding-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);width:100%;max-width:680px;padding:2rem 2.25rem}.onboarding-step-icon{margin-bottom:.75rem}.onboarding-title{color:var(--text);margin-bottom:.35rem;font-size:1.5rem;font-weight:800}.onboarding-subtitle{color:var(--text-muted);margin-bottom:1.5rem;font-size:.9rem}.onboarding-section-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:.75rem;font-size:.8rem;font-weight:700}.onboarding-nav{border-top:1.5px solid var(--border);justify-content:space-between;align-items:center;margin-top:2rem;padding-top:1.25rem;display:flex}.avatar-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:.85rem;margin-bottom:.5rem;display:grid}.avatar-option{border-radius:var(--radius);border:2px solid var(--border);background:var(--bg-card);cursor:pointer;color:var(--text-muted);flex-direction:column;align-items:center;gap:.4rem;padding:.75rem .5rem;font-size:.78rem;font-weight:500;transition:all .15s;display:flex;position:relative}.avatar-option:hover{border-color:var(--primary);background:var(--primary-light)}.avatar-option.selected{border-color:var(--primary);background:var(--primary-light);color:var(--primary)}.avatar-option img{border-radius:50%}.avatar-check{background:var(--primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;display:flex;position:absolute;top:.4rem;right:.4rem}.selection-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.65rem;display:grid}.selection-card{border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--bg-card);text-align:left;color:var(--text-muted);flex-direction:column;align-items:flex-start;gap:.3rem;padding:.85rem 1rem;transition:all .15s;display:flex}.selection-card:hover{border-color:var(--primary);color:var(--text)}.selection-card.selected{border-color:var(--primary);background:var(--primary-light);color:var(--primary)}.selection-label{color:inherit;font-size:.88rem;font-weight:700;line-height:1.2}.selection-desc{color:var(--text-muted);font-size:.75rem;line-height:1.3}.selection-card.selected .selection-desc{color:var(--primary);opacity:.7}.goals-grid{flex-wrap:wrap;gap:.5rem;display:flex}.goal-chip{border:1.5px solid var(--border);background:var(--bg-card);color:var(--text-muted);border-radius:99px;align-items:center;gap:.35rem;padding:.35rem .85rem;font-size:.83rem;font-weight:500;transition:all .15s;display:inline-flex}.goal-chip:hover{border-color:var(--primary);color:var(--text)}.goal-chip.selected{border-color:var(--primary);background:var(--primary-light);color:var(--primary);font-weight:600}.guidelines-box{background:var(--bg-muted);border:1.5px solid var(--border);border-radius:var(--radius-sm);margin-bottom:1.1rem;padding:1.1rem 1.25rem}.guidelines-box h3{color:var(--text);align-items:center;gap:.4rem;margin-bottom:.65rem;font-size:.9rem;font-weight:700;display:flex}.guidelines-box ul{flex-direction:column;gap:.4rem;list-style:none;display:flex}.guidelines-box li{color:var(--text-muted);padding-left:1rem;font-size:.85rem;position:relative}.guidelines-box li:before{content:"·";color:var(--primary);font-weight:700;position:absolute;left:0}.guidelines-checkbox{color:var(--text);cursor:pointer;text-transform:none;letter-spacing:0;align-items:center;gap:.6rem;margin-bottom:0;font-size:.875rem;font-weight:600;display:flex}.guidelines-checkbox input{width:16px;height:16px;accent-color:var(--primary);flex-shrink:0}.post-type-toggle{border:1.5px solid var(--border);border-radius:var(--radius-sm);gap:0;width:fit-content;margin-bottom:1.75rem;display:flex;overflow:hidden}.type-btn{color:var(--text-muted);background:var(--bg-card);border:none;border-radius:0;align-items:center;gap:.4rem;padding:.55rem 1.25rem;font-size:.88rem;font-weight:600;transition:all .15s;display:flex}.type-btn:hover{color:var(--text);background:var(--bg-muted)}.type-btn.active{background:var(--primary);color:#fff}.type-btn:not(:last-child){border-right:1.5px solid var(--border)}.type-btn:active{transform:none}.image-uploader{margin-bottom:.75rem}.drop-zone{border:2px dashed var(--border);border-radius:var(--radius);text-align:center;cursor:pointer;color:var(--text-muted);background:var(--bg-card);flex-direction:column;align-items:center;gap:.5rem;padding:1.75rem 1rem;transition:all .15s;display:flex}.drop-zone:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.drop-zone.drag-over{border-color:var(--primary);background:var(--primary-light);color:var(--primary)}.drop-zone-text{flex-direction:column;gap:.15rem;display:flex}.drop-zone-text strong{color:var(--text);font-size:.9rem}.drop-zone-text span{font-size:.82rem}.drop-zone-hint{color:var(--text-muted);margin-top:.25rem;font-size:.75rem}.drop-zone:hover .drop-zone-text strong,.drop-zone.drag-over .drop-zone-text strong{color:var(--primary)}.upload-list{flex-direction:column;gap:.5rem;margin-top:.75rem;display:flex}.upload-item{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-sm);align-items:center;gap:.75rem;padding:.5rem .75rem;display:flex}.upload-preview{background:var(--bg-muted);width:44px;height:44px;color:var(--text-muted);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;display:flex;overflow:hidden}.upload-preview img{object-fit:cover;width:100%;height:100%}.upload-info{flex:1;min-width:0}.upload-filename{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:600;overflow:hidden}.upload-status{align-items:center;gap:.3rem;margin-top:.1rem;font-size:.75rem;display:flex}.upload-status-uploading{color:var(--primary)}.upload-status-converting{color:#d97706}.upload-status-uploaded{color:var(--success)}.upload-status-error{color:var(--danger)}.upload-remove{color:var(--text-muted);background:0 0;border:none;border-radius:4px;flex-shrink:0;padding:.25rem}.upload-remove:hover{color:var(--danger);background:#fde8e8}.toast{background:var(--text);color:var(--bg);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:999;padding:.7rem 1.2rem;font-size:.88rem;font-weight:600;animation:.2s slideUp;position:fixed;bottom:1.5rem;right:1.5rem}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.divider{border:none;border-top:1.5px solid var(--border);margin:1.5rem 0}.tags-input{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-sm);cursor:text;flex-wrap:wrap;align-items:center;gap:.35rem;min-height:42px;padding:.4rem .75rem;display:flex}.tags-input:focus-within{border-color:var(--primary)}.tags-input input{background:0 0;border:none;outline:none;flex:1;width:auto;min-width:80px;padding:.15rem 0;font-size:.9rem}.tag-chip{background:var(--primary-light);color:var(--primary);border-radius:99px;align-items:center;gap:.25rem;padding:.15rem .5rem .15rem .6rem;font-size:.78rem;font-weight:600;display:flex}.tag-chip button{color:var(--primary);background:0 0;border:none;width:auto;height:auto;padding:0;font-size:.85rem;line-height:1}.tag-chip button:hover{color:var(--danger)}.contact-page{max-width:580px;margin:0 auto;padding:2rem 1.25rem 3rem}.contact-page h1{margin-bottom:.5rem;font-size:1.75rem;font-weight:800}.contact-page p{color:var(--text-muted);margin-bottom:1.75rem}.print-only{display:none}.interactions-rate{align-items:center;gap:.4rem;display:flex}.interactions-rate-label{color:var(--text-muted);font-size:.82rem}.interactions-rate-avg{color:var(--text-muted);font-size:.8rem}.interactions-actions{gap:.5rem;margin-left:auto;display:flex}.interactions-bar{margin-top:1.5rem}.post-detail-breadcrumb{color:var(--text-muted);margin-bottom:1.25rem;font-size:.875rem}.post-detail-gallery{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;margin:1rem 0 2rem;display:grid}.post-detail-gallery img{border-radius:var(--radius-sm);object-fit:cover;aspect-ratio:1;border:1.5px solid var(--border);width:100%}.recipe-section-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin:.85rem 0 .5rem;font-size:.78rem;font-weight:700}@media print{@page{size:A4;margin:1.5cm 1.8cm}.no-print,.navbar,.unverified-banner,.home-sidebar,.toast,.feed-tabs,.feed-controls,.pagination{display:none!important}html,body,#root,.page,.container,main{color:#000!important;box-shadow:none!important;background:#fff!important;min-height:auto!important;margin:0!important;padding:0!important}.page{padding:0!important}.print-only{display:block!important}.print-header{border-bottom:2px solid #000;justify-content:space-between;align-items:baseline;margin-bottom:1rem;padding-bottom:.5rem;font-family:Georgia,Times New Roman,serif;display:flex!important}.print-brand{letter-spacing:-.02em;font-size:18pt;font-weight:800}.print-source{color:#555;font-size:9pt;font-style:italic}.print-footer{color:#555;text-align:center;page-break-inside:avoid;border-top:1px solid #888;margin-top:2rem;padding-top:.5rem;font-size:8.5pt;font-style:italic}.post-detail{color:#000;max-width:none;font-family:Georgia,Times New Roman,serif;box-shadow:none!important;background:0 0!important;border:none!important;padding:0!important}.post-detail-title{color:#000;page-break-after:avoid;margin:0 0 .4rem;font-family:Georgia,Times New Roman,serif;font-size:24pt;font-weight:800;line-height:1.15}.post-detail-meta{color:#444;flex-wrap:wrap;align-items:baseline;gap:.75rem;margin-bottom:1rem;font-size:10pt;display:flex!important}.post-detail-meta .avatar{display:none!important}.post-detail-meta a{font-weight:700;color:#000!important;text-decoration:none!important}.post-detail-meta a:before{content:"By ";color:#555;font-weight:400}.recipe-box{page-break-inside:avoid;border-radius:4px;background:#fafafa!important;border:1px solid #999!important;margin:.5rem 0 1.25rem!important;padding:.85rem 1.1rem!important}.recipe-box h3{letter-spacing:.06em;border-bottom:1px solid #ccc;margin:0 0 .5rem;padding-bottom:.35rem;font-family:Georgia,serif;font-size:11pt;color:#000!important}.recipe-section-label{margin:.5rem 0 .3rem;font-family:Georgia,serif;font-size:8.5pt;color:#000!important}.ingredients-list{columns:2;column-gap:1.5rem;margin:0 0 .5rem;padding:0;list-style:none}.ingredients-list li{page-break-inside:avoid;break-inside:avoid;margin-bottom:.2rem;padding:0;font-size:10.5pt;line-height:1.5;color:#000!important}.ingredients-list li:before{content:"• ";color:#000;font-weight:700}.ingredients-list li span{color:#000!important}.recipe-stats{border-top:1px dashed #bbb;gap:1.5rem;margin-top:.5rem;padding-top:.4rem;display:flex}.recipe-stat{font-size:9.5pt;color:#333!important}.recipe-stat strong{color:#000!important}.post-detail-content{white-space:pre-wrap;text-align:justify;-webkit-hyphens:auto;hyphens:auto;margin:.5rem 0 1.5rem;font-family:Georgia,Times New Roman,serif;font-size:11.5pt;line-height:1.65;color:#000!important}h1,h2,h3{page-break-after:avoid}p,li{orphans:3;widows:3}a{color:#000!important;text-decoration:none!important}}@media (width<=1100px){.home-layout-3col{grid-template-columns:1fr 280px}.left-sidebar{display:none}}@media (width<=860px){.home-layout,.home-layout-3col{grid-template-columns:1fr}.home-sidebar{display:none}.showcase-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}@media (width<=600px){.feed-controls{flex-direction:column;align-items:stretch}.search-bar{max-width:100%}.post-detail-title{font-size:1.4rem}.profile-header{flex-direction:column}.navbar-brand span{display:none}.navbar-links{gap:.4rem}.post-card-thumb{width:72px;height:60px}.hero-banner{flex-direction:column}.hero-banner-cta{width:100%}.hero-banner-cta .btn{flex:1;justify-content:center}}
