/* SkyWebPro v1.0 */
:root{--bg:#f1f3f5;--surface:#fff;--surface2:#f8f9fa;--border:#e1e4e8;--border-l:#eef0f3;--primary:#0085ff;--primary-h:#0070db;--primary-s:#e8f3ff;--text:#0f1419;--text-2:#536471;--text-3:#8b98a5;--danger:#e0245e;--danger-s:#fce8ef;--warn:#f4900c;--font:'DM Sans',sans-serif;--mono:'DM Mono',monospace;--r:12px;--rs:8px;--rf:9999px;--shadow:0 1px 3px rgba(0,0,0,.07),0 4px 12px rgba(0,0,0,.05);--shadow-l:0 8px 30px rgba(0,0,0,.14);--sw:248px;--main-content-max:680px;--thread-line-offset:37px}
[data-theme='dark']{--bg:#0b1117;--surface:#111b28;--surface2:#152536;--border:#31465d;--border-l:#2a3f55;--primary:#32a6ff;--primary-h:#1e92eb;--primary-s:#17364f;--text:#edf3fa;--text-2:#b6c5d5;--text-3:#8fa4b8;--danger:#ff5f89;--danger-s:#3a1d29;--warn:#f7b54a;--shadow:0 1px 3px rgba(0,0,0,.35),0 4px 12px rgba(0,0,0,.28);--shadow-l:0 10px 34px rgba(0,0,0,.5)}
[data-theme='ocean']{--bg:#e9f4f6;--surface:#ffffff;--surface2:#f2f8fa;--border:#c9dde3;--border-l:#dcebf0;--primary:#007c91;--primary-h:#006a7c;--primary-s:#dff3f7;--text:#123642;--text-2:#3e6570;--text-3:#6e8f99;--danger:#c7385a;--danger-s:#fde8ee;--warn:#c57b08;--shadow:0 1px 3px rgba(0,0,0,.08),0 4px 12px rgba(0,0,0,.06);--shadow-l:0 8px 30px rgba(0,0,0,.16)}
[data-theme='forest']{--bg:#edf4ec;--surface:#ffffff;--surface2:#f4f9f3;--border:#cddfcb;--border-l:#dfecde;--primary:#2f7d46;--primary-h:#286a3b;--primary-s:#e3f3e7;--text:#1d3122;--text-2:#4a6650;--text-3:#738a78;--danger:#bf3f5f;--danger-s:#fdeaf0;--warn:#b57910;--shadow:0 1px 3px rgba(0,0,0,.08),0 4px 12px rgba(0,0,0,.06);--shadow-l:0 8px 30px rgba(0,0,0,.16)}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:15px}
html.font-scale-small{font-size:14px}
html.font-scale-large{font-size:16px}
body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased}
img{display:block}button{cursor:pointer;font-family:var(--font)}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}.hidden{display:none!important}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:10px}
.spin-el{transform-origin:center;animation:spin .8s linear infinite}.refresh-btn.spinning svg{animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{from{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}@keyframes toastIn{from{opacity:0;transform:translateY(8px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes toastOut{to{opacity:0;transform:translateY(8px) scale(.95)}}@keyframes blobF{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(20px,-20px) scale(1.05)}66%{transform:translate(-15px,15px) scale(.95)}}
/* LOGIN */
#login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:linear-gradient(135deg,#e8f3ff 0%,#f0f4ff 50%,#e8f8f0 100%)}
.login-bg{position:absolute;inset:0;pointer-events:none}.blob{position:absolute;border-radius:50%;filter:blur(60px);opacity:.35}
.blob.b1{width:400px;height:400px;background:#b3d4ff;top:-100px;left:-100px;animation:blobF 8s ease-in-out infinite}.blob.b2{width:300px;height:300px;background:#a7f0d8;bottom:-80px;right:10%;animation:blobF 10s ease-in-out infinite reverse}.blob.b3{width:250px;height:250px;background:#c4b5fd;top:40%;right:-80px;animation:blobF 12s ease-in-out infinite 2s}
.login-card{background:var(--surface);border-radius:20px;padding:36px 32px;width:100%;max-width:440px;box-shadow:var(--shadow-l);position:relative;z-index:1;animation:fadeUp .5s ease}
.login-logo{display:flex;align-items:center;gap:10px;font-size:1.25rem;font-weight:700;margin-bottom:20px;letter-spacing:-.02em}.login-title{font-size:1.4rem;font-weight:700;letter-spacing:-.03em;margin-bottom:16px}
.login-sub{margin-top:-8px;margin-bottom:14px;font-size:.72rem;color:var(--text-3);letter-spacing:.04em}
.login-tip{background:#fffbea;border:1px solid #f0d060;border-radius:var(--rs);padding:12px 14px;margin-bottom:18px;font-size:.82rem;line-height:1.7}.login-tip strong{display:block;margin-bottom:4px}.login-tip ul{padding-left:16px}
[data-theme='dark'] #login-screen{background:linear-gradient(135deg,#0f1a29 0%,#122236 50%,#102926 100%)}
[data-theme='dark'] .login-tip{background:#243445;border-color:#4a6179;color:#e6eef8}
[data-theme='dark'] .login-tip strong{color:#f3f8ff}
[data-theme='dark'] .login-tip a{color:#8fd1ff}
[data-theme='dark'] .login-sub{color:#a9bcd1}
.form-group{margin-bottom:13px}.form-label{display:flex;justify-content:space-between;align-items:center;font-size:.77rem;font-weight:600;color:var(--text-2);margin-bottom:5px;text-transform:uppercase;letter-spacing:.04em}.label-link{font-size:.75rem;font-weight:400;text-transform:none;letter-spacing:0}
.input-wrap{position:relative;display:flex;align-items:center}.input-pre{position:absolute;left:11px;color:var(--text-3);pointer-events:none;font-size:.93rem}
.form-input{width:100%;padding:10px 13px;border:1.5px solid var(--border);border-radius:var(--rs);font-family:var(--font);font-size:.93rem;background:var(--surface2);color:var(--text);transition:border-color .15s,box-shadow .15s;outline:none}
.input-wrap .form-input{padding-left:26px}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(0,133,255,.12);background:var(--surface)}textarea.form-input{resize:vertical}
.login-error{background:var(--danger-s);color:var(--danger);padding:10px 13px;border-radius:var(--rs);font-size:.85rem;margin-bottom:12px;border:1px solid rgba(224,36,94,.15);line-height:1.6}
.btn-primary{width:100%;padding:11px;background:var(--primary);color:#fff;border:none;border-radius:var(--rs);font-size:.97rem;font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .15s,transform .15s;cursor:pointer}.btn-primary:hover{background:var(--primary-h)}.btn-primary:active{transform:scale(.98)}
.btn-login-check{width:100%;margin-top:8px;padding:9px 11px;background:var(--surface2);color:var(--text-2);border:1.5px solid var(--border);border-radius:var(--rs);font-size:.84rem;font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .15s,color .15s,border-color .15s}
.btn-login-check:hover{background:var(--surface);color:var(--text)}
.btn-login-check .btn-text{white-space:nowrap}
.btn-login-check:disabled{opacity:.72;cursor:not-allowed}
.login-check-result{margin-top:10px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--rs);background:var(--surface2);font-size:.76rem;line-height:1.65;color:var(--text-2);white-space:pre-wrap;word-break:break-word}
.login-check-result.ok{border-color:#32b06e;background:#edf8f1;color:#226944}
.login-check-result.warn{border-color:#d9a441;background:#fff6e9;color:#765112}
.login-check-result.err{border-color:#dc6788;background:#fff0f4;color:#8b2041}
.login-console-wrap{margin-top:10px;border:1px solid var(--border);border-radius:var(--rs);overflow:hidden;background:var(--surface2)}
.login-console-head{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:7px 9px;border-bottom:1px solid var(--border-l);font-size:.72rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text-3)}
.login-console-head .btn-sm{padding:3px 8px;font-size:.7rem}
.login-console-output{margin:0;padding:9px 10px;min-height:88px;max-height:180px;overflow:auto;font-family:var(--mono);font-size:.71rem;line-height:1.45;color:var(--text-2);white-space:pre-wrap;word-break:break-word;background:var(--surface)}
[data-theme='dark'] .btn-login-check{background:#1a2a3b;border-color:#3a526b;color:#ccdaea}
[data-theme='dark'] .btn-login-check:hover{background:#203246;color:#ecf4ff}
[data-theme='dark'] .login-check-result{background:#152536;border-color:#3a526b;color:#c9d9ea}
[data-theme='dark'] .login-check-result.ok{background:#193128;border-color:#3b7c55;color:#9fe4bd}
[data-theme='dark'] .login-check-result.warn{background:#302815;border-color:#7f6831;color:#f1d795}
[data-theme='dark'] .login-check-result.err{background:#341a24;border-color:#8a3754;color:#ffb6cb}
[data-theme='dark'] .login-console-wrap{background:#152536;border-color:#3a526b}
[data-theme='dark'] .login-console-head{border-bottom-color:#2a3f55;color:#9fb4ca}
[data-theme='dark'] .login-console-output{background:#101c29;color:#c9d9ea}
.login-note{margin-top:14px;font-size:.73rem;color:var(--text-3);text-align:center;line-height:1.6}
/* APP LAYOUT */
.app{display:flex;min-height:100vh}
.sidebar{width:var(--sw);background:var(--surface);border-right:1px solid var(--border);position:fixed;top:0;left:0;bottom:0;display:flex;flex-direction:column;padding:16px 10px;z-index:100}
.sidebar-logo{display:flex;align-items:center;gap:9px;font-size:1.05rem;font-weight:700;letter-spacing:-.02em;padding:6px 10px 16px}
.sidebar-nav{display:flex;flex-direction:column;gap:2px;flex:1}
.nav-item{display:flex;align-items:center;gap:11px;padding:10px 13px;border-radius:var(--r);border:none;background:transparent;color:var(--text-2);font-size:.9rem;font-weight:500;width:100%;text-align:left;transition:background .15s,color .15s;position:relative;cursor:pointer}
.nav-item:hover{background:var(--primary-s);color:var(--primary)}.nav-item.active{background:var(--primary-s);color:var(--primary);font-weight:600}
.badge{background:var(--primary);color:#fff;font-size:.67rem;font-weight:700;padding:1px 5px;border-radius:var(--rf);min-width:17px;text-align:center;margin-left:auto}
.sidebar-post-btn{width:100%;margin-top:8px;margin-bottom:8px;padding:9px 12px;border-radius:var(--r);border:none;background:var(--primary);color:#fff;font-size:.86rem;font-weight:700;transition:background .15s,transform .15s}
.sidebar-post-btn:hover{background:var(--primary-h)}.sidebar-post-btn:active{transform:scale(.98)}
.sidebar-bottom{display:flex;align-items:center;gap:7px;padding-top:12px;border-top:1px solid var(--border)}
.user-avatar{width:33px;height:33px;border-radius:50%;object-fit:cover;flex-shrink:0;background:var(--primary-s)}.user-info{flex:1;min-width:0}.user-name{display:block;font-weight:600;font-size:.81rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-handle{display:block;font-size:.72rem;color:var(--text-3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.logout-btn{background:transparent;border:none;color:var(--text-3);padding:7px;border-radius:var(--rs);display:flex;align-items:center;transition:color .15s,background .15s;flex-shrink:0;cursor:pointer}.logout-btn:hover{color:var(--danger);background:var(--danger-s)}
.main-content{margin-left:var(--sw);flex:1;max-width:var(--main-content-max);min-height:100vh}
.tab-section{display:none}.tab-section.active{display:block}
/* COMPOSE */
.compose-area{background:var(--surface);border-bottom:1px solid var(--border);padding:13px 52px 13px 17px;position:sticky;top:0;z-index:50;transition:all .3s ease;position:relative}
.compose-area[data-compose-collapsed="true"]{max-height:52px;overflow:visible;padding:10px 17px}
.compose-area[data-compose-collapsed="true"] .compose-inner{display:none}
.compose-collapse-btn{position:absolute;top:10px;right:10px;background:var(--surface2);border:1px solid var(--border);color:var(--text-2);width:28px;height:28px;border-radius:999px;cursor:pointer;display:grid;place-items:center;font-size:17px;line-height:1;z-index:120;transition:background .15s,color .15s,transform .15s,opacity .15s,border-color .15s;font-weight:700;padding:0;box-shadow:none;font-family:var(--mono);opacity:.45;transform:scale(.95)}
.compose-area:hover .compose-collapse-btn,.compose-area:focus-within .compose-collapse-btn,.compose-area[data-compose-collapsed="true"] .compose-collapse-btn{opacity:1;transform:scale(1)}
.compose-collapse-btn:hover{background:var(--primary-s);color:var(--primary);border-color:var(--primary)}
.compose-collapse-btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px;opacity:1;transform:scale(1)}
.compose-area[data-compose-collapsed="true"] .compose-collapse-btn{background:var(--primary);color:#fff;border-color:var(--primary)}
.compose-inner{display:flex;gap:11px}.compose-av{width:37px;height:37px;border-radius:50%;object-fit:cover;flex-shrink:0;background:var(--primary-s);margin-top:2px}.compose-body{flex:1;min-width:0}
.compose-ta{width:100%;border:none;outline:none;font-family:var(--font);font-size:.97rem;resize:vertical;color:var(--text);background:transparent;line-height:1.5;min-height:62px;max-height:320px}.compose-ta::placeholder{color:var(--text-3)}
.reply-ctx{display:flex;align-items:center;gap:6px;font-size:.78rem;color:var(--text-2);background:var(--primary-s);padding:5px 9px;border-radius:var(--rs);margin-bottom:6px}
.cancel-reply{background:none;border:none;color:var(--text-3);font-size:.72rem;margin-left:auto;padding:2px 4px;cursor:pointer}.cancel-reply:hover{color:var(--danger)}
.preview-area{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:8px}.preview-thumb{position:relative;width:72px;height:72px}.preview-thumb img{width:100%;height:100%;object-fit:cover;border-radius:var(--rs);border:1.5px solid var(--border)}.preview-rm{position:absolute;top:-5px;right:-5px;width:18px;height:18px;background:var(--danger);color:#fff;border:none;border-radius:50%;font-size:.65rem;display:flex;align-items:center;justify-content:center;cursor:pointer}
.image-assist{margin:0 0 8px 0;padding:7px 10px;border:1px dashed var(--border);border-radius:var(--rs);background:var(--surface2)}
.image-assist-head{font-size:.68rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3);margin-bottom:2px}
.image-assist-text{font-size:.78rem;color:var(--text-2);line-height:1.45}
.compose-footer{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;border-top:1px solid var(--border-l);padding-top:6px;margin-top:6px;column-gap:8px;row-gap:0}
.compose-tools{display:flex;align-items:center;gap:4px;min-width:0}
.compose-tool-icons{display:flex;align-items:center;gap:2px;flex-shrink:0}
.compose-tool-selects{display:flex;align-items:center;min-width:0}
.tool-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;color:var(--primary);cursor:pointer;transition:background .15s;border:none;background:none}.tool-btn:hover{background:var(--primary-s)}
.restriction-select{font-family:var(--font);font-size:.72rem;border:1.5px solid var(--border);border-radius:var(--rs);padding:4px 7px;color:var(--text-2);background:var(--surface);outline:none;cursor:pointer;transition:border-color .15s;min-width:0;width:100%;max-width:none}.restriction-select:focus{border-color:var(--primary)}
.compose-options-menu{position:relative}
.compose-options-summary{list-style:none;border:1.5px solid var(--border);border-radius:var(--rs);padding:5px 9px;font-size:.72rem;color:var(--text-2);background:var(--surface);cursor:pointer;user-select:none;line-height:1.2}
.compose-options-summary::-webkit-details-marker{display:none}
.compose-options-menu[open] .compose-options-summary{border-color:var(--primary);color:var(--primary);background:var(--primary-s)}
.compose-options-pop{position:absolute;top:calc(100% + 6px);left:0;z-index:140;display:grid;gap:4px;width:220px;padding:8px;border:1px solid var(--border);border-radius:var(--rs);background:var(--surface);box-shadow:var(--shadow)}
.compose-options-label{font-size:.68rem;color:var(--text-3);padding-left:2px}
.shortcut-key-input{width:34px;text-align:center;font-family:var(--font);font-size:.78rem;border:1.5px solid var(--border);border-radius:var(--rs);padding:4px 6px;color:var(--text-2);background:var(--surface);outline:none;transition:border-color .15s}
.shortcut-key-input:focus{border-color:var(--primary)}
.compose-right{display:flex;align-items:center;gap:6px;flex-shrink:0;justify-self:end;align-self:center;white-space:nowrap}.char-count{font-family:var(--mono);font-size:.76rem;color:var(--text-3)}.char-count.warn{color:var(--warn)}.char-count.danger{color:var(--danger)}
.btn-post{background:var(--primary);color:#fff;border:none;border-radius:var(--rf);padding:6px 14px;font-size:.84rem;font-weight:600;display:flex;align-items:center;gap:5px;transition:background .15s,transform .15s;cursor:pointer}.btn-post:hover{background:var(--primary-h)}.btn-post:active{transform:scale(.97)}.btn-post:disabled{opacity:.72;cursor:not-allowed}
.drafts-panel{background:var(--surface2);border:1px solid var(--border);border-radius:var(--r);margin-top:8px;overflow:hidden}.drafts-header{padding:8px 12px;font-size:.78rem;font-weight:600;color:var(--text-2);border-bottom:1px solid var(--border-l);text-transform:uppercase;letter-spacing:.04em}
.draft-item{padding:9px 12px;border-bottom:1px solid var(--border-l);display:flex;flex-direction:column;gap:3px}.draft-item:last-child{border-bottom:none}.draft-text{font-size:.84rem;color:var(--text)}.draft-time{font-size:.71rem;color:var(--text-3)}.draft-actions{display:flex;gap:5px;margin-top:2px}.draft-empty{padding:12px;color:var(--text-3);font-size:.84rem}
/* SECTION HEAD */
.section-head{display:flex;align-items:center;gap:9px;padding:12px 17px 9px;border-bottom:1px solid var(--border);background:var(--surface);position:relative;top:auto;z-index:20}
.section-title{font-size:.96rem;font-weight:700;letter-spacing:-.02em;flex:1}.refresh-btn{background:none;border:none;color:var(--text-3);padding:5px;border-radius:50%;display:flex;transition:color .15s,background .15s;cursor:pointer}.refresh-btn:hover{color:var(--primary);background:var(--primary-s)}
.sub-tabs{display:flex;gap:2px;flex:1}.sub-tab{background:none;border:none;padding:5px 13px;border-radius:var(--rf);font-family:var(--font);font-size:.83rem;font-weight:500;color:var(--text-2);transition:background .15s,color .15s;cursor:pointer}.sub-tab:hover{background:var(--primary-s);color:var(--primary)}.sub-tab.active{background:var(--primary-s);color:var(--primary);font-weight:600}
#home-pinned-edit{padding:4px 9px;font-size:.73rem}
/* FEED */
.feed{background:var(--surface)}.feed-spinner{display:flex;align-items:center;justify-content:center;flex-direction:column;padding:48px 20px;min-height:200px}.empty-state{padding:48px 24px;text-align:center;color:var(--text-3);line-height:1.8;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:240px}.empty-icon{font-size:3rem;margin-bottom:16px;display:block}.empty-state > div:last-child{max-width:320px;font-size:.9rem}
.feed-skeleton-list{padding:10px 14px}.skeleton-post-card{display:flex;gap:11px;padding:12px 0;border-bottom:1px solid var(--border-l)}.skeleton-post-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(90deg,var(--surface2),var(--border),var(--surface2));background-size:200% 100%;animation:shimmer 1.2s linear infinite}.skeleton-post-body{flex:1;display:flex;flex-direction:column;gap:8px}.skeleton-line{height:10px;border-radius:999px;background:linear-gradient(90deg,var(--surface2),var(--border),var(--surface2));background-size:200% 100%;animation:shimmer 1.2s linear infinite}.skeleton-line.w-40{width:40%}.skeleton-line.w-70{width:70%}.skeleton-line.w-90{width:90%}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
/* POST CARD */
.post-card{padding:13px 17px;border-bottom:1px solid var(--border-l);transition:background .15s;animation:fadeIn .3s ease}.post-card:hover{background:var(--surface2)}.post-card.thread-card{border-bottom:none;padding-bottom:4px}
.post-card-inner{display:flex;gap:11px}.post-left{display:flex;flex-direction:column;align-items:center;flex-shrink:0}
.post-avatar{width:41px;height:41px;border-radius:50%;object-fit:cover;background:var(--primary-s);cursor:pointer;flex-shrink:0}
.density-compact .post-card{padding:9px 13px}
.density-compact .post-card-inner{gap:8px}
.density-compact .post-avatar{width:34px;height:34px}
.density-compact .post-name{font-size:.82rem}
.density-compact .post-text{font-size:.86rem;line-height:1.45}
.density-compact .post-actions{margin-top:5px}
.thread-connector{width:2px;background:var(--border);flex:1;margin:4px auto 0;min-height:16px;border-radius:1px}.post-main{flex:1;min-width:0}
.repost-label{display:flex;align-items:center;gap:5px;font-size:.74rem;color:var(--text-3);margin-bottom:5px}
.reply-indicator{display:flex;align-items:center;gap:4px;font-size:.74rem;color:var(--text-3);margin-bottom:3px}
.post-header{display:flex;align-items:baseline;gap:5px;margin-bottom:3px;flex-wrap:wrap}.post-name{font-weight:600;font-size:.87rem;cursor:pointer}.post-name:hover{text-decoration:underline}.post-handle{font-size:.79rem;color:var(--text-3)}.post-time{font-size:.74rem;color:var(--text-3);margin-left:auto;white-space:nowrap}
.post-text{font-size:.9rem;line-height:1.55;color:var(--text);word-break:break-word;margin-bottom:9px;white-space:pre-wrap;max-width:var(--reading-max-ch,64ch)}.post-text a{color:var(--primary)}.post-text a:hover{text-decoration:underline}
.post-images{display:grid;gap:3px;margin-bottom:9px;border-radius:var(--rs);overflow:hidden;max-height:280px}.post-images.count-1{grid-template-columns:1fr}.post-images.count-2{grid-template-columns:1fr 1fr}.post-images.count-3{grid-template-columns:1fr 1fr;max-height:200px}.post-images.count-3 .img-item:first-child{grid-row:1/3}.post-images.count-4{grid-template-columns:1fr 1fr}.img-item{overflow:hidden;cursor:pointer}.img-item img{width:100%;height:100%;object-fit:cover;transition:transform .2s}.img-item:hover img{transform:scale(1.02)}
.post-images-blocked{display:flex;align-items:center;justify-content:center;min-height:88px;background:var(--surface2);border:1px dashed var(--border);border-radius:var(--rs)}
.post-images-blocked .load-images-btn{font-size:.78rem;padding:6px 12px}
/* QUOTE */
.quote-embed{border:1.5px solid var(--border);border-radius:var(--r);padding:10px 12px;margin-bottom:9px;background:var(--surface2);cursor:pointer;transition:background .15s}.quote-embed:hover{background:var(--bg)}
.quote-header{display:flex;align-items:center;gap:7px;margin-bottom:4px}.quote-avatar{width:20px;height:20px;border-radius:50%;object-fit:cover;background:var(--primary-s)}.quote-name{font-weight:600;font-size:.81rem;color:var(--text)}.quote-handle{font-size:.77rem;color:var(--text-3)}.quote-text{font-size:.85rem;color:var(--text);line-height:1.45;word-break:break-word}
.quote-compose{background:var(--surface2);border:1.5px solid var(--primary-s);border-radius:var(--r);padding:10px 12px;margin-top:8px}.quote-compose-ta{width:100%;border:none;outline:none;font-family:var(--font);font-size:.88rem;background:transparent;resize:none;color:var(--text);min-height:50px}.quote-compose-ta::placeholder{color:var(--text-3)}.quote-compose-footer{display:flex;gap:8px;align-items:center;margin-top:7px;justify-content:flex-end}
/* ACTIONS */
.post-actions{display:flex;gap:3px;flex-wrap:wrap;margin-top:2px}
.act-btn{display:inline-flex;align-items:center;gap:4px;background:none;border:none;color:var(--text-3);font-size:.79rem;padding:4px 7px;border-radius:var(--rf);transition:color .15s,background .15s;font-family:var(--font);text-decoration:none;cursor:pointer}
.act-btn:hover{background:var(--primary-s);color:var(--primary);text-decoration:none}.act-btn.danger:hover{background:var(--danger-s);color:var(--danger)}
.act-btn.active{color:var(--primary)}.like-btn.active{color:var(--danger)}.like-btn.active:hover{background:var(--danger-s);color:var(--danger)}
/* THREAD */
.replies-container{margin-top:4px;border-left:2px solid var(--border-l);margin-left:var(--thread-line-offset)}.no-replies{padding:10px 14px;font-size:.82rem;color:var(--text-3)}
.thread-children{border-left:2px solid var(--border-l);margin-left:var(--thread-line-offset)}.thread-more{padding:6px 14px}.show-more-replies-btn{background:none;border:none;color:var(--primary);font-family:var(--font);font-size:.81rem;font-weight:600;cursor:pointer;padding:4px 0}.show-more-replies-btn:hover{text-decoration:underline}
/* NOTIF */
.notif-card{display:flex;align-items:flex-start;gap:10px;padding:12px 17px;border-bottom:1px solid var(--border-l);transition:background .15s;animation:fadeIn .3s ease}.notif-card:hover{background:var(--surface2)}.notif-card.unread{background:var(--primary-s)}
.notif-avatar{width:33px;height:33px;border-radius:50%;object-fit:cover;flex-shrink:0;background:var(--primary-s);cursor:pointer}.notif-body{flex:1;min-width:0}.notif-text{font-size:.86rem;line-height:1.45;color:var(--text)}.notif-time{font-size:.72rem;color:var(--text-3);margin-top:2px}.notif-snippet{font-size:.79rem;color:var(--text-2);margin-top:3px;border-left:2px solid var(--border);padding-left:7px}.notif-icon-el{font-size:1.2rem;flex-shrink:0}.clickable-name{cursor:pointer}.clickable-name:hover{text-decoration:underline}
.notif-unread-label{display:inline-block;font-size:.68rem;font-weight:700;color:var(--primary);background:var(--primary-s);border:1px solid var(--primary);border-radius:999px;padding:1px 7px;margin-bottom:4px}
.notif-mark-read-btn{margin-top:7px;padding:4px 9px;font-size:.7rem}
.notif-actor{font-weight:700}
.notif-actors-toggle{background:none;border:none;color:var(--primary);font-family:var(--font);font-size:.78rem;font-weight:600;padding:0 0 0 4px;cursor:pointer}
.notif-actors-toggle:hover{text-decoration:underline}
/* USER CARD */
.user-card{display:flex;align-items:center;gap:10px;padding:12px 17px;border-bottom:1px solid var(--border-l);animation:fadeIn .3s ease;transition:background .15s}.user-card:hover{background:var(--surface2)}
.user-card-av{width:42px;height:42px;border-radius:50%;object-fit:cover;flex-shrink:0;background:var(--primary-s);cursor:pointer}.user-card-info{flex:1;min-width:0}.user-card-name{font-weight:600;font-size:.88rem;cursor:pointer}.user-card-name:hover{text-decoration:underline}.user-card-handle{font-size:.77rem;color:var(--text-3)}.user-card-desc{font-size:.8rem;color:var(--text-2);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.user-card-actions{display:flex;flex-direction:column;align-items:flex-end;gap:5px;flex-shrink:0}
.follow-toggle-btn{padding:5px 12px;border-radius:var(--rf);border:1.5px solid var(--primary);background:var(--primary);color:#fff;font-family:var(--font);font-size:.78rem;font-weight:600;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap;flex-shrink:0;min-width:96px}
.follow-toggle-btn.following{background:#fff;color:var(--primary)}.follow-toggle-btn.following:hover{background:var(--danger-s);border-color:var(--danger);color:var(--danger)}
.dm-start-btn{padding:5px 10px;border-radius:var(--rf);border:1.5px solid var(--border);background:var(--surface);color:var(--text-2);font-family:var(--font);font-size:.77rem;font-weight:600;cursor:pointer;transition:background .15s,color .15s,border-color .15s;white-space:nowrap;min-width:96px}
.dm-start-btn:hover{background:var(--primary-s);border-color:var(--primary);color:var(--primary)}
/* USER PROFILE PANEL */
.user-profile-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:400;display:flex;justify-content:flex-end;backdrop-filter:blur(3px)}.user-profile-drawer{width:480px;max-width:100%;background:var(--surface);height:100%;display:flex;flex-direction:column;overflow:hidden;animation:slideIn .25s ease;box-shadow:var(--shadow-l)}
.user-profile-bar{display:flex;align-items:center;gap:10px;padding:13px 16px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}
.icon-btn{background:none;border:none;color:var(--text-2);padding:6px;border-radius:50%;display:flex;align-items:center;transition:color .15s,background .15s;flex-shrink:0;cursor:pointer}.icon-btn:hover{color:var(--primary);background:var(--primary-s)}
.profile-panel{display:flex;flex-direction:column}
.profile-banner{height:148px;background:linear-gradient(135deg,#0085ff,#00c6a7);background-size:cover;background-position:center;flex-shrink:0}
.profile-panel-header{display:flex;gap:12px;padding:12px 16px 0;background:var(--surface);position:relative}.prof-avatar-lg{width:64px;height:64px;border-radius:50%;border:3px solid var(--surface);object-fit:cover;flex-shrink:0;margin-top:-30px;background:var(--primary-s)}
.prof-panel-meta{flex:1;min-width:0;padding-bottom:12px}.prof-panel-name{font-size:1rem;font-weight:700;letter-spacing:-.02em;margin-bottom:1px}.prof-panel-handle{font-size:.8rem;color:var(--text-3);margin-bottom:5px}.prof-panel-desc{font-size:.84rem;color:var(--text-2);line-height:1.5;margin-bottom:7px;white-space:pre-wrap}.prof-panel-stats{display:flex;gap:12px;font-size:.8rem;color:var(--text-2);flex-wrap:wrap}.prof-panel-stats strong{color:var(--text);font-weight:700}
/* SELF PROFILE */
.profile-header{display:flex;gap:13px;padding:13px 17px 0;background:var(--surface)}.prof-avatar{width:68px;height:68px;border-radius:50%;border:3px solid var(--surface);object-fit:cover;flex-shrink:0;margin-top:-33px;background:var(--primary-s)}
.profile-meta{flex:1;min-width:0;padding-bottom:13px}.prof-name{font-size:1.05rem;font-weight:700;letter-spacing:-.02em;margin-bottom:2px}.prof-handle{font-size:.81rem;color:var(--text-3);margin-bottom:5px}.prof-desc{font-size:.85rem;color:var(--text-2);line-height:1.5;margin-bottom:7px;white-space:pre-wrap}.prof-stats{display:flex;gap:13px;font-size:.8rem;color:var(--text-2);flex-wrap:wrap}.prof-stats strong{color:var(--text);font-weight:700}
.edit-profile-section{border-bottom:1px solid var(--border);background:var(--surface)}.edit-profile-toggle{display:block;padding:11px 17px;font-size:.87rem;font-weight:600;color:var(--primary);cursor:pointer;list-style:none;transition:background .15s}.edit-profile-toggle:hover{background:var(--primary-s)}.edit-profile-form{padding:15px 17px;background:var(--surface2);display:flex;flex-direction:column;gap:11px;border-top:1px solid var(--border-l)}
/* SEARCH */
.search-box-wrap{flex:1;display:flex;align-items:center;gap:7px;background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--rf);padding:7px 12px;transition:border-color .15s}.search-box-wrap:focus-within{border-color:var(--primary);background:var(--surface)}.search-box{flex:1;border:none;outline:none;background:transparent;font-family:var(--font);font-size:.92rem;color:var(--text)}
.search-clear-btn{width:22px;height:22px;border:none;background:var(--border-l);color:var(--text-3);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.73rem;transition:background .15s,color .15s}
.search-clear-btn:hover{background:var(--border);color:var(--text)}
.search-recent-wrap{padding:8px 16px 4px;background:var(--surface);border-bottom:1px solid var(--border-l)}
.search-recent-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:7px;font-size:.72rem;font-weight:700;letter-spacing:.05em;color:var(--text-3);text-transform:uppercase}
.search-recent-head .btn-sm{padding:3px 8px;font-size:.7rem}
.search-recent-list{display:flex;flex-wrap:wrap;gap:6px}
.search-chip{display:inline-flex;align-items:center;gap:4px;padding:5px 9px;border-radius:999px;border:1px solid var(--border);background:var(--surface2);font-size:.78rem;color:var(--text-2);cursor:pointer;transition:background .15s,border-color .15s,color .15s}
.search-chip:hover{background:var(--primary-s);border-color:var(--primary);color:var(--primary)}
.search-chip.smart{border-style:dashed}
.trend-category-tabs{display:flex;gap:6px;padding:0 16px 10px;background:var(--surface)}
.trend-category-tabs .btn-sm.active{background:var(--primary-s);border-color:var(--primary);color:var(--primary)}
.trend-card{padding:12px 17px;border-bottom:1px solid var(--border-l);background:var(--surface);display:flex;align-items:flex-start;justify-content:space-between;gap:10px;animation:fadeIn .25s ease}
.trend-main{display:flex;flex-direction:column;gap:3px;min-width:0}
.trend-tag{font-size:.92rem;font-weight:700;color:var(--text);word-break:break-word}
.trend-meta{font-size:.76rem;color:var(--text-3)}
/* DM */
.dm-tip{background:#fffbea;border-bottom:1px solid #f0d060;padding:9px 17px;font-size:.8rem;color:#856404;line-height:1.5}
.dm-convo-card{display:flex;align-items:center;gap:10px;padding:12px 17px;border-bottom:1px solid var(--border-l);cursor:pointer;transition:background .15s;animation:fadeIn .3s ease}.dm-convo-card:hover{background:var(--surface2)}
.dm-avatar{width:42px;height:42px;border-radius:50%;object-fit:cover;flex-shrink:0;background:var(--primary-s)}.dm-info{flex:1;min-width:0}.dm-name{font-weight:600;font-size:.87rem}.dm-preview{font-size:.79rem;color:var(--text-3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dm-badge{background:var(--primary);color:#fff;font-size:.69rem;font-weight:700;padding:1px 5px;border-radius:var(--rf);flex-shrink:0}
.dm-chat-panel{position:fixed;top:0;right:0;bottom:0;width:400px;background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column;z-index:300;box-shadow:var(--shadow-l);animation:slideIn .2s ease}.dm-chat-header{display:flex;align-items:center;gap:10px;padding:13px 15px;border-bottom:1px solid var(--border);font-weight:600;flex-shrink:0}.dm-messages{flex:1;overflow-y:auto;padding:13px 15px;display:flex;flex-direction:column;gap:7px}.dm-msg{display:flex;flex-direction:column;max-width:76%}.dm-msg.mine{align-self:flex-end;align-items:flex-end}.dm-msg.theirs{align-self:flex-start}.dm-bubble{padding:8px 12px;border-radius:15px;font-size:.88rem;line-height:1.45;word-break:break-word}.dm-msg.mine .dm-bubble{background:var(--primary);color:#fff;border-bottom-right-radius:3px}.dm-msg.theirs .dm-bubble{background:var(--surface2);color:var(--text);border:1px solid var(--border);border-bottom-left-radius:3px}.dm-msg-time{font-size:.69rem;color:var(--text-3);margin-top:2px}.dm-input-area{padding:9px 13px;border-top:1px solid var(--border);display:flex;gap:7px;align-items:flex-end;flex-shrink:0}.dm-input{flex:1;border:1.5px solid var(--border);border-radius:var(--r);padding:8px 11px;font-family:var(--font);font-size:.88rem;resize:none;outline:none;background:var(--surface2);color:var(--text);transition:border-color .15s}.dm-input:focus{border-color:var(--primary);background:var(--surface)}
/* LISTS */
.list-card{display:flex;align-items:center;gap:11px;padding:12px 17px;border-bottom:1px solid var(--border-l);transition:background .15s;animation:fadeIn .3s ease}.list-card:hover{background:var(--surface2)}.list-card-info{flex:1;min-width:0}.list-card-name{font-weight:600;font-size:.88rem}.list-card-desc{font-size:.79rem;color:var(--text-2)}.list-card-count{font-size:.74rem;color:var(--text-3)}
/* BUTTONS */
.btn-sm{padding:5px 11px;border-radius:var(--rs);border:1.5px solid var(--border);background:var(--surface);font-family:var(--font);font-size:.79rem;font-weight:500;color:var(--text-2);cursor:pointer;transition:background .15s,color .15s;text-decoration:none;display:inline-flex;align-items:center}.btn-sm:hover{background:var(--bg);text-decoration:none}.btn-sm.danger{border-color:var(--danger);color:var(--danger)}.btn-sm.danger:hover{background:var(--danger-s)}
.btn-modal-cancel{padding:8px 15px;border-radius:var(--rs);border:1.5px solid var(--border);background:none;font-family:var(--font);font-size:.85rem;font-weight:500;color:var(--text-2);cursor:pointer;transition:background .15s}.btn-modal-cancel:hover{background:var(--bg)}
.load-more-btn{width:100%;padding:12px;background:none;border:none;border-top:1px solid var(--border-l);color:var(--primary);font-family:var(--font);font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s}.load-more-btn:hover{background:var(--primary-s)}
.quick-post-card{max-width:520px;width:min(520px,calc(100vw - 24px))}
.quick-post-tools{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:8px}
.quick-post-footer{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:10px}
.quick-post-actions{display:flex;gap:8px;align-items:center}
/* RIGHT MINI PANEL */
.right-mini-panel{position:fixed;right:16px;bottom:22px;z-index:220;width:min(310px,calc(100vw - 22px));max-height:76vh;overflow:auto;background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:10px 11px}
.right-mini-head{font-size:.76rem;font-weight:700;color:var(--text-2);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;position:sticky;top:0;background:var(--surface);padding-bottom:6px;display:flex;align-items:center;justify-content:space-between;gap:8px}
.right-mini-head-actions{display:flex;gap:6px}
.right-mini-head-actions .btn-sm{padding:3px 8px;font-size:.7rem}
.right-mini-panel.collapsed{width:190px;max-height:none;overflow:visible}
.right-mini-panel.collapsed .right-widget{display:none}
.right-mini-panel.collapsed .right-mini-head{margin-bottom:0;padding-bottom:0}
.right-mini-launch{position:fixed;right:16px;bottom:22px;z-index:221;width:42px;height:42px;border-radius:50%;border:1px solid var(--border);background:var(--surface);color:var(--text-2);font-size:18px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);transition:transform .15s,background .15s,color .15s}
.right-mini-launch:hover{background:var(--surface2);color:var(--primary)}
.right-mini-launch:active{transform:scale(.96)}
.right-widget{border:1px solid var(--border);border-radius:10px;padding:8px;margin-bottom:8px;background:var(--surface2)}
.right-widget-title{font-size:.73rem;font-weight:700;color:var(--text-2);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}
.right-toggle{display:flex;align-items:center;gap:8px;font-size:.79rem;color:var(--text-2);margin:3px 0}
.right-toggle input{accent-color:var(--primary)}
.right-mini-note{width:100%;border:1.5px solid var(--border);border-radius:10px;padding:8px 9px;font-family:var(--font);font-size:.84rem;resize:vertical;min-height:82px;outline:none;background:var(--surface2)}
.right-mini-note:focus{border-color:var(--primary);background:var(--surface)}
.right-mini-actions{display:flex;gap:6px;margin-top:8px}
.right-mini-actions.wrap{flex-wrap:wrap}
.right-mini-list{display:flex;flex-direction:column;gap:6px;margin-top:8px;max-height:160px;overflow:auto}
.quick-note-item{display:flex;gap:6px;align-items:center;background:var(--surface2);border:1px solid var(--border);border-radius:9px;padding:6px}
.quick-note-text{flex:1;font-size:.76rem;color:var(--text-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.quick-note-use{padding:4px 8px;font-size:.72rem}
.quick-note-delete{padding:4px 8px;font-size:.72rem;color:var(--danger);border-color:var(--danger)}
.right-mini-status{margin-top:7px;font-size:.72rem;color:var(--text-3)}
.right-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.right-stats-grid .stat{border:1px solid var(--border);border-radius:8px;padding:6px 7px;background:var(--surface)}
.right-stats-grid .stat span{display:block;font-size:.68rem;color:var(--text-3);margin-bottom:2px}
.right-stats-grid .stat strong{font-size:.9rem;color:var(--text)}
.right-range-tabs{display:flex;gap:6px;margin-bottom:8px}
.right-range-tabs .btn-sm{padding:4px 10px;font-size:.73rem}
.right-range-tabs .btn-sm.active{background:var(--primary-s);color:var(--primary);border-color:var(--primary)}
.time-dist-wrap{margin-top:8px;border:1px solid var(--border);border-radius:8px;padding:7px;background:var(--surface)}
.time-dist-head{font-size:.68rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3);margin-bottom:6px}
.time-dist-list{display:flex;flex-direction:column;gap:5px}
.time-dist-row{display:grid;grid-template-columns:78px 1fr 34px;align-items:center;gap:6px}
.time-dist-label{font-size:.72rem;color:var(--text-2)}
.time-dist-bar{height:7px;border-radius:999px;background:var(--surface2);overflow:hidden;border:1px solid var(--border-l)}
.time-dist-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--primary),#4ec1ff);width:0}
.time-dist-value{font-size:.72rem;color:var(--text-2);text-align:right}
[data-theme='dark'] .right-widget{background:#122133;border-color:#3a526b}
[data-theme='dark'] .quick-note-item{background:#132334}
[data-theme='dark'] .right-stats-grid .stat{background:#0f1b28}
[data-theme='dark'] .time-dist-wrap{background:#0f1b28}
/* TOAST */
.toast-container{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;gap:7px;z-index:9999;pointer-events:none}.toast{background:#1a2332;color:#fff;padding:9px 17px;border-radius:var(--rf);font-size:.86rem;font-weight:500;pointer-events:auto;animation:toastIn .25s ease;box-shadow:var(--shadow-l);max-width:360px;text-align:center;line-height:1.5}.toast.success{background:#0a6640}.toast.error{background:#9b1c3a}.toast.info{background:#1a4d80}
/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:500}.modal-card{background:var(--surface);border-radius:16px;padding:26px 30px;width:100%;max-width:340px;box-shadow:var(--shadow-l);animation:fadeUp .2s ease}.modal-title{font-size:1rem;font-weight:700;margin-bottom:7px}.modal-body{font-size:.86rem;color:var(--text-2);margin-bottom:20px}.modal-actions{display:flex;gap:9px;justify-content:flex-end}.btn-modal-danger{padding:8px 16px;border-radius:var(--rs);border:none;background:var(--danger);color:#fff;font-family:var(--font);font-size:.86rem;font-weight:600;cursor:pointer;transition:background .15s}.btn-modal-danger:hover{background:#c01e52}
.shortcuts-card{max-width:520px}
.shortcuts-list{display:flex;flex-direction:column;gap:7px;margin-top:8px}
.shortcut-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:7px 10px;border:1px solid var(--border-l);border-radius:9px;background:var(--surface2);font-size:.82rem;color:var(--text-2)}
.shortcut-row strong{font-family:var(--mono);font-size:.78rem;color:var(--text)}
/* IMAGE VIEWER */
.cursor-pointer{cursor:pointer}
.image-viewer-card{position:relative;max-width:96vw;max-height:92vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px;background:transparent;box-shadow:none;width:auto}
.image-viewer-close{position:absolute;top:12px;right:12px;width:34px;height:34px;border-radius:50%;border:none;background:rgba(0,0,0,.6);color:#fff;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;z-index:10}
.image-viewer-close:hover{background:rgba(0,0,0,.8)}
.image-viewer-container{max-width:96vw;max-height:82vh;display:flex;align-items:center;justify-content:center;overflow:hidden;border-radius:12px;background:transparent}
.image-viewer-img{max-width:min(96vw,1400px);max-height:82vh;width:auto;height:auto;object-fit:contain;border-radius:12px;transition:transform .2s ease;cursor:zoom-in;user-select:none;image-rendering:auto}
.image-viewer-nav{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:8px;font-size:.82rem;color:#d7e2ef}
.image-viewer-nav.hidden{display:none}
.image-viewer-btn{background:rgba(0,0,0,.4);border:none;color:#fff;width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:background .15s}
.image-viewer-btn:hover{background:rgba(0,0,0,.6)}
.image-viewer-counter{min-width:60px;text-align:center;font-family:var(--mono);font-size:.8rem;color:#fff;background:rgba(0,0,0,.4);padding:4px 8px;border-radius:20px}
/* SETTINGS */
.settings-body{padding:8px 0}.settings-section{margin-bottom:4px}.settings-section-title{font-size:.74rem;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;padding:11px 17px 5px}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:11px;padding:12px 17px;border-bottom:1px solid var(--border-l);background:var(--surface);transition:background .15s}.settings-row:hover{background:var(--surface2)}.settings-row-label{font-size:.88rem;font-weight:500;color:var(--text);margin-bottom:2px}.settings-row-desc{font-size:.79rem;color:var(--text-3)}
.main-width-resizer{position:fixed;top:0;bottom:0;left:calc(var(--sw) + var(--main-content-max) - 3px);width:10px;background:transparent;cursor:ew-resize;z-index:180}
.main-width-resizer::after{content:'';position:absolute;top:50%;left:3px;transform:translateY(-50%);width:3px;height:80px;border-radius:999px;background:var(--border)}
.main-width-resizer:hover::after{background:var(--primary)}
.main-width-resizer.dragging::after{background:var(--primary);height:120px}
.mobile-bottom-nav{display:none}
.mobile-nav-item{border:none;background:transparent;color:var(--text-2);font-family:var(--font);font-size:.75rem;font-weight:600;padding:8px 4px;border-radius:8px;min-height:42px}
.mobile-nav-item.active{color:var(--primary);background:var(--primary-s)}
@media(max-width:768){.sidebar{width:0;padding:0;border-right:none}.sidebar-logo,.sidebar-nav,.sidebar-post-btn,.sidebar-bottom{display:none}.main-content{margin-left:0;padding-bottom:72px}.mobile-bottom-nav{position:fixed;left:8px;right:8px;bottom:8px;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:6px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:6px;z-index:260;box-shadow:var(--shadow)}}
/* 他人プロフィールパネル - クラス名エイリアス */
.user-profile-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.4); backdrop-filter: blur(4px); z-index: 300; display: flex; justify-content: flex-end; }
.user-profile-drawer { width: min(460px, 100vw); background: #fff; display: flex; flex-direction: column; height: 100%; overflow: hidden; box-shadow: 0 8px 30px rgba(0,0,0,.14); animation: slideIn .25s ease; }
.user-profile-bar { display: flex; align-items: center; gap: 10px; padding: 12px 14px; border-bottom: 1px solid #e1e4e8; flex-shrink: 0; }

/* スレッド縦線 - クラス名エイリアス */
.thread-connector { width: 2px; background: #e1e4e8; flex: 1; margin-top: 4px; min-height: 20px; border-radius: 1px; }

/* overlay-panel（リストフィード） */
.overlay-panel { position: fixed; top: 0; left: 248px; bottom: 0; width: min(680px, calc(100vw - 248px)); background: #fff; z-index: 150; overflow-y: auto; border-right: 1px solid #e1e4e8; box-shadow: 0 8px 30px rgba(0,0,0,.14); }

/* TOUCH TARGET + ACCESSIBILITY */
.tool-btn,.icon-btn,.nav-item{min-height:44px;min-width:44px}
.btn-sm{min-height:36px;padding:8px 12px}
.form-input,.compose-ta,.dm-input,.right-mini-note{min-height:44px}
button:focus-visible,a:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:2px solid var(--primary);outline-offset:2px}
.post-avatar,.user-avatar,.quote-avatar,.notif-avatar,.user-card-av,.dm-avatar{cursor:pointer;transition:transform .15s,opacity .15s}
.post-avatar:hover,.user-avatar:hover,.quote-avatar:hover,.notif-avatar:hover,.user-card-av:hover,.dm-avatar:hover{transform:scale(1.05);opacity:.95}
/* RESPONSIVE TABLET (768px-1023px) */
@media(max-width:1100px){.right-mini-panel{width:min(248px,calc(100vw - 18px));max-height:70vh}}
@media(max-width:900px){:root{--sw:58px}.sidebar-logo span,.nav-item span,.user-info{display:none}.nav-item{justify-content:center;padding:10px;min-height:44px;min-width:44px}.sidebar-post-btn{width:44px;height:44px;padding:0;font-size:0;line-height:0;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:8px auto}.sidebar-post-btn::before{content:'✎';font-size:18px;line-height:1}.sidebar-bottom{justify-content:center;flex-wrap:wrap}.main-content{max-width:100%}.main-width-resizer{display:none!important}.dm-chat-panel{width:100%;left:0}.overlay-panel{left:var(--sw)}.user-profile-drawer{width:100%}.right-mini-panel{right:10px;bottom:12px}.right-mini-launch{right:10px;bottom:12px}.compose-ta{font-size:16px}.form-input{font-size:16px}.modal-card{max-width:90vw;padding:20px 22px}.toast{font-size:.9rem;padding:11px 15px}}
/* RESPONSIVE MOBILE (480px-767px) */
@media(max-width:768px){:root{--sw:56px;--r:10px;--rs:7px;--rf:999px;--thread-line-offset:31px}html{font-size:14px}body{min-height:100vh;min-height:100dvh}.sidebar{width:var(--sw);padding:12px 6px}.sidebar-logo span{display:none}.sidebar-nav{gap:1px}.nav-item{padding:8px;font-size:0;justify-content:center;min-height:44px}.nav-item span{display:none}.nav-item svg{width:20px;height:20px}.nav-item .badge{margin:0;position:absolute;top:2px;right:4px;min-width:20px;font-size:.6rem}.sidebar-post-btn{width:40px;height:40px;margin:6px auto}.sidebar-bottom{gap:5px;flex-direction:column}.user-avatar{width:28px;height:28px}.user-info,.logout-btn{display:none}.main-content{margin-left:var(--sw);max-width:100%}.compose-area{padding:10px 12px}.compose-inner{gap:9px}.compose-av{width:32px;height:32px;margin-top:1px}.compose-ta{font-size:16px;min-height:50px;max-height:240px}.compose-footer{flex-direction:column;align-items:stretch;gap:8px;padding-top:6px}.compose-right{justify-content:flex-end;align-self:flex-end}.btn-post{width:auto;min-width:112px;padding:9px 12px}.post-card{padding:11px 13px}.post-card-inner{gap:9px}.post-avatar{width:36px;height:36px}.post-header{flex-wrap:wrap}.post-time{margin-left:0;margin-top:2px;width:100%}.post-images{max-height:200px}.post-text{font-size:.88rem}.section-head{top:auto;position:relative;z-index:35;padding:10px 12px 8px;font-size:.9rem}.sub-tab{padding:6px 10px;font-size:.75rem}.notif-card{padding:10px 12px;gap:9px}.notif-avatar{width:32px;height:32px}.user-card{padding:10px 12px}.user-card-av{width:36px;height:36px}.profile-banner{height:118px}.profile-header{gap:10px;padding:10px 12px 0}.prof-avatar{width:56px;height:56px;margin-top:-26px;border-width:2px}.profile-meta{padding-bottom:10px}.prof-name{font-size:.95rem}.prof-stats{gap:10px;font-size:.75rem}.edit-profile-toggle{padding:9px 12px;font-size:.83rem}.dm-convo-card{padding:10px 12px}.dm-info{min-width:0}.dm-name{font-size:.83rem}.dm-preview{font-size:.75rem}.dm-chat-panel{width:100%;left:0;right:0}.dm-messages{padding:10px 12px;gap:6px}.dm-bubble{padding:7px 10px;font-size:.84rem}.dm-input-area{padding:8px 10px;gap:5px}.dm-input{font-size:16px;padding:7px 9px}.modal-overlay{z-index:500}.modal-card{width:calc(100% - 20px);max-width:320px;padding:18px 20px;border-radius:12px}.modal-title{font-size:.95rem}.modal-body{font-size:.82rem;margin-bottom:16px}.modal-actions{gap:7px}.btn-modal-cancel,.btn-modal-danger{padding:7px 14px;font-size:.82rem}.search-box{font-size:.88rem;line-height:1.4}.search-chip{padding:4px 8px;font-size:.73rem}.trend-card{padding:10px 12px;gap:8px}.trend-tag{font-size:.86rem}.trend-meta{font-size:.72rem}.right-mini-panel{display:none!important}.right-mini-launch{width:44px;height:44px;right:12px;bottom:14px}.image-viewer-btn{width:40px;height:40px}.image-viewer-counter{font-size:.75rem;padding:3px 7px}.user-profile-overlay{z-index:300}.user-profile-drawer{width:100%;animation:slideIn .25s ease}.profile-panel-header{padding:10px 12px 0}.prof-avatar-lg{width:56px;height:56px;margin-top:-25px}.prof-panel-name{font-size:.95rem}.prof-panel-handle{font-size:.75rem}.prof-panel-stats{gap:9px;font-size:.75rem}.edit-profile-section,.edit-profile-form{padding:10px 12px}.toast{max-width:calc(100% - 20px);font-size:.83rem;padding:9px 14px;bottom:14px;left:10px;right:10px;transform:none}.toast-container{bottom:0;left:0;right:0;width:100%;justify-content:flex-end}.quick-post-card{max-width:100%}.shortcuts-row{padding:6px 9px;font-size:.78rem}.right-toggle input{cursor:pointer;width:18px;height:18px}.time-dist-wrap{padding:6px}.time-dist-label{font-size:.68rem}.time-dist-row{grid-template-columns:60px 1fr 30px;gap:5px}.right-range-tabs{gap:5px}.right-range-tabs .btn-sm{padding:3px 9px;font-size:.7rem}}

@media(max-width:768px){.compose-footer{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;column-gap:6px;row-gap:0;padding-top:6px}.compose-tools{display:flex;align-items:center;gap:3px;min-width:0}.compose-tool-icons{display:flex;align-items:center;gap:1px}.compose-tool-selects{display:flex;align-items:center}.compose-right{justify-content:flex-end;align-self:center}.compose-options-summary{padding:5px 7px;font-size:.69rem}.compose-options-pop{left:auto;right:0;width:198px}.btn-post{min-width:96px;padding:6px 10px}}
/* RESPONSIVE SMALL MOBILE (< 480px) */
@media(max-width:479px){:root{--sw:50px;--r:9px;--rs:6px;--thread-line-offset:27px}html{font-size:13px}.sidebar{width:var(--sw);padding:10px 4px}.nav-item{padding:6px;min-height:40px}.sidebar-post-btn{width:36px;height:36px;margin:5px auto}.sidebar-post-btn::before{font-size:16px}.compose-inner{display:flex;gap:7px}.compose-av{width:28px;height:28px}.compose-ta{font-size:16px;min-height:45px;line-height:1.4}.form-input,.compose-ta,.dm-input{font-size:16px}.btn-post{padding:8px 11px;font-size:.81rem}.post-card{padding:9px 11px}.post-avatar{width:32px;height:32px}.post-text{font-size:.85rem;line-height:1.5}.post-name{font-size:.82rem}.post-handle{font-size:.74rem}.post-time{font-size:.7rem}.post-images{max-height:160px}.quote-avatar{width:18px;height:18px}.quote-name{font-size:.77rem}.quote-text{font-size:.82rem}.modal-card{width:calc(100% - 16px);max-width:310px;padding:16px 18px;border-radius:10px}.modal-title{font-size:.9rem;margin-bottom:6px}.modal-body{font-size:.8rem;margin-bottom:14px}.btn-modal-cancel,.btn-modal-danger{padding:6px 12px;font-size:.78rem}.profile-header{padding:9px 10px 0;gap:9px}.prof-avatar{width:48px;height:48px;margin-top:-22px}.prof-name{font-size:.9rem}.prof-handle{font-size:.72rem}.prof-stats{gap:8px;font-size:.7rem}.image-viewer-btn{width:36px;height:36px;font-size:16px}.image-viewer-counter{font-size:.7rem;padding:2px 6px;min-width:55px}.dm-chat-panel{width:100%}.dm-messages{padding:8px 10px}.dm-bubble{padding:6px 9px;font-size:.81rem}.right-mini-launch{width:40px;height:40px;right:10px;bottom:12px}.right-mini-panel{display:none!important}.toast-container{bottom:0;left:0;right:0;width:100%}.toast{max-width:calc(100% - 16px);font-size:.8rem;padding:8px 12px;border-radius:var(--rs)}.search-chip{padding:3px 7px;font-size:.7rem}.btn-sm{padding:6px 10px;font-size:.75rem}.trend-card{padding:9px 10px}.trend-tag{font-size:.83rem}.trend-meta{font-size:.69rem}.settings-row{padding:10px 11px;gap:9px}.settings-row-label{font-size:.83rem}.settings-row-desc{font-size:.75rem}}
/* DARK MODE ENHANCEMENTS */
[data-theme='dark'] button:focus-visible{outline-color:#32a6ff}
[data-theme='dark'] .post-avatar:hover,[data-theme='dark'] .user-avatar:hover,[data-theme='dark'] .notif-avatar:hover{opacity:1}
/* LANDSCAPE MODE */
@media(max-height:600px){.compose-area{padding:8px 12px}.compose-ta{min-height:40px;max-height:120px}.section-head{padding:8px 12px}.post-card{padding:9px 12px}.post-text{margin-bottom:6px}.profile-banner{height:96px}.image-viewer-card{max-height:90vh}}
