/* =========================================================
   Culture Service · Modern UI (v2) — 지역 메타 제거 대응판
   파일: culture_service_style.css
   ========================================================= */

/* ---------- Variables ---------- */
:root{
  /* 색상 */
  --bg:#ffffff; --text:#0f172a; --muted:#6b7280; --border:#e5e7eb;
  --card:#ffffff; --primary:#2563eb; --primary-weak:#eff6ff; --accent:#f59e0b;

  /* 효과 */
  --shadow-sm:0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
  --shadow-md:0 8px 20px rgba(15,23,42,.08);
  --shadow-lg:0 18px 50px rgba(15,23,42,.12);

  /* 라운드/전환 */
  --r-sm:12px; --r-md:14px; --r-lg:18px; --r-xl:24px; --r-full:999px;
  --speed:200ms; --easing:cubic-bezier(.2,.6,.2,1);

  /* 레이아웃 */
  --wrap:1100px;

  /* Detail/검색카드용 색 */
  --fg-surface:#fff; --fg-text:#1f2937; --fg-muted:#6b7280; --fg-border:#e5e7eb;
  --fg-primary:#2083e4; --fg-primary-600:#1968b5; --fg-shadow:0 10px 25px rgba(17,24,39,.08);

  /* Thumb scale */
  --thumb-scale:.92;
  --thumb-max-h:300px;
}

@media (prefers-color-scheme: dark){
  :root{
    --bg:#0b1020; --text:#e5e7eb; --muted:#9ca3af; --border:#1f2937; --card:#0f162c;
    --primary:#60a5fa; --primary-weak:#0b1b39; --accent:#fbbf24;
    --shadow-md:0 8px 20px rgba(0,0,0,.35); --shadow-lg:0 18px 50px rgba(0,0,0,.45);
  }
}

/* ---------- Base ---------- */
*{ box-sizing:border-box; }
html,body{
  margin:0; padding:0; background:var(--bg); color:var(--text);
  font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Noto Sans KR,Helvetica,Arial,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,"Noto Color Emoji";
  line-height:1.6; -webkit-text-size-adjust:100%;
}
img{ max-width:100%; display:block; }

/* ---------- Hero ---------- */
.ce-hero{ max-width:min(var(--wrap),92vw); margin:32px auto 10px; text-align:center; }
.ce-title{ margin:0 0 8px; font-size:clamp(20px,3.4vw,32px); font-weight:800; letter-spacing:-.02em; }
.ce-subtitle{ margin:0; color:var(--muted); font-size:clamp(13px,1.4vw,16px); }

/* ---------- (옵션) 기존 탭 컴포넌트 스타일 — 사용하지 않으면 무시 ---------- */
.ce-tab{ display:inline-flex; align-items:center; gap:6px; }
.ce-tab-icon{ width:18px; height:18px; stroke:currentColor; flex-shrink:0; }
.ce-tabs{ display:flex; gap:8px; padding:8px; margin:18px auto 22px; max-width:min(var(--wrap),92vw);
  background:var(--card); border:1px solid var(--border); border-radius:var(--r-xl); box-shadow:var(--shadow-md);
  overflow-x:auto; scrollbar-width:none; }
.ce-tabs::-webkit-scrollbar{ display:none; }
.ce-tab{ border:0; background:transparent; color:var(--text);
  padding:11px 16px; border-radius:var(--r-full); font-weight:700; white-space:nowrap; cursor:pointer;
  transition:background var(--speed) var(--easing), color var(--speed) var(--easing), transform var(--speed) var(--easing); }
.ce-tab:hover{ background:var(--primary-weak); }
.ce-tab.is-active{ color:var(--primary); background:linear-gradient(180deg, rgba(99,102,241,.08), rgba(99,102,241,.04)); }

/* ---------- Panels ---------- */
.ce-panel{ display:none; }
.ce-panel.is-active{ display:block; }
.ce-panel-title{
  max-width:min(var(--wrap),92vw); margin:8px auto 14px; font-size:clamp(16px,2.2vw,20px); font-weight:800; letter-spacing:-.01em;
}
.ce-empty{
  max-width:min(var(--wrap),92vw); margin:24px auto; padding:18px; border:1px dashed var(--border);
  border-radius:var(--r-md); color:var(--muted); text-align:center; background:rgba(125,125,125,.03);
}

/* ---------- Cards/Grid ---------- */
.ce-card{ grid-column:auto; will-change:transform; transition:transform .15s ease, box-shadow .2s ease; }
.ce-card:hover{ transform:translateY(-3px); box-shadow:var(--shadow-lg); }

