/* ================================================================
   K-Culture · Mobile-First Responsive
   320px → 1440px+
   ================================================================ */

:root {
    --brand: #FF3E5F;
    --brand-dark: #C8243D;
    --ink: #1A1A1A;
    --ink-2: #4A4A4A;
    --ink-3: #8A8A8A;
    --bg: #FFFFFF;
    --bg-2: #F7F7F8;
    --line: #E5E5E8;
    --shadow: 0 2px 8px rgba(0,0,0,.06);
    --radius: 14px;
    --radius-sm: 8px;
    --header-h: 56px;
    --bottombar-h: 56px;
    --container: 1200px;
    --font: -apple-system, BlinkMacSystemFont, "Pretendard", "Noto Sans KR", "Noto Sans JP", "Segoe UI", Roboto, sans-serif;
}

/* Category accent colors via body class */
.kc-type-kfood   { --brand: #E94F37; --brand-dark: #B53A26; }
.kc-type-kpop    { --brand: #7A4DFF; --brand-dark: #5832C9; }
.kc-type-kbeauty { --brand: #FF6F9E; --brand-dark: #C84A75; }
.kc-type-kdrama  { --brand: #2F80ED; --brand-dark: #1F5BB8; }
.kc-type-ktour   { --brand: #27AE60; --brand-dark: #1B7A43; }

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
    margin: 0;
    font-family: var(--font);
    font-size: 16px;
    line-height: 1.6;
    color: var(--ink);
    background: var(--bg);
    padding-bottom: var(--bottombar-h);
}
img, video { max-width: 100%; height: auto; display: block; }
a { color: var(--brand); text-decoration: none; }
a:hover { text-decoration: underline; }
button { font-family: inherit; cursor: pointer; }

.kc-skip {
    position: absolute; left: -9999px;
    background: var(--ink); color: #fff; padding: 8px 12px; border-radius: 4px;
}
.kc-skip:focus { left: 8px; top: 8px; z-index: 9999; }

/* ─────────── Header ─────────── */
.kc-header {
    position: sticky; top: 0; z-index: 100;
    background: rgba(255,255,255,.95);
    backdrop-filter: saturate(180%) blur(12px);
    border-bottom: 1px solid var(--line);
}
.kc-header__inner {
    max-width: var(--container);
    margin: 0 auto;
    height: var(--header-h);
    display: flex; align-items: center; gap: 12px;
    padding: 0 16px;
}
.kc-burger {
    background: none; border: 0; width: 40px; height: 40px;
    display: flex; flex-direction: column; justify-content: center; gap: 4px;
    padding: 8px;
}
.kc-burger span { display: block; width: 22px; height: 2px; background: var(--ink); border-radius: 2px; }
.kc-logo { font-weight: 800; letter-spacing: .04em; color: var(--ink); }
.kc-logo span { font-size: 18px; }
.kc-nav { display: none; flex: 1; }
.kc-nav__list { list-style: none; margin: 0; padding: 0; display: flex; gap: 22px; }
.kc-nav__list a { color: var(--ink); font-weight: 600; font-size: 14px; letter-spacing: .05em; }
.kc-header__tools { margin-left: auto; display: flex; align-items: center; gap: 8px; }
.kc-search-toggle { background: none; border: 0; font-size: 18px; padding: 8px; }
.kc-search { max-width: var(--container); margin: 0 auto; padding: 12px 16px; display: flex; gap: 8px; border-top: 1px solid var(--line); background: var(--bg); }
.kc-search input { flex: 1; padding: 10px 12px; border: 1px solid var(--line); border-radius: 999px; font-size: 16px; }
.kc-search button { padding: 10px 16px; background: var(--brand); color: #fff; border: 0; border-radius: 999px; font-weight: 600; }

/* Mobile nav open */
.kc-nav.is-open {
    display: block;
    position: fixed; inset: var(--header-h) 0 0 0;
    background: var(--bg); z-index: 99; padding: 16px;
}
.kc-nav.is-open .kc-nav__list { flex-direction: column; gap: 0; }
.kc-nav.is-open .kc-nav__list li { border-bottom: 1px solid var(--line); }
.kc-nav.is-open .kc-nav__list a { display: block; padding: 14px 4px; font-size: 18px; }

/* ─────────── Main / Container ─────────── */
.kc-main { min-height: 60vh; }
.kc-container { max-width: var(--container); margin: 0 auto; padding: 16px; }

/* ─────────── Hero ─────────── */
.kc-hero {
    position: relative;
    min-height: 56vw;
    max-height: 520px;
    background-size: cover;
    background-position: center;
    display: flex; align-items: flex-end;
    color: #fff;
}
.kc-hero__overlay {
    width: 100%;
    padding: 20px 16px;
    background: linear-gradient(to top, rgba(0,0,0,.75), rgba(0,0,0,0));
}
.kc-hero__cat {
    display: inline-block;
    background: var(--brand); color: #fff;
    padding: 4px 10px; border-radius: 999px;
    font-size: 12px; font-weight: 700; letter-spacing: .05em;
}
.kc-hero__title {
    margin: 8px 0 6px;
    font-size: clamp(20px, 5vw, 36px);
    font-weight: 800; line-height: 1.2;
}
.kc-hero__excerpt { margin: 0 0 12px; font-size: 14px; opacity: .9; }
.kc-hero__cta {
    display: inline-block;
    background: #fff; color: var(--ink);
    padding: 10px 18px; border-radius: 999px;
    font-weight: 700; font-size: 14px;
}

/* ─────────── Sections ─────────── */
.kc-section { margin: 28px 0; }
.kc-section__title {
    font-size: 20px; font-weight: 800; margin: 0 0 14px;
    display: flex; align-items: center; gap: 8px;
}
.kc-section__more { margin: 12px 0 0; text-align: right; }
.kc-section__more a { font-size: 14px; font-weight: 600; }

/* ─────────── Grid / Card ─────────── */
.kc-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 14px;
}
.kc-card {
    display: block;
    background: var(--bg);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    overflow: hidden;
    color: var(--ink);
    transition: transform .15s ease, box-shadow .15s ease;
}
.kc-card:hover { transform: translateY(-2px); box-shadow: var(--shadow); text-decoration: none; }
.kc-card__thumb {
    position: relative;
    aspect-ratio: 16/10;
    background: var(--bg-2);
    overflow: hidden;
}
.kc-card__thumb img { width: 100%; height: 100%; object-fit: cover; }
.kc-card__placeholder { width: 100%; height: 100%; background: linear-gradient(135deg, #f0f0f3, #e4e4ea); }
.kc-card__badge {
    position: absolute; top: 8px; left: 8px;
    background: rgba(0,0,0,.7); color: #fff;
    padding: 3px 8px; border-radius: 999px;
    font-size: 11px; font-weight: 700; letter-spacing: .04em;
}
.kc-card__title {
    margin: 10px 12px 4px;
    font-size: 15px; font-weight: 700; line-height: 1.35;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.kc-card__meta { margin: 0 12px 12px; font-size: 12px; color: var(--ink-3); }

/* ─────────── Cross Recommendations ─────────── */
.kc-cross {
    margin: 32px 0;
    padding: 20px 16px;
    background: var(--bg-2);
    border-radius: var(--radius);
}
.kc-cross__title { margin: 0 0 14px; font-size: 18px; font-weight: 800; }
.kc-cross__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
}
.kc-cross__grid .kc-card { background: var(--bg); }

/* ─────────── Ads ─────────── */
.kc-ad {
    margin: 24px 0;
    text-align: center;
    min-height: 120px;
    background: var(--bg-2);
    border-radius: var(--radius-sm);
    overflow: hidden;
}
.kc-ad::before {
    content: 'Advertisement';
    display: block;
    font-size: 10px; color: var(--ink-3);
    text-transform: uppercase; letter-spacing: .1em;
    padding: 6px 0;
}

/* ─────────── Affiliate Card ─────────── */
.kc-aff {
    margin: 24px 0;
    padding: 18px;
    background: linear-gradient(135deg, var(--brand), var(--brand-dark));
    color: #fff;
    border-radius: var(--radius);
    text-align: center;
}
.kc-aff__tag {
    display: inline-block;
    background: rgba(255,255,255,.18);
    padding: 4px 10px; border-radius: 999px;
    font-size: 11px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
}
.kc-aff__title { margin: 10px 0 6px; font-size: 18px; font-weight: 800; }
.kc-aff__desc { margin: 0 0 14px; font-size: 14px; opacity: .9; }
.kc-aff__btn {
    display: inline-block;
    background: #fff; color: var(--brand-dark);
    padding: 12px 22px; border-radius: 999px;
    font-weight: 800; font-size: 14px; letter-spacing: .03em;
}
.kc-aff__btn:hover { text-decoration: none; transform: scale(1.02); }
.kc-aff__disc { display: block; margin-top: 10px; font-size: 11px; opacity: .75; }

/* ─────────── Reading progress bar ─────────── */
.kc-progress{position:fixed;top:0;left:0;height:3px;background:var(--brand);width:0;z-index:200;transition:width .1s}

/* ─────────── OTT availability ─────────── */
.kc-ott{margin:18px 0;padding:14px 16px;background:var(--bg-2);border-radius:var(--radius);border:1px solid var(--line)}
.kc-ott__title{margin:0 0 8px;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3)}
.kc-ott__list{display:flex;flex-wrap:wrap;gap:6px}
.kc-ott__chip{padding:7px 12px;background:#fff;border:1px solid var(--line);border-radius:8px;font-size:13px;font-weight:700;color:var(--ink)}
.kc-ott__chip[data-available="true"]{border-color:var(--brand);background:rgba(255,62,95,.08);color:var(--brand-dark)}

/* ─────────── Engagement bar ─────────── */
.kc-engage{display:flex;gap:8px;align-items:center;padding:16px 0;margin:28px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.kc-engage__btn{flex:1;padding:10px 12px;background:var(--bg-2);border:0;border-radius:8px;font-size:13px;font-weight:700;color:var(--ink-2);display:flex;align-items:center;justify-content:center;gap:6px;text-decoration:none;cursor:pointer;transition:all .15s}
.kc-engage__btn:hover{background:var(--ink);color:#fff;text-decoration:none}
.kc-engage__btn.is-on{background:rgba(255,62,95,.12);color:var(--brand-dark)}
.kc-share-btn{background:var(--bg-2);border:0;width:34px;height:34px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:13px;cursor:pointer;margin-left:4px}
.kc-share-btn.is-on{background:var(--brand);color:#fff}

/* ─────────── Author bio ─────────── */
.kc-bio{margin:28px 0;padding:20px;background:var(--bg-2);border-radius:var(--radius);display:flex;gap:14px;align-items:flex-start}
.kc-bio__avatar{width:54px;height:54px;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--brand-dark));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px;flex-shrink:0}
.kc-bio__body{flex:1}
.kc-bio__name{margin:0 0 6px;font-weight:800;font-size:16px}
.kc-bio__desc{margin:0;font-size:14px;color:var(--ink-2);line-height:1.6}

/* ─────────── Cross / Related — horizontal mini cards ─────────── */
.kc-cross--mini{margin:40px 0 0;background:transparent;padding:0}
.kc-cross--mini .kc-cross__grid{grid-template-columns:1fr}
.kc-card--mini{display:grid;grid-template-columns:90px 1fr;gap:12px;padding:10px;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-sm);color:var(--ink)}
.kc-card--mini:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.06);text-decoration:none}
.kc-card--mini .kc-card__thumb{aspect-ratio:1/1;border-radius:6px}
.kc-card--mini .kc-card__title{margin:0 0 4px;font-size:14px}
.kc-card--mini .kc-card__author{margin:0;font-size:11px}
@media (min-width:768px){.kc-cross--mini .kc-cross__grid{grid-template-columns:repeat(3,1fr)}}

/* ─────────── Article meta share buttons ─────────── */
.kc-meta__chip{margin-left:auto;display:flex;gap:6px}

/* ─────────── Article (blog single) ─────────── */
.kc-article{ }
.kc-article__hero{position:relative;width:100%;aspect-ratio:16/9;max-height:560px;overflow:hidden;background:var(--bg-2)}
.kc-article__hero-img{width:100%;height:100%;object-fit:cover}
.kc-article__hero-badge{position:absolute;bottom:18px;left:16px;background:var(--brand);color:#fff;padding:5px 12px;border-radius:999px;font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}
.kc-article__wrap{max-width:720px;margin:0 auto;padding:24px 18px 60px}
.kc-article__head{margin-bottom:24px}
.kc-article__title{margin:0 0 14px;font-size:clamp(24px,5vw,38px);font-weight:900;line-height:1.2;letter-spacing:-.01em}
.kc-article__sub{margin:0 0 18px;font-size:17px;color:var(--ink-2);font-weight:400;line-height:1.55}
.kc-article__meta{display:flex;align-items:center;gap:10px;padding:14px 0;margin:0 0 18px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);font-size:14px;color:var(--ink-2);flex-wrap:wrap}
.kc-author{display:flex;align-items:center;gap:10px}
.kc-author__avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--brand-dark));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px}
.kc-author__info{display:flex;flex-direction:column;line-height:1.3}
.kc-author__name{color:var(--ink);font-weight:700;font-size:14px}
.kc-author__role{color:var(--ink-3);font-size:12px}
.kc-meta__dot{color:var(--ink-3)}
.kc-tags{display:flex;flex-wrap:wrap;gap:6px;margin:0 0 18px}
.kc-tag{padding:4px 10px;background:var(--bg-2);color:var(--ink-2);border-radius:999px;font-size:12px;font-weight:600}
.kc-tag:hover{background:var(--ink);color:#fff;text-decoration:none}

/* Blog body typography — for the_content() */
.kc-body{font-size:17px;line-height:1.75;color:var(--ink)}
.kc-body > p{margin:0 0 22px}
.kc-body > p:first-of-type::first-letter{font-size:54px;float:left;line-height:.9;padding:4px 8px 0 0;font-weight:900;color:var(--brand)}
.kc-body h2{margin:40px 0 14px;font-size:26px;font-weight:900;letter-spacing:-.01em;line-height:1.25}
.kc-body h3{margin:32px 0 12px;font-size:20px;font-weight:800}
.kc-body h4{margin:24px 0 10px;font-size:17px;font-weight:800}
.kc-body ul,.kc-body ol{margin:0 0 22px;padding-left:24px}
.kc-body li{margin:0 0 8px}
.kc-body strong{font-weight:800;color:var(--ink)}
.kc-body em{font-style:italic}
.kc-body a{color:var(--brand);border-bottom:1.5px solid color-mix(in srgb, var(--brand) 30%, transparent);transition:border-color .15s}
.kc-body a:hover{border-bottom-color:var(--brand);text-decoration:none}
.kc-body blockquote{margin:30px 0;padding:18px 22px;border-left:4px solid var(--brand);background:linear-gradient(to right,var(--bg-2),transparent);border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-style:italic;font-size:18px;color:var(--ink-2)}
.kc-body blockquote cite{display:block;margin-top:8px;font-size:13px;font-style:normal;color:var(--ink-3)}
.kc-body img{border-radius:var(--radius-sm);margin:24px 0}
.kc-body figure{margin:32px -18px;background:var(--bg-2)}
.kc-body figure img{margin:0;border-radius:0;width:100%}
.kc-body figcaption{padding:10px 18px;font-size:13px;color:var(--ink-3);font-style:italic;line-height:1.5}
.kc-body a.kc-inlink{font-weight:600}
.kc-body .wp-block-embed,.kc-body iframe{margin:32px -18px;width:calc(100% + 36px)}
.kc-body .wp-block-embed iframe{margin:0;width:100%}
.kc-body .wp-block-embed__wrapper{position:relative;aspect-ratio:16/9}
.kc-body .wp-block-embed__wrapper iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.kc-body hr{margin:36px auto;border:0;height:1px;background:var(--line);max-width:120px}
.kc-body pre,.kc-body code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;background:var(--bg-2);border-radius:6px}
.kc-body code{padding:2px 6px;font-size:.92em}
.kc-body pre{padding:14px 16px;overflow-x:auto;font-size:14px;line-height:1.6;margin:0 0 22px}

@media (min-width:768px){
  .kc-body figure{margin:36px 0;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line)}
  .kc-body .wp-block-embed,.kc-body iframe{margin:36px 0;width:100%;border-radius:var(--radius);overflow:hidden}
  .kc-article__wrap{padding:32px 16px 60px}
  .kc-body figcaption{padding:12px 16px}
}

