@import "https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;1,400&family=DM+Sans:wght@300;400;500;600&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--ink:#1a1209;--paper:#faf7f2;--cream:#f0ead8;--accent:#c0392b;--accent-light:#e74c3c;--muted:#8c7b6b;--border:#d9cfc0;--card-bg:#fff;--shadow:0 2px 20px #1a120914;--shadow-hover:0 8px 40px #1a120926;--radius:2px}html,body,#root{height:100%}body{background:var(--paper);color:var(--ink);min-height:100vh;font-family:DM Sans,sans-serif}.app-layout{flex-direction:column;min-height:100vh;display:flex}.app-main{flex-direction:column;flex:1;display:flex}.navbar,.footer{background:var(--ink);flex-shrink:0;justify-content:space-between;align-items:center;height:64px;padding:0 2rem;display:flex}.navbar{border-bottom:3px solid var(--accent);z-index:100;position:sticky;top:0}.footer{border-top:3px solid var(--accent);color:var(--muted);letter-spacing:.1em;justify-content:center;margin-top:auto;font-size:.875rem}.navbar-brand{color:var(--paper);letter-spacing:.02em;cursor:pointer;font-family:Playfair Display,serif;font-size:1.5rem}.navbar-brand span{color:var(--accent);font-style:italic}.navbar-actions{align-items:center;gap:1rem;display:flex}.nav-link{color:var(--cream);letter-spacing:.05em;text-transform:uppercase;cursor:pointer;border:1px solid #0000;padding:.4rem .8rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .2s}.nav-link:hover{border-color:var(--accent);color:var(--accent)}.nav-greeting{color:var(--cream);font-size:.875rem;font-weight:500}.nav-greeting strong{color:var(--accent)}.btn-logout{color:#aaa;border-radius:var(--radius);cursor:pointer;letter-spacing:.05em;text-transform:uppercase;background:0 0;border:1px solid #555;padding:.3rem .7rem;font-family:DM Sans,sans-serif;font-size:.75rem;transition:all .2s}.btn-logout:hover{border-color:var(--accent);color:var(--accent)}.hero{background:var(--ink);text-align:center;border-bottom:1px solid #333;padding:4rem 2rem 3rem;position:relative;overflow:hidden}.hero:before{content:"";background:repeating-linear-gradient(-45deg,#0000,#0000 40px,#c0392b0a 40px 41px);position:absolute;inset:0}.hero-label{letter-spacing:.3em;text-transform:uppercase;color:var(--accent);margin-bottom:.75rem;font-size:.7rem;font-weight:600;position:relative}.hero h1{color:var(--paper);font-family:Playfair Display,serif;font-size:clamp(2.5rem,6vw,4.5rem);line-height:1.1;position:relative}.hero h1 em{color:var(--accent);font-style:italic}.hero p{color:var(--muted);margin-top:1rem;font-size:1rem;position:relative}.container{max-width:1200px;margin:0 auto;padding:3rem 2rem}.section-label{letter-spacing:.3em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border);margin-bottom:2rem;padding-bottom:.75rem;font-size:.7rem}.posts-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2rem;display:grid}.post-card{background:var(--card-bg);border:1px solid var(--border);cursor:pointer;transition:box-shadow .3s,transform .3s;position:relative;overflow:hidden}.post-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-3px)}.post-card-image{object-fit:cover;background:var(--cream);width:100%;height:200px;display:block}.post-card-image-placeholder{background:linear-gradient(135deg, var(--cream) 0%, var(--border) 100%);width:100%;height:200px;color:var(--muted);justify-content:center;align-items:center;font-size:2.5rem;display:flex}.post-card-body{padding:1.5rem}.post-card-meta{letter-spacing:.15em;margin-bottom:.5rem;font-size:.7rem}.post-card-meta-span{letter-spacing:.15em;text-transform:capitalize;color:var(--accent);font-size:.7rem;font-weight:600}.post-card-title{color:var(--ink);margin-bottom:.75rem;font-family:Playfair Display,serif;font-size:1.25rem;line-height:1.35}.post-card-desc{color:var(--muted);-webkit-line-clamp:3;-webkit-box-orient:vertical;font-size:.875rem;line-height:1.6;display:-webkit-box;overflow:hidden}.post-card-actions{border-top:1px solid var(--border);gap:.5rem;margin-top:.5rem;padding:1rem 1.5rem 1.5rem;display:flex}.btn-edit,.btn-remove{letter-spacing:.08em;cursor:pointer;border-radius:var(--radius);border:1px solid;padding:.4rem .9rem;font-family:DM Sans,sans-serif;font-size:.75rem;font-weight:600;transition:all .2s}.btn-edit{border-color:var(--ink);color:var(--ink);background:0 0}.btn-edit:hover{background:var(--ink);color:var(--paper)}.btn-remove{border-color:var(--accent);color:var(--accent);background:0 0}.btn-remove:hover{background:var(--accent);color:#fff}.fab{background:var(--accent);color:#fff;cursor:pointer;z-index:99;border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-family:DM Sans,sans-serif;font-size:1.75rem;transition:all .25s;display:flex;position:fixed;bottom:2rem;right:2rem;box-shadow:0 4px 20px #c0392b66}.fab:hover{transform:scale(1.1)rotate(45deg);box-shadow:0 6px 28px #c0392b80}.auth-page{background:var(--paper);justify-content:center;align-items:center;min-height:calc(100vh - 64px);padding:2rem;display:flex}.auth-card{border:1px solid var(--border);width:100%;max-width:440px;box-shadow:var(--shadow);background:#fff;padding:3rem}.auth-card-header{margin-bottom:2rem}.auth-card-header h2{color:var(--ink);font-family:Playfair Display,serif;font-size:2rem}.auth-card-header p{color:var(--muted);margin-top:.4rem;font-size:.875rem}.auth-tabs{border-bottom:2px solid var(--border);gap:0;margin-bottom:2rem;display:flex}.auth-tab{text-align:center;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;color:var(--muted);background:0 0;border:none;border-bottom:2px solid #0000;flex:1;margin-bottom:-2px;padding:.6rem;font-family:DM Sans,sans-serif;font-size:.8rem;font-weight:600;transition:all .2s}.auth-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.form-group{margin-bottom:1.25rem}.form-label{letter-spacing:.1em;text-transform:uppercase;color:var(--ink);margin-bottom:.5rem;font-size:.75rem;font-weight:600;display:block}.form-input,.form-textarea{border:1px solid var(--border);background:var(--paper);width:100%;color:var(--ink);border-radius:var(--radius);outline:none;padding:.75rem 1rem;font-family:DM Sans,sans-serif;font-size:.9rem;transition:border-color .2s}.form-input:focus,.form-textarea:focus{border-color:var(--accent);background:#fff}.form-textarea{resize:vertical;min-height:120px}.btn-primary{background:var(--accent);color:#fff;letter-spacing:.1em;cursor:pointer;border-radius:var(--radius);border:none;width:100%;margin-top:.5rem;padding:.85rem;font-family:DM Sans,sans-serif;font-size:.875rem;font-weight:600;transition:all .2s}.btn-primary:hover{background:var(--accent-light)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{color:var(--ink);border:1px solid var(--border);letter-spacing:.1em;cursor:pointer;border-radius:var(--radius);background:0 0;padding:.85rem 1.5rem;font-family:DM Sans,sans-serif;font-size:.875rem;font-weight:600;transition:all .2s}.btn-secondary:hover{border-color:var(--ink);background:var(--paper)}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.form-error{color:var(--accent);margin-top:.4rem;font-size:.8rem}.post-form-page{background:var(--paper);justify-content:center;align-items:center;min-height:calc(100vh - 64px);padding:2rem;display:flex}.post-form-container{border:1px solid var(--border);width:100%;max-width:580px;box-shadow:var(--shadow);background:#fff;padding:3rem}.post-form-header{margin-bottom:2rem}.post-form-header h2{color:var(--ink);margin-bottom:.5rem;font-family:Playfair Display,serif;font-size:2rem}.post-form-header p{color:var(--muted);font-size:.875rem}.post-form{flex-direction:column;gap:1.25rem;display:flex}.form-actions{gap:1rem;margin-top:1rem;display:flex}.form-actions .btn-secondary,.form-actions .btn-primary{flex:1;width:auto;height:40px;margin:0}.image-preview-container{border-radius:var(--radius);margin-top:1rem;overflow:hidden}.image-preview{object-fit:cover;background:var(--cream);width:100%;height:200px;display:block}.empty-state{text-align:center;color:var(--muted);padding:4rem 2rem}.empty-state-icon{margin-bottom:1rem;font-size:3rem}.empty-state h3{color:var(--ink);margin-bottom:.5rem;font-family:Playfair Display,serif;font-size:1.5rem}.no-posts-hint{color:var(--muted);margin-top:.5rem;font-size:.875rem}.toast{background:var(--ink);color:var(--paper);border-left:3px solid var(--accent);z-index:200;border-radius:var(--radius);max-width:300px;padding:.75rem 1.25rem;font-size:.875rem;animation:.3s slideUp,.3s 2.5s forwards fadeOut;position:fixed;bottom:6rem;right:2rem}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOut{to{opacity:0}}.overlay{z-index:300;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#1a1209b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.confirm-dialog{border-top:3px solid var(--accent);background:#fff;width:90%;max-width:400px;padding:2.5rem}.confirm-dialog h3{margin-bottom:.5rem;font-family:Playfair Display,serif;font-size:1.4rem}.confirm-dialog p{color:var(--muted);margin-bottom:1.5rem;font-size:.875rem}.confirm-actions{gap:.75rem;display:flex}.confirm-actions .btn-secondary,.confirm-actions .btn-primary{flex:1;width:auto;height:40px;margin:0}
