:root{
  --bg:#ffffff; --fg:#222222; --muted:#717171; --line:#ebebeb;
  --brand:#e8385a; --brand2:#ff5a5f; --chip:#f7f7f7; --shadow:0 6px 20px rgba(0,0,0,.08);
}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Apple SD Gothic Neo","Pretendard",sans-serif;
  color:var(--fg);background:var(--bg);}

/* topbar */
.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:16px;
  padding:14px 24px;background:#fff;border-bottom:1px solid var(--line);}
.brand{font-weight:800;font-size:22px;color:var(--brand);}
.brand span{color:var(--fg);}
.searchbox{flex:1;max-width:520px;display:flex;align-items:center;border:1px solid var(--line);
  border-radius:999px;padding:6px 8px 6px 18px;box-shadow:var(--shadow);}
.searchbox input{flex:1;border:0;outline:0;font-size:15px;background:transparent;}
.searchbox button{border:0;background:var(--brand);color:#fff;width:36px;height:36px;border-radius:50%;cursor:pointer;}
.ghost{border:1px solid var(--line);background:#fff;border-radius:999px;padding:9px 16px;cursor:pointer;font-size:14px;}
.ghost:hover{background:var(--chip);}
.brand{cursor:pointer;}

/* 메인 네비게이션 (에어비앤비식: 축제/로컬맛집/주변관광지)
   브랜드·우측버튼을 같은 폭(flex:1)으로 둬서 네비가 콘텐츠 정중앙에 오게 */
.topbar > .brand{flex:1 1 0;}
.topbar > .topright{flex:1 1 0;justify-content:flex-end;}
.mainnav{display:flex;gap:6px;margin:0 auto;flex:0 0 auto;}
.navtab{display:inline-flex;align-items:center;gap:7px;border:0;background:none;border-radius:10px;
  padding:9px 16px;cursor:pointer;font-size:16px;font-weight:600;color:var(--muted);white-space:nowrap;}
.nt-ico{font-size:18px;line-height:1;}
.navtab:hover{background:var(--chip);color:var(--fg);}
.navtab.active{color:var(--fg);box-shadow:inset 0 -2px 0 var(--fg);border-radius:0;}
.topright{display:flex;align-items:center;gap:10px;}
.cta{border:0;background:var(--brand);color:#fff;border-radius:999px;padding:10px 18px;
  cursor:pointer;font-size:14px;font-weight:700;white-space:nowrap;}
.brand{white-space:nowrap;}
.iconbtn.wish{white-space:nowrap;}
.topbar{flex-wrap:wrap;}
.cta:hover{filter:brightness(1.05);}
.cta.active{box-shadow:0 0 0 3px rgba(232,56,90,.25);}
.iconbtn{border:1px solid var(--line);background:#fff;border-radius:999px;padding:9px 14px;cursor:pointer;font-size:14px;}
.iconbtn.wish.active{color:var(--brand);border-color:var(--brand);}

/* 에어비앤비식 통합 검색 pill */
.searchwrap{display:flex;justify-content:center;padding:18px 24px 6px;}
.searchbar{display:flex;align-items:center;gap:2px;width:100%;max-width:820px;background:#fff;
  border:1px solid var(--line);border-radius:999px;box-shadow:var(--shadow);padding:6px 6px 6px 8px;}
.searchbar:hover{box-shadow:0 8px 28px rgba(0,0,0,.12);}
.sb-seg{display:flex;flex-direction:column;justify-content:center;padding:8px 20px;border-radius:999px;flex:1;min-width:0;cursor:text;}
.sb-seg:hover{background:var(--chip);}
.sb-seg.sb-where{flex:1.5;}
.sb-seg label{font-size:11px;font-weight:700;color:var(--fg);margin-bottom:2px;cursor:pointer;}
.sb-seg input{border:0;outline:0;background:transparent;font-size:14px;color:var(--fg);width:100%;padding:0;font-family:inherit;}
.sb-seg input::placeholder{color:var(--muted);}
.sb-seg input[type=date]{min-width:0;}
.sb-div{width:1px;height:32px;background:var(--line);flex:0 0 auto;}
.sb-go{flex:0 0 auto;border:0;background:var(--brand);color:#fff;width:48px;height:48px;border-radius:50%;
  cursor:pointer;font-size:18px;margin-left:6px;display:flex;align-items:center;justify-content:center;}
.sb-go:hover{filter:brightness(1.05);}

/* 보조 도구 칩 + 필터 */
.chip{border:1px solid var(--line);background:#fff;border-radius:999px;padding:9px 14px;cursor:pointer;font-size:14px;white-space:nowrap;}
.chip:hover{background:var(--chip);}
.chip.active{border-color:var(--fg);font-weight:600;}
.controls .tools{display:flex;gap:8px;}

/* 준비 중 (로컬맛집·주변관광지·코스생성) */
.coming{display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:90px 24px;min-height:50vh;}
.coming .ico{font-size:60px;margin-bottom:18px;}
.coming h2{font-size:26px;margin:0 0 6px;}
.coming .tag{display:inline-block;background:#fff4f1;color:var(--brand);border-radius:999px;
  padding:5px 14px;font-size:13px;font-weight:700;margin-bottom:16px;}
.coming p{color:var(--muted);font-size:15px;line-height:1.6;max-width:460px;margin:0 0 24px;}
.coming button{border:0;background:var(--brand);color:#fff;border-radius:10px;padding:12px 22px;cursor:pointer;font-size:14px;font-weight:600;}

/* category pills */
.cats{display:flex;gap:10px;overflow-x:auto;padding:14px 24px;border-bottom:1px solid var(--line);}
.cats button{flex:0 0 auto;border:1px solid var(--line);background:#fff;border-radius:999px;
  padding:8px 16px;font-size:14px;cursor:pointer;color:var(--muted);white-space:nowrap;}
.cats button.active{border-color:var(--fg);color:var(--fg);font-weight:600;background:#fff;}

/* controls */
.controls{display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding:16px 24px 4px;}
.controls select{padding:9px 12px;border:1px solid var(--line);border-radius:10px;font-size:14px;background:#fff;}
.daterange{display:inline-flex;align-items:center;gap:6px;}
.daterange input[type=date]{padding:8px 10px;border:1px solid var(--line);border-radius:10px;font-size:13px;background:#fff;color:var(--fg);}
.daterange .tilde{color:var(--muted);}
.ghost.sm{padding:6px 10px;font-size:12px;}
.chk{font-size:14px;color:var(--muted);display:flex;align-items:center;gap:6px;cursor:pointer;}
.count{margin-left:auto;color:var(--muted);font-size:14px;}

/* curations (Airbnb 히어로식 가로 캐러셀) */
.curations{padding:14px 24px 50px;}
.crow{margin-bottom:30px;}
.crow-head{display:flex;align-items:baseline;gap:10px;margin:0 0 14px;}
.crow-head h2{font-size:21px;font-weight:700;margin:0;}
.crow-head .sub{color:var(--muted);font-size:13px;}
.crow-head .more{margin-left:auto;font-size:13px;color:var(--brand);background:none;border:0;cursor:pointer;}
.carousel{display:flex;gap:18px;overflow-x:auto;padding:2px 2px 10px;scroll-snap-type:x mandatory;scrollbar-width:thin;}
.carousel .card{flex:0 0 218px;width:218px;scroll-snap-align:start;}

/* 장소 뷰 (로컬맛집·주변관광지 탭) */
.places-view{padding:20px 24px 60px;}
.places-view .crow-head{display:flex;align-items:baseline;gap:10px;margin:0 0 16px;}
.places-view .crow-head h2{font-size:22px;margin:0;}
.places-view .grid{padding:0;}
.card.place{text-decoration:none;color:inherit;}
.card.place:hover h3{color:var(--brand);}

/* 상세 모달 내 주변 맛집 스트립 */
.nearfood{margin-top:22px;border-top:1px solid var(--line);padding-top:18px;}
.nf-sub{color:var(--muted);font-size:13px;margin:0;}
.nf-list{display:flex;gap:12px;overflow-x:auto;padding-bottom:6px;}
.nf-item{flex:0 0 120px;text-decoration:none;color:inherit;}
.nf-thumb{width:120px;height:84px;border-radius:10px;background:var(--chip);display:flex;align-items:center;justify-content:center;font-size:26px;overflow:hidden;}
.nf-thumb img{width:100%;height:100%;object-fit:cover;}
.nf-name{font-size:13px;font-weight:600;margin-top:6px;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.nf-meta{font-size:12px;color:var(--brand);font-weight:600;}

/* grid */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:24px;padding:20px 24px 60px;}
.card{cursor:pointer;display:block;text-decoration:none;color:inherit;}
.card:hover h3{color:var(--brand);}

/* 축제 상세 페이지 (/festival.html) */
.detail-page{max-width:1060px;margin:0 auto;padding:22px 24px 80px;}
.back{display:inline-block;margin-bottom:14px;color:var(--muted);text-decoration:none;font-size:14px;}
.back:hover{color:var(--fg);}
.dp-title{font-size:30px;font-weight:800;margin:0 0 8px;line-height:1.25;}
.dp-sub{color:var(--muted);margin:0 0 18px;font-size:15px;}
.dp-hero{width:100%;max-height:460px;object-fit:cover;border-radius:18px;
  background:linear-gradient(135deg,#ffd9df,#ffe9c7);}
.dp-hero-ph{height:340px;display:flex;align-items:center;justify-content:center;font-size:80px;}
.dp-grid{display:grid;grid-template-columns:1fr 330px;gap:36px;margin-top:30px;}
.dp-main{min-width:0;}  /* 가로 스크롤(주변맛집)이 컬럼을 부풀리지 않도록 */
.dp-h2{font-size:20px;margin:0 0 12px;}
.dp-main .dp-h2{margin-top:30px;}
.dp-main .dp-h2:first-child{margin-top:0;}
.dp-ov{line-height:1.7;color:#333;font-size:15px;white-space:pre-wrap;margin:0;}
.dp-map{height:320px;border-radius:14px;border:1px solid var(--line);}
.dp-info-card{border:1px solid var(--line);border-radius:16px;padding:22px;box-shadow:var(--shadow);position:sticky;top:20px;}
.dp-actions{display:flex;flex-direction:column;gap:10px;margin-top:18px;}
.dp-actions button{padding:13px;border-radius:10px;border:1px solid var(--line);background:#fff;cursor:pointer;font-size:15px;font-weight:600;}
.dp-actions .primary{background:var(--brand);color:#fff;border:0;}
@media(max-width:820px){ .dp-grid{grid-template-columns:1fr;} .dp-info-card{position:static;} }
.card .thumb{position:relative;width:100%;aspect-ratio:1/1;border-radius:14px;overflow:hidden;background:linear-gradient(135deg,#ffd9df,#ffe9c7);}
.card .thumb img{width:100%;height:100%;object-fit:cover;display:block;}
.card .ph{display:flex;align-items:center;justify-content:center;height:100%;font-size:34px;}
.heart{position:absolute;top:10px;right:10px;border:0;background:rgba(0,0,0,.35);color:#fff;
  width:34px;height:34px;border-radius:50%;cursor:pointer;font-size:16px;line-height:1;}
.heart.on{background:var(--brand);}
.badge{position:absolute;top:10px;left:10px;background:#fff;border-radius:8px;padding:3px 8px;font-size:12px;font-weight:600;}
.badge.ongoing{color:#0a7d33;} .badge.upcoming{color:#1668c1;}
.card h3{margin:10px 2px 2px;font-size:15px;font-weight:600;line-height:1.3;}
.card .meta{margin:2px;color:var(--muted);font-size:13px;}
.card .cat{display:inline-block;margin-top:6px;font-size:12px;color:var(--brand);}
.card .dist{color:var(--brand);font-weight:600;}

/* map */
.map-wrap{padding:0 24px 40px;}
#map{height:72vh;border-radius:16px;border:1px solid var(--line);}
.hidden{display:none;}

/* 무료/유료 뱃지 · 정보 key-value (상세 페이지 공용) */
.pill{display:inline-block;border-radius:8px;padding:2px 8px;font-size:12px;font-weight:700;}
.pill.free{background:#e7f7ec;color:#0a7d33;}
.pill.paid{background:#eef1f6;color:#4a5568;}
.kv{display:flex;gap:8px;margin:8px 0;font-size:14px;}
.kv b{min-width:64px;color:var(--muted);font-weight:500;}
.kv a{color:var(--brand);text-decoration:none;}
.kv a:hover{text-decoration:underline;}

.foot{padding:30px 24px;text-align:center;color:var(--muted);font-size:13px;border-top:1px solid var(--line);}

/* ───────── 사이트 푸터 (에어비앤비식) ───────── */
.site-foot{border-top:1px solid var(--line);background:#f7f7f7;margin-top:40px;}
.foot-inner{max-width:1280px;margin:0 auto;padding:40px 24px 28px;}
.foot-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;padding-bottom:26px;
  border-bottom:1px solid var(--line);}
.foot-col h4{margin:0 0 14px;font-size:14px;font-weight:700;color:var(--fg);}
.foot-col a,.foot-col span{display:block;font-size:13px;color:var(--muted);
  text-decoration:none;line-height:2;}
.foot-col a:hover{color:var(--fg);text-decoration:underline;}
.foot-bottom{display:flex;flex-wrap:wrap;gap:6px 16px;align-items:center;
  padding-top:20px;font-size:12px;color:var(--muted);}
.foot-bottom .copy{font-weight:600;color:var(--fg);}
.foot-bottom .dot{opacity:.4;}
@media(max-width:640px){
  .foot-inner{padding:32px 16px 24px;}
  .foot-cols{grid-template-columns:1fr;gap:24px;}
}

/* 위치 권한 실패 등 빈 상태 폴백 */
.empty-state{display:flex;flex-direction:column;align-items:center;gap:14px;
  padding:48px 20px;text-align:center;}
.retry-btn{border:0;background:var(--brand);color:#fff;border-radius:999px;
  padding:10px 22px;font-size:15px;cursor:pointer;}
.retry-btn:hover{filter:brightness(1.05);}

/* ───────── 콘텐츠 중앙 정렬 ─────────
   풀폭 바(배경·구분선)는 그대로 두고 내부 콘텐츠만 1280px 중앙으로.
   화면이 1280보다 넓으면 좌우 여백이 자동으로 늘어 콘텐츠가 가운데 온다. */
.topbar,.subbar,.cats,.controls,.curations,.grid,.places-view,.map-wrap,.foot{
  padding-inline: max(24px, calc((100% - 1280px) / 2));
}

/* ───────── 모바일 반응형 ───────── */
@media(max-width:640px){
  .topbar,.searchwrap,.cats,.controls,.curations,.grid,.places-view,.map-wrap,.foot{
    padding-inline:16px;
  }
  .topbar{gap:10px;padding-block:10px;}
  .mainnav{order:3;flex:1 1 100%;justify-content:center;margin:0;}
  /* 검색 pill: 모바일은 세로 스택 */
  .searchbar{flex-wrap:wrap;border-radius:24px;padding:8px;}
  .sb-seg{flex:1 1 100%;padding:8px 12px;}
  .sb-div{display:none;}
  .sb-go{width:100%;height:42px;border-radius:12px;margin:6px 0 0;}
  .controls .tools{flex-wrap:wrap;}
  .crow-head{flex-wrap:wrap;}
  .crow-head .more{margin-left:0;}
  .dp-title{font-size:24px;}
  .dp-hero{max-height:300px;}
}