/* ─────────── Single (legacy/page) ─────────── */
.kc-single__hero {
    width: 100%;
    aspect-ratio: 16/9;
    overflow: hidden;
    background: var(--bg-2);
}
.kc-single__hero img { width: 100%; height: 100%; object-fit: cover; }
.kc-single__body { max-width: 760px; padding: 24px 16px; }
.kc-single__head { margin-bottom: 20px; }
.kc-badge {
    display: inline-block;
    background: var(--brand); color: #fff;
    padding: 4px 10px; border-radius: 999px;
    font-size: 11px; font-weight: 700; letter-spacing: .05em;
}
.kc-single__title {
    margin: 12px 0 8px;
    font-size: clamp(24px, 5vw, 38px);
    font-weight: 800; line-height: 1.25;
}
.kc-single__meta { margin: 0; font-size: 13px; color: var(--ink-3); }
.kc-single__content { font-size: 16px; line-height: 1.75; }
.kc-single__content h2 { margin-top: 32px; font-size: 22px; font-weight: 800; }
.kc-single__content h3 { margin-top: 24px; font-size: 18px; font-weight: 700; }
.kc-single__content p { margin: 0 0 16px; }
.kc-single__content img { border-radius: var(--radius-sm); margin: 16px 0; }
.kc-single__content blockquote {
    margin: 20px 0; padding: 12px 18px;
    border-left: 4px solid var(--brand);
    background: var(--bg-2); border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
    font-style: italic;
}
.kc-single__content ul, .kc-single__content ol { padding-left: 22px; }

