:root{--bg: #0e0f11;--text: #e8eaed;--accent: #6ee7b7;--danger: #ff6b6b;--surface: #14171b;--surface-2: #1b1f24;--line: #232830;--line-soft: rgba(255,255,255,.04);--text-mid: #aab2bb;--text-dim: #6b727b;--accent-soft: rgba(110,231,183,.12);--accent-deep: #2d8d63;--accent-on: #0b1f14;--accent-tint-strong: rgba(110,231,183,.35);--accent-tint-mid: rgba(110,231,183,.15);--accent-tint-soft: rgba(110,231,183,.08);--accent-tint-faint: rgba(110,231,183,.04);--gold: #d4a872;--gold-soft: rgba(212,168,114,.14);--danger-soft: rgba(255,107,107,.12);--danger-strong: rgba(255,107,107,.4);--header-bg: rgba(14,15,17,.6);--nav-bg: rgba(15,16,19,.9);--modal-bg: rgba(8,9,11,.7);--scrim: rgba(0,0,0,.55);--scrim-strong: rgba(0,0,0,.85);--image-overlay: rgba(0,0,0,.65);--elevation-1: 0 1px 2px rgba(0,0,0,.4);--glow-accent: 0 0 12px var(--accent-soft);--ease: cubic-bezier(.22,.61,.36,1);--app-max: 840px;--sidebar-w: 248px;--card: var(--surface);--muted: var(--text-mid);--border: var(--line)}[data-theme=light]{--bg: #f6f7f9;--text: #111418;--accent: #16a874;--danger: #dc2626;--surface: #ffffff;--surface-2: #f0f2f5;--line: #e3e7eb;--line-soft: rgba(0,0,0,.05);--text-mid: #4a525c;--text-dim: #7a828b;--accent-soft: rgba(22,168,116,.1);--accent-deep: #0d7a52;--accent-on: #ffffff;--accent-tint-strong: rgba(22,168,116,.3);--accent-tint-mid: rgba(22,168,116,.12);--accent-tint-soft: rgba(22,168,116,.06);--accent-tint-faint: rgba(22,168,116,.03);--gold: #9a6a2a;--gold-soft: rgba(154,106,42,.1);--danger-soft: rgba(220,38,38,.08);--danger-strong: rgba(220,38,38,.3);--header-bg: rgba(255,255,255,.75);--nav-bg: rgba(255,255,255,.92);--modal-bg: rgba(255,255,255,.92);--scrim: rgba(0,0,0,.45);--scrim-strong: rgba(0,0,0,.65);--image-overlay: rgba(0,0,0,.55);--elevation-1: 0 1px 3px rgba(15,23,42,.08);--glow-accent: 0 1px 4px rgba(22,168,116,.18)}*{box-sizing:border-box}html,body,#root{height:100%;background:var(--bg);color:var(--text);font-family:Pretendard,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Apple SD Gothic Neo,Noto Sans KR,Malgun Gothic,sans-serif}body:before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;background:radial-gradient(60% 50% at 12% 0%,rgba(110,231,183,.1),transparent 70%),radial-gradient(55% 55% at 100% 100%,rgba(45,141,99,.14),transparent 70%),radial-gradient(40% 40% at 85% 8%,rgba(110,231,183,.05),transparent 70%)}[data-theme=light] body:before{background:radial-gradient(60% 50% at 12% 0%,rgba(22,168,116,.08),transparent 70%),radial-gradient(55% 55% at 100% 100%,rgba(13,122,82,.07),transparent 70%),radial-gradient(40% 40% at 85% 8%,rgba(212,168,114,.06),transparent 70%)}a{color:inherit;text-decoration:none}.app-shell{max-width:var(--app-max);margin:0 auto}.desktop-sidebar{display:none}.container{padding:12px 12px calc(80px + env(safe-area-inset-bottom));max-width:840px;margin:0 auto}.header{position:sticky;top:0;z-index:10;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:var(--header-bg);border-bottom:1px solid var(--border)}.header-inner{padding:env(safe-area-inset-top) 12px 10px;display:flex;align-items:center;gap:10px}.header-spacer{flex:1}.brand-word{display:inline-flex;align-items:center;gap:10px;font-weight:800;font-size:18px;letter-spacing:-.02em;color:var(--text)}.brand-word .brand-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 14px var(--accent)}.profile-pill{display:inline-flex;align-items:center;gap:8px;padding:4px 10px 4px 4px;border-radius:999px;background:var(--surface-2);border:1px solid var(--border);color:var(--text);font-size:12px;font-weight:600}.profile-avatar{width:26px;height:26px;border-radius:999px;object-fit:cover}.profile-name{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.badge{font-size:12px;padding:4px 8px;border:1px solid var(--border);border-radius:999px;color:var(--muted)}.grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media(min-width:560px){.grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:840px){.grid{grid-template-columns:repeat(4,1fr)}}.card{background:var(--card);border:1px solid var(--border);border-radius:14px;overflow:hidden}.card img{width:100%;height:140px;object-fit:cover;display:block}.card-body{padding:10px}.card-title{font-weight:700;font-size:15px}.card-sub{font-size:12px;color:var(--muted);margin-top:4px}.events-list{display:grid;gap:12px;padding:12px 12px calc(80px + env(safe-area-inset-bottom))}.event-row{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:12px;text-decoration:none;color:inherit;transition:border-color .18s var(--ease),transform .18s var(--ease)}.event-row:hover{border-color:var(--text-dim);transform:translateY(-1px)}.event-row-body{flex:1;min-width:0;display:grid;gap:6px}.event-row-name{font-size:15px;font-weight:700;color:var(--text);line-height:1.35;word-break:keep-all}.event-row-date{font-size:12px;color:var(--text-mid)}.event-row-thumb{flex:none;width:84px;height:84px;border-radius:12px;overflow:hidden;background:var(--surface-2)}.event-row-thumb img,.event-row-thumb .safe-image-fallback{width:100%;height:100%;object-fit:cover;display:block}.event-status{width:fit-content;display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:3px 8px;border-radius:999px;background:var(--surface-2);color:var(--text-mid);border:1px solid var(--line)}.event-status:before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor}.event-status.active{background:var(--accent-soft);color:var(--accent);border-color:var(--accent-tint-strong)}.event-status.upcoming{background:var(--gold-soft);color:var(--gold);border-color:#d4a87273}.event-status.ended{color:var(--text-dim)}.tabs{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;margin:10px 0}.tab{white-space:nowrap;padding:8px 12px;border-radius:999px;border:1px solid var(--line);background:var(--surface-2);color:var(--text-mid);font-size:13px;cursor:pointer;transition:color .18s var(--ease),border-color .18s var(--ease)}.tab:hover{color:var(--text);border-color:var(--text-dim)}.tab.active{color:var(--bg);background:var(--accent);border-color:transparent;font-weight:700}.tab-muted{opacity:.55}.bottom-nav{position:fixed;left:0;right:0;bottom:0;padding:10px max(12px,env(safe-area-inset-left)) calc(10px + env(safe-area-inset-bottom));background:var(--nav-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid var(--border)}.bottom-nav ul{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;list-style:none;margin:0;padding:0}.bottom-nav a{position:relative;display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 0;font-size:11px;font-weight:600;color:var(--text-dim);text-decoration:none;transition:color .18s var(--ease)}.bottom-nav a:hover{color:var(--text-mid)}.bottom-nav a.active{color:var(--accent);font-weight:700}.bottom-nav a.active:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:28px;height:2px;background:var(--accent);border-radius:2px;box-shadow:0 0 10px var(--accent)}.bottom-nav a svg{width:20px;height:20px;stroke-width:1.8;fill:none;stroke:currentColor}.button{border:1px solid var(--border);background:var(--surface-2);color:var(--text);padding:10px 12px;border-radius:10px;font-weight:600}.button.ghost{background:transparent;color:var(--muted)}.heart{color:var(--danger)}.home-section{margin-top:16px}.section-title{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.section-actions{display:flex;gap:8px}.section-title h2{margin:2px 0 0;font-size:18px;font-weight:700}.section-kicker{font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.14em;font-weight:700}.section-link{font-size:12px;color:var(--accent);font-weight:600;transition:opacity .18s var(--ease)}.section-link:hover{opacity:.8}.section-link.report-link{color:var(--danger)}.event-strip{display:flex;gap:12px;overflow-x:auto;padding:4px 2px 10px;scroll-snap-type:x mandatory}.event-strip-card{scroll-snap-align:start;min-width:220px;flex:0 0 78%;max-width:320px;background:var(--surface);border:1px solid var(--line);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;color:var(--text);transition:border-color .18s var(--ease),transform .18s var(--ease)}.event-strip-card:hover{border-color:var(--accent-tint-strong);transform:translateY(-2px)}.event-strip-image-wrap{overflow:hidden}.event-strip-image{width:100%;height:120px;object-fit:cover;display:block;transition:transform .5s var(--ease)}.event-strip-card:hover .event-strip-image{transform:scale(1.03)}.event-strip-body{padding:10px 12px 12px}.event-strip-kicker{display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:6px}.event-strip-kicker:before{content:"";width:4px;height:4px;border-radius:50%;background:var(--gold)}.event-strip-title{font-size:14px;font-weight:700;line-height:1.35}.event-strip-date{margin-top:4px;font-size:12px;color:var(--text-dim)}.calendar{background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:14px}.calendar-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.calendar-nav{display:flex;gap:6px}.calendar-nav-button{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line);background:var(--surface-2);color:var(--text-mid);border-radius:999px;cursor:pointer;transition:color .18s var(--ease),border-color .18s var(--ease)}.calendar-nav-button:hover{color:var(--text);border-color:var(--text-dim)}.calendar-nav-button svg{width:16px;height:16px;stroke-width:1.8;fill:none;stroke:currentColor}.calendar-title{font-size:18px;font-weight:700;color:var(--text)}.calendar-hint{font-size:11px;color:var(--text-dim)}.calendar-week{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;text-align:center;font-size:11px;color:var(--text-dim);letter-spacing:.08em;margin-bottom:6px}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;text-align:center}.calendar-cell{position:relative;min-height:60px;border-radius:12px;border:1px solid var(--line-soft);background:var(--surface-2);padding:6px 8px;font-size:13px;color:var(--text-mid)}.calendar-cell-label{position:absolute;top:6px;left:8px;font-size:13px;line-height:1}.calendar-cell.today{border-color:var(--accent);color:var(--accent);font-weight:700;box-shadow:0 0 0 1px var(--accent),0 0 12px var(--accent-soft)}.calendar-cell.today:after{content:"";position:absolute;top:6px;right:6px;width:4px;height:4px;border-radius:50%;background:var(--accent);box-shadow:0 0 6px var(--accent)}.calendar-bar-more{display:block;height:12px;line-height:12px;font-size:10px;font-weight:700;color:var(--text-dim);text-align:left;letter-spacing:0}.calendar-cell.today .calendar-bar-more{color:var(--accent)}.calendar-cell.empty{border:none;background:transparent}.calendar-bars{position:absolute;bottom:6px;left:6px;right:6px;display:grid;gap:2px}.calendar-bar-link{display:block;width:100%}.calendar-bar{display:block;height:7px;width:100%;background:var(--bar-color, #6ee7b7);border-radius:0}.calendar-bar.start{border-top-left-radius:999px;border-bottom-left-radius:999px}.calendar-bar.end{border-top-right-radius:999px;border-bottom-right-radius:999px}.calendar-cell.has-events{cursor:pointer;transition:border-color .18s var(--ease),background .18s var(--ease),box-shadow .18s var(--ease)}.calendar-cell.has-events:hover{border-color:var(--accent-tint-strong);background:var(--accent-tint-soft)}.calendar-cell.selected{border-color:var(--accent);background:var(--accent-tint-mid);box-shadow:0 0 0 1px var(--accent),0 0 12px var(--accent-soft)}.calendar-cell.today.selected{box-shadow:0 0 0 1px var(--accent),0 0 16px var(--accent-soft)}.calendar-cell.has-events:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.calendar-day-panel{margin-top:12px;border-top:1px solid var(--line);padding-top:12px;animation:calendar-panel-in .18s var(--ease)}@keyframes calendar-panel-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.calendar-day-panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.calendar-day-panel-title{font-size:13px;font-weight:700;color:var(--text-mid);letter-spacing:.04em}.calendar-day-panel-close{background:none;border:none;color:var(--text-dim);font-size:14px;line-height:1;cursor:pointer;padding:4px 6px;border-radius:6px;transition:color .18s var(--ease),background .18s var(--ease)}.calendar-day-panel-close:hover{color:var(--text);background:var(--surface-2)}.calendar-day-event-list{list-style:none;margin:0;padding:0;display:grid;gap:6px}.calendar-day-event-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:10px;background:var(--surface-2);border:1px solid var(--line-soft);transition:border-color .18s var(--ease),background .18s var(--ease)}.calendar-day-event-item:hover{border-color:var(--accent-tint-strong);background:var(--accent-tint-faint)}.calendar-day-event-dot{width:10px;height:10px;border-radius:50%;background:var(--bar-color, #6ee7b7);flex-shrink:0;box-shadow:0 0 6px var(--bar-color, #6ee7b7)}.calendar-day-event-body{flex:1;min-width:0;display:grid;gap:2px}.calendar-day-event-name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.calendar-day-event-date{font-size:11px;color:var(--text-dim)}.calendar-day-event-link{color:var(--text-dim);font-size:16px;flex-shrink:0;padding:4px 6px;border-radius:6px;transition:color .18s var(--ease),background .18s var(--ease);line-height:1;text-decoration:none}.calendar-day-event-link:hover{color:var(--accent);background:var(--accent-soft)}.calendar-day-event-link:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.event-detail{display:grid;gap:16px}.event-detail-hero{position:relative;border-radius:20px;overflow:hidden;border:1px solid var(--line);background:var(--surface)}.event-detail-hero img{display:block;margin:0 auto;max-width:100%;max-height:80vh;object-fit:contain;filter:saturate(1.05)}.event-detail-hero-fallback{width:100%;aspect-ratio:16 / 9;max-height:360px;background:linear-gradient(135deg,var(--surface-2),var(--surface))}.event-detail-hero-text{position:absolute;left:0;right:0;bottom:0;padding:16px;background:linear-gradient(180deg,transparent 0%,rgba(10,11,13,.9) 100%)}.event-detail-hero-text h1{margin:6px 0 4px;font-size:20px;color:var(--text)}.event-detail-status{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:4px 10px;border-radius:999px;background:var(--surface-2);color:var(--text-mid);border:1px solid var(--line)}.event-detail-status:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.event-detail-status.active{background:var(--accent-soft);color:var(--accent);border-color:var(--accent-tint-strong)}.event-detail-status.upcoming{background:var(--gold-soft);color:var(--gold);border-color:#d4a87273}.event-detail-status.ended{color:var(--text-dim)}.event-detail-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:14px;display:grid;gap:10px}.event-detail-card h2{margin:0;font-size:16px;color:var(--text)}.event-detail-info{display:grid;gap:10px;font-size:13px;color:var(--text)}.event-detail-info div{display:flex;justify-content:space-between;gap:10px}.event-detail-label{color:var(--text-dim)}.event-detail-muted{color:var(--text-mid);font-size:13px;line-height:1.5}.event-detail-link{display:inline-flex;align-items:center;justify-content:center;gap:6px;border-radius:999px;padding:10px 14px;background:var(--accent);color:var(--bg);font-weight:700;font-size:13px;transition:opacity .18s var(--ease),transform .18s var(--ease)}.event-detail-link:hover{opacity:.92;transform:translateY(-1px)}.event-detail-link svg{width:16px;height:16px;stroke-width:1.8}.event-detail-links{display:grid;gap:8px}.event-detail-link-item{display:inline-flex;align-items:center;gap:8px;padding:10px 12px;border:1px solid var(--line);border-radius:12px;background:var(--bg);color:var(--accent);font-size:13px;font-weight:600;word-break:break-all;transition:border-color .18s var(--ease),background .18s var(--ease)}.event-detail-link-item:hover{border-color:var(--accent);background:var(--surface)}.event-detail-link-item svg{flex-shrink:0}.login{display:grid;gap:14px;justify-items:center}.login-card{width:min(360px,100%);background:var(--card);border:1px solid var(--border);border-radius:18px;padding:20px;text-align:center;display:grid;gap:12px}.login-card h1{margin:0;font-size:20px}.login-muted{margin:0;font-size:13px;color:var(--muted);line-height:1.4}.naver-login-button{border:none;background:#03c75a;color:#fff;font-weight:700;border-radius:12px;padding:12px 16px;font-size:14px}.kakao-login-button{border:none;background:#fee500;color:#000;font-weight:700;border-radius:12px;padding:12px 16px;font-size:14px}.login-hint{margin:0;font-size:12px;color:var(--muted)}.login-back{font-size:12px;color:var(--muted)}.auth-form{text-align:left}.auth-input{width:100%;border:1px solid var(--border);border-radius:10px;padding:10px 12px;background:var(--surface-2);color:var(--text);font-size:13px}.auth-input:focus{outline:none;border-color:var(--accent)}.auth-select{appearance:none;cursor:pointer}.auth-submit-button{width:100%;border:none;border-radius:12px;padding:12px 16px;background:var(--accent);color:#0b1f14;font-weight:700;font-size:14px;cursor:pointer}.auth-submit-button:disabled{opacity:.5;cursor:not-allowed}.auth-error{font-size:12px;color:#ffbcbc;background:#ff6b6b1f;border:1px solid rgba(255,107,107,.35);border-radius:10px;padding:8px 10px}.auth-divider{display:flex;align-items:center;gap:10px;color:var(--text-muted, #8a8f9e);font-size:12px;margin:4px 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border, #2a2d35)}.auth-hint{font-size:12px;color:var(--text-muted, #8a8f9e);padding:4px 2px}.auth-link{display:block;text-align:center;font-size:13px;color:var(--accent);font-weight:600}.community{display:grid;gap:14px}.community-header h2{margin:2px 0 0;font-size:20px}.community-fallback{margin-top:6px;font-size:12px;color:var(--muted)}.community-form,.community-reply-form{display:grid;gap:8px;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:12px}.community-tags{display:flex;flex-wrap:wrap;gap:8px}.community-form-label{font-size:12px;color:var(--text-dim)}.community-selected-tag{font-size:12px;color:var(--accent)}.community-group{display:grid;gap:12px}.community-group-header{display:flex;align-items:center;justify-content:space-between;font-size:13px;color:var(--muted)}.community-group-count{font-size:12px}.community-form input,.community-form textarea,.community-reply-form input,.community-reply-form textarea{width:100%;border:1px solid var(--line);border-radius:10px;padding:10px 12px;background:var(--surface-2);color:var(--text);font-size:13px;transition:border-color .18s var(--ease)}.community-form input:focus,.community-form textarea:focus,.community-reply-form input:focus,.community-reply-form textarea:focus{outline:none;border-color:var(--accent)}.community-form button,.community-reply-form button{border:none;border-radius:10px;padding:10px 12px;background:var(--accent);color:var(--bg);font-weight:700;font-size:13px;cursor:pointer;transition:opacity .18s var(--ease)}.community-form button:hover:not(:disabled),.community-reply-form button:hover:not(:disabled){opacity:.9}.community-form button:disabled,.community-reply-form button:disabled{opacity:.5;cursor:not-allowed}.community-login-hint{font-size:12px;color:var(--text-dim)}.community-search{display:flex;gap:6px;align-items:center;background:var(--surface-2);border:1px solid var(--line);border-radius:10px;padding:0 10px;transition:border-color .18s var(--ease)}.community-search:focus-within{border-color:var(--accent)}.community-search-icon{color:var(--text-dim);flex-shrink:0}.community-search-input{flex:1;border:none;background:transparent;padding:10px 4px;color:var(--text);font-size:13px;outline:none}.community-search-btn{border:none;border-radius:10px;padding:9px 14px;background:var(--accent);color:var(--bg);font-weight:700;font-size:13px;cursor:pointer;white-space:nowrap}.community-search-clear{border:none;background:transparent;color:var(--text-dim);width:24px;height:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:color .18s var(--ease)}.community-search-clear:hover{color:var(--text)}.community-search-info{font-size:12px;color:var(--text-dim);margin-top:4px}.community-tags.board-tabs{display:flex;flex-wrap:nowrap;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:4px;scrollbar-width:none;margin-bottom:8px}.community-tags.board-tabs::-webkit-scrollbar{display:none}.community-tags.board-tabs .tab{scroll-snap-align:start;flex-shrink:0}.plant-search-chip{position:relative;margin-top:12px}.plant-search-chip .search-bar{margin:0}.plant-search-chip.has-selected .search-bar{background:var(--accent-soft);border-color:var(--accent)}.plant-search-chip.has-selected .search-bar-icon,.plant-search-chip.has-selected .search-bar-clear{color:var(--accent)}.plant-search-chip.has-selected .search-bar-clear:hover{color:var(--text)}.plant-search-selected{flex:1;padding:10px 4px;color:var(--accent);font-size:13px;font-weight:600}.plant-search-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--surface);border:1px solid var(--line);border-radius:12px;box-shadow:0 12px 32px #00000080;overflow:hidden;z-index:25;max-height:280px;overflow-y:auto}.plant-search-dropdown-item{display:flex;align-items:center;gap:10px;padding:10px 14px;color:var(--text);font-size:13px;cursor:pointer;border:none;background:none;width:100%;text-align:left;transition:background .18s var(--ease)}.plant-search-dropdown-item:hover{background:var(--surface-2)}.plant-search-dropdown-item svg{color:var(--accent);flex-shrink:0}.plant-search-dropdown-item-sub{margin-left:auto;font-size:11px;color:var(--text-dim);letter-spacing:.04em}.plant-search-empty{padding:14px;text-align:center;color:var(--text-dim);font-size:13px}.community-list{display:grid;gap:12px}.community-post{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:14px;display:grid;gap:10px;transition:border-color .18s var(--ease)}.community-post:hover{border-color:var(--text-dim)}.community-post-header{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--text-dim)}.community-post-header strong{color:var(--text);font-size:13px;font-weight:700}.community-reply-author{display:flex;align-items:center;gap:8px;min-width:0;color:inherit;transition:opacity .18s var(--ease)}.community-reply-author:hover{opacity:.75}.community-reply-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover;flex-shrink:0}.community-post p,.community-reply p{margin:0;font-size:13px;line-height:1.5}.community-post-tag{font-size:11px;color:var(--accent);background:var(--accent-soft);border:1px solid var(--accent-tint-strong);border-radius:999px;padding:4px 8px;width:fit-content}.profile{display:grid;gap:16px}.profile-hero{display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:16px}.profile-hero h1{margin:0;font-size:20px;color:var(--text)}.profile-nickname-row{display:inline-flex;align-items:center;gap:6px}.profile-nickname-edit{display:flex;align-items:center;gap:6px}.profile-nickname-input{font-size:18px;font-weight:600;color:var(--text);background:var(--card);border:1px solid var(--line);border-radius:8px;padding:4px 8px;width:160px;outline:none}.profile-nickname-input:focus{border-color:var(--accent)}.profile-nickname-btn{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:8px;border:1px solid var(--line);background:var(--card);color:var(--text-muted, #9aa0a6);cursor:pointer;padding:0}.profile-nickname-btn:hover{color:var(--accent);border-color:var(--accent)}.profile-nickname-btn:disabled{opacity:.5;cursor:default}.profile-nickname-error{margin:4px 0 0;font-size:12px;color:#ef6f6f}.profile-hero-avatar{width:72px;height:72px;border-radius:20px;object-fit:cover;border:1px solid var(--line)}.profile-hero-stats{grid-column:1 / -1;display:grid;grid-template-columns:repeat(3,1fr);gap:8px;text-align:center;margin-top:6px}.profile-hero-stats div{background:var(--surface-2);border:1px solid var(--line-soft);border-radius:12px;padding:8px 6px;display:grid;gap:4px}.profile-hero-stats strong{font-size:16px;color:var(--text)}.profile-hero-stats span{font-size:11px;color:var(--text-dim);letter-spacing:.04em}.profile-feed{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.profile-feed-item{position:relative;border-radius:10px;overflow:hidden;border:1px solid var(--line-soft);background:var(--surface-2);aspect-ratio:1 / 1;transition:border-color .18s var(--ease)}.profile-feed-item:hover{border-color:var(--text-dim)}.profile-feed-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s var(--ease),opacity .18s var(--ease)}.profile-feed-item:hover img{transform:scale(1.04);opacity:.92}.profile-feed-placeholder{width:100%;height:100%;background:linear-gradient(135deg,var(--surface-2),var(--surface))}.profile-feed-caption{position:absolute;inset:auto 0 0;padding:6px;font-size:11px;color:var(--text);background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.7) 100%);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-card{background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:20px;text-align:center;display:grid;gap:10px}.profile-muted{color:var(--text-dim);font-size:13px;margin:0}.profile-cta{border:none;border-radius:12px;padding:10px 14px;background:var(--accent);color:var(--bg);font-weight:700;font-size:13px;display:inline-flex;justify-content:center;cursor:pointer;transition:opacity .18s var(--ease)}.profile-cta:hover{opacity:.92}.feed-detail{display:grid;gap:14px;padding-bottom:80px}.feed-detail-top{display:flex;align-items:center;gap:10px}.feed-detail-back{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;margin-left:-6px;border-radius:50%;color:var(--text);flex:none;transition:background-color .18s var(--ease)}.feed-detail-back:hover{background:var(--surface)}.feed-detail-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;flex:none}.feed-detail-author-link{display:flex;align-items:center;gap:10px;min-width:0;color:inherit;border-radius:999px;transition:opacity .18s var(--ease)}.feed-detail-author-link:hover{opacity:.75}.feed-detail-author{display:grid;gap:1px;min-width:0}.feed-detail-author strong{font-size:13px;font-weight:700;color:var(--text)}.feed-detail-delete{margin-left:auto}.feed-detail-carousel{position:relative;border-radius:16px;overflow:hidden;background:var(--surface-2)}.feed-detail-carousel-track{display:grid;grid-auto-flow:column;grid-auto-columns:100%;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none}.feed-detail-carousel-track::-webkit-scrollbar{display:none}.feed-detail-slide{scroll-snap-align:start;aspect-ratio:1 / 1;overflow:hidden}.feed-detail-slide img,.feed-detail-slide .safe-image-fallback{width:100%;height:100%;object-fit:cover;display:block}.feed-detail-count{position:absolute;top:10px;right:10px;background:var(--scrim);color:#fff;font-size:11px;font-variant-numeric:tabular-nums;padding:2px 8px;border-radius:999px}.feed-detail-dots{display:flex;gap:5px;justify-content:center;margin-top:-4px}.feed-detail-dots i{width:6px;height:6px;border-radius:50%;background:var(--line);transition:width .2s var(--ease),background-color .2s var(--ease)}.feed-detail-dots i.on{width:16px;border-radius:3px;background:var(--accent)}.feed-detail-caption{font-size:14px;line-height:1.6}.blind-notice{display:flex;align-items:center;gap:8px;margin:12px 0;padding:14px 16px;border:1px solid var(--danger-strong);background:var(--danger-soft);color:var(--danger);border-radius:12px;font-size:13px;line-height:1.5}.profile-feed-item-blinded{pointer-events:auto}.profile-feed-blinded{display:flex;align-items:center;justify-content:center;width:100%;aspect-ratio:1 / 1;background:var(--danger-soft);border:1px dashed var(--danger-strong);color:var(--danger);border-radius:12px;font-size:12px;text-align:center;padding:8px}.feed-comments{display:grid;gap:8px;padding:4px 0}.feed-comment{display:flex;align-items:baseline;gap:6px;font-size:13px;line-height:1.5}.feed-comment-author{font-weight:700;color:var(--text);flex-shrink:0}.feed-comment-content{color:var(--text);flex:1;word-break:break-word}.feed-comment-delete{background:none;border:none;color:var(--muted);font-size:11px;cursor:pointer;padding:0;flex-shrink:0}.feed-detail-sticky{position:fixed;left:0;right:0;bottom:calc(73px + env(safe-area-inset-bottom));z-index:9;display:flex;align-items:center;gap:12px;max-width:840px;margin:0 auto;padding:10px 12px;background:var(--nav-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-top:1px solid var(--line)}.feed-detail-like{display:inline-flex;align-items:center;gap:6px;background:none;border:0;color:var(--text-mid);font-size:13px;font-weight:600;cursor:pointer;padding:0;flex:none;transition:color .18s var(--ease)}.feed-detail-like.on{color:var(--danger)}.feed-detail-cbar{flex:1;display:flex;align-items:center;gap:8px;border:1px solid var(--line);background:var(--surface-2);border-radius:999px;padding:6px 8px 6px 14px;min-width:0}.feed-comment-input{flex:1;width:100%;background:none;border:none;outline:none;color:var(--text);font-size:13px;padding:4px 0}.feed-comment-input::placeholder{color:var(--muted)}.feed-detail-cbar .mention-dropdown{top:auto;bottom:100%;margin-bottom:8px}.feed-comment-submit{background:none;border:none;color:var(--accent);font-size:13px;font-weight:700;cursor:pointer;padding:0;flex-shrink:0}.feed-comment-submit:disabled{opacity:.4;cursor:not-allowed}.feed-create-modal-body{display:grid;gap:14px}.feed-create-card{background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:16px;display:grid;gap:14px}.feed-upload-add{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;width:110px;aspect-ratio:1 / 1;border-radius:12px;border:1px dashed var(--line);background:var(--surface-2);color:var(--text-mid);font-size:12px;font-weight:600;cursor:pointer;transition:color .18s var(--ease),border-color .18s var(--ease),background .18s var(--ease)}.feed-upload-add:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-soft);border-style:solid}.feed-upload-add svg{color:var(--text-dim);transition:color .18s var(--ease)}.feed-upload-add:hover svg{color:var(--accent)}.source-sheet-layer{position:fixed;inset:0;z-index:60;display:flex;align-items:flex-end;justify-content:center}.source-sheet-backdrop{position:absolute;inset:0;background:var(--modal-bg);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.source-sheet{position:relative;z-index:1;width:min(520px,100%);display:grid;gap:8px;padding:12px 12px calc(16px + env(safe-area-inset-bottom));background:var(--surface);border:1px solid var(--line);border-radius:18px 18px 0 0;animation:source-sheet-up .22s var(--ease)}@keyframes source-sheet-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.source-sheet-item{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:12px;border:1px solid var(--line);background:var(--surface-2);color:var(--text);font-size:14px;font-weight:600;cursor:pointer;transition:background .18s var(--ease)}.source-sheet-item:hover{background:var(--surface)}.source-sheet-item svg{color:var(--accent);flex:none}.source-sheet-cancel{padding:13px 16px;border-radius:12px;border:0;background:transparent;color:var(--text-dim);font-size:14px;font-weight:600;cursor:pointer}.source-sheet-cancel:hover{color:var(--text)}.feed-upload{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:18px 14px;border-radius:14px;border:1px dashed var(--line);background:var(--surface-2);color:var(--text-mid);font-size:13px;font-weight:600;cursor:pointer;transition:color .18s var(--ease),border-color .18s var(--ease),background .18s var(--ease)}.feed-upload:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-soft);border-style:solid}.feed-upload svg{color:var(--text-dim);transition:color .18s var(--ease)}.feed-upload:hover svg{color:var(--accent)}.feed-upload input{display:none}.feed-upload-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;max-width:350px;margin-inline:auto}.feed-upload-card{position:relative;width:110px;border-radius:12px;overflow:hidden;border:1px solid var(--line);background:var(--surface-2);cursor:grab;touch-action:none;user-select:none;-webkit-user-select:none}.feed-upload-card:active{cursor:grabbing}.feed-upload-card.is-dragging{opacity:.6;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent)}.feed-upload-card img{width:100%;height:100%;aspect-ratio:1 / 1;object-fit:cover;display:block}.feed-upload-remove{position:absolute;top:6px;right:6px;width:26px;height:26px;border-radius:999px;border:none;background:var(--image-overlay);color:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .18s var(--ease)}.feed-upload-remove:hover{background:var(--scrim-strong)}.feed-upload-order{position:absolute;left:6px;bottom:6px;background:var(--image-overlay);color:#fff;font-size:11px;font-weight:700;padding:4px 7px;border-radius:999px;min-width:22px;text-align:center}.feed-create-modal-body textarea,.feed-create textarea{width:100%;border:1px solid var(--line);background:var(--surface-2);color:var(--text);border-radius:10px;padding:10px 12px;font-size:13px;font-family:inherit;resize:vertical;transition:border-color .18s var(--ease)}.feed-create-modal-body textarea:focus,.feed-create textarea:focus{outline:none;border-color:var(--accent)}.feed-submit{width:100%;border:none;border-radius:12px;padding:12px 14px;background:var(--accent);color:var(--bg);font-weight:700;font-size:14px;cursor:pointer;transition:opacity .18s var(--ease)}.feed-submit:hover:not(:disabled){opacity:.92}.feed-submit:disabled{opacity:.5;cursor:not-allowed}.fab{position:fixed;right:18px;bottom:calc(96px + env(safe-area-inset-bottom));width:54px;height:54px;border-radius:999px;background:var(--accent);color:var(--bg);display:flex;align-items:center;justify-content:center;font-weight:700;box-shadow:0 12px 24px #00000059;cursor:pointer;border:none;transition:transform .18s var(--ease),box-shadow .18s var(--ease);z-index:30}.fab:hover{transform:translateY(-2px);box-shadow:0 16px 28px #0006}.fab svg{width:22px;height:22px;stroke-width:1.8}.report{display:grid;gap:16px}.report-card{background:var(--card);border:1px solid var(--border);border-radius:18px;padding:18px;display:grid;gap:12px}.report-card h2{margin:0;font-size:18px}.report-muted{margin:0;font-size:13px;color:var(--muted)}.report-categories{display:flex;flex-wrap:wrap;gap:8px}.report-card input,.report-card textarea{width:100%;border:1px solid var(--border);border-radius:10px;padding:10px 12px;background:var(--surface-2);color:var(--text);font-size:13px}.report-card button{border:none;border-radius:10px;padding:10px 12px;background:var(--accent);color:#0b1f14;font-weight:700;font-size:13px}.report-card button:disabled{opacity:.5;cursor:not-allowed}.report-success{font-size:12px;color:#bff5de;background:var(--accent-tint-mid);border:1px solid var(--accent-tint-strong);border-radius:12px;padding:8px 10px}.report-error{font-size:12px;color:#ffbcbc;background:#ff6b6b1f;border:1px solid rgba(255,107,107,.35);border-radius:12px;padding:8px 10px}.community-actions{display:flex;gap:8px}.community-action{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);background:var(--surface-2);color:var(--text-mid);padding:6px 10px;border-radius:999px;font-size:12px;font-weight:600;cursor:pointer;transition:color .18s var(--ease),border-color .18s var(--ease),background .18s var(--ease)}.community-action:hover{color:var(--text);border-color:var(--text-dim)}.community-action:disabled{opacity:.45;cursor:not-allowed}.community-action svg{width:14px;height:14px;stroke-width:1.8;flex-shrink:0}.community-action.active{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.community-action.danger{border-color:#ff6b6b66;color:var(--danger)}.community-action.danger:hover{border-color:var(--danger);color:var(--danger)}.community-load-more{display:flex;justify-content:center;margin:12px 0 4px}.community-replies{display:grid;gap:8px}.community-reply{border-bottom:1px solid var(--line-soft);padding:10px 0;display:grid;gap:6px}.community-reply:last-child{border-bottom:none}.community-edit{display:grid;gap:8px}.community-edit textarea{width:100%;border:1px solid var(--line);border-radius:10px;padding:10px 12px;background:var(--surface-2);color:var(--text);font-size:13px}.community-edit-actions{display:flex;gap:8px}.community-modal{position:fixed;inset:0;z-index:40;display:grid;place-items:center}.community-modal-backdrop{position:absolute;inset:0;background:var(--modal-bg);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.community-modal-card{position:relative;z-index:1;width:min(520px,92vw);background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:16px;display:grid;gap:12px}.community-modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.fab-community{background:var(--accent);color:var(--bg)}.community-post-list{list-style:none;margin:0;padding:0;border-top:1px solid var(--line)}.community-post-row{background:transparent;border:0;border-bottom:1px solid var(--line);border-radius:0;overflow:hidden;transition:background-color .18s var(--ease)}.community-post-row:hover{background:var(--surface)}.community-post-row-link{display:flex;gap:12px;padding:12px 4px;color:var(--text);text-decoration:none;align-items:center}.community-post-row-body{flex:1;min-width:0;display:grid;gap:4px}.community-post-row-meta{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--text-dim)}.community-post-row-board{color:var(--accent);background:transparent;border:0;padding:0;font-weight:600;font-size:11px}.community-post-row-board:after{content:"·";color:var(--text-dim);margin-left:8px;font-weight:400}.community-post-row-date{color:var(--text-dim)}.community-post-row-title{margin:0;font-size:14.5px;font-weight:600;color:var(--text);line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.community-post-row-footer{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:11.5px;color:var(--text-mid)}.community-post-row-stats{color:var(--text-dim);font-size:11px}.community-post-row-thumb{flex-shrink:0;width:52px;height:52px;border-radius:8px;overflow:hidden;background:var(--surface-2)}.community-post-row-thumb img,.community-post-row-thumb .safe-image-fallback{width:100%;height:100%;object-fit:cover;display:block}.community-announcement-list{border-top:none;margin-bottom:4px}.community-announcement-row{background:color-mix(in srgb,var(--accent) 6%,var(--card))}.community-announcement-row:hover{background:color-mix(in srgb,var(--accent) 12%,var(--card))}.community-announcement-badge{display:inline-flex;align-items:center;padding:1px 7px;border-radius:4px;font-size:10px;font-weight:700;letter-spacing:.04em;background:var(--accent);color:#0e0f11;flex-shrink:0}.community-title-input{width:100%;border:1px solid var(--line);background:var(--surface-2);color:var(--text);border-radius:10px;padding:12px 14px;font-size:15px;font-weight:600;transition:border-color .18s var(--ease)}.community-title-input:focus{outline:none;border-color:var(--accent)}.community-title-input::placeholder{color:var(--text-dim);font-weight:400}.community-media-actions{display:flex;gap:8px}.community-media-pick{flex:1;flex-direction:row;padding:12px 14px}.community-create{display:grid;gap:14px}.community-create-top{display:flex;align-items:center;gap:10px}.community-create-top h2{flex:1;margin:0;font-size:18px}.community-create-submit{border:none;border-radius:999px;padding:8px 18px;background:var(--accent);color:var(--bg);font-weight:700;font-size:13px;cursor:pointer;transition:opacity .18s var(--ease)}.community-create-submit:hover:not(:disabled){opacity:.92}.community-create-submit:disabled{opacity:.5;cursor:not-allowed}.community-create-content{width:100%;min-height:320px;border:1px solid var(--line);border-radius:12px;padding:14px;background:var(--surface-2);color:var(--text);font-size:15px;line-height:1.7;font-family:inherit;resize:vertical;transition:border-color .18s var(--ease)}.community-create-content:focus{outline:none;border-color:var(--accent)}.community-create-content::placeholder{color:var(--text-dim)}.community-post-detail{display:grid;gap:14px;padding-bottom:80px}.community-detail-back{display:inline-flex;align-items:center;gap:6px;color:var(--text-mid);font-size:13px;text-decoration:none;transition:color .18s var(--ease)}.community-detail-back:hover{color:var(--text)}.community-detail-head{display:grid;gap:8px}.community-detail-title{margin:0;font-size:20px;font-weight:800;line-height:1.35;color:var(--text);letter-spacing:-.01em;word-break:keep-all}.community-detail-content{font-size:15px;line-height:1.65;color:var(--text);white-space:pre-wrap;word-break:break-word}.community-detail-replies{display:grid;gap:10px}.community-detail-replies-title{margin:0;font-size:14px;font-weight:700;color:var(--text-mid)}.terms-screen{position:fixed;inset:0;z-index:50;background:var(--bg);display:flex;flex-direction:column;padding:max(env(safe-area-inset-top),20px) 20px calc(20px + env(safe-area-inset-bottom));gap:16px}@media(min-width:900px){.terms-screen{align-items:center;justify-content:center;padding:32px}.terms-screen-header,.terms-screen-body,.terms-screen-actions{width:100%;max-width:640px}.terms-screen-body{flex:none;max-height:60vh}}.terms-screen-header{display:grid;gap:6px}.terms-screen-kicker{font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.14em;font-weight:700}.terms-screen-header h1{margin:0;font-size:22px;color:var(--text);font-weight:800;letter-spacing:-.02em}.terms-screen-sub{margin:0;font-size:13px;color:var(--text-mid)}.terms-screen-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;border-radius:14px;border:1px solid var(--line);background:var(--surface);padding:16px;min-height:0;display:grid;gap:18px}.terms-doc{display:grid;gap:18px}.terms-section{display:grid;gap:8px}.terms-section-heading{margin:0;font-size:14px;font-weight:700;color:var(--text);letter-spacing:-.01em}.terms-lead,.terms-closing{margin:0;font-size:13px;line-height:1.7;color:var(--text-mid)}.terms-closing{color:var(--text-dim);font-style:italic}.terms-p{margin:0;font-size:13px;line-height:1.7;color:var(--text-mid);white-space:pre-line}.terms-list{margin:6px 0 0;padding-left:20px;display:grid;gap:6px;font-size:13px;line-height:1.7;color:var(--text-mid)}.terms-ol{list-style:decimal}.terms-ul{list-style:disc}.terms-sublist{margin:6px 0 0;padding-left:18px;list-style:disc;display:grid;gap:4px}.terms-doc strong{color:var(--text);font-weight:700}.archive-list{display:grid;gap:8px}.archive-row{display:flex;gap:12px;align-items:stretch;width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:12px;background:var(--surface-2);color:var(--text);text-align:left;cursor:pointer;transition:background .18s var(--ease),border-color .18s var(--ease)}.archive-row:hover{background:var(--surface);border-color:var(--accent)}.archive-row-thumb{flex:none;width:56px;height:56px;border-radius:10px;object-fit:cover;background:var(--surface)}.archive-row-main{flex:1;min-width:0;display:grid;gap:4px}.archive-row-title{font-size:14px;font-weight:700;color:var(--text);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.archive-row-sub{font-size:12px;color:var(--text-mid);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.archive-row-meta{font-size:11px;color:var(--text-dim)}.settings-page{padding-bottom:calc(96px + env(safe-area-inset-bottom))}.settings-page-header{display:grid;gap:4px;margin:6px 2px 14px}.settings-page-header h2{margin:2px 0 0;font-size:20px;font-weight:800;letter-spacing:-.02em;color:var(--text)}.settings-list{list-style:none;margin:0;padding:0;border-top:1px solid var(--line)}.settings-list li{border-bottom:1px solid var(--line)}.settings-row{display:flex;align-items:center;gap:12px;padding:14px 4px;color:var(--text);text-decoration:none;transition:background-color .18s var(--ease)}.settings-row:hover{background:var(--surface)}.settings-row-icon{display:inline-flex;color:var(--text-mid)}.settings-row-label{flex:1;font-size:14.5px;font-weight:600;text-align:left}.settings-row-chevron{color:var(--text-dim);flex-shrink:0}.settings-row-button{width:100%;background:none;border:0;font-family:inherit;cursor:pointer}.settings-row.danger,.settings-row.danger .settings-row-icon{color:var(--danger)}.settings-row.danger:hover{background:var(--danger-soft)}.settings-section{margin:6px 0 18px}.settings-section-title{font-size:12px;font-weight:700;letter-spacing:.04em;color:var(--text-dim);margin-bottom:8px;text-transform:uppercase}.settings-section-help{margin:10px 2px 0;font-size:12px;color:var(--text-dim);line-height:1.5}.theme-toggle{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;padding:4px;border-radius:12px;background:var(--surface-2);border:1px solid var(--line)}.theme-toggle-option{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 4px;border-radius:9px;border:0;background:transparent;color:var(--text-mid);font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:background .18s var(--ease),color .18s var(--ease),box-shadow .18s var(--ease)}.theme-toggle-option:hover{color:var(--text)}.theme-toggle-option.active{background:var(--surface);color:var(--accent);box-shadow:0 0 0 1px var(--accent-tint-strong),var(--elevation-1)}.theme-toggle-option svg{flex-shrink:0}.terms-manage-status{display:flex;align-items:center;gap:8px;padding:12px 14px;border:1px solid var(--line);border-radius:12px;background:var(--surface);font-size:13px;color:var(--text-mid);margin-bottom:14px}.terms-manage-status-dot{width:8px;height:8px;border-radius:50%;background:var(--text-dim);flex-shrink:0}.terms-manage-status-dot.agreed{background:var(--accent);box-shadow:0 0 10px var(--accent)}.terms-manage-body{border:1px solid var(--line);border-radius:14px;background:var(--surface);padding:16px;display:grid;gap:18px}.terms-manage-version{font-size:12px;color:var(--text-dim);font-weight:600}.terms-manage-withdraw{width:100%;margin-top:16px;border:1px solid rgba(255,107,107,.4);background:transparent;color:var(--danger);border-radius:12px;padding:14px 12px;font-size:14px;font-weight:700;cursor:pointer;transition:background-color .18s var(--ease),opacity .18s var(--ease)}.terms-manage-withdraw:hover:not(:disabled){background:#ff6b6b14}.terms-manage-withdraw:disabled{opacity:.5;cursor:not-allowed}.terms-screen-actions{display:grid;grid-template-columns:1fr 2fr;gap:10px}.terms-screen-decline,.terms-screen-accept{border-radius:12px;padding:14px 12px;font-size:14px;font-weight:700;cursor:pointer;transition:opacity .18s var(--ease),border-color .18s var(--ease)}.terms-screen-decline{background:var(--surface-2);border:1px solid var(--line);color:var(--text-mid)}.terms-screen-decline:hover:not(:disabled){color:var(--text);border-color:var(--text-dim)}.terms-screen-accept{background:var(--accent);border:none;color:var(--bg)}.terms-screen-accept:hover:not(:disabled){opacity:.92}.terms-screen-decline:disabled,.terms-screen-accept:disabled{opacity:.5;cursor:not-allowed}.safe-image-fallback{width:100%;height:100%;background:linear-gradient(135deg,var(--surface-2),var(--surface));display:block}.vendor-detail-hero .safe-image-fallback{aspect-ratio:16 / 9;max-height:360px}.search-bar{display:flex;gap:6px;align-items:center;background:var(--surface-2);border:1px solid var(--line);border-radius:10px;padding:0 10px;margin-top:12px;transition:border-color .18s var(--ease)}.search-bar:focus-within{border-color:var(--accent)}.search-bar-icon{color:var(--text-dim);flex-shrink:0}.search-bar-input{flex:1;border:none;background:transparent;padding:10px 4px;color:var(--text);font-size:13px;outline:none}.search-bar-clear{border:none;background:transparent;color:var(--text-dim);width:24px;height:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:color .18s var(--ease)}.search-bar-clear:hover{color:var(--text)}.vendor-results{margin-top:16px;display:grid;gap:18px}.vendor-results-header{display:flex;align-items:flex-end;justify-content:space-between;gap:12px}.vendor-results-header h2{margin:2px 0 0;font-size:18px;color:var(--text)}.vendor-results-count{font-size:12px;color:var(--text-dim)}.vendor-group{display:grid;gap:12px}.vendor-group-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.vendor-group-header h3{margin:0;font-size:16px;color:var(--text)}.vendor-plant-sci{font-size:12px;color:var(--text-dim)}.vendor-grid{display:grid;gap:8px}.vendor-card{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:10px;overflow:hidden;text-decoration:none;color:inherit;transition:border-color .18s var(--ease),transform .18s var(--ease)}.vendor-card:hover{border-color:var(--text-dim);transform:translateY(-1px)}.vendor-card-body{flex:1;min-width:0;display:grid;gap:3px;text-decoration:none;color:inherit}.vendor-card-name{font-size:14px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vendor-location{font-size:11px;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vendor-distance{font-size:11px;font-weight:600;color:var(--accent, #6ee7b7);white-space:nowrap}.vendor-nearby-row{display:flex;align-items:center;gap:8px;margin:8px 0 4px}.vendor-nearby-toggle{flex:0 0 auto}.vendor-nearby-error{font-size:11px;color:#f87171}.vendor-description{margin:0;font-size:12px;color:var(--text-mid);line-height:1.45;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.vendor-navi{flex:none;display:flex;flex-direction:column;gap:8px;align-items:center}.vendor-navi-label{font-size:10px;font-weight:700;color:var(--text-dim);text-align:center;letter-spacing:.02em}.vendor-navi-buttons{display:flex;gap:8px}.vendor-navi-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border-radius:50%;border:1px solid var(--line);background:var(--surface-2);color:var(--text-mid);cursor:pointer;transition:border-color .18s var(--ease),transform .18s var(--ease),box-shadow .18s var(--ease)}.vendor-navi-btn svg{flex-shrink:0}.vendor-navi-btn:hover{transform:translateY(-1px)}.vendor-navi-btn.naver{border-color:#03c75a66}.vendor-navi-btn.naver:hover{border-color:#03c75a;box-shadow:0 0 0 1px #03c75a59}.vendor-navi-btn.kakao{border-color:#f5de0073}.vendor-navi-btn.kakao:hover{border-color:#fee500;box-shadow:0 0 0 1px #fee50066}.vendor-tags{display:flex;flex-wrap:wrap;gap:6px}.vendor-tag{font-size:11px;padding:4px 8px;border-radius:999px;border:1px solid var(--line);color:var(--text-mid);background:var(--surface-2)}.vendor-items{display:flex;flex-wrap:wrap;gap:6px}.vendor-item{font-size:11px;padding:4px 8px;border-radius:999px;background:var(--accent-soft);color:var(--accent);border:1px solid var(--accent-tint-strong)}.vendor-empty{padding:16px;border-radius:12px;border:1px dashed var(--line);color:var(--text-dim);font-size:13px;text-align:center}.vendor-detail{display:grid;gap:16px}.vendor-detail-hero{position:relative;border-radius:20px;overflow:hidden;border:1px solid var(--line);background:var(--surface)}.vendor-detail-hero img{width:100%;aspect-ratio:16 / 9;max-height:360px;object-fit:cover;display:block}.vendor-detail-hero-text{position:absolute;left:0;right:0;bottom:0;padding:16px;background:linear-gradient(180deg,transparent 0%,rgba(10,11,13,.9) 100%)}.vendor-detail-hero-text h1{margin:0 0 6px;font-size:20px;color:var(--text)}.vendor-detail-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:14px;display:grid;gap:10px}.vendor-detail-card h2{margin:0;font-size:16px;color:var(--text)}.vendor-detail-info{display:grid;gap:10px;font-size:13px;color:var(--text)}.vendor-detail-info div{display:flex;justify-content:space-between;gap:10px}.vendor-detail-label{color:var(--text-dim)}.vendor-detail-muted{color:var(--text-mid);font-size:13px;line-height:1.5}.vendor-detail-tags{margin-top:8px}.vendor-detail-items{display:flex;flex-wrap:wrap;gap:8px}.vendor-detail-link{display:inline-flex;align-items:center;justify-content:center;gap:6px;border-radius:999px;padding:10px 14px;background:var(--accent);color:var(--bg);font-weight:700;font-size:13px;transition:opacity .18s var(--ease),transform .18s var(--ease)}.vendor-detail-link:hover{opacity:.92;transform:translateY(-1px)}.vendor-detail-link svg{width:16px;height:16px;stroke-width:1.8}.mention{color:var(--accent);font-weight:600}.mention-input-wrapper{position:relative;width:100%}.mention-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--card);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:1000;max-height:200px;overflow-y:auto}.mention-dropdown-item{padding:8px 12px;cursor:pointer;font-size:.9rem}.mention-dropdown-item:hover{background:var(--accent-light, rgba(100,200,150,.1))}.notif-btn{position:relative;background:none;border:none;cursor:pointer;padding:6px;color:var(--text-mid);display:inline-flex;align-items:center;justify-content:center;transition:color .18s var(--ease)}.notif-btn:hover{color:var(--text)}.notif-btn svg{width:20px;height:20px}.settings-wrapper{position:relative}.settings-btn{background:none;border:none;cursor:pointer;padding:6px;color:var(--text-mid);display:inline-flex;align-items:center;justify-content:center;transition:color .18s var(--ease)}.settings-btn:hover{color:var(--text)}.settings-btn svg{width:20px;height:20px}.settings-dropdown{position:absolute;right:0;min-width:140px;background:var(--surface);border:1px solid var(--line);border-radius:12px;box-shadow:0 10px 30px #0006;overflow:hidden;z-index:20}.settings-dropdown--down{top:calc(100% + 6px)}.settings-dropdown--up{bottom:calc(100% + 6px)}.settings-dropdown-item{display:block;width:100%;text-align:left;background:none;border:none;padding:12px 14px;color:var(--text);font-size:13px;font-weight:600;cursor:pointer;transition:background .18s var(--ease);text-decoration:none}.settings-dropdown-item:hover{background:var(--surface-2)}.settings-dropdown-item.danger{color:var(--danger)}.settings-dropdown-item.danger:hover{background:var(--danger-soft)}.settings-dropdown-divider{height:1px;background:var(--line-soft)}.notif-dot{position:absolute;top:2px;right:2px;width:8px;height:8px;border-radius:50%;background:#ef4444;border:2px solid var(--bg);box-sizing:content-box}.notif-panel-overlay{position:fixed;inset:0;z-index:2000;background:var(--scrim);opacity:0;visibility:hidden;overflow:hidden;transition:opacity .25s var(--ease),visibility .25s var(--ease)}.notif-panel-overlay.open{opacity:1;visibility:visible}.notif-panel{position:absolute;top:0;right:0;height:100%;width:100%;background:var(--bg);border-left:1px solid var(--line);box-shadow:-8px 0 30px #00000073;display:flex;flex-direction:column;transform:translate(100%);transition:transform .28s var(--ease);padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}.notif-panel-overlay.open .notif-panel{transform:translate(0)}.notif-panel-header{display:flex;align-items:center;gap:8px;padding:12px;border-bottom:1px solid var(--line)}.notif-panel-title{font-size:16px;font-weight:700;color:var(--text)}.notif-panel-header .settings-wrapper{margin-left:auto}.notif-panel-close{background:none;border:none;cursor:pointer;color:var(--text-mid);display:inline-flex;align-items:center;justify-content:center;padding:6px;transition:color .18s var(--ease)}.notif-panel-close:hover{color:var(--text)}.notif-list{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.notif-item{padding:12px 16px;border-bottom:1px solid var(--border);font-size:.85rem;cursor:pointer}.notif-item:last-child{border-bottom:none}.notif-item.unread{background:var(--accent-light, rgba(100,200,150,.08))}.notif-item-head{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.notif-item-sender{font-weight:600;color:var(--accent)}.notif-item-time{flex-shrink:0;font-size:11px;color:var(--text-dim)}.notif-item-preview{color:var(--text-mid);margin-top:4px;white-space:normal;word-break:break-word;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notif-empty{height:100%;display:flex;align-items:center;justify-content:center;padding:24px;text-align:center;color:var(--text-muted, #888);font-size:.9rem}@media(min-width:900px){.app-root{display:flex;align-items:flex-start}.app-content{flex:1;min-width:0}.desktop-sidebar{display:flex;flex-direction:column;position:sticky;top:0;height:100vh;width:var(--sidebar-w);flex:none;padding:22px 14px 18px;border-right:1px solid var(--line);background:color-mix(in srgb,var(--surface) 60%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.sidebar-brand{display:inline-flex;align-items:center;gap:10px;padding:6px 12px;margin-bottom:22px;font-weight:800;font-size:19px;letter-spacing:-.02em;color:var(--text)}.sidebar-brand .brand-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 14px var(--accent)}.sidebar-nav{display:grid;gap:4px}.sidebar-nav-link{position:relative;display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:12px;color:var(--text-mid);font-size:14px;font-weight:600;transition:color .18s var(--ease),background .18s var(--ease)}.sidebar-nav-link:hover{color:var(--text);background:var(--surface-2)}.sidebar-nav-link.active{color:var(--accent);background:var(--accent-soft);font-weight:700}.sidebar-nav-link.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;border-radius:0 3px 3px 0;background:var(--accent);box-shadow:0 0 10px var(--accent)}.sidebar-nav-icon{width:20px;height:20px;stroke-width:1.8;fill:none;stroke:currentColor;flex:none}.sidebar-footer{margin-top:auto;padding-top:14px;border-top:1px solid var(--line-soft)}.sidebar-footer-row{display:flex;align-items:center;gap:4px}.sidebar-footer-row .sidebar-profile{flex:1;min-width:0}.sidebar-profile,.sidebar-login{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:12px;color:var(--text-mid);font-size:14px;font-weight:600;transition:color .18s var(--ease),background .18s var(--ease)}.sidebar-profile:hover,.sidebar-login:hover{color:var(--text);background:var(--surface-2)}.sidebar-profile-avatar{width:30px;height:30px;border-radius:999px;object-fit:cover;flex:none}.sidebar-profile-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-inner{max-width:none;margin:0;padding:14px 28px 12px;justify-content:flex-end}.header .brand-word,.header .header-spacer,.header .profile-pill,.header .badge,.notif-panel-header .settings-wrapper,.bottom-nav{display:none}.app-shell{max-width:none}.container{padding-bottom:32px}.events-list{max-width:var(--app-max);margin:0 auto;padding-bottom:32px}.fab{right:max(24px,calc((100vw - var(--sidebar-w) - var(--app-max)) / 2 + 24px));bottom:28px}.feed-detail-sticky{left:var(--sidebar-w);right:0;bottom:0;max-width:var(--app-max);margin:0 auto;border-top:1px solid var(--line)}}@media(min-width:1024px){.container:has(>.home-section){display:grid;grid-template-columns:minmax(0,1fr) 340px;align-items:start;gap:28px;max-width:1080px}.home-section:nth-child(1){order:2}.home-section:nth-child(2){order:1;margin-top:0}.home-section:nth-child(1){position:sticky;top:24px}.home-section .event-strip{flex-direction:column;overflow:visible;scroll-snap-type:none;gap:8px}.home-section .event-strip-card{flex:none;min-width:0;max-width:none;width:100%}.home-section .event-strip-image-wrap{display:none}.home-section .event-strip-body{padding:12px 14px}}
