/* ============ TOKENS ============ */
:root{
  --bg:#f4f6fa;
  --surface:#ffffff;
  --ink:#16202e;
  --ink-2:#5a6b80;
  --ink-3:#8a98aa;
  --line:#e6eaf1;
  --line-2:#eef1f6;
  --brand:#1a4fd6;        /* deep blue */
  --brand-dark:#1239a8;
  --brand-soft:#eaf0ff;
  --accent:#ff5a3c;       /* warm coral CTA */
  --accent-dark:#e84527;
  --gold:#ffb020;
  --radius:14px;
  --radius-sm:10px;
  --shadow:0 1px 2px rgba(20,32,46,.04), 0 8px 24px rgba(20,32,46,.06);
  --shadow-lg:0 12px 40px rgba(20,32,46,.12);
  --font:"Pretendard","Pretendard Variable",-apple-system,BlinkMacSystemFont,system-ui,"Segoe UI",Roboto,"Apple SD Gothic Neo","Malgun Gothic",sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--ink);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1200px;margin:0 auto;padding:0 20px}

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  font-family:inherit;font-weight:700;font-size:.95rem;
  padding:11px 20px;border-radius:999px;border:1.5px solid transparent;
  cursor:pointer;transition:.16s ease;white-space:nowrap;
}
.btn-sm{padding:8px 15px;font-size:.85rem}
.btn-lg{padding:14px 28px;font-size:1.02rem}
.btn-accent{background:var(--accent);color:#fff}
.btn-accent:hover{background:var(--accent-dark);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--brand);border-color:var(--brand-soft);background:var(--brand-soft)}
.btn-ghost:hover{background:#dde7ff}
.btn-light{background:#fff;color:var(--brand)}
.btn-light:hover{transform:translateY(-1px)}
.btn-ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn-ghost-light:hover{background:rgba(255,255,255,.12)}

/* ============ UTILITY BAR ============ */
.utility{background:var(--ink);color:#cbd5e3;font-size:.8rem}
.utility-inner{display:flex;justify-content:space-between;align-items:center;height:36px}
.utility-left{display:flex;gap:16px}
.util-weather{color:#9fb0c4}
.utility-right{display:flex;align-items:center;gap:8px}
.utility-right a{color:#cbd5e3;transition:.15s}
.utility-right a:hover{color:#fff}
.utility .dot{color:#3f4d60}
.util-biz{color:var(--gold)!important;font-weight:700}
.utility-inner{position:relative}

/* 지역 선택 토글 + 드롭다운 */
.region-toggle{background:none;border:none;color:#cbd5e3;font-family:inherit;font-size:.8rem;
  font-weight:700;cursor:pointer;padding:0;display:inline-flex;align-items:center;gap:3px}
.region-toggle:hover{color:#fff}
.region-toggle .caret{font-size:.7rem;opacity:.7}
.region-menu{position:absolute;top:40px;right:0;z-index:60;background:#fff;color:var(--ink);
  border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-lg);
  padding:10px;min-width:200px;display:grid;grid-template-columns:1fr 1fr;gap:8px}
.region-menu[hidden]{display:none}
.rm-group{min-width:0}
.rm-country{font-size:.72rem;font-weight:800;color:var(--ink-3);padding:4px 8px 2px;letter-spacing:.02em}
.rm-item{display:block;padding:7px 10px;border-radius:8px;font-size:.9rem;font-weight:600;
  color:var(--ink-2);transition:.12s}
.rm-item:hover{background:var(--brand-soft);color:var(--brand)}
.rm-item.active{background:var(--brand-soft);color:var(--brand);font-weight:700}

/* 푸터 다른 지역 링크 */
#footer-regions a{display:block;font-size:.88rem;padding:5px 0;color:#9fb0c4;transition:.15s}
#footer-regions a:hover{color:#fff}

/* ============ HEADER ============ */
.header{background:var(--surface);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.header-inner{display:flex;align-items:center;gap:24px;height:74px}
.logo{display:flex;align-items:center;gap:10px;flex-shrink:0}
.logo-mark{
  width:40px;height:40px;border-radius:11px;flex-shrink:0;
  background:linear-gradient(135deg,var(--brand),#3d6df0);
  color:#fff;font-weight:800;font-size:1.25rem;
  display:grid;place-items:center;box-shadow:0 4px 12px rgba(26,79,214,.3);
}
.logo-text{font-weight:800;font-size:1.3rem;letter-spacing:-.02em}
.logo-text em{font-style:normal;color:var(--brand);font-size:.78rem;font-weight:700;vertical-align:middle;
  background:var(--brand-soft);padding:2px 7px;border-radius:6px;margin-left:2px}

.search{flex:1;display:flex;align-items:center;background:var(--bg);
  border:1.5px solid var(--line);border-radius:999px;padding:4px 4px 4px 18px;max-width:520px}
.search:focus-within{border-color:var(--brand);background:#fff}
.search input{flex:1;border:none;background:none;font-family:inherit;font-size:.95rem;outline:none;color:var(--ink)}
.search button{width:38px;height:38px;border:none;border-radius:999px;background:var(--brand);
  color:#fff;cursor:pointer;font-size:.9rem;flex-shrink:0}
.search button:hover{background:var(--brand-dark)}
.header-cta{flex-shrink:0}

.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.hamburger span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.2s}

/* ============ NAV ============ */
.nav{background:var(--surface);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;gap:4px;overflow-x:auto;scrollbar-width:none}
.nav-inner::-webkit-scrollbar{display:none}
.nav-inner a{padding:14px 16px;font-weight:600;font-size:.96rem;color:var(--ink-2);
  white-space:nowrap;border-bottom:2.5px solid transparent;transition:.15s}
.nav-inner a:hover{color:var(--brand)}
.nav-inner a.active{color:var(--brand);border-bottom-color:var(--brand)}
.nav-hot{color:var(--accent)!important}

/* ============ HERO ============ */
.hero{background:
   radial-gradient(1200px 500px at 80% -10%, rgba(26,79,214,.10), transparent 60%),
   radial-gradient(900px 400px at 0% 0%, rgba(255,90,60,.07), transparent 55%),
   var(--surface);
  border-bottom:1px solid var(--line)}
.hero-inner{padding:60px 20px 64px}
.eyebrow{color:var(--brand);font-weight:700;font-size:.9rem;letter-spacing:.01em;margin-bottom:14px}
.eyebrow-light{color:#9fc0ff}
.hero h1{font-size:3.1rem;line-height:1.12;letter-spacing:-.03em;font-weight:800}
.hero h1 span{color:var(--brand)}
.hero-sub{color:var(--ink-2);font-size:1.12rem;margin:18px 0 28px;line-height:1.6}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.hero-trust{display:flex;gap:36px;margin-top:40px;padding-top:28px;border-top:1px solid var(--line)}
.hero-trust div{display:flex;flex-direction:column}
.hero-trust strong{font-size:1.7rem;font-weight:800;letter-spacing:-.02em}
.hero-trust span{color:var(--ink-3);font-size:.88rem;margin-top:2px}

/* ============ SECTIONS ============ */
.section{padding:44px 0}
.section h2{font-size:1.22rem;font-weight:800;letter-spacing:-.01em}

/* ============ CATEGORY TILES ============ */
.cat-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:12px}
.cat{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px 12px;text-align:center;transition:.18s;box-shadow:var(--shadow)}
.cat:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--brand-soft)}
.cat-ico{font-size:1.9rem;display:block;margin-bottom:10px}
.cat strong{display:block;font-size:.98rem;font-weight:700}
.cat em{display:block;font-style:normal;color:var(--ink-3);font-size:.78rem;margin-top:3px}

/* ============ MAIN GRID ============ */
.main-grid{display:grid;grid-template-columns:1fr 320px;gap:26px}
.main-col{display:flex;flex-direction:column;gap:22px}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.side-col{display:flex;flex-direction:column;gap:22px}

/* ============ PANELS ============ */
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px 22px;box-shadow:var(--shadow)}
.panel-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.more{color:var(--ink-3);font-size:.85rem;font-weight:600;transition:.15s}
.more:hover{color:var(--brand)}

/* lists */
.list{list-style:none;display:flex;flex-direction:column}
.list li a{display:flex;align-items:center;gap:9px;padding:10px 4px;font-size:.95rem;
  border-bottom:1px solid var(--line-2);transition:.12s}
.list li:last-child a{border-bottom:none}
.list li a:hover{color:var(--brand);padding-left:8px}
.list li a em{margin-left:auto;font-style:normal;color:var(--ink-3);font-size:.78rem;white-space:nowrap}

.tag{font-size:.72rem;font-weight:700;padding:2px 8px;border-radius:6px;flex-shrink:0}
.tag-job{background:#e8f5ec;color:#1d8a4e}
.tag-seek{background:#eef0f4;color:#5a6b80}
.tag-rent{background:#eaf0ff;color:var(--brand)}
.tag-room{background:#fdf0e8;color:#c2691a}
.tag-sale{background:#f3eafe;color:#7d3fd1}
.tag-sell{background:#fdeceb;color:var(--accent-dark)}
.tag-buy{background:#eef0f4;color:#5a6b80}
.tag-free{background:#e8f5ec;color:#1d8a4e}
.tag-talk{background:#eaf0ff;color:var(--brand)}

/* ============ BUSINESS GRID (업소록) ============ */
.biz-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.biz{position:relative;display:flex;gap:13px;padding:15px;border:1px solid var(--line);
  border-radius:var(--radius-sm);transition:.18s;background:#fff}
.biz:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px);border-color:var(--brand-soft)}
.biz.featured{border-color:#ffe2bd;background:linear-gradient(180deg,#fffaf2,#fff)}
.biz-badge{position:absolute;top:10px;right:10px;font-size:.68rem;font-weight:800;
  background:var(--gold);color:#5a3d00;padding:2px 7px;border-radius:5px}
.biz-logo{width:48px;height:48px;border-radius:11px;background:var(--bg);display:grid;
  place-items:center;font-size:1.5rem;flex-shrink:0}
.biz-logo.big{width:64px;height:64px;font-size:2rem;margin:0 auto 10px}
.biz-info strong{display:block;font-size:1rem;font-weight:700}
.biz-cat{font-size:.76rem;color:var(--brand);font-weight:600}
.biz-info p{font-size:.84rem;color:var(--ink-2);margin:5px 0 6px;line-height:1.45}
.biz-meta{font-size:.78rem;color:var(--ink-3)}

/* ============ SIDEBAR ============ */
.rank{list-style:none;counter-reset:r;display:flex;flex-direction:column;gap:2px}
.rank li{counter-increment:r}
.rank li a{display:flex;align-items:center;gap:11px;padding:8px 2px;font-size:.92rem;font-weight:500;transition:.12s}
.rank li a::before{content:counter(r);width:22px;height:22px;border-radius:6px;background:var(--bg);
  color:var(--ink-3);font-size:.78rem;font-weight:800;display:grid;place-items:center;flex-shrink:0}
.rank li:nth-child(-n+3) a::before{background:var(--brand);color:#fff}
.rank li a:hover{color:var(--brand)}

.event-list{list-style:none;display:flex;flex-direction:column;gap:12px}
.event-list li{display:flex;gap:13px;align-items:center}
.ev-date{width:50px;height:50px;border-radius:11px;background:var(--brand-soft);color:var(--brand);
  display:flex;flex-direction:column;align-items:center;justify-content:center;flex-shrink:0;font-size:.66rem;font-weight:700}
.ev-date b{font-size:1.15rem;line-height:1}
.event-list strong{display:block;font-size:.92rem;font-weight:700}
.event-list em{font-style:normal;color:var(--ink-3);font-size:.8rem}

/* ============ AD SLOTS ============ */
.ad-slot{position:relative;background:linear-gradient(135deg,var(--brand),#3d6df0);
  border-radius:var(--radius);padding:24px 22px;color:#fff;overflow:hidden;box-shadow:var(--shadow)}
.ad-slot-alt{background:var(--surface);border:1px dashed var(--line);color:var(--ink);text-align:center}
.ad-label{position:absolute;top:12px;right:12px;font-size:.66rem;font-weight:700;
  background:rgba(255,255,255,.22);padding:2px 8px;border-radius:5px;letter-spacing:.04em}
.ad-slot-alt .ad-label{background:var(--bg);color:var(--ink-3)}
.ad-body strong{display:block;font-size:1.12rem;font-weight:800;margin-bottom:8px;margin-top:4px}
.ad-body p{font-size:.86rem;opacity:.92;margin-bottom:16px;line-height:1.5}
.ad-slot-alt .ad-body p{opacity:1;color:var(--ink-2)}

/* ============ NEWSLETTER ============ */
.newsletter{background:
   radial-gradient(900px 500px at 100% 0%, rgba(26,79,214,.5), transparent 60%),
   #101a2b;color:#fff;padding:64px 0}
.newsletter-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.newsletter h2{font-size:2.1rem;font-weight:800;letter-spacing:-.02em;line-height:1.2}
.newsletter h2 span{color:var(--gold)}
.nl-sub{color:#aebccf;margin:16px 0 22px;font-size:1rem;line-height:1.6}
.nl-perks{list-style:none;display:flex;flex-direction:column;gap:9px}
.nl-perks li{color:#dbe5f0;font-size:.96rem}
.nl-form{background:#fff;border-radius:18px;padding:28px;color:var(--ink);box-shadow:var(--shadow-lg)}
.nl-form label{display:block;font-size:.82rem;font-weight:700;color:var(--ink-2);margin:0 0 6px}
.nl-form input,.nl-form select{width:100%;padding:12px 14px;border:1.5px solid var(--line);
  border-radius:10px;font-family:inherit;font-size:.95rem;margin-bottom:16px;outline:none;color:var(--ink);background:#fff}
.nl-form input:focus,.nl-form select:focus{border-color:var(--brand)}
.nl-form .btn{width:100%}
.nl-fine{font-size:.76rem;color:var(--ink-3);margin-top:12px;line-height:1.5;text-align:center}

/* ============ BIZ CTA ============ */
.biz-cta{background:linear-gradient(135deg,var(--brand),var(--brand-dark));color:#fff;padding:54px 0}
.biz-cta-inner{display:flex;justify-content:space-between;align-items:center;gap:36px;flex-wrap:wrap}
.biz-cta h2{font-size:1.8rem;font-weight:800;letter-spacing:-.02em}
.biz-cta p{color:#cdd9f5;margin-top:10px;max-width:560px;font-size:1.02rem}
.biz-cta-actions{display:flex;gap:12px;flex-wrap:wrap}

/* ============ FOOTER ============ */
.footer{background:var(--ink);color:#9fb0c4;padding:48px 0 0}
.footer-inner{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;padding-bottom:36px}
.logo-footer .logo-text{color:#fff}
.footer-brand p{margin-top:14px;font-size:.9rem;line-height:1.6;color:#7f90a6}
.footer-cols{display:flex;gap:56px;flex-wrap:wrap}
.footer-cols h4{color:#fff;font-size:.92rem;margin-bottom:14px;font-weight:700}
.footer-cols a{display:block;font-size:.88rem;padding:5px 0;color:#9fb0c4;transition:.15s}
.footer-cols a:hover{color:#fff}
.footer-bottom{border-top:1px solid #2a3647;padding:18px 0;font-size:.82rem;color:#6b7c92}

/* ============ RESPONSIVE ============ */
@media(max-width:980px){
  .main-grid{grid-template-columns:1fr}
  .cat-grid{grid-template-columns:repeat(4,1fr)}
  .newsletter-inner{grid-template-columns:1fr;gap:32px}
  .hero h1{font-size:2.5rem}
}
@media(max-width:680px){
  .header-inner{height:64px;gap:12px}
  .search{display:none}
  .header-cta{display:none}
  .hamburger{display:flex}
  .nav{display:none}
  .nav.open{display:block}
  .nav-inner{flex-direction:column;gap:0}
  .nav-inner a{border-bottom:1px solid var(--line-2);border-left:3px solid transparent}
  .nav-inner a.active{border-bottom-color:var(--line-2);border-left-color:var(--brand)}
  .util-weather{display:none}
  .utility-inner{height:34px;font-size:.76rem}
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .two-col{grid-template-columns:1fr}
  .biz-grid{grid-template-columns:1fr}
  .hero-inner{padding:40px 20px 44px}
  .hero h1{font-size:2.1rem}
  .hero-trust{gap:24px}
  .hero-trust strong{font-size:1.4rem}
  .newsletter,.biz-cta{padding:44px 0}
  .biz-cta-inner{flex-direction:column;align-items:flex-start}
}

/* logo .com accent */
.logo-dot{color:var(--accent);font-weight:800}

/* ===================================================================
   ADMIN
   =================================================================== */
.admin-notice{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:40px;
  text-align:center;box-shadow:var(--shadow)}
.admin-notice h2{font-size:1.3rem;font-weight:800;margin-bottom:10px}
.admin-notice p{color:var(--ink-2);line-height:1.6;margin-bottom:8px}
.admin-notice code{background:var(--bg);padding:2px 7px;border-radius:5px;font-size:.86rem;color:var(--brand)}
.admin-steps{margin-top:14px;font-size:.9rem}
.stat-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.stat-card{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:20px;
  text-align:center;box-shadow:var(--shadow)}
.stat-card strong{display:block;font-size:1.9rem;font-weight:800;letter-spacing:-.02em}
.stat-card span{font-size:.84rem;color:var(--ink-3)}
.admin-form{display:flex;flex-wrap:wrap;gap:8px;align-items:center;background:var(--surface);
  border:1px solid var(--line);border-radius:14px;padding:14px;margin-bottom:16px;box-shadow:var(--shadow)}
.admin-form input,.admin-form select{font-family:inherit;font-size:.9rem;padding:9px 12px;border:1.5px solid var(--line);
  border-radius:9px;outline:none;flex:1;min-width:120px}
.admin-form input[type=color]{padding:3px;width:46px;flex:none;min-width:0}
.admin-form .ck{display:flex;align-items:center;gap:5px;font-size:.86rem;color:var(--ink-2);flex:none}
.admin-form .btn{flex:none}
.admin-table{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--line);
  border-radius:14px;overflow:hidden;box-shadow:var(--shadow);font-size:.9rem}
.admin-table th{text-align:left;padding:12px 14px;background:var(--bg);color:var(--ink-2);font-weight:700;font-size:.82rem}
.admin-table td{padding:11px 14px;border-top:1px solid var(--line-2);vertical-align:middle}
.admin-table .sw{display:inline-block;width:12px;height:12px;border-radius:3px;margin-right:6px;vertical-align:middle}
.mini-btn{font-family:inherit;font-size:.8rem;font-weight:600;padding:5px 11px;border:1px solid var(--line);
  border-radius:7px;background:#fff;color:var(--ink-2);cursor:pointer;transition:.14s}
.mini-btn:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.admin-hint{color:var(--ink-3);font-size:.9rem;margin-bottom:12px}
.admin-table .muted{color:var(--ink-3);font-size:.82rem}

/* 광고 안내 페이지 */
.adq-title{font-size:1.3rem;font-weight:800;margin-bottom:4px}
.adq-sub{color:var(--ink-2);margin-bottom:16px;font-size:.95rem}

/* 광고 위치 안내 — 와이어프레임 + 범례 */
.admap{display:flex;gap:24px;align-items:center;background:var(--surface);border:1px solid var(--line);
  border-radius:16px;padding:24px;box-shadow:var(--shadow);margin-bottom:30px}
.admap-wire{width:300px;flex-shrink:0;background:var(--bg);border:1px solid var(--line);border-radius:12px;
  padding:10px;display:flex;flex-direction:column;gap:7px}
.w-bar{height:22px;background:var(--ink);color:#fff;border-radius:5px;font-size:.62rem;display:grid;place-items:center}
.w-cols{display:grid;grid-template-columns:0.8fr 2fr 0.8fr;gap:7px}
.w-main{display:flex;flex-direction:column;gap:7px}
.w-ph{background:#e4e9f1;border-radius:5px;min-height:26px}
.w-side{min-height:88px}
.w-banner{min-height:30px}
.w-bottom{min-height:30px}
.w-dir{border-top:1px dashed var(--line);margin-top:3px;padding-top:7px;display:flex;flex-direction:column;gap:7px}
.w-dir-label{font-size:.62rem;font-weight:800;color:var(--ink-3)}
.w-dirtop{min-height:26px}
.w-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}
.w-cards span{background:#e4e9f1;border-radius:5px;height:24px;display:block}

/* 광고 zone 하이라이트 */
.zone{position:relative;display:grid;place-items:center;border-radius:5px;font-size:.6rem;font-weight:800;
  color:var(--brand);background:var(--brand-soft);border:1.5px dashed var(--brand)}
.zone i{position:absolute;top:3px;left:3px;width:14px;height:14px;border-radius:50%;background:var(--brand);
  color:#fff;font-size:.58rem;font-style:normal;display:grid;place-items:center;line-height:1}
.zone.z2{color:#c2691a;background:#fdf2e6;border-color:#c2691a}.zone.z2 i{background:#c2691a}
.zone.z3{color:#1a824a;background:#e8f5ed;border-color:#1a824a}.zone.z3 i{background:#1a824a}
.zone.z4{color:#8a63c4;background:#f3edfd;border-color:#8a63c4}.zone.z4 i{background:#8a63c4}

/* 범례 */
.admap-legend{list-style:none;display:flex;flex-direction:column;gap:14px;flex:1}
.admap-legend li{display:flex;gap:12px;align-items:center}
.admap-legend b{width:26px;height:26px;border-radius:50%;background:var(--brand);color:#fff;font-size:.8rem;
  display:grid;place-items:center;flex-shrink:0}
.admap-legend b.z2{background:#c2691a}.admap-legend b.z3{background:#1a824a}.admap-legend b.z4{background:#8a63c4}
.admap-legend strong{display:block;font-size:1rem;font-weight:700}
.admap-legend span{font-size:.86rem;color:var(--ink-3)}
@media(max-width:680px){ .admap{flex-direction:column;align-items:stretch} .admap-wire{width:100%} }

/* 로고 (아이콘 제거 후) */
.logo .logo-text{font-size:1.32rem}

/* 뉴스 페이지 */
.news-page-list{background:var(--surface);border:1px solid var(--line);border-radius:14px;
  padding:6px 18px;box-shadow:var(--shadow)}
.news-page-list li a{padding:13px 2px}
.news-page-list .nt-title{white-space:normal}
.news-src{font-size:.82rem;color:var(--ink-3);margin-top:14px;text-align:center}
@media(max-width:760px){ .stat-grid{grid-template-columns:repeat(3,1fr)} .admin-table{display:block;overflow-x:auto} }

/* ===================================================================
   PORTAL HOME (dense / ad-forward)
   =================================================================== */

/* 속보 티커 */
.ticker{background:#fff;border-bottom:1px solid var(--line)}
.ticker-inner{display:flex;align-items:center;gap:16px;height:46px;overflow:hidden}
.ticker-label{color:var(--accent);font-weight:800;font-size:.78rem;flex-shrink:0;letter-spacing:.06em;
  position:relative;padding-left:14px}
.ticker-label::before{content:"";position:absolute;left:0;top:50%;width:6px;height:6px;border-radius:50%;
  background:var(--accent);transform:translateY(-50%);box-shadow:0 0 0 3px rgba(255,90,60,.15)}
.ticker-track{display:flex;align-items:center;gap:18px;white-space:nowrap;overflow:hidden;flex:1;font-size:.9rem}
.tk-item{color:var(--ink-2);font-weight:500}
.tk-item:hover{color:var(--brand)}
.tk-item b{color:var(--ink);font-weight:700;margin-right:4px}
.tk-dot{color:var(--line)}

/* 리더보드 광고 */
.ad-leaderboard{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:3px;margin:18px 0;height:104px;border-radius:16px;border:1px solid var(--line);
  background:linear-gradient(180deg,#fbfcfe,#f5f7fb);color:var(--ink-2);text-align:center;transition:.16s}
.ad-leaderboard:hover{border-color:var(--brand-soft);box-shadow:var(--shadow)}
.ad-leaderboard strong{font-size:1.02rem;color:var(--ink);font-weight:700}
.ad-leaderboard span{font-size:.82rem;color:var(--ink-3)}
.ad-tag{position:absolute;top:10px;left:12px;color:var(--ink-3);font-size:.62rem;
  font-weight:800;letter-spacing:.1em}

/* 포털 3단 그리드 */
.portal{display:grid;grid-template-columns:220px 1fr 220px;gap:22px;align-items:start;margin-bottom:28px}
.rail{display:flex;flex-direction:column;gap:12px;position:sticky;top:84px}
.portal-main{display:flex;flex-direction:column;gap:20px;min-width:0}

/* 광고 카드 (사이드) — 깔끔 텍스트형 + 왼쪽 컬러 띠 */
.ad-box{position:relative;display:flex;flex-direction:column;gap:5px;padding:15px 15px 14px 17px;
  border-radius:14px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);transition:.16s;overflow:hidden}
.ad-box::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--ad,#1a4fd6)}
.ad-box.ad-space::before{display:none}
.ad-box:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--brand-soft)}
.ad-mark{width:38px;height:38px;border-radius:11px;color:#fff;font-weight:800;font-size:1.1rem;
  display:grid;place-items:center;background:var(--ad,#1a4fd6);letter-spacing:-.02em}
.ad-name{font-size:.95rem;font-weight:700;color:var(--ink);line-height:1.3}
.ad-desc{font-size:.8rem;color:var(--ink-3);line-height:1.4}
.ad-phone{font-size:.85rem;font-weight:700;color:var(--brand);margin-top:1px}
.ad-badge{position:absolute;top:12px;right:12px;font-size:.58rem;font-weight:800;color:var(--ink-3);
  letter-spacing:.08em;background:var(--bg);padding:2px 6px;border-radius:5px}
.ad-vacant{align-items:center;justify-content:center;text-align:center;border-style:dashed;
  border-color:#cdd6e6;background:#fbfcff;min-height:92px;gap:3px}
.ad-vacant .av-plus{width:30px;height:30px;border-radius:50%;background:var(--brand-soft);color:var(--brand);
  font-size:1.2rem;font-weight:700;display:grid;place-items:center;margin-bottom:3px}
.ad-vacant strong{font-size:.9rem;color:var(--ink)}
.ad-vacant span{font-size:.74rem;color:var(--ink-3)}

/* 빠른 링크 */
.quick-links{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);
  border-radius:14px;padding:6px;box-shadow:var(--shadow)}
.ql{font-weight:600;font-size:.92rem;color:var(--ink-2);padding:11px 14px;border-radius:10px;
  display:flex;justify-content:space-between;align-items:center;transition:.14s}
.ql::after{content:"›";color:var(--ink-3);font-weight:400}
.ql:hover{background:var(--bg);color:var(--brand)}

/* 중앙 박스 */
.pcols{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.pbox{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:20px 22px;box-shadow:var(--shadow);min-width:0}
.pbox-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px;
  padding-bottom:13px;border-bottom:1px solid var(--line)}
.pbox-head h2{font-size:1.04rem;font-weight:800;letter-spacing:-.02em;position:relative;padding-left:12px}
.pbox-head h2::before{content:"";position:absolute;left:0;top:3px;bottom:3px;width:3px;border-radius:2px;background:var(--brand)}

/* 뉴스 리스트 */
.news-list{list-style:none}
.news-list--2{columns:2;column-gap:28px}
.news-list li a{display:flex;align-items:center;gap:9px;padding:9px 2px;border-bottom:1px solid var(--line-2);font-size:.92rem}
.news-list li:last-child a{border-bottom:none}
.news-list li a:hover .nt-title{color:var(--brand)}
.nt-title{flex:1;min-width:0;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}
.nt-time{font-size:.74rem;color:var(--ink-3);flex-shrink:0}
.nt-cmt{font-size:.74rem;color:var(--ink-3);font-weight:600;flex-shrink:0}

/* 뉴스 태그 — 부드러운 톤 */
.ntag{font-size:.68rem;font-weight:700;padding:3px 7px;border-radius:6px;flex-shrink:0}
.ntag-hot{background:#fdecec;color:#d4392f}.ntag-scoop{background:#eaf0ff;color:#1a4fd6}
.ntag-immig{background:#f3edfd;color:#7d3fd1}.ntag-estate{background:#e4f3f2;color:#0c7a84}
.ntag-case{background:#eef0f4;color:#48566a}.ntag-life{background:#e8f5ed;color:#1a824a}
.ntag-ent{background:#fdeaf1;color:#cf2e66}.ntag-sport{background:#e9eefb;color:#0a3d91}
.ntag-talk{background:#eef1f6;color:var(--ink-2)}

/* 빈 목록 안내 */
.list-empty a{display:block;padding:18px 4px;color:var(--brand);font-size:.9rem;font-weight:600;text-align:center}
.list-empty a:hover{text-decoration:underline}

/* 미니 리스트 (구인/벼룩/렌트) */
.mini-list{list-style:none}
.mini-list li a{display:flex;align-items:center;gap:8px;padding:9px 2px;border-bottom:1px solid var(--line-2);font-size:.9rem}
.mini-list li:last-child a{border-bottom:none}
.mini-list li a:hover .mn-title{color:var(--brand)}
.mn-title{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ink);font-weight:500}
.mn-price{font-weight:700;color:var(--ink);font-size:.86rem;flex-shrink:0}

/* 실시간 베스트 */
.best-list{list-style:none}
.best-list li a{display:flex;align-items:center;gap:11px;padding:9px 2px;border-bottom:1px solid var(--line-2);font-size:.92rem}
.best-list li:last-child a{border-bottom:none}
.best-rank{width:20px;text-align:center;font-size:.92rem;font-weight:800;color:var(--ink-3);flex-shrink:0}
.best-list li:nth-child(-n+3) .best-rank{color:var(--accent)}
.best-list li a:hover .nt-title{color:var(--brand)}
.best-hot{background:none;color:var(--accent);font-size:.6rem;font-weight:800;letter-spacing:.04em;vertical-align:middle;margin-left:2px}

/* 본문 중간 배너 스트립 — 네이티브 카드 */
.ad-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.strip-ad{position:relative;display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:14px;
  background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);transition:.16s;min-width:0}
.strip-ad:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--brand-soft)}
.strip-ad .ad-mark{flex-shrink:0}
.strip-ad .sa-text{min-width:0}
.strip-ad strong{display:block;font-size:.92rem;font-weight:700;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.strip-ad small{font-size:.78rem;color:var(--ink-3)}

/* 업소 로고 스트립 */
.strip-head{display:flex;justify-content:space-between;align-items:baseline;margin:10px 0 14px}
.strip-head h2{font-size:1.15rem;font-weight:800;letter-spacing:-.02em}
.logo-strip{display:grid;grid-template-columns:repeat(8,1fr);gap:14px;margin-bottom:22px}
.logo-card{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:18px 10px;
  text-align:center;box-shadow:var(--shadow);transition:.16s;display:flex;flex-direction:column;gap:8px;align-items:center}
.logo-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--brand-soft)}
.lc-emoji{width:48px;height:48px;border-radius:14px;background:var(--bg);display:grid;place-items:center;font-size:1.6rem}
.lc-name{font-size:.85rem;font-weight:700;line-height:1.3}
.lc-cat{font-size:.72rem;color:var(--ink-3)}

/* 광고 자리 (여기에 광고하세요) */
.ad-space{align-items:center;text-align:center;justify-content:center;border-style:dashed;
  border-color:#cdd6e6;background:linear-gradient(180deg,#fbfcff,#f3f7ff);gap:3px}
.ad-space:hover{border-color:var(--brand)}
.ad-space strong{font-size:.95rem;color:var(--ink)}
.adsp-ico{font-size:1.4rem}
.adsp-sub{font-size:.74rem;color:var(--ink-3)}
.adsp-cta{font-size:.78rem;font-weight:700;color:var(--brand);margin-top:3px}
.strip-ad{overflow:hidden}
.strip-ad:not(.strip-space)::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--ad,#1a4fd6)}
.strip-ad:not(.strip-space){padding-left:18px}
.strip-space{border-style:dashed;border-color:#cdd6e6;background:linear-gradient(180deg,#fbfcff,#f3f7ff)}
.adsp-mark{background:var(--brand-soft)!important;color:var(--brand)}

/* 하단 와이드 광고 모집 */
.ad-row{margin-bottom:8px}
.ad-wide{position:relative;display:flex;align-items:center;justify-content:center;gap:9px;padding:20px;
  border-radius:14px;border:1.5px dashed #cdd6e6;background:linear-gradient(180deg,#fbfcff,#f3f7ff);
  color:var(--ink-2);font-size:1rem;transition:.16s}
.ad-wide:hover{border-color:var(--brand);color:var(--brand)}
.ad-wide strong{color:var(--ink)}

@media(max-width:1080px){
  .portal{grid-template-columns:1fr 1fr}
  .rail{flex-direction:row;flex-wrap:wrap;position:static;grid-column:1/-1;order:3}
  .rail .ad-box,.rail .quick-links,.rail .ad-vacant{flex:1;min-width:160px}
  .portal-main{grid-column:1/-1;order:1}
  #rail-right{order:4}
  .logo-strip{grid-template-columns:repeat(4,1fr)}
  .ad-row{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:680px){
  .portal{grid-template-columns:1fr}
  .pcols{grid-template-columns:1fr}
  .ad-strip{grid-template-columns:1fr}
  .news-list--2{columns:1}
  .logo-strip{grid-template-columns:repeat(2,1fr)}
  .ad-row{grid-template-columns:1fr 1fr}
  .rail{flex-direction:column}
}

/* ===================================================================
   PAGE LAYOUT (board / post / write / directory / business)
   =================================================================== */
.page{padding:32px 0 64px;min-height:60vh}
.wrap-narrow{max-width:780px}
.back-link{display:inline-block;color:var(--ink-3);font-weight:600;font-size:.9rem;margin-bottom:16px;transition:.15s}
.back-link:hover{color:var(--brand)}

.page-head{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:22px;flex-wrap:wrap}
.page-head h1{font-size:1.7rem;font-weight:800;letter-spacing:-.02em}
.page-lead{color:var(--ink-2);margin-top:4px;font-size:.98rem}

/* toolbar: chips + search */
.toolbar{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-bottom:18px;flex-wrap:wrap}
.chips{display:flex;gap:8px;flex-wrap:wrap}
.chip{font-family:inherit;font-size:.9rem;font-weight:600;padding:8px 16px;border-radius:999px;
  border:1.5px solid var(--line);background:#fff;color:var(--ink-2);cursor:pointer;transition:.14s}
.chip:hover{border-color:var(--brand-soft);color:var(--brand)}
.chip.active{background:var(--brand);border-color:var(--brand);color:#fff}
.board-search input{font-family:inherit;font-size:.92rem;padding:9px 16px;border:1.5px solid var(--line);
  border-radius:999px;outline:none;min-width:220px;background:#fff;color:var(--ink)}
.board-search input:focus{border-color:var(--brand)}

/* board list rows */
.board-list{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow)}
.board-row{display:flex;align-items:center;gap:14px;padding:16px 20px;border-bottom:1px solid var(--line-2);transition:.12s}
.board-row:last-child{border-bottom:none}
.board-row:hover{background:var(--brand-soft)}
.board-row .tag{flex-shrink:0}
.row-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.row-title{font-weight:600;font-size:1rem;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.row-sub{font-size:.82rem;color:var(--ink-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.row-price{font-weight:800;color:var(--brand);font-size:.96rem;white-space:nowrap;flex-shrink:0}
.row-time{font-size:.8rem;color:var(--ink-3);white-space:nowrap;flex-shrink:0;min-width:48px;text-align:right}
.empty{text-align:center;color:var(--ink-3);padding:48px 20px;font-size:.96rem}
.empty a{color:var(--brand);font-weight:600}

/* post detail */
.post{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:30px 32px;box-shadow:var(--shadow)}
.post-head{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.post-time{color:var(--ink-3);font-size:.85rem}
.post h1{font-size:1.6rem;font-weight:800;letter-spacing:-.02em;line-height:1.3}
.post-byline{color:var(--ink-3);font-size:.9rem;margin-top:6px}
.post-info{width:100%;border-collapse:collapse;margin:20px 0;border-top:1px solid var(--line)}
.post-info th,.post-info td{text-align:left;padding:11px 4px;border-bottom:1px solid var(--line-2);font-size:.95rem;vertical-align:top}
.post-info th{width:110px;color:var(--ink-3);font-weight:600}
.post-info td{color:var(--ink);font-weight:500}
.post-body{margin-top:20px;font-size:1.02rem;line-height:1.75;color:var(--ink);white-space:pre-line}
.post-contact{margin-top:24px;padding:16px 18px;background:var(--brand-soft);border-radius:12px;
  display:flex;align-items:center;gap:12px}
.pc-label{font-size:.8rem;font-weight:700;color:var(--brand)}
.post-contact a{font-weight:700;font-size:1.05rem;color:var(--brand)}

/* comments */
.comments{margin-top:26px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:26px 30px;box-shadow:var(--shadow)}
.comments h3{font-size:1.1rem;font-weight:800;margin-bottom:18px}
.comment{padding:14px 0;border-bottom:1px solid var(--line-2)}
.comment-top{display:flex;align-items:center;gap:10px;margin-bottom:4px}
.comment-top strong{font-size:.92rem}
.comment-top span{font-size:.78rem;color:var(--ink-3)}
.comment p{font-size:.95rem;color:var(--ink);line-height:1.6}
.no-comments{color:var(--ink-3);font-size:.92rem;padding:8px 0 16px}
.comment-form{margin-top:18px;display:flex;flex-direction:column;gap:10px}
.comment-form input,.comment-form textarea{font-family:inherit;font-size:.95rem;padding:11px 14px;
  border:1.5px solid var(--line);border-radius:10px;outline:none;color:var(--ink);background:#fff}
.comment-form input:focus,.comment-form textarea:focus{border-color:var(--brand)}
.comment-form textarea{resize:vertical;min-height:80px}
.comment-form .btn{align-self:flex-end}

/* write form */
.write-title{font-size:1.6rem;font-weight:800;letter-spacing:-.02em;margin-bottom:22px}
.write-form{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:28px 30px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:18px}
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-size:.88rem;font-weight:700;color:var(--ink-2)}
.field .req{color:var(--accent)}
.field input,.field select,.field textarea{font-family:inherit;font-size:.96rem;padding:11px 14px;
  border:1.5px solid var(--line);border-radius:10px;outline:none;color:var(--ink);background:#fff;width:100%}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--brand)}
.field textarea{resize:vertical}
.form-actions{display:flex;gap:10px;margin-top:4px}
.write-note{font-size:.82rem;color:var(--ink-3);line-height:1.5;margin-top:2px}

/* directory grid */
.dir-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.dir-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px;box-shadow:var(--shadow);transition:.18s;position:relative;display:flex;flex-direction:column}
.dir-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--brand-soft)}
.dir-card.featured{border-color:#ffe2bd;background:linear-gradient(180deg,#fffaf2,#fff)}
.dir-top{display:flex;gap:13px;align-items:center;margin-bottom:12px}
.dir-logo{width:52px;height:52px;border-radius:13px;background:var(--bg);display:grid;place-items:center;font-size:1.7rem;flex-shrink:0}
.dir-card h3{font-size:1.06rem;font-weight:800}
.dir-card .biz-cat{font-size:.8rem}
.dir-desc{color:var(--ink-2);font-size:.9rem;line-height:1.5;flex:1;margin-bottom:12px}
.dir-foot{display:flex;justify-content:space-between;align-items:center;font-size:.82rem;color:var(--ink-3)}
.dir-rating{color:var(--gold);font-weight:700}

/* business detail */
.biz-detail{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:30px 32px;box-shadow:var(--shadow)}
.bd-head{display:flex;gap:18px;align-items:center;margin-bottom:22px}
.bd-logo{width:74px;height:74px;border-radius:18px;background:var(--bg);display:grid;place-items:center;font-size:2.4rem;flex-shrink:0}
.bd-head h1{font-size:1.6rem;font-weight:800}
.bd-rating{color:var(--gold);font-weight:700;margin-top:4px}
.bd-info{width:100%;border-collapse:collapse;margin-top:8px;border-top:1px solid var(--line)}
.bd-info th,.bd-info td{text-align:left;padding:13px 4px;border-bottom:1px solid var(--line-2);font-size:.96rem}
.bd-info th{width:90px;color:var(--ink-3);font-weight:600}
.bd-info a{color:var(--brand);font-weight:600}
.bd-cta{margin-top:24px;display:flex;gap:10px;flex-wrap:wrap}

/* ===================================================================
   PHOTOS — grid cards / uploader / gallery / lightbox / thumbnails
   =================================================================== */

/* 사진 카드 그리드 (사고팔기 / 부동산) */
.market-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.mcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow);transition:.18s;display:flex;flex-direction:column}
.mcard:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--brand-soft)}
.mcard-photo{position:relative;aspect-ratio:1/1;background-size:cover;background-position:center;background-color:var(--bg)}
.mcard-photo--ph{display:grid;place-items:center;font-size:3.4rem;
  background:linear-gradient(135deg,#eef2fa,#e6ecf7)}
.photo-count{position:absolute;left:8px;bottom:8px;background:rgba(0,0,0,.6);color:#fff;
  font-size:.72rem;font-weight:700;padding:2px 8px;border-radius:999px}
.mcard-body{padding:13px 14px 15px;display:flex;flex-direction:column;gap:4px}
.mcard-top{display:flex;justify-content:space-between;align-items:center}
.mcard-time{font-size:.76rem;color:var(--ink-3)}
.mcard-title{font-weight:700;font-size:.98rem;line-height:1.35;color:var(--ink);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.mcard-price{font-weight:800;font-size:1.08rem;color:var(--brand)}
.mcard-sub{font-size:.8rem;color:var(--ink-3)}

/* 행 썸네일 (커뮤니티) */
.row-thumb{width:44px;height:44px;border-radius:9px;flex-shrink:0;background-size:cover;
  background-position:center;background-color:var(--bg)}

/* 업로더 */
.up-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(92px,1fr));gap:10px}
.up-thumb{position:relative;aspect-ratio:1/1;border-radius:11px;overflow:hidden;border:1px solid var(--line)}
.up-thumb img{width:100%;height:100%;object-fit:cover}
.up-x{position:absolute;top:4px;right:4px;width:22px;height:22px;border:none;border-radius:50%;
  background:rgba(0,0,0,.6);color:#fff;font-size:1rem;line-height:1;cursor:pointer;display:grid;place-items:center}
.up-x:hover{background:rgba(0,0,0,.85)}
.up-add{aspect-ratio:1/1;border:2px dashed var(--line);border-radius:11px;display:flex;
  flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:pointer;
  color:var(--ink-3);transition:.15s;background:var(--bg)}
.up-add:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-soft)}
.up-add span{font-size:1.5rem;line-height:1}
.up-add small{font-size:.74rem;font-weight:600}
.up-hint{font-size:.78rem;color:var(--ink-3);margin-top:8px}

/* 상세 갤러리 */
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px;margin:18px 0 4px}
.gal-img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:12px;cursor:zoom-in;
  border:1px solid var(--line);transition:.15s}
.gal-img:hover{filter:brightness(.94)}

/* 라이트박스 */
.lightbox{position:fixed;inset:0;z-index:200;background:rgba(8,12,20,.92);display:grid;place-items:center;
  padding:24px;cursor:zoom-out;animation:lbin .15s ease}
.lightbox img{max-width:100%;max-height:100%;border-radius:8px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.lb-close{position:fixed;top:18px;right:22px;width:44px;height:44px;border:none;border-radius:50%;
  background:rgba(255,255,255,.15);color:#fff;font-size:1.6rem;cursor:pointer}
.lb-close:hover{background:rgba(255,255,255,.28)}
@keyframes lbin{from{opacity:0}to{opacity:1}}

/* ===================================================================
   AUTH — utility user / modal / login gate
   =================================================================== */
.util-user{color:var(--gold);font-weight:700}

.modal-backdrop{position:fixed;inset:0;z-index:300;background:rgba(8,12,20,.55);
  backdrop-filter:blur(3px);display:grid;place-items:center;padding:20px;animation:lbin .15s ease}
.modal-backdrop[hidden]{display:none}
.modal{background:#fff;border-radius:20px;width:100%;max-width:400px;padding:30px 28px;
  box-shadow:0 24px 70px rgba(0,0,0,.3);position:relative}
.modal-close{position:absolute;top:14px;right:16px;width:34px;height:34px;border:none;border-radius:50%;
  background:var(--bg);color:var(--ink-3);font-size:1.3rem;cursor:pointer;line-height:1}
.modal-close:hover{background:var(--line);color:var(--ink)}
.modal-brand{display:flex;align-items:center;gap:9px;font-weight:800;font-size:1.1rem;margin-bottom:20px}
.modal-brand .logo-mark{width:32px;height:32px;font-size:1rem;border-radius:9px}

.auth-tabs{display:flex;gap:4px;background:var(--bg);padding:4px;border-radius:12px;margin-bottom:22px}
.auth-tabs button{flex:1;font-family:inherit;font-size:.95rem;font-weight:700;padding:10px;border:none;
  border-radius:9px;background:transparent;color:var(--ink-2);cursor:pointer;transition:.14s}
.auth-tabs button.active{background:#fff;color:var(--brand);box-shadow:var(--shadow)}

.btn-google{display:flex;align-items:center;justify-content:center;gap:9px;width:100%;font-family:inherit;
  font-size:.96rem;font-weight:700;padding:12px;border:1.5px solid var(--line);border-radius:11px;
  background:#fff;color:var(--ink);cursor:pointer;transition:.14s}
.btn-google:hover{background:var(--bg);border-color:var(--ink-3)}
.g-ico{width:20px;height:20px;border-radius:50%;background:#fff;border:1px solid var(--line);
  display:grid;place-items:center;font-weight:800;color:#4285f4;font-size:.85rem}
.auth-or{display:flex;align-items:center;gap:10px;margin:16px 0;color:var(--ink-3);font-size:.8rem}
.auth-or::before,.auth-or::after{content:"";flex:1;height:1px;background:var(--line)}

.auth-form{display:flex;flex-direction:column;gap:14px}
.auth-form[hidden]{display:none}
.auth-form .field{gap:6px}
.auth-form input{font-family:inherit;font-size:.96rem;padding:12px 14px;border:1.5px solid var(--line);
  border-radius:10px;outline:none;color:var(--ink);background:#fff;width:100%}
.auth-form input:focus{border-color:var(--brand)}
.auth-form .btn{width:100%;margin-top:4px}
.auth-error{color:var(--accent-dark);font-size:.85rem;font-weight:600;min-height:1px;margin:-4px 0}
.auth-error:empty{display:none}
.auth-note{font-size:.78rem;color:var(--ink-3);line-height:1.5;margin-top:16px;text-align:center}

/* 로그인 필요 안내 */
.login-gate{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:48px 24px;text-align:center;box-shadow:var(--shadow)}
.login-gate p{font-size:1.05rem;color:var(--ink-2);margin-bottom:18px}
.login-gate--sm{padding:24px;margin-top:18px}
.login-gate--sm p{font-size:.95rem;margin-bottom:14px}

@media(max-width:1100px){ .market-grid{grid-template-columns:repeat(3,1fr)} }
@media(max-width:900px){ .dir-grid{grid-template-columns:repeat(2,1fr)} }
@media(max-width:680px){
  .dir-grid{grid-template-columns:1fr}
  .market-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .toolbar{flex-direction:column;align-items:stretch}
  .board-search input{width:100%}
  .row-sub{display:none}
  .post,.write-form,.comments,.biz-detail{padding:22px 18px}
  .page-head h1{font-size:1.4rem}
}