/* ─────────── Archive ─────────── */
.kc-archive__head { margin: 12px 0 20px; }
.kc-archive__title { margin: 0; font-size: 28px; font-weight: 800; }

.pagination, .nav-links {
    display: flex; gap: 6px; justify-content: center;
    margin: 32px 0;
}
.page-numbers {
    display: inline-flex; align-items: center; justify-content: center;
    min-width: 38px; height: 38px; padding: 0 10px;
    border: 1px solid var(--line); border-radius: 999px;
    color: var(--ink); font-weight: 600;
}
.page-numbers.current { background: var(--brand); color: #fff; border-color: var(--brand); }

/* ─────────── Footer ─────────── */
.kc-footer {
    background: var(--bg-2);
    border-top: 1px solid var(--line);
    padding: 28px 16px 40px;
    margin-top: 40px;
}
.kc-footer__inner { max-width: var(--container); margin: 0 auto; }
.kc-footer__brand strong { font-size: 18px; letter-spacing: .04em; }
.kc-footer__brand p { margin: 4px 0 0; color: var(--ink-2); font-size: 14px; }
.kc-footer__nav { margin: 16px 0; display: flex; flex-wrap: wrap; gap: 16px; }
.kc-footer__nav a { color: var(--ink-2); font-weight: 600; font-size: 14px; }
.kc-footer__legal { margin: 12px 0 0; font-size: 12px; color: var(--ink-3); }

/* ─────────── Bottom Bar (Mobile) ─────────── */
.kc-bottombar {
    position: fixed; bottom: 0; left: 0; right: 0; z-index: 90;
    height: var(--bottombar-h);
    background: rgba(255,255,255,.95);
    backdrop-filter: saturate(180%) blur(12px);
    border-top: 1px solid var(--line);
    display: flex; justify-content: space-around; align-items: center;
    padding-bottom: env(safe-area-inset-bottom);
}
.kc-bottombar a {
    flex: 1;
    display: flex; flex-direction: column; align-items: center; gap: 2px;
    font-size: 18px;
    color: var(--ink-2);
    text-decoration: none;
    padding: 6px 0;
}
.kc-bottombar a span { font-size: 10px; font-weight: 600; letter-spacing: .03em; }
.kc-bottombar a:hover { color: var(--brand); }

/* ─────────── 404 ─────────── */
.kc-404 { text-align: center; padding: 60px 16px; }
.kc-404 h1 { font-size: 80px; margin: 0; color: var(--brand); }
.kc-btn {
    display: inline-block;
    background: var(--brand); color: #fff;
    padding: 12px 22px; border-radius: 999px;
    font-weight: 700;
}

/* ═══════════════════════════════════════════════════
   BREAKPOINTS
   ═══════════════════════════════════════════════════ */

/* Mobile L: 480px+ */
@media (min-width: 480px) {
    .kc-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
    .kc-cross__grid { grid-template-columns: repeat(3, 1fr); }
}

/* Tablet: 768px+ */
@media (min-width: 768px) {
    :root { --header-h: 64px; }
    body { padding-bottom: 0; }
    .kc-bottombar { display: none; }
    .kc-burger { display: none; }
    .kc-nav { display: block; }
    .kc-nav__list { gap: 28px; }
    .kc-nav__list a { font-size: 13px; }
    .kc-grid { grid-template-columns: repeat(3, 1fr); gap: 18px; }
    .kc-cross__grid { grid-template-columns: repeat(3, 1fr); gap: 14px; }
    .kc-hero { min-height: 420px; }
    .kc-hero__overlay { padding: 32px; }
    .kc-section { margin: 40px 0; }
    .kc-section__title { font-size: 24px; }
    .kc-card__title { font-size: 16px; }
    .kc-footer__inner {
        display: grid;
        grid-template-columns: 1fr 2fr;
        gap: 24px; align-items: start;
    }
    .kc-footer__legal { grid-column: 1 / -1; }
}

/* Desktop: 1024px+ */
@media (min-width: 1024px) {
    .kc-grid { grid-template-columns: repeat(4, 1fr); gap: 20px; }
    .kc-cross__grid { grid-template-columns: repeat(6, 1fr); }
    .kc-hero { min-height: 500px; }
    .kc-hero__overlay {
        max-width: var(--container);
        margin: 0 auto;
        background: linear-gradient(to top, rgba(0,0,0,.7), rgba(0,0,0,0) 60%);
    }
    .kc-single__body { padding: 40px 16px 60px; }
    .kc-aff { padding: 28px; }
    .kc-aff__title { font-size: 22px; }
}

/* Wide: 1440px+ */
@media (min-width: 1440px) {
    :root { --container: 1280px; }
}

/* ─────────── Universal Meta Panel ─────────── */
.kc-meta-facts{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:16px 0;padding:14px;background:var(--bg-2);border-radius:var(--radius)}
.kc-meta-fact{display:flex;flex-direction:column;gap:2px}
.kc-meta-fact__label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3)}
.kc-meta-fact__value{font-size:15px;font-weight:800;color:var(--ink)}
.kc-meta-fact--accent .kc-meta-fact__value{color:var(--brand)}
@media (min-width:560px){.kc-meta-facts{grid-template-columns:repeat(4,1fr)}}

