*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

/* Keep only numeric glyphs on Arial while preserving each original font family. */
@font-face{
  font-family:'Noto Sans KR';
  src:local('Arial'),local('ArialMT');
  font-weight:400;
  unicode-range:U+0025,U+0028-0029,U+002B-002F,U+0030-003A;
}
@font-face{
  font-family:'Noto Sans KR';
  src:local('Arial Bold'),local('Arial-BoldMT'),local('Arial');
  font-weight:500;
  unicode-range:U+0025,U+0028-0029,U+002B-002F,U+0030-003A;
}
@font-face{
  font-family:'Noto Sans KR';
  src:local('Arial Bold'),local('Arial-BoldMT'),local('Arial');
  font-weight:700;
  unicode-range:U+0025,U+0028-0029,U+002B-002F,U+0030-003A;
}
@font-face{
  font-family:'Noto Sans KR';
  src:local('Arial Bold'),local('Arial-BoldMT'),local('Arial');
  font-weight:900;
  unicode-range:U+0025,U+0028-0029,U+002B-002F,U+0030-003A;
}
@font-face{
  font-family:'Black Han Sans';
  src:local('Arial'),local('ArialMT');
  font-weight:400;
  unicode-range:U+0025,U+0028-0029,U+002B-002F,U+0030-003A;
}

:root{
  --feed-card-max:740px;
  --orange:#EC221F;
  --orange2:#f04442;
  --red-btn-shadow:0 2px 8px rgba(255,69,0,.3);
  --orange-hover:#c91c1a;
  --orange-pale:#fef2f2;
  --orange-pale2:#fde8e8;
  --bg:#ffffff;
  --white:#ffffff;
  --surface:#fafaf9;
  --border:#e8e8e5;
  --border-light:#f0f0ed;
  --border-strong:#d4d4d0;
  --text:#0f0f0f;
  --text2:#2a2a2a;
  --text3:#454545;
  --muted:#8a8a86;
  --muted2:#8a8a86;
  --tag-bg:#f0f0ed;
  --header-h:56px;
  --page-top-gap:clamp(12px,2.2dvh,20px);
  --page-bottom-gap:var(--page-top-gap);
  --page-side-pad:clamp(14px,2.4vw,20px);
  --radius:14px;
  --radius-sm:6px;
  --shadow-sm:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);
}

html{scroll-behavior:smooth;scrollbar-gutter:stable}
html.login-modal-open{scrollbar-gutter:auto}
html.home-view-preload .page-wrap{visibility:hidden}
html.home-panel-preload #postFeed{display:none!important}
html.home-panel-preload[data-initial-home-panel="inquiry"] #inquiryFeed{display:block!important}
html.home-panel-preload[data-initial-home-panel="guideline"] #guidelineFeed{display:block!important}
html.home-panel-preload[data-initial-home-panel="inquiry"][data-initial-inquiry-mode="compose"] #inquiryListSection{display:none!important}
html.home-panel-preload[data-initial-home-panel="inquiry"][data-initial-inquiry-mode="compose"] #inquiryComposeCard{display:block!important}
html.auth-ui-preload #authBtns,
html.auth-ui-preload #userArea,
html.auth-ui-preload #langPicker,
html.auth-ui-preload #slLoginMsg,
html.auth-ui-preload #slProfile{
  visibility:hidden!important;
}
body{
  background:var(--bg);color:var(--text);
  font-family:'Noto Sans KR',sans-serif;
  font-size:14px;min-height:100vh;min-height:100dvh;
  -webkit-font-smoothing:antialiased;
}

/* ─── HEADER ─── */
header{
  position:sticky;top:0;z-index:300;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  height:var(--header-h);box-shadow:var(--shadow-sm);
}
.header-inner{
  max-width:1100px;margin:0 auto;height:100%;
  display:flex;align-items:center;padding:0 20px;gap:8px;
}
.logo{display:flex;align-items:center;text-decoration:none;flex-shrink:0;user-select:none}
.logo-img-pc{height:24px;width:auto;display:block}

.mobile-header-logo{display:none;align-items:center;text-decoration:none;flex-shrink:0}
.logo-img-mobile{height:16px;width:auto;display:block}

.gnb{display:flex;align-items:center;gap:1px;margin-left:8px}
.gnb-item{
  padding:6px 12px;font-size:14px;font-weight:600;color:var(--muted);
  border-radius:20px;cursor:pointer;border:none;background:none;
  font-family:'Noto Sans KR',sans-serif;white-space:nowrap;
  transition:background .15s,color .15s;letter-spacing:-.3px;
}
.gnb-item:hover{background:var(--tag-bg);color:var(--text2)}
.gnb-item.active{color:var(--orange);font-weight:700;background:var(--orange-pale)}

.header-search{flex:0 1 460px;width:460px;max-width:460px;position:relative;margin-left:8px}
.header-search input{
  width:100%;height:36px;background:var(--tag-bg);border:1.5px solid transparent;
  border-radius:20px;padding:0 14px 0 36px;
  font-size:13px;font-family:'Noto Sans KR',sans-serif;
  outline:none;color:var(--text);transition:border-color .2s,background .2s,box-shadow .2s;
}
.header-search input:focus{background:#fff;border-color:var(--orange);box-shadow:0 0 0 3px rgba(255,69,0,.1)}
.header-search input::placeholder{color:var(--muted2)}
.s-ico{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--muted2);pointer-events:none;font-size:14px}