.ce-grid{
  display:grid; gap:14px;
  max-width:min(var(--wrap),92vw); margin:0 auto 28px;
  grid-template-columns:repeat(2,minmax(0,1fr)) !important; /* 모바일 기본 2열 */
}
.cf-grid-wrap{ max-width:1000px; margin:14px auto 0; }
.cf-grid{ display:grid; gap:14px; grid-template-columns:repeat(2,minmax(0,1fr)) !important; }

/* ≤360px: 1열 폴백 */
@media (max-width:360px){
  .ce-grid{ grid-template-columns:1fr !important; }
  .cf-grid{ grid-template-columns:1fr !important; }
}

/* ≥641px: 2열 유지 + 여백 개선 */
@media (min-width:641px){
  .ce-grid{ grid-template-columns:repeat(2,1fr) !important; gap:16px; }
  .cf-grid{ grid-template-columns:repeat(2,1fr) !important; gap:16px; }
}

/* ---------- Thumbs (원본 비율 유지 + 살짝 확대감) ---------- */
.ce-thumb,
.cf-card__thumb{
  width:calc(100% * var(--thumb-scale)) !important;
  height:auto !important; aspect-ratio:auto !important; object-fit:contain !important;
  max-height:var(--thumb-max-h);
  display:block; margin:0 auto; background:#f3f4f6; border-radius:12px;
}
.ce-thumb--empty{
  display:grid; place-items:center; color:var(--muted); font-size:13px; height:160px; border-radius:12px; background:#f3f4f6;
}

/* 매우 작은 화면에서는 꽉 채우기 */
@media (max-width:360px){
  .ce-thumb, .cf-card__thumb{ width:100% !important; max-height:none; }
}

/* ---------- Card Body/Text ---------- */
.ce-body{ padding:12px 12px 10px; }
.ce-card-title{
  margin:2px 0 4px; font-size:clamp(14px,2.2vw,17px); font-weight:800; letter-spacing:-.01em;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
  word-break:break-word; overflow-wrap:anywhere; line-height:1.35;
}
.ce-desc{
  margin:0 0 8px; color:var(--muted); font-size:13px; line-height:1.55;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
  word-break:break-word; overflow-wrap:anywhere;
}

