*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f7f5f0;--surface:#fff;--border:#e2ddd6;--text:#1a1814;--muted:#7a7368;--accent:#c0392b;--accent-light:#fdf0ee;--green:#16a34a}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:DM Sans,sans-serif}a{color:inherit;text-decoration:none}nav{background:var(--text);color:#fff;z-index:100;justify-content:space-between;align-items:center;height:64px;padding:0 2rem;display:flex;position:sticky;top:0}.logo{color:#fff;font-family:Playfair Display,serif;font-size:1.4rem}.logo span{color:var(--accent)}.nav-links{align-items:center;gap:1rem;display:flex}.nav-links a,.nav-links button{color:#ffffffb3;cursor:pointer;background:0 0;border:none;font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:500;text-decoration:none;transition:color .15s}.nav-links a:hover,.nav-links button:hover{color:#fff}.btn-nav-cta{border-radius:4px;padding:.45rem 1.1rem;background:var(--accent)!important;color:#fff!important;font-weight:600!important}.hero{background:var(--text);color:#fff;text-align:center;border-bottom:3px solid var(--accent);padding:3.5rem 2rem 4.5rem}.hero h1{max-width:640px;margin:0 auto .75rem;font-family:Playfair Display,serif;font-size:clamp(1.8rem,4vw,3rem);line-height:1.15}.hero p{color:#ffffff8c;max-width:460px;margin:0 auto 2rem;font-size:.95rem;line-height:1.6}.search-wrap{max-width:520px;margin:0 auto;position:relative}.search-wrap input{color:#fff;background:#ffffff12;border:2px solid #ffffff26;border-radius:4px;outline:none;width:100%;padding:1rem 3rem 1rem 1.25rem;font-family:DM Sans,sans-serif;font-size:.95rem;transition:border-color .2s}.search-wrap input::placeholder{color:#ffffff59}.search-wrap input:focus{border-color:var(--accent)}.stats-bar{background:var(--accent);color:#fff;text-align:center;letter-spacing:.03em;padding:.6rem;font-size:.8rem;font-weight:500}.page-wrap{max-width:860px;margin:0 auto;padding:2rem 1.5rem 4rem}.toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.filters{flex-wrap:wrap;gap:.4rem;display:flex}.filter-btn{border:1.5px solid var(--border);background:var(--surface);cursor:pointer;color:var(--muted);border-radius:999px;padding:.35rem .8rem;font-family:DM Sans,sans-serif;font-size:.78rem;font-weight:500;transition:all .15s}.filter-btn.active,.filter-btn:hover{background:var(--text);border-color:var(--text);color:#fff}.new-post-btn{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:4px;padding:.6rem 1.25rem;font-family:DM Sans,sans-serif;font-size:.88rem;font-weight:600;transition:opacity .15s}.new-post-btn:hover{opacity:.88}.results-info{color:var(--muted);border-bottom:1px solid var(--border);margin-bottom:1rem;padding-bottom:.75rem;font-size:.82rem}.results-info strong{color:var(--text)}.post-card{background:var(--surface);border:1px solid var(--border);border-radius:6px;margin-bottom:1rem;transition:box-shadow .2s;overflow:hidden}.post-card:hover{box-shadow:0 4px 18px #00000012}.post-body{padding:1.4rem 1.5rem}.post-top{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.75rem;display:flex}.post-names h2{margin-bottom:.15rem;font-family:Playfair Display,serif;font-size:1.1rem}.post-names h2 a{color:var(--text)}.post-names h2 a:hover{color:var(--accent)}.post-names .biz{color:var(--muted);font-size:.82rem}.post-meta{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:.35rem;display:flex}.badge{letter-spacing:.04em;text-transform:uppercase;background:var(--accent-light);color:var(--accent);border-radius:3px;padding:.22rem .6rem;font-size:.7rem;font-weight:700;display:inline-block}.post-date{color:var(--muted);font-size:.72rem}.post-desc{color:#3d3a34;font-size:.88rem;line-height:1.65}.post-desc.collapsed{-webkit-line-clamp:3;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.read-more-link{color:var(--accent);margin-top:.4rem;font-size:.78rem;font-weight:600;display:inline-block}.read-more-link:hover{text-decoration:underline}.post-footer{border-top:1px solid var(--border);background:#faf9f7;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;padding:.75rem 1.5rem;display:flex}.post-footer-left{align-items:center;gap:1rem;display:flex}.vote-btn{border:1.5px solid var(--border);cursor:pointer;color:var(--muted);background:0 0;border-radius:999px;align-items:center;gap:.35rem;padding:.3rem .75rem;font-family:DM Sans,sans-serif;font-size:.78rem;font-weight:600;transition:all .15s;display:flex}.vote-btn.up.active{color:#16a34a;background:#dcfce7;border-color:#16a34a}.vote-btn.down.active{background:var(--accent-light);border-color:var(--accent);color:var(--accent)}.vote-btn:hover{border-color:var(--text);color:var(--text)}.comment-toggle-btn{color:var(--muted);cursor:pointer;background:0 0;border:none;font-family:DM Sans,sans-serif;font-size:.78rem;font-weight:500}.comment-toggle-btn:hover{color:var(--text)}.post-footer-right{gap:.5rem;display:flex}.post-action-btn{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:3px;padding:.25rem .5rem;font-family:DM Sans,sans-serif;font-size:.75rem;transition:all .15s}.post-action-btn:hover{background:var(--bg);color:var(--text)}.post-action-btn.delete:hover{color:var(--accent)}.poster-info{color:var(--muted);font-size:.72rem}.comments-section{border-top:1px solid var(--border);padding:1rem 1.5rem}.comment{gap:.75rem;margin-bottom:.85rem;display:flex}.comment-avatar{background:var(--text);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;margin-top:2px;font-size:.7rem;font-weight:700;display:flex}.comment-bubble{background:var(--bg);border-radius:6px;flex:1;padding:.65rem .9rem}.comment-bubble .comment-author{margin-bottom:.2rem;font-size:.75rem;font-weight:600}.comment-bubble .comment-text{color:#3d3a34;font-size:.85rem;line-height:1.55}.comment-bubble .comment-date{color:var(--muted);margin-top:.25rem;font-size:.7rem}.comment-delete{color:var(--muted);cursor:pointer;background:0 0;border:none;margin-left:.5rem;font-size:.7rem}.comment-delete:hover{color:var(--accent)}.comment-form{gap:.5rem;margin-top:.75rem;display:flex}.comment-form input{border:1.5px solid var(--border);background:var(--surface);border-radius:4px;outline:none;flex:1;padding:.6rem .9rem;font-family:DM Sans,sans-serif;font-size:.85rem}.comment-form input:focus{border-color:var(--accent)}.comment-form button{background:var(--text);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:4px;padding:.6rem 1rem;font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:600}.login-prompt{color:var(--muted);margin-top:.75rem;font-size:.82rem}.login-prompt a{color:var(--accent);cursor:pointer;font-weight:600}.empty{text-align:center;color:var(--muted);padding:4rem 2rem}.empty h3{color:var(--text);margin-bottom:.5rem;font-family:Playfair Display,serif;font-size:1.3rem}.modal-overlay{z-index:300;background:#00000080;padding:2rem 1rem;display:none;position:fixed;inset:0;overflow-y:auto}.modal-overlay.open{justify-content:center;align-items:flex-start;display:flex}.modal{background:var(--surface);border-radius:8px;width:100%;max-width:620px;margin:auto;padding:2rem;position:relative}.modal h2{margin-bottom:1.5rem;font-family:Playfair Display,serif;font-size:1.4rem}.modal-close{cursor:pointer;color:var(--muted);background:0 0;border:none;font-size:1.4rem;position:absolute;top:1rem;right:1rem}.form-group{margin-bottom:1.1rem}.form-group label{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.4rem;font-size:.78rem;font-weight:600;display:block}.form-group input,.form-group select,.form-group textarea{border:1.5px solid var(--border);background:var(--surface);width:100%;color:var(--text);border-radius:4px;outline:none;padding:.75rem 1rem;font-family:DM Sans,sans-serif;font-size:.9rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent)}.form-group textarea{resize:vertical;min-height:130px;line-height:1.6}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.btn-submit{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:4px;width:100%;margin-top:.5rem;padding:.9rem;font-family:DM Sans,sans-serif;font-size:.95rem;font-weight:700;transition:opacity .15s}.btn-submit:hover{opacity:.88}.modal-alt{text-align:center;color:var(--muted);margin-top:1rem;font-size:.82rem}.modal-alt a{color:var(--accent);cursor:pointer;font-weight:600}.msg{text-align:center;margin-top:.5rem;font-size:.82rem}.msg.error{color:var(--accent)}.msg.success{color:var(--green)}.post-page-wrap{max-width:760px;margin:0 auto;padding:2.5rem 1.5rem 5rem}.post-page-back{color:var(--muted);margin-bottom:1.5rem;font-size:.82rem;display:inline-block}.post-page-back:hover{color:var(--accent)}.post-page-header{border-bottom:1px solid var(--border);margin-bottom:1.5rem;padding-bottom:1.5rem}.post-page-header h1{margin-bottom:.35rem;font-family:Playfair Display,serif;font-size:clamp(1.6rem,3vw,2.2rem);line-height:1.2}.post-page-biz{color:var(--muted);margin-bottom:1rem;font-size:.9rem}.post-page-badges{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.post-page-body{color:#3d3a34;white-space:pre-wrap;margin-bottom:2rem;font-size:.95rem;line-height:1.8}.post-page-meta{background:var(--surface);border:1px solid var(--border);color:var(--muted);border-radius:6px;margin-bottom:2rem;padding:1rem 1.25rem;font-size:.82rem}footer{background:var(--text);color:#ffffff59;text-align:center;padding:1.25rem;font-size:.75rem}.profile-wrap{max-width:640px;margin:0 auto;padding:3rem 1.5rem 5rem}.profile-title{margin-bottom:.35rem;font-family:Playfair Display,serif;font-size:2rem}.profile-sub{color:var(--muted);margin-bottom:2.5rem;font-size:.88rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:8px;margin-bottom:1.5rem;padding:2rem}.card-title{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);border-bottom:1px solid var(--border);margin-bottom:1.25rem;padding-bottom:.75rem;font-size:.75rem;font-weight:700}.field-note{color:var(--muted);margin-top:.3rem;font-size:.72rem}.optional-tag{background:var(--bg);color:var(--muted);border:1px solid var(--border);vertical-align:middle;text-transform:none;letter-spacing:0;border-radius:999px;margin-left:.4rem;padding:.1rem .5rem;font-size:.68rem;font-weight:400}.btn-primary{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:4px;width:100%;padding:.9rem;font-family:DM Sans,sans-serif;font-size:.95rem;font-weight:700;transition:opacity .15s}.btn-primary:hover{opacity:.88}.save-msg{text-align:center;border-radius:4px;margin-top:.75rem;padding:.6rem;font-size:.82rem}.save-msg.success{color:#15803d;background:#dcfce7}.save-msg.error{background:var(--accent-light);color:var(--accent)}.btn-danger{border:1.5px solid var(--accent);width:100%;color:var(--accent);cursor:pointer;background:0 0;border-radius:4px;padding:.85rem;font-family:DM Sans,sans-serif;font-size:.9rem;font-weight:600;transition:all .15s}.btn-danger:hover{background:var(--accent);color:#fff}.avatar-circle{background:var(--text);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin-bottom:1.25rem;font-family:Playfair Display,serif;font-size:1.8rem;font-weight:700;display:flex}@media (max-width:600px){.post-top{flex-direction:column}.post-meta{flex-direction:row}.form-row{grid-template-columns:1fr}nav{padding:0 1rem}.page-wrap{padding:1.5rem 1rem 3rem}}