.header-right{display:flex;align-items:center;gap:8px;margin-left:0}
#authBtns{margin-left:8px}
.hbtn{
  padding:7px 16px;border-radius:20px;font-size:13px;font-weight:700;
  cursor:pointer;border:none;font-family:'Noto Sans KR',sans-serif;
  white-space:nowrap;transition:all .15s;letter-spacing:-.2px;
}
.hbtn-join,
.s-btn-orange,
.post-edit-btn.save,
.post-confirm-btn.ok,
.sl-login-btn,
.btn-email-login,
.onboarding-submit,
.wm-submit,
.comm-join-btn,
.comm-submit-btn,
.btn-submit,
.lp-ok,
.acc-panel-btn,
.settings-edit-btn.btn-save,
.btn-save,
.delete-modal-btn:not(:disabled),
.post-confirm-btn.ok,
#coreAdminPwOk,
#coreAdminOffYes,
#profileAdminPwOk,
#profileAdminOffYes{
  box-shadow:var(--red-btn-shadow);
}
.post-confirm-btn.cancel,
.post-confirm-btn.ok,
#coreAdminPwCancel,
#coreAdminOffNo,
#profileAdminOffNo,
#profileAdminPwCancel,
#coreAdminPwOk,
#coreAdminOffYes,
#profileAdminPwOk,
#profileAdminOffYes{
  transition:transform .15s,box-shadow .2s,background .15s,border-color .15s,color .15s,filter .15s;
}
.post-confirm-btn.cancel:hover,
#coreAdminPwCancel:hover,
#coreAdminOffNo:hover,
#profileAdminOffNo:hover,
#profileAdminPwCancel:hover{
  background:#fff;
  border-color:#bcbcb6;
  transform:translateY(-1px);
  box-shadow:0 4px 10px rgba(0,0,0,.12);
}
.post-confirm-btn.cancel:active,
#coreAdminPwCancel:active,
#coreAdminOffNo:active,
#profileAdminOffNo:active,
#profileAdminPwCancel:active{
  transform:translateY(0) scale(.98);
  box-shadow:inset 0 1px 2px rgba(0,0,0,.08);
}
.post-confirm-btn.ok:hover,
#coreAdminPwOk:hover,
#coreAdminOffYes:hover,
#profileAdminPwOk:hover,
#profileAdminOffYes:hover{
  transform:translateY(-1px);
  box-shadow:0 4px 10px rgba(255,69,0,.4);
  filter:saturate(1.03);
}
.post-confirm-btn.ok:active,
#coreAdminPwOk:active,
#coreAdminOffYes:active,
#profileAdminPwOk:active,
#profileAdminOffYes:active{
  transform:translateY(0) scale(.98);
  box-shadow:0 3px 10px rgba(255,69,0,.3);
}
.hbtn-login{background:transparent;color:var(--text3);border:1.5px solid var(--border-strong)}
.hbtn-login:hover{border-color:var(--orange);color:var(--orange);background:var(--orange-pale)}
.hbtn-join{background:linear-gradient(135deg,var(--orange),var(--orange2));color:#fff;box-shadow:0 2px 8px rgba(255,69,0,.3)}
.hbtn-join:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(255,69,0,.4)}
.hbtn-login-join{
  padding:6px 12px;
  border-radius:16px;
  font-size:12px;
  font-weight:500;
  letter-spacing:-.25px;
  background:linear-gradient(180deg,#fff,#f8f8f7);
  color:var(--text3);
  border:1.5px solid #cfcfca;
  box-shadow:0 1px 2px rgba(0,0,0,.06);
}
.hbtn-login-join:hover{
  border-color:var(--orange);
  color:var(--orange);
  background:#fff;
  box-shadow:0 3px 8px rgba(255,69,0,.14);
}
.hbtn-lang{background:none;border:none;color:var(--text3);padding:7px 10px;font-size:13px;cursor:pointer;font-family:'Noto Sans KR',sans-serif;font-weight:500;transition:color .15s;display:flex;align-items:center;gap:6px;border-radius:20px}
.hbtn-lang:hover{color:var(--orange)}
.lang-icon{width:14px;height:14px;flex-shrink:0}

.lang-picker{position:relative;display:flex;align-items:center;margin-left:0}
.lang-menu{
  position:absolute;top:38px;right:0;z-index:350;min-width:120px;
  background:#fff;border:1px solid var(--border);border-radius:10px;
  box-shadow:0 10px 24px rgba(0,0,0,.12);padding:6px;display:none;
}
.lang-menu.open{display:block}
.lang-option{
  width:100%;border:none;background:transparent;border-radius:8px;
  padding:8px 10px;text-align:left;font-size:12px;font-weight:600;
  color:var(--text2);cursor:pointer;font-family:'Noto Sans KR',sans-serif;
}
.lang-option:hover{background:var(--tag-bg)}
.lang-option.active{color:var(--orange);background:var(--orange-pale)}

.user-area{display:none;align-items:center;gap:8px}
/* 알림 버튼 */
.hbtn-notif{
  position:relative;display:flex;align-items:center;justify-content:center;
  width:36px;height:36px;border:none;background:transparent;
  cursor:pointer;border-radius:50%;transition:background .15s;
  color:var(--text2);
}
.hbtn-notif svg{width:21px;height:21px}
.hbtn-notif:hover{background:var(--bg-hover,#f2f2f2)}
.notif-dot{
  position:absolute;top:5px;right:6px;
  width:9px;height:9px;border-radius:50%;
  background:var(--orange);border:1.5px solid #fff;
}
/* 알림 드롭다운 */
.notif-dropdown{
  position:absolute;top:calc(100% + 8px);right:0;
  width:259px;max-height:440px;
  background:#fff;border:1px solid var(--border);
  border-radius:14px;box-shadow:0 8px 30px rgba(0,0,0,.15);
  z-index:999;overflow:hidden;
  opacity:0;transform:translateY(-8px) scale(.97);
  pointer-events:none;
  transition:opacity .18s ease,transform .18s ease;
}
.notif-dropdown.open{
  opacity:1;transform:translateY(0) scale(1);
  pointer-events:auto;
}
.notif-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px 10px;border-bottom:1px solid var(--border-light);
}
.notif-header-title{font-size:16px;font-weight:700;color:var(--text)}
.notif-mark-read{
  font-size:12px;color:var(--orange);cursor:pointer;
  background:none;border:none;font-family:'Noto Sans KR',sans-serif;
  font-weight:600;
}
.notif-mark-read:hover{text-decoration:underline}
.notif-list{
  overflow-y:auto;max-height:370px;
  scrollbar-width:thin;
}
.notif-list::-webkit-scrollbar{width:4px}
.notif-list::-webkit-scrollbar-thumb{background:#ddd;border-radius:4px}
.notif-item{
  display:flex;align-items:flex-start;gap:10px;
  padding:8px 12px;cursor:pointer;
  transition:background .1s;
  border-bottom:1px solid var(--border-light);
  touch-action:manipulation;
}
.notif-item:last-child{border-bottom:none}
.notif-item:hover{background:#f9f9f9}
.notif-item.unread{background:#fff8f5}
.notif-item.unread:hover{background:#fff3ee}
.notif-item-avatar{
  width:30px;height:30px;border-radius:50%;flex-shrink:0;
  overflow:hidden;background:var(--surface);
  display:flex;align-items:center;justify-content:center;
}
.notif-item-avatar-link{
  display:flex;flex-shrink:0;text-decoration:none;
}
.notif-item-avatar img{width:100%;height:100%;object-fit:cover}
.notif-item-body{flex:1;min-width:0}
.notif-item-text{
  font-size:11px;color:var(--text);line-height:1.28;
  display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;
  overflow:hidden;
}
.notif-item-text .notif-actor-link{
  color:inherit;text-decoration:none;font-weight:700;
}
.notif-item-text .notif-actor-link:hover{color:var(--orange)}
.notif-item-text strong{font-weight:700}
.notif-item-time{font-size:11px;color:var(--muted);margin-top:1px}
.notif-item-unread-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--orange);flex-shrink:0;
  margin-top:4px;
}
.notif-empty{
  padding:40px 16px;text-align:center;
  font-size:13px;color:var(--muted);
}
.notif-dropdown-anchor{position:relative}
.user-avatar{
  width:32px;height:32px;border-radius:50%;
  background:var(--surface);border:1.5px solid var(--border-strong);
  display:flex;align-items:center;justify-content:center;
  color:var(--text3);font-size:13px;font-weight:700;
  cursor:pointer;overflow:hidden;
}
.user-avatar img{width:100%;height:100%;object-fit:cover}
.user-nick{font-size:13px;font-weight:700;color:var(--text2);max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hbtn-admin{
  display:none;align-items:center;gap:5px;
  padding:5px 12px;min-height:28px;
  border-radius:999px;
  background:var(--tag-bg);border:1px solid var(--border);
  cursor:pointer;color:#222;
  font-size:11px;font-weight:700;font-family:'Noto Sans KR',sans-serif;
  white-space:nowrap;transition:all .2s;
}
.hbtn-admin:hover{opacity:.8}
.admin-btn-label{pointer-events:none;color:#222}
.hbtn-admin svg{stroke:#222}
.hbtn-admin.active{
  background:rgba(236,34,31,.1);border-color:rgba(236,34,31,.4);
  color:var(--orange);
}
.hbtn-admin.active .admin-btn-label{color:var(--orange)}
.hbtn-admin.active svg{stroke:var(--orange)}
.hbtn-admin.active::before{
  content:'';width:6px;height:6px;border-radius:50%;
  background:var(--orange);flex-shrink:0;
  animation:adminPulse 1.5s ease-in-out infinite;
}
@keyframes adminPulse{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.4;transform:scale(.7)}
}
.hbtn-logout{
  padding:5px 12px;border-radius:20px;font-size:12px;font-weight:700;
  cursor:pointer;background:var(--tag-bg);color:var(--muted);
  border:none;font-family:'Noto Sans KR',sans-serif;
  transition:all .15s;
}
.hbtn-logout:hover{color:var(--orange);background:var(--orange-pale)}

.mobile-menu-btn{
  display:none;
  width:28px;height:28px;
  border:none;
  border-radius:0;
  background:transparent;
  color:var(--text2);
  align-items:center;
  justify-content:center;
  cursor:pointer;
  flex-shrink:0;
}
.mobile-menu-btn svg{width:20px;height:20px}

.mobile-menu-overlay{
  position:fixed;
  inset:0;
  z-index:520;
  background:rgba(0,0,0,.36);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:opacity .32s ease,visibility .32s ease;
}
.mobile-menu-overlay.open{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
}
.mobile-menu-overlay.closing{
  opacity:0;
  visibility:visible;
  pointer-events:none;
}
.mobile-menu-panel{
  width:min(286px,78vw);
  height:100%;
  background:#fff;
  border-right:1px solid var(--border);
  box-shadow:14px 0 36px rgba(0,0,0,.2);
  transform:translate3d(-102%,0,0);
  will-change:transform;
  transition:transform .46s cubic-bezier(.2,.9,.2,1);
  display:flex;
  flex-direction:column;
}
.mobile-menu-overlay.open .mobile-menu-panel{transform:translate3d(0,0,0)}
.mobile-menu-overlay.closing .mobile-menu-panel{transform:translate3d(-102%,0,0)}
.mobile-menu-head{
  height:56px;
  padding:0 12px 0 22px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  border-bottom:1px solid var(--border-light);
}
.mobile-menu-title{font-family:'Bebas Neue',sans-serif;font-size:24px;letter-spacing:1px}
.mobile-menu-title b{color:var(--orange)}
.mobile-menu-close{
  width:36px;height:36px;
  border:none;
  border-radius:0;
  background:transparent;
  color:var(--text);
  cursor:pointer;
  font-size:20px;
}
.mobile-menu-body{padding:10px;display:flex;flex-direction:column;gap:6px}
.mobile-profile-card{
  width:100%;
  border:none;
  border-radius:0;
  background:transparent;
  padding:8px 2px 10px;
  display:flex;
  align-items:flex-start;
  gap:10px;
  text-align:left;
  cursor:pointer;
  margin-bottom:2px;
}
.mobile-profile-card:active{background:transparent}
.mobile-profile-avatar{
  width:42px;
  height:42px;
  border-radius:50%;
  border:1.5px solid var(--border-strong);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  color:var(--text3);
  font-size:14px;
  font-weight:700;
  flex-shrink:0;
  background:var(--surface);
}
.mobile-profile-avatar img{width:100%;height:100%;object-fit:cover}
.mobile-profile-main{display:flex;flex-direction:column;gap:4px;min-width:0}
.mobile-profile-name{font-size:15px;font-weight:700;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mobile-profile-handle{font-size:12px;font-weight:700;color:var(--muted2);line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mobile-profile-meta{display:flex;align-items:center;gap:0;flex-wrap:wrap;margin-top:2px}
.mobile-profile-stat{display:inline-flex;align-items:center;gap:6px;position:relative}
.mobile-profile-stat + .mobile-profile-stat{padding-left:12px;margin-left:12px}
.mobile-profile-stat + .mobile-profile-stat::before{
  content:'';
  position:absolute;
  left:0;
  top:50%;
  width:1px;
  height:12px;
  background:var(--border-strong);
  transform:translateY(-50%);
}
.mobile-profile-stat b{
  font-family:'Bebas Neue',sans-serif;
  font-size:22px;
  font-weight:400;
  color:var(--text);
  line-height:1;
  transform:translateY(1px);
}
.mobile-profile-stat span{
  font-size:12px;
  color:var(--muted);
  font-weight:700;
  letter-spacing:.2px;
  line-height:1.15;
}
.mobile-menu-item{
  width:100%;
  min-height:42px;
  padding:0 12px;
  border:none;
  border-radius:10px;
  background:transparent;
  text-align:left;
  display:flex;
  align-items:center;
  gap:10px;
  font-size:14px;
  font-weight:700;
  color:var(--text2);
  font-family:'Noto Sans KR',sans-serif;
  cursor:pointer;
  opacity:0;
  transform:translateX(-10px);
  transition:background .15s,color .15s,opacity .24s ease,transform .24s ease;
}
.mobile-menu-item i,.mobile-menu-item svg{width:16px;height:16px;flex-shrink:0}
.mobile-menu-item{-webkit-tap-highlight-color:transparent}
.mobile-menu-item:active{background:var(--tag-bg)}
.mobile-menu-item.strong{background:var(--orange-pale);color:var(--orange)}
.mobile-menu-item.create-toggle{justify-content:space-between;padding-right:10px}
.mobile-menu-item-main{display:flex;align-items:center;gap:10px}
.mobile-create-chevron{width:16px;height:16px;flex-shrink:0;transition:transform .16s ease}
.mobile-menu-item.create-toggle[aria-expanded="true"] .mobile-create-chevron{transform:rotate(180deg)}
.mobile-create-submenu{display:none;flex-direction:column;gap:6px;padding-left:12px}
.mobile-create-submenu.open{display:flex}
.mobile-menu-subitem{
  width:100%;
  min-height:38px;
  padding:0 12px;
  border:none;
  border-radius:10px;
  background:transparent;
  text-align:left;
  display:flex;
  align-items:center;
  gap:10px;
  font-size:13px;
  font-weight:700;
  color:var(--text3);
  font-family:'Noto Sans KR',sans-serif;
  cursor:pointer;
}
.mobile-menu-subitem i,.mobile-menu-subitem svg{width:15px;height:15px;flex-shrink:0}
.mobile-menu-subitem{-webkit-tap-highlight-color:transparent}
.mobile-menu-subitem:active{background:transparent;color:var(--text3)}
.mobile-menu-overlay.open .mobile-menu-item{opacity:1;transform:translateX(0)}
.mobile-menu-overlay.open .mobile-menu-item:nth-child(1){transition-delay:.03s}
.mobile-menu-overlay.open .mobile-menu-item:nth-child(2){transition-delay:.05s}
.mobile-menu-overlay.open .mobile-menu-item:nth-child(3){transition-delay:.07s}
.mobile-menu-overlay.open .mobile-menu-item:nth-child(4){transition-delay:.09s}
.mobile-menu-overlay.open .mobile-menu-item:nth-child(5){transition-delay:.11s}
.mobile-menu-overlay.open .mobile-menu-item:nth-child(6){transition-delay:.13s}
.mobile-menu-overlay.open .mobile-menu-item:nth-child(7){transition-delay:.15s}

@media(hover:hover) and (pointer:fine){
  .mobile-menu-item:hover{background:var(--tag-bg)}
  .mobile-menu-subitem:hover{background:transparent;color:var(--text3)}
}

/* ─── LAYOUT ─── */
.page-wrap{
  max-width:1280px;margin:0 auto;padding:var(--page-top-gap) var(--page-side-pad) var(--page-bottom-gap);
  display:grid;grid-template-columns:264px minmax(700px,1fr) 264px;gap:18px;
  justify-content:center;
}
.page-wrap > div{min-width:0}

/* ─── SORT BAR ─── */
.sort-bar{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:10px 14px;display:flex;align-items:center;gap:6px;
  margin-bottom:14px;box-shadow:var(--shadow-sm);
}
#postFeed{max-width:100%;padding:0;}
.sort-bar{max-width:100%;}
.sidebar{position:static;align-self:start}
.sort-btn{
  display:flex;align-items:center;gap:5px;padding:7px 14px;border-radius:20px;
  font-size:13px;font-weight:700;color:var(--muted);cursor:pointer;
  border:none;background:none;font-family:'Noto Sans KR',sans-serif;transition:all .15s;
}
.sort-btn:hover{color:var(--text);background:var(--tag-bg)}
.sort-btn.active{color:var(--orange);background:var(--orange-pale)}

/* ─── WRITE BOX ─── */
.write-box{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:12px 14px;display:flex;align-items:center;gap:10px;
  margin-bottom:14px;cursor:pointer;box-shadow:var(--shadow-sm);
  transition:border-color .15s;
}
.write-box:hover{border-color:var(--orange)}
.write-avatar{
  width:38px;height:38px;border-radius:50%;
  background:var(--surface);border:1.5px solid var(--border-strong);
  display:flex;align-items:center;justify-content:center;
  color:var(--text3);font-size:15px;font-weight:700;flex-shrink:0;overflow:hidden;
}
.write-avatar img{width:100%;height:100%;object-fit:cover}
.write-placeholder{
  flex:1;padding:9px 14px;background:var(--tag-bg);border-radius:20px;
  font-size:13px;color:var(--muted2);cursor:pointer;
  border:1.5px solid transparent;transition:border-color .15s;
}
.write-box:hover .write-placeholder{border-color:var(--orange-pale2)}

/* ─── CARD FEED ─── */
.post-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  max-width:var(--feed-card-max);
  margin:0 auto 10px;
  box-shadow:var(--shadow-sm);
  transition:border-color .15s;overflow:visible;
  position:relative;
}
.post-card:hover{border-color:var(--border-strong)}

.post-card-header{
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  width:min(calc(95% - 10px),690px);
  margin:0 auto;
  padding:16px 0 8px;
}
.post-head-left{display:flex;align-items:flex-start;gap:8px;min-width:0}
.post-rank-strip{
  width:100%;
  padding:12px 0 10px;
  border-bottom:1px solid var(--border);
}
.post-rank-number-wrap{
  width:min(calc(95% - 10px),690px);
  margin:0 auto;
}
.post-rank-number{
  display:inline-block;
  margin-left:16px;
  transform:translateX(-50%);
  font-family:'Bebas Neue',sans-serif;
  font-size:20px;
  line-height:1;
  color:var(--orange);
}
.post-rank-strip + .post-card-header{padding-top:12px}
.post-author-avatar{
  width:34px;height:34px;border-radius:50%;
  background:var(--surface);border:1.5px solid var(--border-strong);
  display:flex;align-items:center;justify-content:center;
  color:var(--text3);font-size:12px;font-weight:700;flex-shrink:0;overflow:hidden;
}
.post-author-avatar-link,
.post-comment-avatar-link{
  appearance:none;
  padding:0;
  margin:0;
  cursor:pointer;
  text-decoration:none;
  color:inherit;
}
.post-author-avatar-link{
  border:none;
  background:none;
}
.post-comment-avatar-link{
  border:1px solid var(--border-strong);
  background:var(--surface);
}
.post-author-avatar-empty{
  border:1.5px solid var(--border-strong)!important;
  background:var(--surface)!important;
}
.post-author-avatar img{width:100%;height:100%;object-fit:cover}
.post-author-info{min-width:0;padding-top:1px;display:flex;flex-direction:column;gap:0}
.post-head-left > .post-author-info{flex:0 1 auto}
.post-head-left > .post-author-community{align-self:flex-start;flex-shrink:1;min-width:0;margin-top:0}
.post-author-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap;min-width:0}
.post-author-name{font-size:14px;font-weight:700;color:var(--text2);line-height:1.2;transition:color .15s ease}
.post-author-name-link{
  appearance:none;
  border:none;
  background:none;
  padding:0;
  margin:0;
  cursor:pointer;
  text-align:left;
  font-family:'Noto Sans KR',sans-serif;
  font-size:14px;
  font-weight:700;
  line-height:1.2;
  color:var(--text2);
}
.post-author-name-link:hover{color:var(--orange)}
.post-author-name-link:focus-visible{
  outline:2px solid rgba(236,34,31,.18);
  outline-offset:4px;
  border-radius:8px;
}
.post-author-community{
  display:inline-flex;
  align-items:center;
  gap:6px;
  min-width:0;
  max-width:188px;
  height:22px;
  padding:0 8px 0 6px;
  border:none;
  border-radius:999px;
  background:#F0F0ED;
  box-sizing:border-box;
  font-size:11px;
  font-weight:600;
  color:var(--text2);
  line-height:1.2;
  text-decoration:none;
  transition:border-color .15s ease,color .15s ease,background .15s ease;
}
.post-author-community-avatar{
  width:16px;
  height:16px;
  border-radius:50%;
  border:1px solid var(--border-light);
  background:var(--surface);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  flex-shrink:0;
}
.post-author-community-avatar img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.post-author-community-avatar svg{
  width:75%;
  height:75%;
}
.post-author-community-name{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.post-author-community:hover{
  color:var(--orange);
  background:#fff7f6;
}
.post-author-handle{font-size:11px;color:var(--muted);line-height:1.3;margin:0 0 2px}
.post-author-time{font-size:11px;color:var(--muted2);line-height:1.3}
.post-card-header-expanded .post-author-handle,
.post-card-header-expanded .post-author-time{font-size:12px}

.post-more{position:relative;flex-shrink:0}
.post-more-btn{
  width:30px;height:30px;border-radius:50%;border:none;background:transparent;color:#111;
  display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;
}
.post-card-header .post-more,
.post-card-header-expanded .post-more{margin-top:2px;align-self:flex-start}
.post-more-btn:hover{background:var(--tag-bg);color:#111}
.post-more-btn svg{width:16px;height:16px}
.post-more-menu{
  position:absolute;top:34px;right:0;z-index:20;min-width:112px;background:#fff;border:1px solid var(--border);
  border-radius:10px;box-shadow:0 10px 24px rgba(0,0,0,.12);padding:6px;display:none;
}
.post-more.open .post-more-menu{display:block}
.post-more-item{
  width:100%;display:flex;align-items:center;gap:6px;border:none;background:transparent;border-radius:8px;
  min-height:34px;padding:7px 9px;font-size:12px;font-weight:700;color:var(--text2);cursor:pointer;font-family:'Noto Sans KR',sans-serif;line-height:1;
}
.post-more-item i,.post-more-item svg{width:14px;height:14px;display:block;flex-shrink:0}
.post-more-item span{display:block;line-height:1;transform:translateY(-.5px)}
.post-more-item:hover{background:var(--tag-bg)}
.post-more-item.delete{color:#cb3a00}
.post-more-item.delete:hover{background:#fff1ec}

.post-card-body{width:min(calc(95% - 10px),690px);margin:0 auto;padding:0 0 8px;cursor:pointer}
.post-card.no-image .post-card-body{padding:0 0 8px}
.post-card.no-image:has(.post-card-fullview) .post-card-body{padding:0 0 7px}
.post-card-title{
  font-size:18px;font-weight:700;color:var(--text);
  line-height:1.45;margin-bottom:4px;letter-spacing:-.2px;
}
.post-card-title:hover{color:var(--orange)}
.post-card-text{
  font-size:14px;color:var(--text3);line-height:1.7;
  display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
}
.post-card-text.compact{-webkit-line-clamp:2;line-clamp:2}
.post-card-text.expanded{display:block;-webkit-line-clamp:unset;line-clamp:unset;overflow:visible;white-space:pre-wrap;word-break:break-word}
.post-more-toggle{
  margin-top:4px;padding:0;border:none;background:transparent;cursor:pointer;
  color:var(--muted);font-size:12px;font-weight:700;font-family:'Noto Sans KR',sans-serif;
}
.post-more-toggle:hover{color:var(--orange)}
.post-card-thumb-wrap{
  width:min(calc(95% - 10px),690px);
  margin:0 auto 12px;
  padding:0;
  border-radius:var(--radius);
  overflow:hidden;
}
.post-card-thumb-stage{
  position:relative;
  width:100%;
  margin:0 auto;
  display:flex;
  align-items:flex-start;
  justify-content:center;
  aspect-ratio:16/11;
  border-radius:var(--radius);
  overflow:hidden;
  border:1px solid var(--border-light);
  background:linear-gradient(145deg,#eceff4,#dfe4ec);
  cursor:pointer;
  --thumb-content-width:100%;
  --thumb-content-height:100%;
}
.post-card-thumb-stage::before{
  content:'';
  position:absolute;
  top:0;
  left:50%;
  width:var(--thumb-content-width);
  height:var(--thumb-content-height);
  transform:translateX(-50%);
  pointer-events:none;
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(18px) saturate(1.35);
  z-index:1;
}
.post-card-thumb-stage::after{
  content:'';
  position:absolute;
  inset:0;
  z-index:3;
  pointer-events:none;
  background:
    radial-gradient(circle at 18% 18%,rgba(255,255,255,.34),rgba(255,255,255,0) 32%),
    linear-gradient(115deg,rgba(255,255,255,.22),rgba(255,255,255,0) 38%,rgba(255,255,255,.14) 72%,rgba(255,255,255,0));
  mix-blend-mode:screen;
}
.post-card-thumb-blur{
  position:absolute;
  inset:-28px;
  width:calc(100% + 56px);
  height:calc(100% + 56px);
  object-fit:cover;
  filter:blur(48px) saturate(1.85) contrast(1.02) brightness(1.08);
  transform:scale(1.2);
  opacity:.62;
  z-index:0;
  pointer-events:none;
}
.post-card-thumb-stage.is-wide .post-card-thumb-blur,
.post-card-thumb-stage.is-wide::before,
.post-card-thumb-stage.is-wide::after{display:none}
.post-card-thumb-stage.is-wide{
  aspect-ratio:auto;
  background:transparent;
}
.post-card-thumb{
  position:relative;
  z-index:2;
  width:100%;
  height:100%;
  max-width:none;
  max-height:none;
  object-fit:contain;
  object-position:center top;
  display:block;
  background:transparent;
}
.post-card-thumb-stage.is-wide .post-card-thumb{
  width:100%;
  height:auto;
  max-width:none;
  max-height:none;
  object-fit:unset;
}
.post-card-img{width:100%;border-radius:10px;display:block;object-fit:cover}

.post-card-fullview{
  width:min(calc(95% - 10px),690px);
  margin:0 auto;
  padding:0 0 12px;
  display:flex;
  justify-content:center;
}
.post-fullview-btn{
  border:none;
  background:var(--tag-bg);
  color:var(--text3);
  border-radius:999px;
  height:auto;
  font-size:12px;
  font-weight:700;
  font-family:'Noto Sans KR',sans-serif;
  cursor:pointer;
  transition:all .15s;
  padding:6px 11px;
  line-height:1.2;
}
.post-fullview-btn:hover{color:var(--orange);background:var(--orange-pale)}

.post-card.expanded{margin-bottom:14px}
.post-card-header-expanded{
  width:min(calc(100% - 40px),700px);
  padding-top:8px;
  padding-bottom:10px;
}
.post-card-body-expanded{
  width:min(calc(100% - 40px),700px);
  cursor:default;
  padding:0 0 4px;
}
.post-expanded-top{
  width:min(calc(100% - 40px),700px);
  margin:20px auto 12px;
  display:flex;
  align-items:center;
  justify-content:flex-start;
}
.post-expanded-back{
  display:inline-flex;align-items:center;gap:5px;
  border:none;border-radius:999px;padding:6px 11px;
  background:var(--tag-bg);color:var(--text3);
  font-size:12px;font-weight:700;cursor:pointer;
  font-family:'Noto Sans KR',sans-serif;transition:all .15s;
}
.post-expanded-back:hover{color:var(--orange);background:var(--orange-pale)}
.post-expanded-back i,.post-expanded-back svg{width:14px;height:14px;display:block;flex-shrink:0}
.post-card-title-expanded{
  font-size:24px;
  line-height:1.22;
  margin-bottom:8px;
  letter-spacing:-.4px;
}
.post-detail-body{
  font-size:15px;
  color:var(--text2);
  line-height:1.82;
  padding:0;
  white-space:pre-wrap;
  word-break:break-word;
}
.post-detail-body a{color:var(--orange);text-decoration:none}
.post-detail-body a:hover{text-decoration:underline}
.post-detail-body p,
.post-detail-body div,
.post-detail-body blockquote,
.post-detail-body ul,
.post-detail-body ol,
.post-detail-body pre{margin:0 0 12px}
.post-detail-body > :last-child{margin-bottom:0}
.post-detail-body blockquote{
  border-left:3px solid var(--orange-pale2);
  padding-left:12px;
  color:var(--text3);
}
.post-detail-body pre{
  overflow:auto;
  border-radius:10px;
  background:#f7f6f4;
  padding:12px;
  border:1px solid var(--border-light);
}
.post-detail-body code{
  font-family:'SFMono-Regular',Consolas,'Liberation Mono',Menlo,monospace;
  font-size:.92em;
}
.post-inline-image{
  max-width:100%;
  margin:12px 0;
  border:1px solid var(--border-light);
  border-radius:10px;
  overflow:hidden;
  background:#fff;
}
.post-inline-image img{width:100%;height:auto;display:block}
.post-detail-images{display:grid;gap:10px;margin-top:14px}
.post-detail-images img{
  width:100%;
  border-radius:10px;
  display:block;
  object-fit:cover;
  border:1px solid var(--border-light);
}
.post-card-footer-expanded{margin-top:16px;padding-top:12px;padding-bottom:12px}
.post-comments{
  width:min(calc(100% - 40px),700px);
  margin:0 auto 18px;
  padding-top:16px;
  border-top:1px solid var(--border-light);
  overflow-anchor:none;
}
.post-comments-head{
  font-size:14px;
  font-weight:700;
  color:var(--text2);
  margin-bottom:10px;
}
.post-comment-editor{
  display:flex;
  flex-direction:column;
  gap:10px;
  align-items:stretch;
  margin-bottom:10px;
  position:relative;
  z-index:6;
}
.post-comment-input{
  flex:none;
  width:100%;
  height:auto;
  min-height:44px;
  max-height:none;
  border:1.5px solid var(--border-strong);
  border-radius:15px;
  padding:10px 13px;
  font-family:'Noto Sans KR',sans-serif;
  font-size:13px;
  line-height:1.55;
  resize:none;
  overflow:hidden;
  overflow-y:hidden;
  box-sizing:border-box;
  outline:none;
  display:block;
  position:relative;
  z-index:6;
}
.post-comment-input:not(.post-inline-reply-input){padding:11px 13px 9px}
.post-comment-input:focus{border-color:var(--orange);box-shadow:0 0 0 3px rgba(255,69,0,.1)}
.post-comment-side{
  display:flex;
  width:100%;
  box-sizing:border-box;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  opacity:0;
  max-height:0;
  overflow:hidden;
  transform:translateY(-6px);
  pointer-events:none;
  transition:opacity .28s ease,transform .28s ease,max-height .28s ease,margin-top .28s ease;
  margin-top:-4px;
  position:relative;
  z-index:6;
}
.post-comment-editor:focus-within .post-comment-side{
  opacity:1;
  max-height:64px;
  transform:translateY(0);
  pointer-events:auto;
  margin-top:0;
  overflow:visible;
}
.post-comment-actions{display:flex;align-items:center;gap:8px;justify-content:flex-end}
.post-comment-cancel,
.post-comment-submit{
  border-radius:999px;
  font-weight:800;
  font-size:11px;
  cursor:pointer;
  font-family:'Noto Sans KR',sans-serif;
  transition:all .15s;
  letter-spacing:-.2px;
  min-width:58px;
  min-height:32px;
  padding:6px 12px;
}
.post-comment-cancel{
  background:#fff;
  border:1.5px solid var(--border-strong);
  color:var(--text2);
}
.post-comment-cancel:hover{background:#fff;border-color:#bcbcb6;transform:translateY(-1px);box-shadow:0 4px 10px rgba(0,0,0,.12)}
.post-comment-cancel:active{transform:translateY(0) scale(.98);box-shadow:inset 0 1px 2px rgba(0,0,0,.08)}
.post-comment-submit{
  border:none;
  background:linear-gradient(135deg,var(--orange),var(--orange2));
  color:#fff;
  box-shadow:0 2px 8px rgba(255,69,0,.3);
}
.post-comment-submit:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(255,69,0,.4)}
.post-comment-submit:active{transform:translateY(0) scale(.98);box-shadow:0 3px 10px rgba(255,69,0,.3)}
.post-comment-tools{display:none}
.post-comment-anon-inline{margin-left:0;padding-left:0;align-self:flex-start}
.anon-inline{display:flex;align-items:center;gap:6px;flex-shrink:0}
.anon-inline-label{font-size:11px;color:var(--muted);font-weight:600;transition:color .2s}
.anon-inline-label.active{color:var(--orange)}
.anon-toggle-sm{
  width:36px;
  height:20px;
  border:none;
  border-radius:99px;
  background:var(--border-strong);
  cursor:pointer;
  position:relative;
  transition:background .2s;
  flex-shrink:0;
  appearance:none;
  padding:0;
  display:inline-flex;
  align-items:center;
}
.anon-toggle-sm.on{background:var(--orange)}
.anon-thumb-sm{
  width:14px;
  height:14px;
  border-radius:50%;
  background:#fff;
  position:absolute;
  top:3px;
  left:3px;
  transition:left .2s;
  box-shadow:0 1px 3px rgba(0,0,0,.2)
}
.anon-toggle-sm.on .anon-thumb-sm{left:19px}
.anon-tooltip-wrap{position:relative;display:inline-flex;align-items:center}
.anon-tooltip{
  position:absolute;
  bottom:calc(100% + 7px);
  left:50%;
  transform:translateX(-50%) translateY(4px);
  background:rgba(20,20,20,.88);
  color:#fff;
  font-size:11px;
  font-weight:500;
  white-space:nowrap;
  padding:5px 10px;
  border-radius:7px;
  opacity:0;
  pointer-events:none;
  transition:opacity .15s,transform .15s;
  z-index:20
}
.anon-tooltip::after{
  content:'';
  position:absolute;
  top:100%;
  left:50%;
  transform:translateX(-50%);
  border:5px solid transparent;
  border-top-color:rgba(20,20,20,.88)
}
.anon-tooltip-wrap:hover .anon-tooltip{opacity:1;transform:translateX(-50%) translateY(0)}
.post-comment-reply-target{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  border:1px solid rgba(255,69,0,.18);
  background:rgba(255,69,0,.06);
  border-radius:12px;
  padding:10px 12px;
}
.post-comment-reply-target-copy{display:flex;flex-direction:column;gap:3px;min-width:0}
.post-comment-reply-target-label{
  font-size:11px;
  font-weight:800;
  color:var(--orange);
  letter-spacing:-.1px;
}
.post-comment-reply-target-text{
  font-size:12px;
  color:var(--text2);
  font-weight:600;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.post-comment-reply-target-cancel{
  border:none;
  background:transparent;
  color:var(--muted2);
  cursor:pointer;
  font-size:12px;
  font-weight:700;
  flex-shrink:0;
}
.post-comment-reply-target-cancel:hover{color:var(--text2)}
.post-inline-reply-editor{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin:8px 0 2px var(--comment-content-offset);
  padding:0;
  border-top:none;
  overflow:hidden;
  transform-origin:top;
  transition:max-height .22s cubic-bezier(.22,1,.36,1),opacity .22s ease,transform .22s cubic-bezier(.22,1,.36,1);
  animation:replyEditorReveal .22s cubic-bezier(.22,1,.36,1);
}
.post-inline-reply-editor.is-closing{
  opacity:0;
  transform:translateY(-4px);
  pointer-events:none;
}
.post-inline-reply-head{
  font-size:12px;
  color:var(--text2);
  font-weight:700;
  line-height:1.45;
}
.post-inline-reply-input{
  min-height:44px;
  padding:11px 13px 9px;
}
@keyframes replyEditorReveal{
  0%{
    opacity:0;
    transform:translateY(-8px);
  }
  100%{
    opacity:1;
    transform:translateY(0);
  }
}
.post-comment-list{
  display:flex;
  flex-direction:column;
  gap:6px;
  overflow-anchor:none;
  --comment-avatar-size:34px;
  --comment-avatar-center:17px;
  --comment-meta-gap:6px;
  --comment-content-offset:40px;
  --comment-thread-indent:15px;
  --comment-thread-pad:21px;
  --comment-thread-stroke:1px;
  --comment-thread-hit-stroke:12px;
  --comment-thread-color:#dcdcd7;
  --comment-thread-hover:#111111;
}
.post-comment-thread{
  position:relative;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.post-comment-thread.is-reply-thread{
  margin-left:var(--comment-thread-indent);
  padding-left:var(--comment-thread-pad);
}
.post-comment-replies{
  position:relative;
  display:flex;
  flex-direction:column;
  gap:6px;
  animation:commentRepliesReveal .24s cubic-bezier(.22,1,.36,1);
  transform-origin:top left;
}
.post-comment-replies.no-reveal,
.post-comment-list.skip-replies-reveal .post-comment-replies{
  animation:none!important;
}
.post-comment-replies.is-collapsing{
  animation:none!important;
  overflow:hidden;
  pointer-events:none;
  transition:
    height .22s cubic-bezier(.22,1,.36,1),
    opacity .18s ease,
    transform .22s cubic-bezier(.22,1,.36,1);
}
.post-comment-replies::before{
  content:none;
}
.post-comment-thread.is-reply-thread::after{
  content:none;
}
@keyframes commentRepliesReveal{
  0%{
    opacity:0;
    transform:translateY(-4px) scaleY(.96);
  }
  100%{
    opacity:1;
    transform:translateY(0) scaleY(1);
  }
}
.post-comment-thread-connector{
  position:absolute;
  left:0;
  top:0;
  display:block;
  overflow:visible;
  z-index:2;
}
.post-comment-thread-connector-line{
  fill:none;
  stroke:var(--comment-thread-color);
  stroke-width:var(--comment-thread-stroke);
  stroke-linecap:round;
  stroke-linejoin:round;
  vector-effect:non-scaling-stroke;
  shape-rendering:geometricPrecision;
  pointer-events:none;
  transition:stroke .16s ease;
}
.post-comment-thread-connector-fade{
  pointer-events:none;
}
.post-comment-thread.is-replies-collapsing .post-comment-thread-connector-hit{
  pointer-events:none;
}
.post-comment-thread-connector-hit{
  fill:none;
  stroke:rgba(0,0,0,.001);
  stroke-width:var(--comment-thread-hit-stroke);
  stroke-linecap:round;
  stroke-linejoin:round;
  vector-effect:non-scaling-stroke;
  pointer-events:stroke;
  cursor:default;
}
.post-comment-thread-connector.is-hovered .post-comment-thread-connector-line{
  stroke:var(--comment-thread-hover);
}
.post-comment-item{
  position:relative;
  border:none;
  border-radius:0;
  padding:6px 0 6px;
  background:transparent;
  box-shadow:none;
}
.post-comment-item.is-reply{
  background:transparent;
  border-color:transparent;
}
.post-comment-meta{
  display:flex;
  align-items:flex-start;
  gap:var(--comment-meta-gap);
  margin-bottom:0;
  position:relative;
  z-index:4;
  min-height:var(--comment-avatar-size);
}
.post-comment-meta-main{
  display:flex;
  align-items:center;
  gap:var(--comment-meta-gap);
  min-width:0;
  min-height:30px;
  flex:1 1 auto;
  flex-wrap:wrap;
  align-content:center;
}
.post-comment-avatar{
  position:relative;
  z-index:3;
  width:var(--comment-avatar-size);height:var(--comment-avatar-size);border-radius:50%;border:1px solid var(--border-strong);
  display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;
  color:var(--text3);overflow:hidden;flex-shrink:0;background:var(--surface);
}
.post-comment-avatar img{width:100%;height:100%;object-fit:cover}
.post-comment-author{
  display:inline-flex;
  align-items:center;
  font-size:14px;
  font-weight:700;
  color:var(--text2);
  font-family:inherit;
  line-height:1.1;
  letter-spacing:0;
  white-space:nowrap;
}
.post-comment-handle,
.post-comment-time{
  display:inline-flex;
  align-items:center;
  font-size:12px;
  color:var(--muted2);
  font-weight:400;
  line-height:1.1;
  white-space:nowrap;
}
.post-comment-body{
  margin-top:-5px;
  margin-left:var(--comment-content-offset);
  font-size:13px;
  line-height:1.6;
  color:var(--text2);
  white-space:pre-wrap;
  word-break:break-word;
  position:relative;
  z-index:4;
  user-select:text;
  -webkit-user-select:text;
}
.post-comment-mention{
  display:inline-block;
  border:none;
  background:none;
  padding:0;
  margin:0;
  color:var(--orange);
  font:inherit;
  font-weight:inherit;
  cursor:pointer;
  text-decoration:none;
  vertical-align:baseline;
  transition:color .18s ease,text-shadow .18s ease,filter .18s ease;
}
.post-comment-mention:not(.is-static):hover{
  color:#ff5a1f;
  animation:commentMentionGlow .95s ease-in-out infinite alternate;
}
.post-comment-mention.is-static{cursor:default;text-decoration:none}
.post-comment-mention.is-static:hover{
  color:var(--orange);
  text-shadow:none;
  filter:none;
}
@keyframes commentMentionGlow{
  0%{
    text-shadow:
      0 0 0 rgba(255,69,0,0),
      0 0 0 rgba(255,128,92,0),
      0 0 0 rgba(255,90,31,0),
      0 0 0 rgba(255,90,31,0);
    filter:brightness(1);
  }
  100%{
    text-shadow:
      0 0 6px rgba(255,69,0,.24),
      0 0 14px rgba(255,128,92,.18),
      .18px 0 0 rgba(255,90,31,.7),
      -.18px 0 0 rgba(255,90,31,.7);
    filter:brightness(1.05);
  }
}
.post-comment-empty{font-size:12px;color:var(--muted2);padding:6px 2px}
.post-comment-foot{
  display:flex;
  align-items:center;
  gap:8px;
  row-gap:6px;
  margin-top:5px;
  margin-left:var(--comment-content-offset);
  flex-wrap:wrap;
  position:relative;
  z-index:4;
}
.post-comment-foot-break{
  flex-basis:100%;
  width:0;
  height:0;
  pointer-events:none;
}
.post-comment-reply-btn,
.post-comment-replies-toggle{
  border:none;
  background:transparent;
  padding:0;
  cursor:pointer;
  color:#2A2A2A;
  font-size:12px;
  font-weight:700;
  font-family:inherit;
  line-height:1.2;
  letter-spacing:0;
  position:relative;
  z-index:5;
}
.post-comment-reply-btn:hover,
.post-comment-replies-toggle:hover{color:#2A2A2A}
.post-comment-replies-toggle{
  position:relative;
  order:20;
  display:inline-flex;
  align-items:center;
  gap:6px;
  flex:0 0 auto;
  width:auto;
  max-width:max-content;
  margin-left:7px;
  margin-top:4px;
  padding-left:0;
  align-self:flex-start;
}
.post-comment-replies-toggle::before{
  content:none;
}
.post-comment-replies-toggle::after{
  content:'';
  display:inline-block;
  width:7px;
  height:7px;
  border-right:2px solid currentColor;
  border-bottom:2px solid currentColor;
  transform:rotate(45deg) translateY(-1px);
  opacity:.85;
}
.post-comment-replies-toggle.is-open::after{transform:rotate(-135deg) translateY(-1px)}
.post-comment-more{
  margin-left:auto;
  align-self:flex-start;
  position:relative;
  z-index:30;
}
.post-comment-more.open{z-index:99990}
.post-comment-more .post-more-btn{
  width:30px;
  height:30px;
}
.post-comment-more .post-more-btn svg{
  width:16px;
  height:16px;
}
.post-comment-more .post-more-menu{
  top:34px;
  right:0;
  min-width:112px;
  z-index:90;
  pointer-events:auto;
}
.post-comment-more.is-floating-menu .post-more-menu{
  position:fixed;
  top:var(--comment-menu-top,0);
  left:var(--comment-menu-left,0);
  right:auto;
  display:block;
  z-index:99990;
  min-width:156px;
  background:#fff;
  border-color:rgba(212,212,208,.95);
  box-shadow:0 18px 42px rgba(0,0,0,.18);
  isolation:isolate;
}
.post-comment-more .post-more-item{
  min-height:34px;
}
.post-comment-edit,.post-comment-delete{
  border:none;background:transparent;color:#2A2A2A;cursor:pointer;font-size:12px;font-weight:700;font-family:inherit;line-height:1.2;letter-spacing:0;
}
.post-comment-edit:hover{color:#2A2A2A}
.post-comment-delete:hover{color:#2A2A2A}
.post-comment-edit-editor{
  margin:2px 0 0 var(--comment-content-offset);
  padding:0;
  border-top:none;
}
.post-comment-edit-editor .post-comment-input{
  min-height:44px;
}
@media (max-width:560px){
  .post-comment-list{
    --comment-thread-indent:13px;
    --comment-thread-pad:18px;
  }
  .post-comment-reply-target{padding:9px 10px}
  .post-inline-reply-editor{
    margin-left:var(--comment-content-offset);
    padding-top:0;
  }
  .post-comment-replies-toggle{
    margin-left:6px;
    padding-left:0;
  }
  .post-comment-replies-toggle::after{
    width:6px;
    height:6px;
  }
}

.post-card-footer{
  display:flex;align-items:center;gap:2px;
  width:min(calc(95% - 10px),690px);
  margin:0 auto;
  padding:8px 0 10px;
  border-top:1px solid var(--border-light);
}
.post-action{
  display:flex;align-items:center;gap:3px;padding:5px 6px;border-radius:15px;
  font-size:12px;font-weight:700;color:var(--text3);cursor:pointer;
  border:none;background:none;font-family:'Noto Sans KR',sans-serif;
  transition:color .1s,background .1s;white-space:nowrap;line-height:14px;
}
.post-action span{display:inline-flex;align-items:center;line-height:14px}
.post-action i,.post-action svg{width:14px;height:14px;display:block;flex-shrink:0}
.post-action:hover{color:var(--text);background:var(--tag-bg)}
.post-action.post-stat{
  margin-left:auto;
  padding:5px 10px;
  border:1px solid var(--border-light);
  border-radius:999px;
  background:#fff;
  color:var(--text3);
  cursor:default;
  pointer-events:none;
}
.post-action.post-stat:hover{
  color:var(--text3);
  background:#fff;
}
.post-action.post-stat span{
  line-height:1;
  transform:translateY(-.5px);
}
.vote-wrap{display:flex;align-items:center;gap:0;flex-shrink:0}
.post-meta-actions{display:flex;align-items:center;gap:0;flex:1;min-width:0;margin-left:0}
.vbtn{
  display:flex;align-items:center;gap:3px;padding:5px 6px;border-radius:15px;
  font-size:12px;font-weight:700;color:var(--text3);cursor:pointer;
  border:none;background:none;font-family:'Noto Sans KR',sans-serif;
  transition:color .1s,background .1s;white-space:nowrap;
  line-height:14px;
}
.vbtn i,.vbtn svg{width:14px;height:14px;display:block;flex-shrink:0}
.vbtn:hover{color:var(--text);background:var(--tag-bg)}
.vbtn.voted{color:var(--text)}
.vbtn.voted svg,.vbtn.voted svg *{stroke:#111;fill:#111}
.vcount{font-size:12px;font-weight:600;padding-left:0;color:inherit;line-height:14px;display:inline-flex;align-items:center}
.vcount.bump{animation:voteCountBump .22s ease}
@keyframes voteCountBump{
  0%{transform:translateY(0) scale(1);opacity:.9}
  45%{transform:translateY(-2px) scale(1.12);opacity:1}
  100%{transform:translateY(0) scale(1);opacity:1}
}

.post-card-edit{display:flex;flex-direction:column;gap:8px}
.post-edit-title,.post-edit-body{
  width:100%;border:1.5px solid var(--border-strong);border-radius:8px;
  font-family:'Noto Sans KR',sans-serif;color:var(--text);outline:none;
  transition:border-color .15s,box-shadow .15s;
}
.post-edit-title{padding:10px 12px;font-size:15px;font-weight:700}
.post-edit-body{padding:10px 12px;font-size:14px;line-height:1.6;resize:vertical;min-height:96px}
.post-edit-title:focus,.post-edit-body:focus{border-color:var(--orange);box-shadow:0 0 0 3px rgba(255,69,0,.1)}
.post-edit-actions{display:flex;justify-content:flex-end;gap:6px}
.post-edit-btn{
  border:none;border-radius:14px;padding:6px 11px;font-size:12px;font-weight:700;
  cursor:pointer;font-family:'Noto Sans KR',sans-serif;
}
.post-edit-btn.save{background:var(--orange);color:#fff}
.post-edit-btn.cancel{background:var(--tag-bg);color:var(--muted)}

.post-confirm-modal{
  width:360px!important;
  max-width:88vw!important;
  padding:24px;
  border-radius:16px!important;
  box-shadow:0 8px 32px rgba(0,0,0,.15);
  overflow:visible;
}
.post-confirm-head{
  padding:0;
  margin-bottom:10px;
  font-size:16px;
  font-weight:700;
  color:var(--text);
}
.post-confirm-body{
  padding:0;
  margin-bottom:6px;
  font-size:13px;
  color:var(--muted);
  line-height:1.55;
  white-space:pre-line;
}
.post-confirm-actions{
  padding:0;
  margin-top:14px;
  display:flex;
  justify-content:flex-end;
  gap:8px;
}
.post-confirm-btn{
  height:30px;
  min-width:56px;
  padding:0 12px;
  border:none;
  border-radius:999px;
  font-size:12px;
  font-weight:700;
  line-height:1;
  cursor:pointer;
  font-family:'Noto Sans KR',sans-serif;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.post-confirm-btn.cancel{background:#fff;border:1.5px solid var(--border-strong);color:var(--text2)}
.post-confirm-btn.ok{background:var(--orange);color:#fff}

/* ─── EMPTY FEED ─── */
.empty-feed{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:72px 20px;text-align:center;box-shadow:var(--shadow-sm);
}
.empty-icon{font-size:48px;margin-bottom:16px;display:block;filter:grayscale(1);opacity:.2}
.empty-title{font-size:16px;font-weight:700;color:var(--text2);margin-bottom:8px}
.empty-desc{font-size:13px;color:var(--muted);line-height:1.8}
.feed-subview-empty{margin-top:0}

.feed-subview-panel{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
  padding:12px 24px 8px;
  margin-bottom:8px;
}
.feed-subview-head{
  display:flex;
  flex-direction:column;
  gap:4px;
}
.feed-subview-title{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:18px;
  font-weight:700;
  color:var(--text);
  letter-spacing:-.3px;
  line-height:1.2;
  margin-top:4px;
  margin-bottom:4px;
}
.feed-subview-title svg{
  width:18px;
  height:18px;
  stroke-width:2.2;
  flex-shrink:0;
}
.feed-subview-title.is-popular span{margin-left:-3px}
.feed-subview-empty .empty-icon{display:none}
.feed-subview-empty .empty-title{
  font-size:13px;
  font-weight:500;
  color:var(--muted);
  margin-bottom:0;
}
.feed-subview-empty .empty-desc{display:none}
.feed-subview-tabs{
  margin-top:0;
  margin-bottom:0;
}
.feed-subview-tabrow{
  display:flex;
  align-items:flex-start;
  gap:8px;
  margin-top:4px;
}
.feed-subview-tabrow .feed-subview-tabs{
  flex:1;
  min-width:0;
}
.feed-subview-tabs .comm-tab{
  padding:4px 0;
  font-size:11px;
}
.feed-subview-sort-row{
  display:flex;
  align-items:flex-start;
  margin-top:0;
  margin-left:auto;
  padding-top:0;
  flex-shrink:0;
}
.feed-subview-sort-picker{
  position:relative;
}
.feed-subview-sort-trigger{
  width:32px;
  height:32px;
  border-radius:50%;
  border:1px solid var(--border-light);
  background:#fff;
  color:var(--text);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:all .15s;
}
.feed-subview-sort-trigger:hover{border-color:var(--orange);color:var(--orange);background:var(--orange-pale)}
.feed-subview-sort-trigger svg{
  width:14px;
  height:14px;
  flex-shrink:0;
}
.feed-subview-sort-menu{
  position:absolute;
  top:calc(100% + 6px);
  right:0;
  min-width:156px;
  padding:4px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:10px;
  box-shadow:0 8px 24px rgba(0,0,0,.12);
  display:none;
  z-index:30;
}
.feed-subview-sort-menu.open{display:flex;flex-direction:column;gap:4px}
.feed-subview-sort-group{display:flex;flex-direction:column;gap:2px}
.feed-subview-sort-label{
  padding:6px 10px 2px;
  font-size:11px;
  font-weight:700;
  color:var(--muted);
  line-height:1.2;
}
.feed-subview-sort-divider{
  height:1px;
  margin:0 4px;
  background:var(--border-light);
}
.feed-subview-sort-group + .feed-subview-sort-group .feed-subview-sort-label{
  padding-top:2px;
}
.feed-subview-sort-opt{
  width:100%;
  border:none;
  background:transparent;
  text-align:left;
  padding:8px 12px;
  color:var(--text2);
  font-size:12px;
  font-weight:700;
  font-family:'Noto Sans KR',sans-serif;
  cursor:pointer;
  border-radius:7px;
}
.feed-subview-sort-opt:hover{background:#f6f6f3}
.feed-subview-sort-opt.active{color:var(--orange);background:var(--orange-pale)}

/* ─── LEFT SIDEBAR ─── */
.sidebar-left{display:flex;flex-direction:column;gap:12px;position:static;align-self:start;margin-right:5px}

/* 프로필 카드 - 모바일 탭과 동일한 가로 레이아웃 */
.sl-profile{display:flex;align-items:flex-start;gap:10px;padding:20px 14px;cursor:pointer;transition:background .15s;min-height:96px}
.sl-profile:hover{background:var(--tag-bg)}
.sl-avatar{width:44px;height:44px;border-radius:50%;overflow:hidden;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;background:#FAFAF9;color:#8A8A86;box-shadow:0 4px 20px rgba(0,0,0,.08);flex-shrink:0}
.sl-avatar svg{width:20px;height:20px}
.sl-avatar img{width:100%;height:100%;object-fit:cover}
.sl-profile-main{display:flex;flex-direction:column;gap:3px;min-width:0;flex:1}
.sl-name{
  display:block;
  font-size:var(--sl-name-size,14px);
  font-weight:700;
  color:var(--text2);
  line-height:var(--sl-name-line,1.25);
  white-space:normal;
  overflow:hidden;
  overflow-wrap:anywhere;
  word-break:break-word;
}
.sl-name.balanced{text-align:justify;text-align-last:justify}
.sl-handle{font-size:11px;font-weight:700;color:var(--muted2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sl-stats{display:flex;align-items:center;gap:0;margin-top:4px;flex-wrap:wrap}
.sl-stat{display:inline-flex;align-items:center;gap:5px;position:relative}
.sl-stat+.sl-stat{padding-left:10px;margin-left:10px}
.sl-stat+.sl-stat::before{content:'';position:absolute;left:0;top:50%;width:1px;height:11px;background:var(--border-strong);transform:translateY(-50%)}
.sl-stat b{font-family:'Bebas Neue',sans-serif;font-size:18px;font-weight:400;color:var(--text);line-height:1;transform:translateY(1px)}
.sl-stat span{font-size:10px;color:var(--muted);font-weight:700;letter-spacing:.2px;line-height:1.15}

/* 라벨이 긴 언어용: 스탯 행을 위젯 폭 풀로 채워 한 줄로 표시 (한국어/중국어는 원형 유지) */
html[lang="en"] .sl-profile,
html[lang="ja"] .sl-profile,
html[lang="es"] .sl-profile,
html[lang="pt"] .sl-profile,
html[lang="fr"] .sl-profile,
html[lang="de"] .sl-profile,
html[lang="id"] .sl-profile,
html[lang="ru"] .sl-profile{position:relative;padding-bottom:36px;height:102px;min-height:102px;overflow:hidden}
html[lang="en"] .sl-stats,
html[lang="ja"] .sl-stats,
html[lang="es"] .sl-stats,
html[lang="pt"] .sl-stats,
html[lang="fr"] .sl-stats,
html[lang="de"] .sl-stats,
html[lang="id"] .sl-stats,
html[lang="ru"] .sl-stats{position:absolute;left:14px;right:14px;bottom:18px;margin-top:0;flex-wrap:nowrap;white-space:nowrap;justify-content:center}
html[lang="en"] .sl-profile-main,
html[lang="ja"] .sl-profile-main,
html[lang="es"] .sl-profile-main,
html[lang="pt"] .sl-profile-main,
html[lang="fr"] .sl-profile-main,
html[lang="de"] .sl-profile-main,
html[lang="id"] .sl-profile-main,
html[lang="ru"] .sl-profile-main{padding-top:3px}
html[lang="en"] .sl-avatar,
html[lang="ja"] .sl-avatar,
html[lang="es"] .sl-avatar,
html[lang="pt"] .sl-avatar,
html[lang="fr"] .sl-avatar,
html[lang="de"] .sl-avatar,
html[lang="id"] .sl-avatar,
html[lang="ru"] .sl-avatar{transform:translateY(-2px)}
html[lang="en"] .sl-stat,
html[lang="ja"] .sl-stat,
html[lang="es"] .sl-stat,
html[lang="pt"] .sl-stat,
html[lang="fr"] .sl-stat,
html[lang="de"] .sl-stat,
html[lang="id"] .sl-stat,
html[lang="ru"] .sl-stat{flex-shrink:0}
html[lang="en"] .sl-stat span,
html[lang="ja"] .sl-stat span,
html[lang="es"] .sl-stat span,
html[lang="pt"] .sl-stat span,
html[lang="fr"] .sl-stat span,
html[lang="de"] .sl-stat span,
html[lang="id"] .sl-stat span,
html[lang="ru"] .sl-stat span{white-space:nowrap}
html[lang="en"] .sl-stat+.sl-stat,
html[lang="ja"] .sl-stat+.sl-stat,
html[lang="es"] .sl-stat+.sl-stat,
html[lang="pt"] .sl-stat+.sl-stat,
html[lang="fr"] .sl-stat+.sl-stat,
html[lang="de"] .sl-stat+.sl-stat,
html[lang="id"] .sl-stat+.sl-stat,
html[lang="ru"] .sl-stat+.sl-stat{padding-left:5px;margin-left:5px}
html[lang="fr"] .sl-stat,
html[lang="ru"] .sl-stat{gap:3px}

.sl-login-msg{padding:20px 14px;text-align:center;font-size:12px;color:var(--muted);line-height:1.6;min-height:96px}
.sl-login-msg span{display:block;margin-bottom:10px}
.sl-login-btn{display:inline-block;padding:7px 20px;border-radius:20px;border:none;background:linear-gradient(135deg,var(--orange),var(--orange2));color:#fff;font-size:12px;font-weight:700;cursor:pointer;font-family:'Noto Sans KR',sans-serif}
.sl-comm-item{display:flex;align-items:center;gap:8px;padding:7px 10px;text-decoration:none;color:inherit;border-radius:6px;transition:background .1s;cursor:pointer;font-size:12px}
.sl-comm-item:hover{background:var(--orange-pale)}
.sl-comm-avatar{width:26px;height:26px;border-radius:50%;overflow:hidden;background:var(--surface);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--muted)}
.sl-comm-avatar img{width:100%;height:100%;object-fit:cover}
.sl-comm-name{font-weight:600;color:var(--text2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}
.sl-comm-empty{padding:16px 10px;text-align:center;font-size:11px;color:var(--muted);line-height:1.7}
.sl-divider{height:1px;background:var(--border-light);margin:0}
.sl-section-head{display:flex;align-items:center;gap:6px;padding:11px 14px;font-size:13px;font-weight:700;color:var(--text);letter-spacing:-.2px;user-select:none;transition:color .15s}
.sl-section-head:hover{color:var(--orange)}
.sl-head-icon{width:13px;height:13px;flex-shrink:0;color:currentColor}
.sl-sub-head{display:flex;align-items:center;gap:6px;padding:11px 14px;font-size:13px;font-weight:700;color:var(--text);letter-spacing:-.2px;user-select:none;transition:color .15s}
.sl-sub-head:hover{color:var(--orange)}
.sl-toggle-icon{color:var(--muted);transition:none;margin-left:auto;display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px}
.sl-toggle-icon i,.sl-toggle-icon svg{width:14px;height:14px}
.sl-toggle-icon.collapsed{transform:rotate(180deg)}
.sl-comm-body{display:grid;grid-template-rows:minmax(0,1fr);overflow:hidden;transition:none}
.sl-comm-body>*{min-height:0;overflow:hidden}
.sl-comm-body.collapsed{grid-template-rows:minmax(0,0fr)}
html.sl-sidebar-ready .sl-toggle-icon{transition:transform .25s ease}
html.sl-sidebar-ready .sl-comm-body{transition:grid-template-rows .28s ease}
html.sl-sidebar-preload #slCreateBody,
html.sl-sidebar-preload #slCommBody,
html.sl-sidebar-preload #slCreateToggle,
html.sl-sidebar-preload #slCommToggle{transition:none!important}
html.sl-sidebar-preload[data-sidebar-create-state="collapsed"] #slCreateBody,
html.sl-sidebar-preload[data-sidebar-comm-state="collapsed"] #slCommBody{grid-template-rows:minmax(0,0fr)!important}
html.sl-sidebar-preload[data-sidebar-create-state="expanded"] #slCreateBody,
html.sl-sidebar-preload[data-sidebar-comm-state="expanded"] #slCommBody{grid-template-rows:minmax(0,1fr)!important}
html.sl-sidebar-preload[data-sidebar-create-state="collapsed"] #slCreateToggle,
html.sl-sidebar-preload[data-sidebar-comm-state="collapsed"] #slCommToggle{transform:rotate(180deg)!important}
html.sl-sidebar-preload[data-sidebar-create-state="expanded"] #slCreateToggle,
html.sl-sidebar-preload[data-sidebar-comm-state="expanded"] #slCommToggle{transform:none!important}
html.sl-create-collapsed #slCreateBody,
html.sl-comm-collapsed #slCommBody{grid-template-rows:minmax(0,0fr)}
html.sl-create-collapsed #slCreateToggle,
html.sl-comm-collapsed #slCommToggle{transform:rotate(180deg)}
.sl-inq-badge{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;padding:0;border-radius:50%;background:#e03c00;color:#fff;font-size:10px;font-weight:700;line-height:1;text-align:center;letter-spacing:-.1px;font-variant-numeric:tabular-nums;font-family:Arial,sans-serif;box-sizing:border-box;padding-top:1px;flex-shrink:0}

/* ── 가이드라인 카드 (피드 영역) ── */
.guideline-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-sm);color:#111}
.guideline-card-body{padding:8px 18px 0}
.guideline-card-title-wrap{min-height:28px}
.guideline-hero{display:flex;flex-direction:column;align-items:center;gap:10px;padding:14px 0 26px;margin-bottom:22px;border-bottom:1px solid #f0f0f0}
.guideline-logo{height:26px;width:auto;display:block}
.guideline-kicker{font-family:'Bebas Neue',sans-serif;font-size:15px;font-weight:400;color:#111;letter-spacing:1px;line-height:1;margin-top:2px}
.guideline-intro{margin:0 0 16px;color:#111;font-size:13.5px;line-height:1.7;letter-spacing:-.2px;text-align:center;max-width:560px;margin-left:auto;margin-right:auto}
.guideline-intro b{color:#111;font-weight:800}
.guideline-list{margin:18px 0 0;padding:0;display:flex;flex-direction:column;gap:6px;list-style:none}
.guideline-list li{position:relative;color:#111;letter-spacing:-.2px;font-size:13px;line-height:1.6;padding:4px 0 4px 18px}
.guideline-list li::before{content:"";position:absolute;left:4px;top:14px;width:4px;height:4px;border-radius:50%;background:var(--orange)}
.guideline-note{margin:22px 0 0;padding:14px 16px;background:#f7f7f7;border-left:3px solid #111;border-radius:6px;color:#111;font-size:12px;line-height:1.65;letter-spacing:-.2px}
.guideline-note b{color:#111;font-weight:800}
@media (max-width:640px){
  .guideline-card{padding:14px;border-radius:var(--radius)}
  .guideline-card-body{padding:8px 6px 0}
  .guideline-hero{padding:10px 0 20px;margin-bottom:18px}
  .guideline-logo{height:22px}
  .guideline-kicker{font-size:13px;letter-spacing:.8px}
  .guideline-intro{font-size:12.5px}
  .guideline-list li{font-size:12px}
}

/* ── 신고 모달 ── */
.report-modal{max-width:440px;border-radius:16px;padding:0;overflow:hidden;display:flex;flex-direction:column;max-height:min(640px,90vh)}
.report-modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px 12px;border-bottom:1px solid #f0f0f0}
.report-modal-title{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:800;color:#111;letter-spacing:-.3px}
.report-modal-title i,.report-modal-title svg{color:#111}
.report-modal-close{background:none;border:none;cursor:pointer;color:#999;padding:4px;border-radius:6px;transition:all .15s;display:flex;align-items:center;justify-content:center}
.report-modal-close:hover{background:#f5f5f5;color:#111}
.report-modal-desc{padding:14px 22px 6px;font-size:12.5px;color:#666;letter-spacing:-.2px}
.report-modal-body{padding:6px 22px 4px;display:flex;flex-direction:column;gap:2px;overflow-y:auto;flex:1}
.report-reason{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:8px;cursor:pointer;transition:background .12s;user-select:none}
.report-reason:hover{background:#fafafa}
.report-reason input[type="checkbox"]{
  appearance:none;-webkit-appearance:none;
  width:18px;height:18px;cursor:pointer;flex-shrink:0;margin:0;
  display:grid;place-items:center;
  border:1.5px solid rgba(236,34,31,.34);
  border-radius:6px;background:#fff;
  box-shadow:0 1px 2px rgba(236,34,31,.06);
  transition:border-color .18s ease,background .18s ease,box-shadow .18s ease;
}
.report-reason input[type="checkbox"]::before{
  content:"";
  width:8px;height:5px;
  border:2px solid #fff;
  border-top:0;border-right:0;
  transform:rotate(-45deg) scale(0);
  transform-origin:center;
  transition:transform .16s ease;
}
.report-reason:hover input[type="checkbox"]{
  border-color:rgba(236,34,31,.55);
  background:#fff;
  box-shadow:0 3px 8px rgba(236,34,31,.1);
}
.report-reason input[type="checkbox"]:checked{
  border-color:var(--orange);
  background:linear-gradient(135deg,var(--orange),var(--orange2));
  box-shadow:0 4px 10px rgba(236,34,31,.18);
}
.report-reason input[type="checkbox"]:checked::before{transform:rotate(-45deg) scale(1)}
.report-reason input[type="checkbox"]:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px rgba(236,34,31,.14),0 4px 10px rgba(236,34,31,.14);
}
.report-reason span{font-size:13px;color:#222;letter-spacing:-.2px;font-weight:500}
.report-reason:has(input:checked){background:rgba(255,69,0,.06)}
.report-reason:has(input:checked) span{color:#111;font-weight:600}
.report-other-input{width:calc(100% - 4px);margin:6px 2px 8px;padding:10px 12px;border:1px solid #e0e0e0;border-radius:8px;font-size:13px;font-family:inherit;resize:vertical;min-height:70px;outline:none;color:#111;background:#fafafa;letter-spacing:-.2px;transition:border-color .15s}
.report-other-input:focus{border-color:#e03c00;background:#fff}
.report-modal-err{padding:0 22px;min-height:18px;color:#e03c00;font-size:12px;font-weight:600}
.report-modal-actions{display:flex;gap:10px;padding:12px 22px 18px;border-top:1px solid #f0f0f0}
.report-btn{
  flex:1;
  min-height:40px;
  padding:10px 16px;
  border-radius:999px;
  border:1.5px solid transparent;
  cursor:pointer;
  font-size:13.5px;
  font-weight:700;
  letter-spacing:-.2px;
  font-family:'Noto Sans KR',sans-serif;
  transition:transform .15s,box-shadow .2s,background .15s,border-color .15s,color .15s,filter .15s;
}
.report-btn.cancel{background:#fff;border-color:#d4d4d0;color:#3a3a3a;box-shadow:0 1px 2px rgba(0,0,0,.06)}
.report-btn.cancel:hover{background:#fff;border-color:#bcbcb6;transform:translateY(-1px);box-shadow:0 4px 10px rgba(0,0,0,.12)}
.report-btn.cancel:active{transform:translateY(0) scale(.98);box-shadow:inset 0 1px 2px rgba(0,0,0,.08)}
.report-btn.submit{background:linear-gradient(135deg,var(--orange),var(--orange2));color:#fff;box-shadow:var(--red-btn-shadow)}
.report-btn.submit:hover{transform:translateY(-1px);box-shadow:0 6px 14px rgba(236,34,31,.36);filter:saturate(1.03)}
.report-btn.submit:active{transform:translateY(0) scale(.98);box-shadow:0 3px 10px rgba(236,34,31,.3)}
.report-btn.submit:disabled{background:#ccc;border-color:#ccc;cursor:not-allowed;box-shadow:none;transform:none;filter:none;opacity:.9}

/* ── 문의하기 피드 ── */
#inquiryFeed{max-width:100%}
.inq-list-section,.inq-compose-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-sm)}
.inq-card-head{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;min-height:30px;margin-bottom:16px}
.inq-card-head-left{
  display:grid;
  grid-template-columns:28px minmax(0,1fr);
  align-items:center;
  column-gap:8px;
  min-width:0;
  min-height:28px;
  margin-left:-6px;
}
.inq-card-back,.guideline-back{
  display:inline-flex;align-items:center;justify-content:center;
  width:28px;height:28px;border:none;background:transparent;
  cursor:pointer;border-radius:50%;transition:background .12s;
  color:var(--text);margin-right:0;flex-shrink:0;padding:0;
}
.inq-card-back:hover,.guideline-back:hover{background:var(--bg-hover,#f5f5f5)}
.inq-card-back svg,.guideline-back svg{display:block;width:18px;height:18px}
.inq-list-title{display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:13px;font-weight:800;color:var(--text);letter-spacing:-.3px;margin-bottom:14px}
.inq-card-title-wrap{display:flex;align-items:center;gap:8px;min-width:0;min-height:28px}
.inq-list-count{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border-radius:50%;background:#f0f0f0;color:var(--muted);font-size:11px;font-weight:700;line-height:1;text-align:center;letter-spacing:-.1px;font-variant-numeric:tabular-nums;font-family:Arial,sans-serif;box-sizing:border-box;padding-top:1px;flex-shrink:0}

.inq-compose-toggle-btn{display:inline-flex;align-items:center;gap:5px;padding:7px 12px;border-radius:999px;border:1px solid var(--orange);background:var(--white);color:var(--orange);font-size:12px;font-weight:800;letter-spacing:-.2px;cursor:pointer;font-family:inherit;transition:all .15s}
.inq-compose-toggle-btn:hover{background:var(--orange);color:var(--white)}
.inq-compose-toggle-btn:active{transform:scale(.96)}
.inq-compose-toggle-btn.active{background:var(--orange);color:var(--white)}
.inq-compose-toggle-btn.active svg{transform:rotate(45deg)}
.inq-compose-toggle-btn svg{transition:transform .2s}
.inq-compose-toggle-placeholder{visibility:hidden;pointer-events:none}

.inq-card-title{
  display:block;
  min-height:28px;
  line-height:28px;
  transform:translateY(0);
  font-size:20px;
  font-weight:900;
  color:var(--text);
  letter-spacing:-.45px;
  margin:0;
}
.inq-compose{display:flex;flex-direction:column;gap:10px;padding:14px;background:#fafafa;border:1px solid var(--border-light);border-radius:10px;margin-bottom:14px;animation:inqComposeSlide .2s ease}
.inq-compose-card .inq-compose{margin-top:0;margin-bottom:0;padding:0;background:transparent;border:none;border-radius:0}
@keyframes inqComposeSlide{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.inquiry-input,.inquiry-textarea{width:100%;padding:11px 13px;border:1px solid var(--border);border-radius:10px;font-size:13px;font-family:inherit;color:var(--text);background:var(--white);transition:border-color .15s,box-shadow .15s;box-sizing:border-box;resize:none}
.inquiry-input:focus,.inquiry-textarea:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px rgba(255,90,0,.08)}
.inquiry-textarea{min-height:110px;line-height:1.55}
.inquiry-field{position:relative}
.inquiry-counter{position:absolute;right:10px;bottom:8px;font-size:10px;color:var(--muted);background:rgba(255,255,255,.92);padding:1px 6px;border-radius:6px;pointer-events:none}
.inq-compose-footer{display:flex;align-items:center;gap:12px;justify-content:space-between;margin-top:2px}
.inquiry-modal-err{font-size:12px;color:#e03c00;min-height:16px;flex:1}
.inq-compose-actions{display:flex;gap:8px;flex-shrink:0}
.inquiry-btn-cancel,.inquiry-btn-submit{padding:9px 16px;border-radius:999px;font-size:13px;line-height:1.2;font-weight:800;cursor:pointer;font-family:inherit;letter-spacing:-.2px;transition:all .15s}
.inquiry-btn-cancel{background:#fff;border:1.5px solid var(--border-strong);color:var(--text2)}
.inquiry-btn-cancel:hover{background:#fff;border-color:#bcbcb6;transform:translateY(-1px);box-shadow:0 4px 10px rgba(0,0,0,.12)}
.inquiry-btn-cancel:active{transform:translateY(0) scale(.98);box-shadow:inset 0 1px 2px rgba(0,0,0,.08)}
.inquiry-btn-submit{background:linear-gradient(135deg,var(--orange),var(--orange2));border:none;color:#fff;box-shadow:var(--red-btn-shadow)}
.inquiry-btn-submit:hover{transform:translateY(-1px);box-shadow:0 4px 10px rgba(255,69,0,.4)}
.inquiry-btn-submit:active{transform:translateY(0) scale(.98);box-shadow:0 3px 10px rgba(255,69,0,.3)}
.inquiry-btn-submit:disabled{opacity:.5;cursor:not-allowed}
.inq-list{display:flex;flex-direction:column;gap:8px}
.inq-empty{padding:28px 12px;text-align:center;font-size:12px;color:var(--muted);line-height:1.7}

.inq-item{border:1px solid var(--border);border-radius:10px;overflow:hidden;background:var(--white);transition:border-color .15s,box-shadow .15s}
.inq-item:hover{border-color:#ddd}
.inq-item-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px;cursor:pointer;user-select:none;transition:background .15s}
.inq-item-head:hover{background:#fafafa}
.inq-item:active .inq-item-head{background:#f0f0f0}
.inq-item-head-left{display:flex;align-items:center;gap:10px;min-width:0;flex:1}
.inq-item-head-right{display:flex;align-items:center;gap:10px;flex-shrink:0}
.inq-item-status{font-size:10px;font-weight:800;padding:3px 8px;border-radius:999px;letter-spacing:-.2px;flex-shrink:0}
.inq-item-status.pending{background:#fff4e6;color:#e67e00}
.inq-item-status.done{background:#e8f5e9;color:#2e7d32}
.inq-item-subject{font-size:13px;font-weight:700;color:var(--text);letter-spacing:-.2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.inq-item-time{font-size:11px;color:var(--muted);font-weight:500}
.inq-item-chevron{transition:transform .2s;color:var(--muted)}
.inq-item.open .inq-item-chevron{transform:rotate(180deg)}
.inq-item-body{max-height:0;overflow:hidden;transition:max-height .3s ease;display:flex;flex-direction:column;gap:10px;padding:0 14px;border-top:1px solid transparent}
.inq-item.open .inq-item-body{max-height:1200px;padding:12px 14px 14px;border-top-color:var(--border-light)}
.inq-item-question,.inq-item-reply{padding:10px 12px;border-radius:8px}
.inq-item-question{background:#fafafa;border:1px solid var(--border-light)}
.inq-item-reply{background:#fff8f3;border:1px solid #ffd8bf}
.inq-item-reply.waiting{background:#fafafa;border:1px dashed var(--border)}
.inq-item-block-label{font-size:10px;font-weight:800;color:var(--muted);letter-spacing:0;margin-bottom:6px;text-transform:uppercase}
.inq-item-reply .inq-item-block-label{color:var(--orange)}
.inq-item-reply.waiting .inq-item-block-label{color:var(--muted)}
.inq-item-block-content{font-size:13px;color:var(--text);line-height:1.6;white-space:pre-wrap;word-break:break-word}

@media (max-width:720px){
  .inq-list-section,.inq-compose-card{padding:14px}
  .inq-card-head{align-items:flex-start}
  .inq-card-head-left{margin-left:-4px}
  .inq-card-title{font-size:18px}
  .inq-item-time{display:none}
  .inquiry-btn-submit{width:100%}
  .inq-compose-footer{flex-direction:column;align-items:stretch}
}

/* ─── RIGHT SIDEBAR ─── */
.sidebar{display:flex;flex-direction:column;gap:12px;margin-left:5px}
.widget{
  background:var(--white);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);
  content-visibility:auto;
  contain-intrinsic-size:260px;
}
.widget-top-plain{padding:12px 14px;border-bottom:1px solid var(--border-light);display:flex;align-items:center;gap:6px}
.widget-top-plain h3{font-size:13px;font-weight:700;color:var(--text);letter-spacing:-.2px;min-width:0;flex:1;line-height:1.35}
.widget-body{padding:12px 14px}

.comm-tabs{display:flex;gap:3px;margin-bottom:12px;background:var(--tag-bg);padding:3px;border-radius:20px}
.comm-tab{flex:1;padding:5px 0;font-size:12px;font-weight:700;color:var(--muted);cursor:pointer;border:none;border-radius:16px;background:transparent;font-family:'Noto Sans KR',sans-serif;transition:all .15s}
.comm-tab:hover{color:var(--text2);background:rgba(255,255,255,.6)}
.comm-tab.active{background:#fff;color:var(--orange);box-shadow:0 1px 4px rgba(0,0,0,.1)}
html[lang="en"] .widget-body>.comm-tabs>.comm-tab,
html[lang="de"] .widget-body>.comm-tabs>.comm-tab,
html[lang="es"] .widget-body>.comm-tabs>.comm-tab,
html[lang="fr"] .widget-body>.comm-tabs>.comm-tab,
html[lang="pt"] .widget-body>.comm-tabs>.comm-tab,
html[lang="ru"] .widget-body>.comm-tabs>.comm-tab,
html[lang="ja"] .widget-body>.comm-tabs>.comm-tab,
html[lang="id"] .widget-body>.comm-tabs>.comm-tab{flex:1 1 auto;min-width:0;padding:5px 4px;white-space:nowrap}

.comm-list{display:flex;flex-direction:column}
.comm-item{display:flex;align-items:center;gap:10px;padding:7px 4px;border:none;background:none;width:100%;font-family:'Noto Sans KR',sans-serif;text-align:left;border-bottom:1px solid var(--border-light);font-size:13px;text-decoration:none;color:inherit;border-radius:6px;transition:background .1s;cursor:pointer}
.comm-item:last-child{border-bottom:none}
.comm-item.no-divider,.pop-comm-item.no-divider{border-bottom:none}
.comm-item:hover{background:var(--orange-pale)}
.comm-more-btn{margin-top:10px;width:100%;padding:8px 10px;border-radius:18px;border:1.5px solid var(--border-strong);background:#fff;color:var(--text2);font-size:12px;font-weight:700;font-family:'Noto Sans KR',sans-serif;cursor:pointer;transition:all .15s}
.comm-more-btn:hover{border-color:var(--orange);color:var(--orange);background:var(--orange-pale)}
#popularPostList .comm-more-btn,
#popularCommList .comm-more-btn{
  margin-top:8px;
  padding:6px 10px;
  border-radius:16px;
  font-size:11px;
  font-weight:700;
}
.comm-rank{
  font-weight:700;
  color:var(--orange);
  width:18px;
  text-align:center;
  font-size:13px;
  font-family:'Bebas Neue',sans-serif;
  flex-shrink:0;
}
.comm-name{flex:1;color:var(--text2);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.comm-trend{font-size:10px;width:32px;text-align:right;font-weight:700}
.trend-up{color:var(--orange)}
.trend-down{color:#5b6fe6}
.trend-new{color:#fff;background:#ffc107;padding:1px 4px;border-radius:4px;font-size:10px;font-weight:700}

/* 인기 커뮤니티 정렬 드롭다운 */
.pop-comm-sort-wrap,
.pop-post-sort-wrap{
  position:relative;
  flex-shrink:0;
  display:flex;
  align-items:center;
  justify-content:flex-end;
  min-width:28px;
}
.pop-comm-sort-btn,
.pop-post-sort-btn{
  width:28px;height:28px;border-radius:50%;border:1px solid var(--border-light);
  background:#fff;color:var(--text);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all .15s;
}
.pop-comm-sort-btn svg,
.pop-post-sort-btn svg{width:14px;height:14px;display:block;flex-shrink:0}
.pop-comm-sort-btn:hover,
.pop-post-sort-btn:hover{border-color:var(--orange);color:var(--orange);background:var(--orange-pale)}
.pop-comm-sort-menu,
.pop-post-sort-menu{
  position:absolute;top:calc(100% + 6px);right:0;
  min-width:160px;
  background:#fff;border:1px solid var(--border);border-radius:10px;
  box-shadow:0 8px 24px rgba(0,0,0,.12);
  padding:4px;
  display:none;flex-direction:column;gap:2px;
  z-index:30;
  white-space:nowrap;
}
.pop-comm-sort-menu.open,
.pop-post-sort-menu.open{display:flex}
.pop-comm-sort-opt,
.pop-post-sort-opt{
  border:none;background:transparent;padding:8px 12px;
  font-size:12px;font-weight:700;color:var(--text3);
  font-family:'Noto Sans KR',sans-serif;cursor:pointer;
  border-radius:7px;text-align:left;transition:all .12s;
}
.pop-comm-sort-opt:hover,
.pop-post-sort-opt:hover{background:var(--orange-pale);color:var(--orange)}
.pop-comm-sort-opt.active,
.pop-post-sort-opt.active{color:var(--orange);background:var(--orange-pale)}

/* 인기 커뮤니티 아이템 (아바타 포함) */
.pop-comm-item{
  display:flex;align-items:center;gap:10px;
  padding:8px 4px;border-radius:8px;
  text-decoration:none;color:inherit;
  transition:background .12s;cursor:pointer;
  border-bottom:1px solid var(--border-light);
}
.pop-comm-item:last-child{border-bottom:none}
.pop-comm-item:hover{background:var(--orange-pale)}
.pop-comm-item-rank{
  font-weight:700;color:var(--orange);width:18px;text-align:center;
  font-size:13px;font-family:'Bebas Neue',sans-serif;flex-shrink:0;
  margin-right:0;
}
.pop-comm-item-avatar{
  width:32px;height:32px;border-radius:50%;
  border:1px solid var(--border-light);overflow:hidden;
  flex-shrink:0;display:flex;align-items:center;justify-content:center;
  background:#f9f9f9;
}
.pop-comm-item-avatar img{width:100%;height:100%;object-fit:cover}
.pop-comm-item-info{min-width:0;flex:1}
.pop-comm-item-name{
  font-size:12px;font-weight:700;color:var(--text);
  min-width:0;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
  display:block;
}
.pop-comm-item-stat{font-size:10px;color:var(--muted);font-weight:600;margin-top:1px}

.explore-panel{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  max-width:var(--feed-card-max);
  margin:0 auto 10px;
  box-shadow:var(--shadow-sm);
  overflow:hidden;
}
.explore-panel-head{
  padding:22px 24px 14px;
  border-bottom:1px solid var(--border-light);
  background:linear-gradient(180deg,#fff 0%,#fcfcfb 100%);
}
.explore-panel-kicker{
  font-family:'Bebas Neue',sans-serif;
  font-size:15px;
  letter-spacing:.08em;
  color:var(--orange);
  margin-bottom:6px;
}
.explore-panel-title{
  margin:0;
  font-size:24px;
  font-weight:700;
  color:var(--text);
  letter-spacing:-.04em;
}
.explore-panel-desc{
  margin:8px 0 0;
  font-size:13px;
  line-height:1.65;
  color:var(--muted);
}
.explore-comm-tabs{
  margin-top:0;
  margin-bottom:0;
  flex:1;
  min-width:0;
}
.explore-panel-controls{
  display:flex;
  align-items:center;
  gap:8px;
  margin-top:14px;
}
.explore-sort-row{
  display:flex;
  align-items:center;
  margin-top:0;
  margin-left:auto;
  padding:0;
  flex-shrink:0;
}
.explore-sort-picker{
  position:relative;
}
.explore-sort-trigger{
  width:38px;
  height:38px;
  border-radius:50%;
  border:1px solid var(--border-light);
  background:#fff;
  color:var(--text);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:all .15s ease;
}
.explore-sort-trigger:hover{
  border-color:var(--orange);
  color:var(--orange);
  background:var(--orange-pale);
}
.explore-sort-trigger svg{
  width:14px;
  height:14px;
  flex-shrink:0;
}
.explore-sort-menu{
  position:absolute;
  top:calc(100% + 6px);
  right:0;
  min-width:160px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:10px;
  box-shadow:0 10px 24px rgba(0,0,0,.10);
  padding:4px;
  display:none;
  z-index:40;
}
.explore-sort-menu.open{
  display:flex;
  flex-direction:column;
  gap:2px;
}
.explore-sort-opt{
  width:100%;
  border:none;
  background:#fff;
  padding:8px 12px;
  text-align:left;
  color:var(--text2);
  font-size:12px;
  font-weight:700;
  font-family:'Noto Sans KR',sans-serif;
  cursor:pointer;
  transition:background .12s ease,color .12s ease;
  border-radius:7px;
}
.explore-sort-opt:hover{
  background:var(--orange-pale);
  color:var(--orange);
}
.explore-sort-opt.active{
  background:#fff7f3;
  color:var(--orange);
}
.explore-comm-list{
  padding:10px 14px 14px;
}
.explore-comm-item{
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px 8px;
  border-bottom:1px solid var(--border-light);
  text-decoration:none;
  color:inherit;
  transition:background .12s ease;
}
.explore-comm-item:last-child{
  border-bottom:none;
}
.explore-comm-item:hover{
  background:var(--orange-pale);
}
.explore-comm-rank{
  width:24px;
  flex-shrink:0;
  text-align:center;
  font-family:'Bebas Neue',sans-serif;
  font-size:20px;
  color:var(--orange);
}
.explore-comm-avatar{
  width:44px;
  height:44px;
  border-radius:50%;
  border:1px solid var(--border-light);
  background:#f9f9f9;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  flex-shrink:0;
}
.explore-comm-avatar img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.explore-comm-main{
  min-width:0;
  flex:1;
}
.explore-comm-name{
  font-size:14px;
  font-weight:700;
  color:var(--text);
  line-height:1.35;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.explore-comm-flag{
  font-weight:400;
}
.explore-comm-meta{
  margin-top:3px;
  font-size:11px;
  font-weight:600;
  color:var(--muted);
}
.explore-panel-empty{
  padding:38px 20px 42px;
  text-align:center;
  color:var(--muted);
  font-size:13px;
  line-height:1.7;
}

.side-btn-list{display:flex;flex-direction:column;gap:8px}
.s-btn{width:100%;padding:9px;border-radius:20px;font-size:13px;font-weight:700;cursor:pointer;font-family:'Noto Sans KR',sans-serif;border:none;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:6px;letter-spacing:-.2px;white-space:nowrap}
.s-btn-orange{background:linear-gradient(135deg,var(--orange),var(--orange2));color:#fff;box-shadow:0 2px 8px rgba(255,69,0,.3)}
.s-btn-orange:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(255,69,0,.4)}
.s-btn-white{background:#fff;color:var(--text2);border:1.5px solid var(--border-strong)}
.s-btn-white:hover{background:#fff;border-color:#bcbcb6;transform:translateY(-1px);box-shadow:0 4px 10px rgba(0,0,0,.12)}
.s-btn-white:active{transform:translateY(0) scale(.98);box-shadow:inset 0 1px 2px rgba(0,0,0,.08)}

/* ─── 모달 공통 ─── */
.modal-overlay{
  position:fixed;inset:0;z-index:500;
  background:rgba(0,0,0,.45);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  display:none;align-items:center;justify-content:center;padding:20px;
}
.modal-overlay.open{display:flex}
.modal{
  background:#fff;border-radius:16px;width:100%;max-width:400px;
  box-shadow:0 20px 60px rgba(0,0,0,.2);overflow:hidden;
  animation:modalIn .2s cubic-bezier(.34,1.56,.64,1);
}
@keyframes modalIn{from{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}
.modal-wrap{position:relative}
.modal-head{padding:24px 24px 0;text-align:center}
.modal-logo{width:48px;height:48px;background:linear-gradient(135deg,#ff4500,#ff7043);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:26px;margin:0 auto 14px;box-shadow:0 4px 12px rgba(255,69,0,.3)}
.modal-title{font-family:'Bebas Neue',sans-serif;font-size:26px;letter-spacing:1px;margin-bottom:4px}
.modal-title b{color:var(--orange)}
.modal-desc{font-size:13px;color:var(--muted);line-height:1.6;margin-bottom:24px}
.modal-body{padding:0 24px 24px;display:flex;flex-direction:column;gap:10px}
.modal-close-btn,
.onboarding-modal-close{position:absolute;top:14px;right:14px;background:transparent;border:none;border-radius:0;width:30px;height:30px;cursor:pointer;font-size:16px;color:var(--muted);display:flex;align-items:center;justify-content:center;transition:color .15s}
.modal-close-btn:hover,
.onboarding-modal-close:hover{background:transparent;color:var(--text)}

.btn-google{width:100%;padding:10px 16px;border-radius:20px;background:#fff;border:1.5px solid var(--border-strong);display:flex;align-items:center;justify-content:center;gap:10px;font-size:14px;font-weight:700;color:var(--text2);cursor:pointer;font-family:'Noto Sans KR',sans-serif;transition:all .15s;box-shadow:0 1px 4px rgba(0,0,0,.08)}
.btn-google:hover{border-color:#4285f4;box-shadow:0 2px 8px rgba(66,133,244,.2);transform:translateY(-1px)}
.google-icon{width:20px;height:20px;flex-shrink:0}
.modal-divider{display:flex;align-items:center;gap:10px;margin:4px 40px}
.modal-divider::before,.modal-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.modal-divider span{font-size:12px;color:var(--muted2);white-space:nowrap}
.modal-notice{font-size:11px;color:var(--muted2);text-align:center;line-height:1.6;padding:0 4px}
/* 이메일 로그인 */
.email-login-section{display:flex;flex-direction:column;gap:10px}
.email-login-fields{display:flex;flex-direction:column;gap:10px}
.float-field{position:relative}
.float-field .email-login-input{
  width:100%;
  padding:18px 14px 6px;
  border:1.5px solid var(--border);
  border-radius:12px;
  font-size:14px;
  font-family:'Noto Sans KR',sans-serif;
  outline:none;
  background:#fff;
  transition:border-color .15s;
  box-sizing:border-box;
}
.float-field .email-login-input:focus{border-color:var(--orange)}
.float-field .email-login-input::placeholder{color:transparent}
.float-field label{
  position:absolute;
  left:15px;top:50%;
  transform:translateY(-50%);
  color:var(--muted);
  font-size:14px;
  pointer-events:none;
  transition:all .18s ease;
  transform-origin:left top;
  line-height:1;
}
.float-field .email-login-input:focus+label,
.float-field .email-login-input:not(:placeholder-shown)+label{
  top:9px;
  transform:translateY(0);
  font-size:10px;
  color:var(--muted2);
}
.pw-toggle-host{position:relative}
.pw-toggle-inline-wrap{display:block;width:100%}
.password-toggle-input{padding-right:46px!important}
.password-toggle-input::-ms-reveal,
.password-toggle-input::-ms-clear{display:none}
.password-toggle-btn{
  position:absolute;
  top:50%;
  right:12px;
  width:24px;
  height:24px;
  transform:translateY(-50%);
  border:none;
  background:transparent;
  color:var(--muted2);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0;
  margin:0;
  cursor:pointer;
  opacity:0;
  pointer-events:none;
  transition:opacity .16s ease,color .16s ease,transform .16s ease;
  z-index:2;
}
.password-toggle-btn svg{width:18px;height:18px;display:block}
.pw-toggle-host:focus-within .password-toggle-btn,
.pw-toggle-host.has-value .password-toggle-btn,
.pw-toggle-host.is-revealed .password-toggle-btn{
  opacity:1;
  pointer-events:auto;
}
.pw-toggle-host.is-revealed .password-toggle-btn{color:#111}
.password-toggle-btn:hover{color:var(--text2)}
.password-toggle-btn:active{transform:translateY(-50%) scale(.95)}
.password-toggle-btn:focus-visible{outline:none;color:var(--text2)}
.email-login-error{
  font-size:12px;
  color:#e03c00;
  padding:2px 2px 0;
  line-height:1.5;
}
.btn-email-login{
  width:100%;
  padding:10px 16px;
  border-radius:20px;
  background:var(--orange);
  border:none;
  font-size:14px;
  font-weight:700;
  color:#fff;
  cursor:pointer;
  font-family:'Noto Sans KR',sans-serif;
  transition:all .15s;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
}
.btn-email-login:hover{background:var(--orange2);transform:translateY(-1px);box-shadow:0 2px 8px rgba(255,69,0,.25)}
.btn-email-login:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}
.forgot-pw-link{
  display:block;text-align:left;font-size:11px;color:var(--muted);
  cursor:pointer;padding:2px 0;margin-top:0;
  text-decoration:none;transition:color .15s;
}
.forgot-pw-link:hover{color:var(--orange);text-decoration:underline}

.login-drawer-panel #loginScreen .email-login-fields,
.login-drawer-panel #loginScreen .btn-google,
.login-drawer-panel #loginScreen .forgot-pw-link,
.login-drawer-panel #loginScreen .email-action-stack{
  width:calc(100% - 18px);
  margin-left:auto;
  margin-right:auto;
}
.login-drawer-panel #signupScreen .email-login-fields,
.login-drawer-panel #signupScreen .email-action-stack{
  width:calc(100% - 18px);
  margin-left:auto;
  margin-right:auto;
}
.email-action-stack{
  display:flex;
  flex-direction:column;
}
.email-action-stack .btn-email-login{width:100%;margin-top:0!important}
.login-drawer-panel #loginScreen .email-action-stack{
  margin-top:4px;
  transition:margin-top .24s ease;
}
.login-drawer-panel #signupScreen .email-action-stack{
  margin-top:16px;
  transition:margin-top .24s ease;
}
.login-drawer-panel #signupScreen .email-action-stack.is-expanded{
  margin-top:0;
}
.login-drawer-panel #loginScreen .email-action-stack.is-expanded{
  margin-top:-6px;
}
.login-drawer-panel #loginScreen .forgot-pw-link{
  padding-top:0;
  margin-top:0;
  line-height:1;
  padding-left:6px;
}
.login-drawer-panel #loginScreen #emailLoginError,
.login-drawer-panel #signupScreen #signupError{
  display:block!important;
  max-height:0;
  opacity:0;
  overflow:hidden;
  margin:0;
  padding-top:0;
  padding-bottom:0;
  transform:translateY(-2px);
  transition:max-height .24s ease,opacity .2s ease,transform .2s ease,margin-bottom .24s ease,padding-top .24s ease,padding-bottom .24s ease;
  pointer-events:none;
  will-change:max-height,opacity,transform,margin-bottom,padding-top,padding-bottom;
}
.login-drawer-panel #loginScreen #emailLoginError.is-visible,
.login-drawer-panel #signupScreen #signupError.is-visible{
  max-height:32px;
  opacity:1;
  transform:translateY(0);
  padding-top:0;
  padding-bottom:0;
  margin-bottom:10px;
}
.login-drawer-panel #loginOnboardingScreen .onboarding-submit{
  width:calc(100% - 18px);
  margin-left:auto;
  margin-right:auto;
  padding:10px 16px;
  font-size:14px;
}

.login-drawer-panel #loginOnboardingScreen .onboarding-input,
.login-drawer-panel #loginOnboardingScreen .onboarding-handle-box{
  width:calc(100% - 18px);
  margin-left:auto;
  margin-right:auto;
  box-sizing:border-box;
}
.login-drawer-panel #loginOnboardingScreen .onboarding-country-box{
  width:auto;
  margin-left:9px;
  margin-right:auto;
  align-self:flex-start;
  justify-content:flex-start;
}

.btn-email-signup{
  width:100%;
  padding:8px 16px;
  border-radius:20px;
  background:transparent;
  border:none;
  font-size:12px;
  font-weight:600;
  color:var(--muted);
  cursor:pointer;
  font-family:'Noto Sans KR',sans-serif;
  transition:color .15s;
}
.btn-email-signup:hover{color:var(--orange)}
.btn-email-signup:disabled{opacity:.6;cursor:not-allowed}

.spinner{width:18px;height:18px;border:2px solid rgba(255,69,0,.2);border-top-color:var(--orange);border-radius:50%;animation:spin .7s linear infinite;display:none}
.btn-email-login .spinner{border-color:rgba(255,255,255,.3);border-top-color:#fff}
@keyframes spin{to{transform:rotate(360deg)}}

/* ─── 로그인 우측 슬라이드 패널 ─── */
.login-drawer-overlay{
  display:flex;
  align-items:stretch;
  justify-content:flex-end;
  padding:0;
  opacity:0;
  pointer-events:none;
  background:rgba(0,0,0,0);
  backdrop-filter:blur(0);
  -webkit-backdrop-filter:blur(0);
  transition:opacity .46s ease,background .56s ease,backdrop-filter .56s ease,-webkit-backdrop-filter .56s ease;
}
.login-drawer-overlay.open{
  opacity:1;
  pointer-events:auto;
  background:rgba(0,0,0,.36);
  backdrop-filter:blur(7px);
  -webkit-backdrop-filter:blur(7px);
}
.login-drawer-wrap{
  margin-left:auto;
  width:min(420px,100vw);
  height:100%;
  transition:width .28s ease;
}
.login-drawer-panel{
  width:100%;
  max-width:none;
  height:100%;
  border-radius:0;
  display:flex;
  flex-direction:column;
  transform:translateX(108%);
  transition:transform .52s cubic-bezier(.22,1,.36,1);
  animation:none;
  box-shadow:-24px 0 56px rgba(0,0,0,.22);
}
.login-drawer-wrap.is-onboarding{width:min(420px,100vw)}
.login-drawer-panel.is-onboarding{overflow-y:auto}
.login-onboarding-screen{display:flex;flex-direction:column;height:100%}
.login-drawer-overlay.open .login-drawer-panel{transform:translateX(0)}
.login-drawer-panel #loginScreen,
.login-drawer-panel #signupScreen{
  display:flex;flex-direction:column;justify-content:center;height:100%;
}
.login-drawer-panel .modal-head{padding-top:0}
.login-drawer-panel .modal-body{padding-bottom:28px}
.login-drawer-panel .modal-close-btn{top:14px;right:14px}
.onboarding-modal-head{
  padding:72px 24px 16px;
  border-bottom:1px solid var(--border-light);
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:16px;
  position:relative;
}
.onboarding-modal-brand{display:flex;flex-direction:column;align-items:flex-start;gap:6px;min-width:0;flex:1;text-align:left;margin-left:9px}
.onboarding-modal-logo{height:18px;max-height:18px;width:auto;max-width:190px;display:block;object-fit:contain;align-self:flex-start}
.onboarding-modal-copy{font-size:12px;color:var(--muted);line-height:1.6}
.onboarding-modal-body{
  padding:20px 24px 28px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:18px;
}
.onboarding-avatar-stack{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
  padding-top:0;
}
.onboarding-avatar-preview{
  width:96px;
  height:96px;
  border-radius:50%;
  background:#fff;
  border:1.5px solid var(--border-strong);
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  position:relative;
  overflow:hidden;
  box-shadow:0 4px 16px rgba(0,0,0,.08);
  color:var(--muted);
}
.onboarding-avatar-preview img{width:100%;height:100%;object-fit:cover}
.onboarding-avatar-preview svg{width:44px;height:44px}
.onboarding-avatar-preview:hover .onboarding-avatar-overlay{opacity:1}
.onboarding-avatar-overlay{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.38);
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  opacity:0;
  transition:opacity .15s;
}
.onboarding-avatar-action{
  border:none;
  background:rgba(255,255,255,.18);
  color:#fff;
  cursor:pointer;
  padding:9px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:background .15s;
}
.onboarding-avatar-action:hover{background:rgba(255,255,255,.35)}
.onboarding-avatar-action svg{width:16px;height:16px}
.onboarding-avatar-hint{
  font-size:10px;
  color:var(--muted2);
  text-align:center;
  line-height:1.5;
}
.onboarding-fields{width:100%;display:flex;flex-direction:column;gap:14px}
.onboarding-field{display:flex;flex-direction:column;gap:6px}
.onboarding-label{
  font-size:11px;
  font-weight:700;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.5px;
}
.login-drawer-panel #loginOnboardingScreen .onboarding-label{
  width:calc(100% - 18px);
  margin-left:auto;
  margin-right:auto;
  box-sizing:border-box;
  text-align:left;
}
.onboarding-input,
.onboarding-handle-box,
.onboarding-country-box{
  border-radius:999px;
}
.onboarding-input{
  padding:12px 16px;
  border:1.5px solid var(--border-strong);
  font-size:14px;
  font-family:'Noto Sans KR',sans-serif;
  outline:none;
  transition:border-color .15s,box-shadow .15s;
  width:100%;
  color:var(--text);
}
.onboarding-input:focus{
  border-color:var(--orange);
  box-shadow:0 0 0 3px rgba(255,69,0,.1);
}
.onboarding-handle-box{
  display:flex;
  align-items:center;
  border:1.5px solid var(--border-strong);
  overflow:hidden;
  transition:border-color .15s,box-shadow .15s;
  background:#fff;
}
.onboarding-handle-box:focus-within{
  border-color:var(--orange);
  box-shadow:0 0 0 3px rgba(255,69,0,.1);
}
.onboarding-handle-prefix{
  padding:12px 8px 12px 16px;
  font-weight:700;
  color:var(--muted);
  font-size:14px;
  flex-shrink:0;
}
.onboarding-handle-input{
  padding:12px 16px 12px 0;
  border:none;
  outline:none;
  font-size:14px;
  font-family:'Noto Sans KR',sans-serif;
  width:100%;
  color:var(--text);
  background:transparent;
}
.onboarding-country-box{
  display:inline-flex;
  align-self:flex-start;
  align-items:center;
  gap:8px;
  padding:5px 11px;
  max-width:100%;
  box-sizing:border-box;
  background:var(--tag-bg);
  border:1.5px solid var(--border);
  font-size:11px;
  white-space:nowrap;
}
.onboarding-country-auto{
  font-size:11px;
  color:var(--muted2);
  margin-left:auto;
  flex-shrink:0;
}
.onboarding-submit{
  width:100%;
  margin:0;
  padding:11px 16px;
  border-radius:999px;
  background:linear-gradient(135deg,var(--orange),var(--orange2));
  color:#fff;
  border:none;
  font-size:13px;
  font-weight:700;
  cursor:pointer;
  font-family:'Noto Sans KR',sans-serif;
  box-shadow:0 2px 8px rgba(255,69,0,.3);
  transition:all .15s;
}
.onboarding-submit:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(255,69,0,.34)}

/* ─── 글쓰기 모달 ─── */
.write-modal{max-width:640px}
.write-modal-head{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.write-modal-head h2{font-size:16px;font-weight:700;letter-spacing:-.3px}
.wm-body{padding:16px 20px;display:flex;flex-direction:column;gap:12px}
.wm-title-input{
  width:100%;padding:11px 14px;border:1.5px solid var(--border-strong);border-radius:8px;
  font-size:15px;font-weight:500;font-family:'Noto Sans KR',sans-serif;color:var(--text);
  outline:none;transition:border-color .15s,box-shadow .15s;
}
.wm-title-input:focus{border-color:var(--orange);box-shadow:0 0 0 3px rgba(255,69,0,.1)}
.wm-title-input::placeholder{color:var(--muted2)}
.wm-editor{
  border:1.5px solid var(--border-strong);
  border-radius:8px;
  background:#fff;
  overflow:hidden;
  transition:border-color .15s,box-shadow .15s;
}
.wm-editor:focus-within{border-color:var(--orange);box-shadow:0 0 0 3px rgba(255,69,0,.1)}
.wm-body-input{
  width:100%;padding:11px 14px;min-height:160px;
  border:none;border-radius:0;
  font-size:14px;font-family:'Noto Sans KR',sans-serif;color:var(--text);
  outline:none;resize:vertical;line-height:1.7;
  transition:none;
}
.wm-body-input::placeholder{color:var(--muted2)}
.wm-toolbar{display:flex;align-items:center;gap:6px;padding:8px 10px;border-top:1px solid var(--border-light);background:#fafaf9}
.wm-tool{
  padding:6px 10px;border-radius:6px;font-size:12px;font-weight:700;
  color:var(--muted);cursor:pointer;border:none;background:none;
  font-family:'Noto Sans KR',sans-serif;transition:all .15s;
}
.wm-tool:hover{color:var(--text);background:var(--tag-bg)}
.wm-img-preview{
  display:flex;flex-wrap:wrap;gap:8px;padding:0 10px 10px;
}
.wm-img-thumb{
  width:80px;height:80px;border-radius:8px;object-fit:cover;
  border:1px solid var(--border);position:relative;
}
.wm-footer{padding:12px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;background:var(--surface)}

@media(max-width:760px){
  .post-card-title-expanded{font-size:19px;line-height:1.38;margin-bottom:10px}
  .post-expanded-top{
    width:calc(100% - 32px);
    margin:18px auto 8px;
  }
  .post-expanded-back{
    width:auto;
    justify-content:center;
    padding:7px 12px;
    border:1px solid var(--border-light);
    background:#fff;
    box-shadow:0 1px 4px rgba(0,0,0,.04);
  }
  .post-card-header-expanded{width:calc(100% - 32px);padding:10px 0 8px}
  .post-card-body-expanded{width:calc(100% - 32px);padding:0 0 2px}
  .post-detail-body{font-size:15px;line-height:1.82;padding:0 16px}
  .post-card-footer-expanded{
    width:calc(100% - 32px);
    margin:14px auto 0;
    padding:12px 0 0;
    gap:8px;
    align-items:center;
    justify-content:space-between;
    flex-wrap:nowrap;
  }
  .post-card-footer-expanded .vote-wrap,
  .post-card-footer-expanded .post-meta-actions{
    gap:6px;
    flex-wrap:nowrap;
  }
  .post-card-footer-expanded .vote-wrap{flex:1;min-width:0}
  .post-card-footer-expanded .post-meta-actions{flex:1;min-width:0;margin-left:0}
  .post-card-footer-expanded .vbtn,
  .post-card-footer-expanded .post-action{
    min-height:36px;
    padding:0 11px;
    border:1px solid var(--border-light);
    border-radius:999px;
    background:#fff;
    font-size:12px;
    line-height:1;
  }
  .post-card-footer-expanded .vbtn{justify-content:center}
  .post-card-footer-expanded .post-action{justify-content:center}
  .post-card-footer-expanded .vcount,
  .post-card-footer-expanded .post-action span{line-height:1}
  .post-comments{
    width:calc(100% - 32px);
    margin:0 auto 18px;
    padding-top:14px;
  }
  .post-inline-image{width:100%!important}
  .post-comment-side{width:100%;flex-direction:row;align-items:center;justify-content:space-between}
  .post-comment-actions{gap:7px}
  .post-comment-cancel,.post-comment-submit{min-height:32px;min-width:58px;padding:6px 12px}
  .explore-panel{
    border:none;
    border-radius:0;
    box-shadow:none;
    margin:0 auto;
  }
  .explore-panel-head{
    padding:18px 16px 12px;
  }
  .explore-panel-title{
    font-size:21px;
  }
  .explore-panel-desc{
    font-size:12px;
  }
  .explore-panel-controls{gap:6px;margin-top:12px}
  .explore-comm-tabs{margin-top:0}
  .explore-sort-row{margin-top:0}
  .explore-sort-trigger{width:36px;height:36px;border-radius:50%}
  .explore-sort-menu{
    min-width:176px;
  }
  .explore-sort-opt{
    padding:11px 12px;
    font-size:12px;
  }
  .explore-comm-list{
    padding:8px 10px 12px;
  }
  .explore-comm-item{
    gap:10px;
    padding:11px 6px;
  }
  .explore-comm-rank{
    width:20px;
    font-size:18px;
  }
  .explore-comm-avatar{
    width:40px;
    height:40px;
  }
  .explore-comm-name{
    font-size:13px;
  }
  .explore-comm-meta{
    font-size:10px;
  }
}
.wm-cancel{padding:8px 16px;border-radius:20px;background:#fff;border:1.5px solid var(--border-strong);font-size:13px;font-weight:700;cursor:pointer;font-family:'Noto Sans KR',sans-serif;color:var(--text2);transition:all .15s}
.wm-cancel:hover{background:#fff;border-color:#bcbcb6;transform:translateY(-1px);box-shadow:0 4px 10px rgba(0,0,0,.12)}
.wm-cancel:active{transform:translateY(0) scale(.98);box-shadow:inset 0 1px 2px rgba(0,0,0,.08)}
.wm-submit{padding:8px 20px;border-radius:20px;background:linear-gradient(135deg,var(--orange),var(--orange2));color:#fff;border:none;font-size:13px;font-weight:700;cursor:pointer;font-family:'Noto Sans KR',sans-serif;box-shadow:0 2px 6px rgba(255,69,0,.3);transition:all .15s}
.wm-submit:hover{transform:translateY(-1px);box-shadow:0 4px 10px rgba(255,69,0,.4)}
.wm-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}

/* ─── TOAST ─── */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(80px);z-index:999;background:linear-gradient(180deg,rgba(255,255,255,.94),rgba(248,248,245,.9));backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:var(--text2);border:1px solid rgba(212,212,208,.9);border-radius:14px;padding:11px 22px;font-size:13px;font-weight:500;display:flex;align-items:center;gap:8px;transition:transform .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 10px 26px rgba(44,44,36,.12),inset 0 1px 0 rgba(255,255,255,.7);white-space:nowrap}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast.error{
  background:linear-gradient(180deg,#fff4f4,#ffecec);
  color:#bc7b7b;
  border-color:#f3dede;
  box-shadow:0 8px 18px rgba(170,40,40,.10),inset 0 1px 0 rgba(255,255,255,.7);
}
.toast.error::before{
  content:'✕';
  width:18px;
  height:18px;
  border-radius:50%;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:transparent;
  border:1.5px solid #cf8e8e;
  color:#cf8e8e;
  font-size:11px;
  font-weight:700;
  line-height:1;
  flex-shrink:0;
}
.toast.success{
  background:#ffffff;
  color:#2c2c24;
  border-color:#e6e6e1;
  box-shadow:0 12px 30px rgba(44,44,36,.14),0 2px 8px rgba(44,44,36,.06),inset 0 1px 0 rgba(255,255,255,.9);
}
.toast.success::before{
  content:'✓';
  width:18px;height:18px;
  border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  background:transparent;
  border:1.5px solid #c9c9c3;
  color:#6e6e66;
  font-size:11px;font-weight:700;line-height:1;flex-shrink:0;
}

/* ─── FOOTER ─── */
footer{background:var(--white);border-top:1px solid var(--border);padding:20px;text-align:center;font-size:12px;color:var(--muted);margin-top:24px}
footer a{color:var(--muted);text-decoration:none;margin:0 8px;transition:color .15s}
footer a:hover{color:var(--orange)}
.footer-copy{margin-top:8px;font-size:11px;color:var(--muted2)}

/* ─── RESPONSIVE ─── */
@media(max-width:1024px){
  .header-inner{padding:0 14px}
  .mobile-menu-btn{display:flex;padding:6px 0;width:auto;height:auto}
  .gnb{display:none}
  .header-search{flex:1 1 260px;width:auto;max-width:420px}
  .page-wrap{padding:var(--page-top-gap) var(--page-side-pad) var(--page-bottom-gap);grid-template-columns:1fr}
  .sidebar{display:none}
  .sidebar-left{display:none}
}

@media(max-width:760px){
  :root{--header-h:52px;--bg:#fff;--page-top-gap:12px;--page-bottom-gap:12px;--page-side-pad:14px}

  html{scrollbar-gutter:auto;overflow-x:hidden}
  body{overflow-x:hidden}
  body{background:var(--bg)}
  .page-wrap{width:100%;max-width:100%}
  #postFeed{padding:0}
  .post-card{border:none;box-shadow:none;border-bottom:none;border-radius:0}
  .post-card:hover{border-color:transparent}
  .empty-feed,
  .feed-subview-panel,
  .guideline-card,
  .inq-list-section,
  .inq-compose-card{
    border:none;
    border-radius:0;
    box-shadow:none;
  }

  .mobile-menu-btn{display:flex;padding:6px 0;width:auto;height:auto}
  .logo{display:none}
  .header-right{display:flex;align-items:center;gap:0;margin-left:0;flex-shrink:0}
  #authBtns{display:none!important}
  .user-area{gap:0}
  .user-avatar,.user-nick,.hbtn-admin{display:none!important}
  .hbtn-notif{width:34px;height:34px}
  .mobile-header-logo{display:flex}
  .header-inner{gap:4px;padding:0 4px}
  .header-search{display:block;max-width:none;margin-left:0;flex:1}
  .header-search input{height:34px;font-size:12px;padding-left:34px}
  .s-ico{left:11px}

  .sort-bar{padding:8px 10px;gap:4px;margin-bottom:10px}
  .sort-btn{padding:6px 11px;font-size:12px}

  .post-card + .post-card{border-top:none}
  .post-rank-strip{width:100%;padding:10px 0 8px}
  .post-rank-number-wrap{width:min(96%,640px)}
  .post-rank-number{margin-left:17px}
  .post-card-header{width:min(96%,640px);padding:14px 0 8px}
  .post-card-body{width:min(96%,640px);padding:0 0 12px}
  .post-card.no-image .post-card-body{padding:0 0 8px}
  .post-card.no-image:has(.post-card-fullview) .post-card-body{padding:0 0 6px}
  .post-card.no-image .post-card-fullview{padding:0 0 10px}
  .post-card-title{font-size:17px;line-height:1.4}
  .post-card-text{font-size:14px;line-height:1.65}
  .post-card-thumb-wrap{width:min(96%,640px);margin:0 auto 11px;padding:0}
  .post-card-thumb-stage{width:100%;aspect-ratio:1/1}
  .post-card-fullview{width:min(96%,640px);padding:0 0 10px}
  .post-card-footer{width:min(96%,640px);padding:4px 0 0;gap:2px;flex-wrap:wrap;border-top:1px solid var(--border-light);border-bottom:none;justify-content:flex-start}
  .post-fullview-btn{font-size:12px;padding:6px 12px}

  .post-author-avatar{width:36px;height:36px;font-size:14px}
  .post-author-name{font-size:15px}
  .post-author-handle{font-size:12px}
  .post-author-time{font-size:12px;margin-top:2px}
  .post-author-views{font-size:12px}
  .post-author-views i,.post-author-views svg{width:13px;height:13px}

  .vote-wrap{gap:2px}
  .post-meta-actions{gap:2px;margin-left:0}
  .post-action,
  .vbtn{font-size:13px;padding:5px 5px}
  .vbtn svg,.post-action svg{width:16px;height:16px}

  .empty-feed{padding:52px 16px}
  .empty-title{font-size:15px}
  .empty-desc{font-size:12px}
  .feed-subview-panel{padding:10px 16px 7px}
  .feed-subview-title{font-size:16px}
  .feed-subview-title{margin-top:3px;margin-bottom:3px}
  .feed-subview-title svg{width:16px;height:16px}
  .feed-subview-title.is-popular span{margin-left:-2px}
  .feed-subview-tabrow{gap:6px;margin-top:3px}
  .feed-subview-tabs{margin-top:0}
  .feed-subview-tabs .comm-tab{padding:4px 0;font-size:10px}
  .feed-subview-sort-row{margin-top:0}
  .feed-subview-sort-trigger{width:32px;height:32px;border-radius:50%}
  .feed-subview-sort-opt{font-size:11px;padding:7px 10px}

  .modal-overlay{padding:10px}
  .modal{border-radius:14px}
  .modal-head{padding:18px 16px 0}
  .modal-body{padding:0 16px 16px}
  .wm-body{padding:12px 14px}
  .wm-footer{padding:10px 14px}

  footer{margin-top:16px;padding:16px 10px}
}

@media(max-width:520px){
  .header-inner{gap:8px;padding:0 10px}
  .header-search{display:block}

  .page-wrap{padding:10px}

  .post-author-avatar{width:38px;height:38px}
  .post-author-name{font-size:15px}
  .post-author-time{font-size:11px}
  .post-author-views{font-size:11px}
  .post-author-views i,.post-author-views svg{width:12px;height:12px}

  .post-card-title{font-size:16px}
  .post-card-text{font-size:13.5px}
  .post-card-thumb-stage{aspect-ratio:1/1}

  .vbtn{min-height:30px;font-size:14px;padding:4px 6px}
  .post-action{min-height:30px;font-size:14px;padding:4px 6px}
  .vbtn svg,.post-action svg{width:17px;height:17px}
  .post-expanded-top,
  .post-card-header-expanded,
  .post-card-body-expanded,
  .post-card-footer-expanded,
  .post-comments{width:calc(100% - 32px)}
  .post-expanded-back{
    width:100%;
    min-height:38px;
    padding:0 12px;
  }
  .post-card-title-expanded{font-size:18px}
  .post-card-footer-expanded{
    gap:8px;
    flex-wrap:wrap;
    justify-content:flex-start;
  }
  .post-card-footer-expanded .vote-wrap,
  .post-card-footer-expanded .post-meta-actions{
    width:100%;
    gap:8px;
  }
  .post-card-footer-expanded .vote-wrap{
    display:grid;
    grid-template-columns:1fr 1fr;
  }
  .post-card-footer-expanded .post-meta-actions{
    display:grid;
    grid-template-columns:1fr 1fr;
    margin-left:0;
  }
  .post-card-footer-expanded .vbtn,
  .post-card-footer-expanded .post-action{
    width:100%;
    min-height:38px;
    padding:0 10px;
    justify-content:center;
  }

  .toast{
    left:10px;right:10px;bottom:12px;
    transform:translateY(80px);
    width:auto;font-size:12px;padding:10px 12px;border-radius:12px;
  }
  .toast.show{transform:translateY(0)}

  .wm-footer{justify-content:stretch}
  .wm-cancel,.wm-submit{flex:1;text-align:center}
}

/* ─── 광고 카드 (.ad-card) — 피드 게시물과 동일한 형식 ── */
.ad-card{
  position:relative;
  cursor:pointer;
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  max-width:var(--feed-card-max);
  margin:0 auto 10px;
  box-shadow:var(--shadow-sm);
  overflow:hidden;
  transition:border-color .15s, box-shadow .15s;
}
.ad-card:hover{border-color:var(--border-strong);box-shadow:0 2px 8px rgba(0,0,0,.06)}

/* 광고주 아바타 (이니셜) */
.ad-card .ad-avatar{
  width:36px;height:36px;border-radius:50%;
  background:#EC221F;color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:15px;
  flex-shrink:0;
  letter-spacing:0;
}
/* "광고" 라벨 - 일반 게시물의 핸들 자리에 배지 형태 */
.ad-card .ad-handle{
  display:inline-block;
  font-size:11px;font-weight:600;
  color:#9aa0a6;
  background:#f3f4f6;
  padding:1px 7px;border-radius:8px;
  letter-spacing:.3px;
  margin-top:2px;
}
.ad-card .post-card-thumb-wrap.ad-thumb-wrap{margin-top:0}
/* 광고 카드 이미지: 일반 게시물과 완전히 동일한 썸네일 규칙 사용 (style.css 805~889 기본 규칙).
   별도 오버라이드 없음 — tuneFeedThumbStage가 동적으로 비율/블러 처리. */
/* CTA 버튼 영역 (footer 자리) */
.ad-card .ad-cta-row{
  padding:10px 16px 14px;
  border-top:1px solid var(--border-light,#eee);
  background:#fff;
}
.ad-card .ad-cta-btn{
  display:inline-flex;align-items:center;gap:4px;
  font-size:13px;font-weight:700;
  color:#EC221F;
  text-decoration:none;
  padding:6px 0;
}
.ad-card .ad-cta-btn:hover{text-decoration:underline}
.ad-sponsored-label{
  position:absolute;top:10px;right:14px;
  font-size:10px;font-weight:600;
  color:#9aa0a6;
  letter-spacing:.5px;text-transform:uppercase;
  background:rgba(255,255,255,.92);
  padding:2px 8px;border-radius:8px;
  z-index:2;
}
.ad-card-inner{padding:14px 16px 12px}
.ad-card-image{
  margin:-14px -16px 12px;
  background:#f4f4f5;
  aspect-ratio:1.91/1;
  overflow:hidden;
}
.ad-card-image img{width:100%;height:100%;object-fit:cover;display:block}
.ad-card-advertiser{
  font-size:11px;color:var(--text-mute);
  margin-bottom:4px;font-weight:500;
}
.ad-card-title{
  font-size:16px;font-weight:700;color:var(--text);
  line-height:1.35;margin-bottom:6px;
}
.ad-card-body-text{
  font-size:13px;color:var(--text-mute);
  line-height:1.55;margin-bottom:10px;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;
  overflow:hidden;
}
.ad-card-cta{
  display:inline-block;
  font-size:12px;font-weight:600;
  color:#EC221F;
  text-decoration:none;
  padding:6px 0;
}
.ad-card-cta:hover{text-decoration:underline}
.ad-card-adsense{padding:0;cursor:auto}
.ad-card-adsense ins.adsbygoogle{
  display:block;width:100%;min-height:120px;
}
@media(max-width:1024px){
  .ad-card{border-radius:0;border-left:none;border-right:none;border-top:none;box-shadow:none;margin:0 0 10px}
  .ad-card-image{aspect-ratio:1.91/1}
}