/* ---------- Meta (지역 삭제 반영) ---------- */
.ce-meta{
  display:flex; flex-wrap:wrap; gap:6px 12px; margin:8px 0 10px; font-size:12.5px; line-height:1.45;
}
.ce-kv{ display:inline-flex; align-items:center; gap:6px; }
.ce-meta .k{ font-weight:700; color:#6b7280; opacity:.95; }
.ce-meta .k::after{ content:" : "; }

/* 메타 라벨/값 줄바꿈 허용 */
.ce-meta .k, .ce-meta .v{
  white-space:normal;
  word-break:break-word;
  overflow-wrap:anywhere;
}

/* ✅ 레거시 강제 nowrap 제거 (모바일 넘침 방지) */
/* (기존에 있던 #tab-period 관련 nowrap/inline 강제 규칙을 삭제했습니다) */

/* ---------- Actions ---------- */
.ce-actions{ display:flex; justify-content:flex-end; margin-top:2px; }
.ce-btn{
  display:inline-flex; align-items:center; gap:6px; padding:9px 12px; color:#1f2937; text-decoration:none;
  border-radius:var(--r-sm); font-weight:800; font-size:12.5px; background:#f3f4ff;
  transition:transform var(--speed) var(--easing), box-shadow var(--speed) var(--easing), background var(--speed) var(--easing);
}
.ce-btn:hover{ transform:translateY(-1px); box-shadow:0 10px 22px rgba(37,99,235,.22); }
.ce-btn:active{ transform:translateY(0); }

/* ---------- Detail ---------- */
.ce-detail{
  max-width:min(var(--wrap),92vw); margin:0 auto 32px; padding:18px; background:var(--card);
  border:1px solid var(--border); border-radius:var(--r-lg); box-shadow:var(--shadow-sm);
}
.ce-detail-title{ margin:0 0 12px; font-size:clamp(18px,2.6vw,22px); font-weight:800; }
.ce-detail-list{ list-style:none; padding:0; margin:0 0 12px; display:grid; gap:10px; }
.ce-detail-list li{ display:grid; grid-template-columns:96px 1fr; gap:10px; font-size:14px; align-items:start; }
.ce-detail-list strong{ color:var(--muted); font-weight:700; }
@media (max-width:520px){ .ce-detail-list li{ grid-template-columns:80px 1fr; } }

/* ---------- Calendar ---------- */
.ce-calendar{
  max-width:min(var(--wrap),92vw); margin:0 auto 32px; padding:0; list-style:none; display:grid; gap:10px;
}
.ce-calendar-item{
  display:flex; align-items:center; justify-content:space-between; gap:12px; padding:14px 16px;
  background:var(--card); border:1px solid var(--border); border-radius:var(--r-md);
  transition:box-shadow var(--speed) var(--easing), transform var(--speed) var(--easing);
}
.ce-calendar-item:hover{ transform:translateY(-2px); box-shadow:var(--shadow-md); }
.ce-calendar-link{ color:var(--text); text-decoration:none; font-weight:800; }
.ce-calendar-meta{ color:var(--muted); font-size:12.5px; }

/* ---------- Badges ---------- */
.ce-badge{
  display:inline-flex; align-items:center; gap:6px; padding:6px 10px;
  border-radius:var(--r-full); background:var(--primary-weak); color:var(--primary);
  font-weight:800; font-size:11.5px;
}

/* 큰 화면에서 살짝 여백 증가 */
@media (min-width:1200px){ .ce-hero{ margin-top:40px; } }

/* ---------- Notice ---------- */
.cf-notice{
  max-width:1000px; margin:12px auto; padding:10px 12px;
  border:1px solid var(--fg-border); border-radius:10px; background:#f9fafb; color:#374151; font-size:13px;
}

/* ---------- Hero/Prompt (cf-) ---------- */
.cf-hero{ max-width:1000px; margin:16px auto 8px; text-align:center; }
.cf-title{ font-size:28px; font-weight:800; margin:0 0 6px; color:#1f2937; }
.cf-subtitle{ margin:0 0 18px; color:#6b7280; font-size:14px; }

.cf-searchcard{
  display:grid; grid-template-columns:1.3fr .7fr 120px; gap:10px;
  background:var(--fg-surface); border:1px solid var(--fg-border);
  border-radius:16px; padding:14px; box-shadow:var(--fg-shadow);
}
.cf-field{ text-align:left; display:flex; flex-direction:column; gap:6px; }
.cf-label{ font-size:12px; font-weight:800; color:#111827; }
.cf-input input, .cf-select select{
  width:100%; padding:12px; border:1px solid var(--fg-border); border-radius:12px; font-size:14px; background:#fff;
}
.cf-btn-primary{
  align-self:end; height:44px; background:var(--fg-primary); color:#fff; border:none; border-radius:12px;
  font-weight:900; cursor:pointer; transition:transform .12s ease, background .2s ease;
}
.cf-btn-primary:hover{ background:var(--fg-primary-600); transform:translateY(-1px); }
@media (max-width:720px){
  .cf-searchcard{ grid-template-columns:1fr; }
  .cf-btn-primary{ width:100%; }
}

/* ---------- cf-Card ---------- */
.cf-card{
  background:#fff; border:1px solid #e5e7eb; border-radius:16px; overflow:hidden;
  box-shadow:0 6px 18px rgba(15,23,42,.06); transition:transform .15s ease, box-shadow .2s ease;
}
.cf-card:hover{ transform:translateY(-2px); box-shadow:0 14px 36px rgba(15,23,42,.12); }
.cf-card__body{ padding:14px 14px 12px; }
.cf-badges{ display:flex; gap:6px; margin-bottom:8px; }
.cf-badge{
  font-size:11px; font-weight:900; padding:4px 8px; border-radius:999px;
  background:#eef2ff; color:#1e40af; border:1px solid #dbe4ff;
}
.cf-title-row{ display:flex; justify-content:space-between; align-items:center; gap:8px; }
.cf-card__title{ font-size:16px; font-weight:900; margin:0 0 6px; color:#111827; line-height:1.25; }
.cf-addr,.cf-tel{
  display:flex; align-items:center; gap:6px; font-size:12px; color:#374151; margin-top:6px;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.cf-card__footer{ display:flex; justify-content:flex-end; padding:10px 14px 14px; }
.cf-more{
  display:inline-flex; align-items:center; gap:6px; font-size:12px; font-weight:800;
  background:#111827; color:#fff; border:0; border-radius:10px; padding:8px 10px; text-decoration:none;
}
.cf-more:hover{ filter:brightness(.98); }

/* ---------- Quick Filters (qf-) ---------- */
:root{
  --qf-max:1100px; --qf-text:#0f172a; --qf-muted:#6b7280; --qf-card:#fff; --qf-border:#e5e7eb;
  --qf-primary:#111827; --qf-accent:#3b82f6; --qf-shadow-sm:0 1px 2px rgba(0,0,0,.04);
  --qf-shadow-md:0 10px 30px rgba(15,23,42,.08); --qf-radius:16px; --qf-ease:cubic-bezier(.2,.6,.2,1); --qf-speed:200ms;
}
@media (prefers-color-scheme: dark){
  :root{
    --bg:#ffffff;
    --text:#0f172a;
    --muted:#6b7280;
    --border:#e5e7eb;
    --card:#ffffff;   /* 타일/카드 배경을 다시 라이트로 */
    --primary:#2563eb;
    --primary-weak:#eff6ff;
    --accent:#f59e0b;
  }
}

/* 모바일에서 특히 어둡게 보이는 요소 보정 */
@media (max-width: 640px){
  .ce-card,
  .ce-calendar-item,
  .qf-card{
    background:#fff !important;
    border-color:#e5e7eb !important;
  }
  .ce-calendar-link{ color:#0f172a !important; }
}
.qf{ max-width:min(var(--qf-max),92vw); margin:24px auto 8px; text-align:center; }
.qf-head{ margin-bottom:12px; }
.qf-title{ margin:0; color:var(--qf-text); font-weight:900; letter-spacing:-.02em; font-size:clamp(20px,3vw,32px); }
.qf-sub{ margin:6px 0 0; color:var(--qf-muted); font-size:14px; }

.qf-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:12px; width:100%; }
@media (max-width:640px){ .qf-grid{ grid-template-columns:repeat(2,minmax(0,1fr)); } }

.qf-card{
  appearance:none; border:1px solid var(--qf-border); background:var(--qf-card); border-radius:var(--qf-radius);
  box-shadow:var(--qf-shadow-sm); padding:16px 14px; display:grid; place-items:center; gap:10px; cursor:pointer;
  transition:transform var(--qf-speed) var(--qf-ease), box-shadow var(--qf-speed) var(--qf-ease), border-color var(--qf-speed) var(--qf-ease), background var(--qf-speed) var(--qf-ease);
}
.qf-card:hover{ transform:translateY(-2px); box-shadow:var(--qf-shadow-md); }
.qf-card:focus-visible{ outline:3px solid rgba(59,130,246,.35); outline-offset:3px; }
.qf-card.is-active{ border-color:var(--qf-accent); box-shadow:0 12px 28px rgba(59,130,246,.18); }
.qf-icon{ width:52px; height:52px; border-radius:999px; display:grid; place-items:center; background:#eef2ff; color:#4f46e5; }
.qf-icon svg{ width:22px; height:22px; stroke:currentColor; fill:none; }
.qf-text-ko{ color:var(--qf-text); font-weight:900; font-size:14px; letter-spacing:-.01em; }
.qf-text-en{ color:var(--qf-muted); font-size:11.5px; }

@media (max-width:480px){
  .qf-card{ padding:14px 12px; }
  .qf-icon{ width:48px; height:48px; }
  .qf-text-ko{ font-size:13.5px; }
  .qf-text-en{ font-size:11px; }
}

/* -----------------------------
   ⛑ 모바일 텍스트 넘침 방지 보완
------------------------------*/

/* 그리드 자식이 칼럼 안에서 줄어들 수 있게 */
.ce-card, .cf-card { min-width:0; }

/* ≤420px: 라벨/값 2열 정돈 */
@media (max-width:420px){
  .ce-kv{
    display:grid;
    grid-template-columns:auto 1fr; /* "라벨 : 값" 형태 */
    align-items:start;
    gap:4px 8px;
  }
  .ce-body{ padding:10px 10px 8px; }
  .ce-card-title{ font-size:14px; }
  .ce-meta{ font-size:12px; }
}

/* =========================================
   초소형 모바일(≤380px) 패치
=========================================*/
@media (max-width: 380px){
  .ce-card, .cf-card { min-width: 0; }
  .ce-body{ padding:10px 10px 8px; }

  .ce-card-title{
    font-size:13.5px;
    line-height:1.35;
    display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
    word-break:break-word; overflow-wrap:anywhere;
  }

  .ce-meta{
    display:grid; grid-template-columns:1fr; gap:6px;
    font-size:12px; line-height:1.45;
  }

  .ce-kv{
    display:grid; grid-template-columns:auto 1fr;
    align-items:start; column-gap:8px; row-gap:2px;
  }

  .ce-meta .k{
    white-space:nowrap !important; color:#6b7280; font-weight:700;
  }
  .ce-meta .k::after{ content:" :"; }

  .ce-meta .v{
    white-space:normal !important;
    word-break:break-word; overflow-wrap:anywhere;
    display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
  }

  .ce-desc{ word-break:break-word; overflow-wrap:anywhere; }
}

/* 335px 같은 극좁은 기기에서는 1열 폴백 */
@media (max-width: 360px){
  .ce-grid, .cf-grid{ grid-template-columns:1fr !important; }
}