.kc-meta-chips{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin:14px 0}
.kc-meta-chips__label{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);margin-right:4px}
.kc-meta-chip{padding:5px 11px;background:var(--bg-2);color:var(--ink);border-radius:999px;font-size:13px;font-weight:600}
.kc-meta-chip--loc{background:#EBF4FF;color:#1F5BB8}
.kc-meta-chip--member{background:#F0EBFF;color:#5832C9}
.kc-meta-chip--ing{background:#E8F5E8;color:#1B7A43}
.kc-meta-link{margin:14px 0;font-weight:700;font-size:14px}

/* OST / Spotify embed */
.kc-ost{margin:20px 0;padding:14px;background:#1DB954;color:#fff;border-radius:var(--radius)}
.kc-ost__title{margin:0 0 10px;font-size:14px;font-weight:800;letter-spacing:.04em}
.kc-ost__embed{width:100%;height:152px;border:0;border-radius:8px;display:block}

/* Recipe card */
.kc-recipe-card{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:16px 0;padding:16px;background:linear-gradient(135deg,#FFF1ED,#FFE8E0);border-radius:var(--radius);border:1px solid #FFD4C5}
.kc-recipe-card__cell{display:flex;gap:10px;align-items:center}
.kc-recipe-card__icon{font-size:24px}
.kc-recipe-card__num{display:block;font-size:18px;font-weight:900;color:var(--ink);line-height:1.1}
.kc-recipe-card__unit{display:block;font-size:11px;font-weight:600;color:var(--ink-3);text-transform:uppercase;letter-spacing:.06em}
@media (min-width:560px){.kc-recipe-card{grid-template-columns:repeat(4,1fr)}}
@media (prefers-color-scheme:dark){
  .kc-recipe-card{background:linear-gradient(135deg,#251A18,#2A1F1B);border-color:#3D2820}
  .kc-meta-chip--loc{background:#1A2845;color:#9CB8E8}
  .kc-meta-chip--member{background:#2A1F45;color:#B89BFF}
  .kc-meta-chip--ing{background:#1A2E1F;color:#8FC9A8}
}

/* Recipe video embed */
.kc-video-embed{position:relative;width:100%;aspect-ratio:16/9;margin:20px 0;border-radius:var(--radius);overflow:hidden;background:#000;display:block}
.kc-video-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.kc-video-facade{cursor:pointer;text-decoration:none}
.kc-video-embed .kc-video-poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;margin:0;border-radius:0}
.kc-video-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:68px;height:48px;border:0;border-radius:12px;background:rgba(0,0,0,.72);color:#fff;font-size:22px;display:flex;align-items:center;justify-content:center}
.kc-video-facade:hover .kc-video-play{background:#f00}

/* Routine bar (K-Beauty 10-step) */
.kc-routine-bar{margin:18px 0;padding:14px;background:var(--bg-2);border-radius:var(--radius)}
.kc-routine-bar__label{display:block;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);margin-bottom:10px}
.kc-routine-bar__steps{list-style:none;margin:0;padding:0;display:flex;gap:4px;align-items:flex-end;overflow-x:auto;scrollbar-width:none}
.kc-routine-bar__steps::-webkit-scrollbar{display:none}
.kc-routine-bar__step{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0}
.kc-routine-bar__num{width:32px;height:32px;border-radius:50%;background:#fff;color:var(--ink-3);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px;border:2px solid var(--line)}
.kc-routine-bar__step.is-active .kc-routine-bar__num{background:var(--brand);color:#fff;border-color:var(--brand);transform:scale(1.15)}
.kc-routine-bar__name{font-size:11px;font-weight:700;color:var(--brand)}

/* ─────────── K-Pop Calendar ─────────── */
.kc-cal{display:grid;grid-template-columns:1fr;gap:10px;margin:20px 0}
.kc-cal__item{display:grid;grid-template-columns:80px 1fr;gap:14px;padding:14px;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-sm);color:var(--ink);transition:transform .15s,box-shadow .15s}
.kc-cal__item:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.06);text-decoration:none}
.kc-cal__date{display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#7A4DFF,#5832C9);color:#fff;border-radius:var(--radius-sm);padding:10px 6px}
.kc-cal__month{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;opacity:.85}
.kc-cal__day{font-size:28px;font-weight:900;line-height:1;margin:2px 0}
.kc-cal__weekday{font-size:11px;font-weight:600;opacity:.8}
.kc-cal__body{display:flex;flex-direction:column;justify-content:center}
.kc-cal__title{margin:0 0 4px;font-size:15px;font-weight:800}
.kc-cal__agency{margin:0;font-size:12px;color:var(--ink-3)}
.kc-cal__empty{text-align:center;padding:30px;color:var(--ink-3);background:var(--bg-2);border-radius:var(--radius)}
@media (min-width:768px){.kc-cal{grid-template-columns:repeat(2,1fr)}}

/* ─────────── K-Beauty Quiz ─────────── */
.kc-quiz{margin:28px 0;padding:24px;background:linear-gradient(135deg,#FFE4EC,#E4ECFF);border-radius:var(--radius)}
.kc-quiz__title{margin:0 0 8px;font-size:20px;font-weight:900}
.kc-quiz__desc{margin:0 0 14px;color:var(--ink-2);font-size:14px}
.kc-quiz__btn{display:inline-block;background:var(--ink);color:#fff;padding:12px 24px;border-radius:999px;font-weight:800;font-size:14px;border:0;cursor:pointer;transition:transform .15s}
.kc-quiz__btn:hover{transform:translateY(-1px);background:#000;text-decoration:none}
.kc-quiz__progress{display:inline-block;font-size:11px;font-weight:800;letter-spacing:.08em;color:var(--ink-3);text-transform:uppercase;margin-bottom:8px}
.kc-quiz__q{margin:0 0 18px;font-size:20px;font-weight:800;line-height:1.35}
.kc-quiz__options{display:flex;flex-direction:column;gap:8px}
.kc-quiz__opt{padding:14px 18px;background:#fff;border:2px solid transparent;border-radius:var(--radius-sm);font-size:15px;font-weight:600;text-align:left;color:var(--ink);cursor:pointer;transition:all .15s}
.kc-quiz__opt:hover{border-color:var(--brand);transform:translateX(2px)}
.kc-quiz__steps{margin:16px 0;padding-left:22px}
.kc-quiz__steps li{margin:0 0 8px;font-size:15px;font-weight:600;color:var(--ink)}
@media (prefers-color-scheme:dark){
  .kc-quiz{background:linear-gradient(135deg,#2A1A22,#1A222A)}
  .kc-quiz__opt{background:var(--bg-2)}
}

/* ─────────── K-Tour facts / map / price badge ─────────── */
.kc-tour__price-badge{position:absolute;bottom:18px;right:16px;background:#fff;color:#27AE60;padding:8px 14px;border-radius:999px;font-weight:900;font-size:15px;box-shadow:0 4px 14px rgba(0,0,0,.2)}
.kc-tour__facts{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:18px 0;padding:14px;background:var(--bg-2);border-radius:var(--radius)}
.kc-tour__fact{display:flex;flex-direction:column;gap:2px}
.kc-tour__fact-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3)}
.kc-tour__fact-value{font-size:14px;font-weight:800;color:var(--ink)}
.kc-tour__map-section{margin:32px 0}
.kc-tour__map-title{margin:0 0 12px;font-size:20px;font-weight:900}
.kc-tour__map{position:relative;width:100%;height:360px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);background:var(--bg-2)}
.kc-tour__map iframe{width:100%;height:100%;border:0;display:block}
.kc-tour__map-link{margin:10px 0 0;font-size:13px;color:var(--ink-3)}
.kc-tour__map-link a{color:var(--ink-2);font-weight:600}
@media (min-width:768px){.kc-tour__facts{grid-template-columns:repeat(4,1fr)}}

/* Reduce motion */
@media (prefers-reduced-motion: reduce) {
    * { transition: none !important; animation: none !important; }
}

/* Dark mode (system) */
@media (prefers-color-scheme: dark) {
    :root {
        --ink: #F2F2F4;
        --ink-2: #C4C4CA;
        --ink-3: #8A8A93;
        --bg: #121215;
        --bg-2: #1C1C20;
        --line: #2A2A30;
    }
    .kc-header { background: rgba(18,18,21,.92); }
    .kc-bottombar { background: rgba(18,18,21,.92); }
    .kc-card { background: var(--bg-2); }
}

/* Print */
@media print {
    .kc-header, .kc-footer, .kc-bottombar, .kc-ad, .kc-aff, .kc-cross { display: none; }
}
