@font-face{font-family:Fraunces;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/fb526027db1fc1ae-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Fraunces;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/4da3161b738b07dd-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Fraunces;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/af4bf8399d1aacdf-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Fraunces;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/fb526027db1fc1ae-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Fraunces;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/4da3161b738b07dd-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Fraunces;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/af4bf8399d1aacdf-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Fraunces Fallback;src:local("Times New Roman");ascent-override:84.71%;descent-override:22.09%;line-gap-override:0.00%;size-adjust:115.45%}.__className_25c8a1{font-family:Fraunces,Fraunces Fallback;font-style:normal}.__variable_25c8a1{--font-display:"Fraunces","Fraunces Fallback"}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/e1aab0933260df4d-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/b7387a63dd068245-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/36966cca54120369-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/e1aab0933260df4d-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/b7387a63dd068245-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/36966cca54120369-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/e1aab0933260df4d-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/b7387a63dd068245-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/36966cca54120369-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Space Grotesk Fallback;src:local("Arial");ascent-override:89.71%;descent-override:26.62%;line-gap-override:0.00%;size-adjust:109.69%}.__className_5dce4b{font-family:Space Grotesk,Space Grotesk Fallback;font-style:normal}.__variable_5dce4b{--font-sans:"Space Grotesk","Space Grotesk Fallback"}:root{color-scheme:only light;--bg:#f6f1e6;--bg-deep:#e9dec9;--ink:#181510;--muted:#5a5246;--accent:#f06a2b;--accent-deep:#d34b21;--paper:#fff9f0;--border:#e2d6bf;--shadow:0 12px 30px rgba(27,20,12,0.12);--radius:18px}*{box-sizing:border-box}body,html{padding:0;margin:0;min-height:100%}body{font-family:var(--font-sans),ui-sans-serif,system-ui,sans-serif;color:var(--ink);background:radial-gradient(circle at top left,#f7d9c2 0,transparent 42%),radial-gradient(circle at 70% 20%,#f4b7a0 0,transparent 38%),linear-gradient(135deg,var(--bg) 0,var(--bg-deep) 100%)}code{background:#f3e7d4;padding:2px 6px;border-radius:6px;font-size:.9em}a{color:inherit;text-decoration:none}main{display:block}button,input,textarea{font-family:inherit}button{cursor:pointer}.page{min-height:100vh;display:flex;flex-direction:column}.container{width:min(1100px,92vw);margin:0 auto}.surface{background:var(--paper);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.badge{padding:4px 12px;border-radius:999px;font-size:12px;display:flex;justify-content:space-between;text-transform:uppercase;letter-spacing:.08em;background:#f1e2ca}.hero{padding:96px 0 72px}.hero h1{font-family:var(--font-display),"Times New Roman",serif;font-size:clamp(2.6rem,5vw,4.2rem);margin:0 0 16px}.hero p{font-size:1.1rem;color:var(--muted);max-width:560px}.grid{display:grid;grid-gap:24px;gap:24px}.grid.two{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.card{padding:20px 22px;display:flex;flex-direction:column;gap:14px}.section-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.section-title h2{font-family:var(--font-display),"Times New Roman",serif;font-size:1.6rem;margin:0}.form-field{display:flex;flex-direction:column;gap:6px}.form-field span{font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.form-field input,.form-field select,.form-field textarea{padding:10px 12px;border-radius:12px;border:1px solid var(--border);background:#fff;transition:border-color .2s ease}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{outline:none;border-color:var(--accent)}.form-field input[style*="borderColor: rgb(180, 35, 24)"],.form-field textarea[style*="borderColor: rgb(180, 35, 24)"]{border-width:2px}.form-field textarea{min-height:90px;resize:vertical}.button{border:none;border-radius:999px;padding:10px 18px;font-weight:600;background:var(--accent);color:#fff;transition:transform .2s ease,box-shadow .2s ease,background .2s ease;box-shadow:0 10px 20px rgba(240,106,43,.35)}.button:hover{background:var(--accent-deep);transform:translateY(-1px)}.button:disabled{opacity:.5;cursor:not-allowed;background:#ccc}.button.ghost{background:transparent;color:var(--ink);border:1px solid var(--border);box-shadow:none}.button-sm{padding:6px 12px;font-size:.85rem}.navbar{align-items:center;justify-content:space-between;padding:20px 0}.nav-links,.navbar{display:flex;gap:16px;flex-wrap:wrap}.search{display:flex;align-items:center;gap:8px;padding:6px 10px;border:1px solid var(--border);border-radius:999px;background:#fff7ea}.search input{border:none;outline:none;background:transparent;min-width:180px}.search button{border:none;background:var(--accent);color:#fff;padding:6px 12px;border-radius:999px}.nav-links a,.search button{font-weight:600}.feed{display:grid;max-width:100%;grid-gap:20px;gap:20px}.post-meta{display:flex;gap:12px;font-size:.85rem;color:var(--muted)}.tag{background:#f0e6d4;padding:4px 10px;border-radius:999px;font-size:12px}.split{display:grid;grid-template-columns:1fr;grid-gap:24px;gap:24px}.split.two-col{grid-template-columns:minmax(0,2fr) minmax(0,1fr)}@media (max-width:900px){.split{grid-template-columns:1fr}}@media (max-width:640px){.comment-form-container{flex-direction:column}.comment-form-button,.comment-form-button button{width:100%}}.logo{display:block;object-fit:contain}.logo--small{height:32px;width:auto}.logo--medium{height:48px;width:auto}.logo--large{height:64px;width:auto}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:16px}.tab{padding:10px 16px;background:transparent;font-weight:500;color:var(--muted);cursor:pointer;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .2s,border-color .2s}.tab:hover{color:var(--ink)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.follow-btn{min-width:100px}.follow-btn.following,.follow-btn.requested{background:transparent;color:var(--ink);border:1px solid var(--border);box-shadow:none}.follow-btn.following:hover{border-color:#b42318;color:#b42318}.followers-list{display:flex;flex-direction:column;gap:12px}.follower-item{padding:12px;border-radius:12px;transition:background .2s}.follower-item:hover{background:var(--bg)}.follower-info{display:flex;flex-direction:column}.follower-name{font-weight:600}.follower-nickname{font-size:.85rem;color:var(--muted)}.follow-requests-list{display:flex;flex-direction:column;gap:12px}.follow-request-item{display:flex;align-items:center;justify-content:space-between;padding:12px;border-radius:12px;background:var(--bg)}.request-user{display:flex;align-items:center;gap:12px}.request-info{display:flex;flex-direction:column}.request-name{font-weight:600}.request-time{font-size:.8rem;color:var(--muted)}.request-actions{display:flex;gap:8px}.profile-header{display:flex;gap:20px;align-items:flex-start}.profile-header-info{flex:1 1}.profile-header-top{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.profile-stats{display:flex;gap:20px;margin-top:8px;font-size:.9rem}.profile-stats strong{color:var(--ink)}.edit-avatar-section{display:flex;align-items:center;gap:16px}.reaction-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid var(--border);border-radius:999px;background:transparent;cursor:pointer;transition:transform .2s,background .2s}.reaction-btn:hover{background:var(--bg);transform:scale(1.05)}.reaction-btn.reacted{background:#fff0e8;border-color:var(--accent)}.reaction-icon{font-size:1.1rem}.reaction-count{font-weight:600;font-size:.9rem}.comment-section{border-top:1px solid var(--border);padding-top:14px;overflow:hidden;max-width:100%}.comment-toggle{background:transparent;border:none;color:var(--muted);font-size:.9rem;cursor:pointer;padding:8px 0}.comment-toggle:hover{color:var(--ink)}.comment-input-wrapper{display:flex;flex-direction:column;gap:12px;margin-bottom:16px;width:100%;box-sizing:border-box}.comment-form{margin-bottom:20px;width:100%}.comment-form-container{display:flex;gap:12px;align-items:flex-start}.comment-form-input-area{flex:1 1;display:flex;flex-direction:column;gap:8px;min-width:0}.comment-form-content{background:var(--bg);border:1.5px solid var(--border);border-radius:12px;padding:12px;transition:border-color .2s ease}.comment-form-content:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px rgba(240,106,43,.1)}.comment-form-button{flex-shrink:0;align-self:stretch;display:flex;align-items:flex-start;padding-top:0}.comment-input{width:100%;padding:10px 12px;border:none;background:transparent;border-radius:8px;resize:vertical;min-height:60px;max-height:200px;font-size:.95rem;line-height:1.5;font-family:inherit;box-sizing:border-box;transition:background-color .2s ease}.comment-reply-form-buttons{display:flex;flex-direction:column;padding:.25rem;gap:.2rem}.comment-input::placeholder{color:var(--muted);opacity:.7}.comment-input:focus{outline:none;background:rgba(0,0,0,.02)}.comment-form-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.comment-form-button button{min-height:48px;white-space:nowrap}.comment-form-error{margin-top:8px;padding:10px 12px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#b42318;font-size:.875rem;line-height:1.4;display:flex;align-items:flex-start;gap:8px;animation:slideDown .2s ease-out}.comment-form-error:before{content:"⚠";font-size:1rem;flex-shrink:0}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.comments-list{display:flex;flex-direction:column;gap:12px;overflow:hidden;max-width:100%}.comment-loading,.no-comments{color:var(--muted);font-size:.9rem;padding:12px 0}.comment-thread{position:relative;margin-bottom:2px}.comment-thread.comment-reply{margin-left:32px}.comment-thread-line{position:absolute;left:-20px;top:0;width:16px;height:32px;border-left:2px solid var(--border);border-bottom:2px solid var(--border);border-bottom-left-radius:12px;pointer-events:none}.comment-replies{position:relative;margin-top:4px;animation:slideIn .2s ease-out;transform-origin:top;overflow:hidden;max-height:10000px;transition:max-height .2s ease-out,opacity .2s ease-out}.comment-replies.collapsing{animation:slideOut .2s ease-out;max-height:0;opacity:0}.comment-replies:before{top:0;background-color:var(--border)}.comment-replies:before,.comment-replies>.comment-thread:last-child:after{content:"";position:absolute;left:4px;bottom:0;width:2px;pointer-events:none}.comment-replies>.comment-thread:last-child:after{height:50%;background-color:var(--bg)}@keyframes slideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-8px)}}.comment-card{display:flex;gap:12px;padding:12px;border-radius:12px;background:var(--bg);overflow:hidden;max-width:100%;position:relative;transition:background-color .2s ease}.comment-card:hover{background-color:rgba(0,0,0,.02)}.comment-avatar-link{flex-shrink:0;align-self:flex-start;text-decoration:none}.comment-content{flex:1 1;min-width:0;overflow:hidden}.comment-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.comment-author{font-weight:600;font-size:.9rem;text-decoration:none;color:var(--ink);transition:color .2s ease}.comment-author:hover{color:var(--accent)}.comment-time{font-size:.8rem;color:var(--muted)}.comment-text{margin:0 0 8px;font-size:.95rem;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;white-space:pre-wrap;max-width:100%;color:var(--ink);line-height:1.5}.comment-actions{display:flex;gap:12px;margin-top:8px;align-items:center;flex-wrap:wrap}.comment-action{background:transparent;border:none;padding:4px 8px;font-size:.85rem;color:var(--muted);cursor:pointer;border-radius:6px;transition:all .2s ease;display:flex;align-items:center;gap:4px}.comment-action:hover{background-color:rgba(0,0,0,.05);color:var(--ink)}.comment-action.danger:hover{background-color:#fef2f2;color:#b42318}.comment-action:disabled{opacity:.5;cursor:not-allowed}.comment-action.collapse-toggle{font-weight:500;color:var(--accent)}.comment-action.collapse-toggle:hover{background-color:rgba(240,106,43,.1)}.comment-action.collapse-toggle svg{flex-shrink:0;margin-right:2px}.comment-reply-form{margin-top:12px;padding:12px;background-color:rgba(0,0,0,.02);border:1px solid var(--border);border-radius:8px}.comment-edit{display:flex;flex-direction:column;width:100%}.comment-edit-content{background:var(--bg);border:1.5px solid var(--border);border-radius:12px;padding:12px;transition:border-color .2s ease}.comment-edit-content:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px rgba(240,106,43,.1)}.comment-edit-input{width:100%;padding:10px 12px;border:none;background:transparent;border-radius:8px;resize:none;font-size:.95rem;line-height:1.5;font-family:inherit;box-sizing:border-box;min-height:80px;transition:background-color .2s ease}.comment-edit-input:focus{outline:none;background:rgba(0,0,0,.02)}.comment-edit-actions{display:flex;gap:8px;align-items:center;margin-top:12px;flex-wrap:wrap}@media (max-width:640px){.comment-edit-actions{flex-direction:column;align-items:stretch}.comment-edit-actions button{width:100%}}.comment-image{max-width:100%;width:auto;max-height:200px;object-fit:contain;border-radius:8px;border:1px solid var(--border);margin-top:8px;display:block}.comment-image-preview{position:relative;margin-top:12px;border-radius:8px;overflow:hidden}.comment-image-preview img{width:100%;max-height:200px;object-fit:cover;border-radius:8px;border:1px solid var(--border);display:block}.comment-image-preview .remove-image-btn{position:absolute;top:8px;right:8px;background:rgba(0,0,0,.7);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:white;border:none;width:28px;height:28px;border-radius:50%;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;line-height:1;padding:0}.comment-image-preview .remove-image-btn:hover{background:#b42318;transform:scale(1.1)}@media (prefers-color-scheme:dark){.comment-card:hover{background-color:rgba(255,255,255,.05)}.comment-action:hover{background-color:rgba(255,255,255,.08)}.comment-action.collapse-toggle:hover{background-color:rgba(240,106,43,.15)}.comment-reply-form{background-color:rgba(255,255,255,.03)}.comment-edit-input:focus,.comment-input:focus{background:rgba(255,255,255,.05)}.comment-replies>.comment-thread:last-child:after{background-color:var(--bg)}}.post-detail-container{max-width:800px;width:100%;margin:0 auto;padding-bottom:64px}.post-card{position:relative}.post-header{justify-content:space-between}.post-author,.post-header{display:flex;align-items:center;gap:12px}.post-author-info{display:flex;flex-direction:column}.post-author-name{font-weight:600}.post-time{font-size:.8rem;color:var(--muted)}.post-header-right{display:flex;align-items:center;gap:8px}.post-content-link{display:block}.post-text{font-size:1.05rem;margin:0}.post-image{width:100%;max-height:400px;object-fit:cover;border-radius:14px;border:1px solid var(--border)}.post-detail-container .post-image{max-height:600px;object-fit:contain}.post-interactions{display:flex;gap:16px;align-items:center}.post-comment-link{display:flex;align-items:center;gap:6px;color:var(--muted);font-size:.9rem}.post-comment-link:hover{color:var(--ink)}.post-actions-trigger{background:transparent;border:none;font-size:1.2rem;cursor:pointer;padding:4px 8px;border-radius:4px;color:var(--muted)}.post-actions-trigger:hover{background:var(--bg);color:var(--ink)}.dropdown{position:relative}.dropdown-menu{position:absolute;top:100%;right:0;min-width:140px;background:var(--paper);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);z-index:100;overflow:hidden}.dropdown-item{display:block;width:100%;padding:10px 16px;border:none;background:transparent;text-align:left;cursor:pointer;font-size:.9rem}.dropdown-item:hover{background:var(--bg)}.dropdown-item.danger{color:#b42318}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:var(--paper);border-radius:var(--radius);box-shadow:var(--shadow);max-width:500px;width:100%;max-height:90vh;overflow-y:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.modal-title{margin:0;font-size:1.2rem}.modal-close{background:transparent;border:none;font-size:1.5rem;cursor:pointer;color:var(--muted);line-height:1}.modal-close:hover{color:var(--ink)}.modal-body{padding:20px}.modal-actions{display:flex;gap:12px;margin-top:20px}.edit-post-form{display:flex;flex-direction:column;gap:16px}.edit-post-input{width:100%;padding:12px;border:1px solid var(--border);border-radius:12px;resize:vertical;min-height:100px}.image-upload{display:flex;flex-direction:column;gap:12px}.upload-dropzone{border:2px dashed var(--border);border-radius:12px;padding:32px;text-align:center;cursor:pointer;transition:all .3s ease;background:var(--paper)}.upload-dropzone:hover{border-color:var(--accent);background:#fff5ed;transform:translateY(-2px)}.upload-dropzone.dragging{border-color:var(--accent);background:#ffecd6;transform:scale(1.02)}.upload-dropzone.uploaded{border-color:#22c55e;background:#f0fdf4;border-style:solid}.dropzone-content{display:flex;flex-direction:column;align-items:center;gap:8px}.dropzone-icon{font-size:2.5rem;color:var(--muted);transition:color .3s}.dropzone-icon.success{color:#22c55e;font-size:3rem}.dropzone-text{font-weight:600;color:var(--ink)}.dropzone-hint{font-size:.85rem;color:var(--muted)}.upload-error{color:#b42318;font-size:.85rem;margin-top:4px}.image-upload-compact{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}.image-upload-compact .upload-success{color:#22c55e;font-size:.85rem;display:inline-flex;align-items:center;gap:4px}.post-image-preview{position:relative}.post-image-preview img{width:100%;max-height:200px;object-fit:cover;border-radius:12px;border:1px solid var(--border)}.post-image-preview .remove-preview{position:absolute;top:8px;right:8px;background:rgba(0,0,0,.7);color:#fff;border:none;border-radius:8px;padding:6px 12px;cursor:pointer}.composer-footer{display:flex;gap:16px;justify-content:end;align-items:flex-end;flex-wrap:wrap}.composer-actions{display:flex;gap:8px;align-items:center}.follower-selector{margin-top:16px;padding:16px;background:var(--bg);border-radius:12px;border:1px solid var(--border)}.follower-selector-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;flex-wrap:wrap;gap:8px}.follower-selector-title{font-weight:500;color:var(--text)}.selected-count{color:var(--primary);font-weight:600}.follower-selector-actions{display:flex;align-items:center;gap:8px}.follower-selector-actions .text-button{background:none;border:none;color:var(--primary);cursor:pointer;font-size:.875rem;padding:0}.follower-selector-actions .text-button:hover{text-decoration:underline}.follower-selector-actions .divider{color:var(--text-secondary)}.follower-list{display:flex;flex-direction:column;gap:8px;max-height:240px;overflow-y:auto}.follower-item{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--surface);border-radius:8px;cursor:pointer;transition:background .15s}.follower-item:hover{background:var(--surface-hover,var(--bg-hover))}.follower-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary);cursor:pointer}.follower-name{display:flex;flex-direction:column;gap:2px}.follower-nickname{display:block;font-size:.8rem;color:var(--text-secondary)}.empty-followers{text-align:center;padding:20px}.validation-hint{color:var(--warning,#c77700)}.success-message,.validation-hint{font-size:.875rem;margin-top:12px;text-align:center}.success-message{color:var(--success,#16a34a);padding:10px 16px;background:var(--success-bg,#dcfce7);border-radius:8px;font-weight:500}.chat-threads{display:flex;flex-direction:column;gap:8px}.chat-thread{display:flex;align-items:center;justify-content:space-between;padding:14px;border-radius:12px;background:var(--bg);transition:background .2s}.chat-thread:hover{background:var(--bg-deep)}.chat-thread-info{flex:1 1;min-width:0}.chat-thread-name{display:block;margin-bottom:4px}.chat-thread-preview{margin:0;font-size:.9rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-thread-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.chat-thread-time{font-size:.8rem;color:var(--muted)}.chat-unread-badge{background:var(--accent);color:#fff;font-size:.75rem;font-weight:600;padding:2px 8px;border-radius:999px}.chat-room-header{margin-bottom:-12px}.back-link{font-size:.9rem;color:var(--muted)}.back-link:hover{color:var(--ink)}.chat-room-container{height:calc(100vh - 200px);min-height:400px}.chat-room{display:flex;flex-direction:column;height:100%}.chat-room-title{padding-bottom:12px;display:flex;align-content:center;position:relative;justify-content:space-between;height:3rem;border-bottom:1px solid var(--border)}.chat-room-name{font-size:1.25rem;font-weight:700;display:flex;align-items:center}.chat-room-title-edit-btn{border-width:0;background:transparent}.chat-messages{flex:1 1;overflow-y:auto;display:flex;flex-direction:column;gap:12px;padding:12px 0}.chat-empty,.chat-loading{color:var(--muted);text-align:center;padding:20px}.chat-input-form{display:flex;gap:12px;align-items:center;padding-top:12px;border-top:1px solid var(--border)}.chat-input{flex:1 1;padding:10px 14px;border:1px solid var(--border);border-radius:999px;outline:none}.chat-input:focus{border-color:var(--accent)}.edit-roomname-drawer{position:absolute;left:0;top:100%;z-index:20;background:#fffbf3;border:1px solid #eee;border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,.1);margin-top:8px;padding:16px;min-width:220px}.edit-roomname-form{display:flex;flex-direction:row;align-items:center;gap:8px}.edit-roomname-button-wrapper{display:flex;gap:4px;padding-top:1.33rem}.edit-roomname-field-wrapper{flex:1 1;display:flex;flex-direction:column;gap:4px}.edit-roomname-input{flex:1 1;padding:6px 10px;border:1px solid #ddd;border-radius:4px;font-size:16px}.edit-roomname-submit{padding:6px 12px;border-radius:4px;background-color:#ee692b;color:#fff;border:none;cursor:pointer;font-weight:500}.edit-roomname-submit:disabled{opacity:.5;cursor:not-allowed;background:#ccc}.edit-roomname-cancel{padding:6px 10px;border-radius:4px;background-color:#f0f0f0;border:1px solid #ddd;color:#555;cursor:pointer}.message-bubble{display:flex;gap:10px;max-width:80%}.message-bubble.own{margin-left:auto;flex-direction:row-reverse}.message-bubble.other{margin-right:auto}.message-content{background:var(--bg);padding:10px 14px;border-radius:16px}.message-bubble.own .message-content{background:var(--accent);color:#fff}.message-sender{display:block;font-size:.8rem;font-weight:600;margin-bottom:4px}.message-text{margin:0;word-break:break-word}.message-time{display:block;font-size:.7rem;opacity:.7;margin-top:4px;text-align:right}.emoji-picker{position:relative}.emoji-trigger{background:transparent;border:1px solid var(--border);border-radius:8px;padding:6px 10px;font-size:1.2rem;cursor:pointer}.emoji-dropdown{position:absolute;bottom:100%;left:0;background:var(--paper);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);padding:12px;z-index:100;max-height:200px;overflow-y:auto}.emoji-category{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}.emoji-btn{background:transparent;border:none;font-size:1.2rem;cursor:pointer;padding:4px;border-radius:4px}.emoji-btn:hover{background:var(--bg)}.new-chat-search{display:flex;gap:12px;margin-bottom:16px}.new-chat-input{flex:1 1;padding:10px 14px;border:1px solid var(--border);border-radius:12px}.new-chat-results{display:flex;flex-direction:column;gap:8px}.new-chat-hint{color:var(--muted);text-align:center;padding:20px}.new-chat-user{display:flex;align-items:center;gap:12px;padding:12px;border:none;background:var(--bg);border-radius:12px;cursor:pointer;width:100%;text-align:left}.new-chat-user:hover{background:var(--bg-deep)}.new-chat-user-info{flex:1 1;display:flex;flex-direction:column}.new-chat-user-name{font-weight:600}.new-chat-user-nickname{font-size:.85rem;color:var(--muted)}.members-grid{display:grid;grid-gap:12px;gap:12px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.member-card{flex-direction:row;align-items:center;justify-content:space-between}.member-link{display:flex;align-items:center;gap:12px}.member-info{display:flex;flex-direction:column}.member-name{font-weight:600}.member-status{font-size:.8rem;color:var(--muted)}.member-you{font-size:.8rem;color:var(--accent)}.member-remove{padding:6px 12px;font-size:.85rem}.group-invite-search{display:flex;gap:12px;margin-bottom:16px}.group-invite-input{flex:1 1;padding:10px 14px;border:1px solid var(--border);border-radius:12px}.group-invite-results{display:flex;flex-direction:column;gap:8px}.group-invite-hint{color:var(--muted);text-align:center;padding:20px}.group-invite-user{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg);border-radius:12px}.group-invite-user-info{flex:1 1;display:flex;flex-direction:column}.group-invite-user-name{font-weight:600}.group-invite-user-nickname{font-size:.85rem;color:var(--muted)}.group-requests-list{display:flex;flex-direction:column;gap:12px}.group-request-item{display:flex;align-items:center;justify-content:space-between;padding:12px;border-radius:12px;background:var(--bg)}.group-settings-form{display:flex;flex-direction:column;gap:16px}.danger-zone{padding-top:16px}.notification-dropdown{position:relative}.notification-trigger{background:transparent;border:none;position:relative;cursor:pointer;padding:4px}.notification-badge-link{position:relative;display:inline-block}.notification-bell{font-size:1.2rem}.notification-count{position:absolute;top:-6px;right:-8px;background:var(--accent);color:#fff;font-size:.65rem;font-weight:700;min-width:18px;height:18px;border-radius:999px;display:flex;align-items:center;justify-content:center;padding:0 4px}.ws-status{position:absolute;bottom:0;right:0;width:8px;height:8px;border-radius:50%;background:#ccc}.ws-status.connected{background:#22c55e;box-shadow:0 0 4px rgba(34,197,94,.5)}.notification-menu{position:absolute;top:100%;right:0;width:360px;background:var(--paper);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);z-index:100;overflow:hidden}.notification-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border)}.notification-header h4{margin:0}.notification-header a{font-size:.85rem;color:var(--accent)}.notification-header-actions{display:flex;align-items:center;gap:12px}.notification-list{max-height:400px;overflow-y:auto}.notification-empty{padding:20px;text-align:center;color:var(--muted)}.notification-item{display:flex;flex-direction:column;gap:8px;padding:12px 16px;border-bottom:1px solid var(--border);transition:background .2s;position:relative}.notification-item:last-child{border-bottom:none}.notification-item:hover{background:var(--bg)}.notification-item.unread{background:rgba(240,106,43,.05);border-left:3px solid var(--accent)}.notification-item-main{display:flex;align-items:center;gap:12px}.notification-content-link{flex:1 1;min-width:0;text-decoration:none;color:inherit}.notification-content{flex:1 1;min-width:0}.notification-text{margin:0;font-size:.9rem;line-height:1.4}.notification-time{font-size:.75rem;color:var(--muted);display:block;margin-top:2px}.notification-icon{font-size:1.2rem;flex-shrink:0}.notification-actions{display:flex;gap:8px;margin-left:52px}.notification-actions .button{font-size:.8rem;padding:5px 12px}.notifications-list{display:flex;flex-direction:column}.notification-page-header{justify-content:space-between;flex-wrap:wrap}.notification-page-actions,.notification-page-header{display:flex;align-items:center;gap:12px}.ws-indicator{display:flex;align-items:center;gap:6px;font-size:.8rem;color:#22c55e}.ws-dot{width:8px;height:8px;border-radius:50%;background:#22c55e;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.events-list{gap:16px}.event-card,.events-list{display:flex;flex-direction:column}.event-card{gap:12px}.event-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.event-title{margin:0;font-size:1.1rem}.event-date{font-size:.85rem;color:var(--muted);white-space:nowrap}.event-description{margin:0;color:var(--muted)}.event-location{display:flex;align-items:center;gap:6px;font-size:.9rem;margin:0}.event-location-icon{font-size:1rem}.event-stats{display:flex;gap:16px}.event-stat{display:flex;align-items:center;gap:4px;font-size:.85rem;color:var(--muted)}.event-actions{display:flex;gap:8px}.button.danger,.danger .button{background:#b42318;border-color:#b42318}.button.danger:hover{background:#8a1a12}.button.ghost.danger{background:transparent;color:#b42318;border-color:#b42318}.button.ghost.danger:hover{background:#fff0f0}.nav-links,.search-result{align-items:center}.search-result{flex-direction:row;gap:12px}.search-result-info{display:flex;flex-direction:column}