/*
Theme Name: Cadian Travel Child
Theme URI: http://ct.local
Description: GeneratePress 자식 테마 — Cadian Travel 전용 디자인 시스템 (오션 틸 + 코랄 / Calm Coastal Editorial). 히어로·카드 목록·사이드바·푸터·도움 페이지를 모두 코드로 렌더하여 파일 업로드만으로 이식됩니다.
Author: Cadian Research
Template: generatepress
Version: 1.0.0
Text Domain: cadian-child
*/

/* =====================================================================
   0. 디자인 토큰 (컬러 / 라운드 / 그림자)
   ===================================================================== */
:root{
	--ct-primary:#0E7C86;        /* 오션 틸 */
	--ct-primary-dark:#0A5E66;
	--ct-primary-soft:#E6F2F2;
	--ct-accent:#FF7A59;         /* 코랄 */
	--ct-accent-dark:#F2613F;
	--ct-paper:#FAFAF7;          /* 페이퍼 배경 */
	--ct-card:#FFFFFF;
	--ct-ink:#1F2A30;            /* 본문 차콜 */
	--ct-muted:#5B6B72;
	--ct-line:#E7E8E2;
	--ct-radius:14px;
	--ct-radius-sm:10px;
	--ct-shadow:0 6px 24px rgba(15,40,48,.08);
	--ct-shadow-lg:0 14px 40px rgba(15,40,48,.14);
	--ct-trans:.25s ease;
}

/* =====================================================================
   1. 전체 톤 (타이포 / 배경 / 링크)
   ===================================================================== */
body{
	font-family:'Pretendard Variable','Pretendard',-apple-system,BlinkMacSystemFont,
		'Apple SD Gothic Neo','Segoe UI',Roboto,'Noto Sans KR',sans-serif;
	background:var(--ct-paper);
	color:var(--ct-ink);
	line-height:1.8;
	letter-spacing:-.01em;
	-webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,h5,h6{
	color:var(--ct-ink);
	line-height:1.35;
	letter-spacing:-.02em;
	font-weight:700;
}
a{ color:var(--ct-primary); transition:color var(--ct-trans); }
a:hover{ color:var(--ct-accent-dark); }

.entry-content p{ margin-bottom:1.4em; }
.entry-content h2{
	margin-top:1.8em;
	padding-bottom:.4em;
	border-bottom:2px solid var(--ct-primary-soft);
}
.entry-content h2::before{
	content:"";
	display:inline-block;
	width:6px;height:1.05em;
	margin-right:.5em;
	vertical-align:-2px;
	background:var(--ct-accent);
	border-radius:3px;
}
.entry-content img{ border-radius:var(--ct-radius); }
.entry-content ul li{ margin-bottom:.5em; }

/* 컨테이너 분리형 카드 느낌 강화 */
.separate-containers .inside-article,
.separate-containers .comments-area,
.separate-containers .page-header,
.separate-containers .paging-navigation,
.one-container .site-content,
.inside-page-header{
	background:var(--ct-card);
}

/* 버튼 공통 */
.ct-btn{
	display:inline-flex;align-items:center;gap:.5em;
	padding:.85em 1.6em;
	border-radius:999px;
	font-weight:700;
	text-decoration:none;
	transition:transform var(--ct-trans),box-shadow var(--ct-trans),background var(--ct-trans);
}
.ct-btn--accent{ background:var(--ct-accent); color:#fff; box-shadow:0 8px 20px rgba(255,122,89,.35); }
.ct-btn--accent:hover{ background:var(--ct-accent-dark); color:#fff; transform:translateY(-2px); }
.ct-btn--ghost{ background:transparent; color:#fff; border:2px solid rgba(255,255,255,.7); }
.ct-btn--ghost:hover{ background:#fff; color:var(--ct-primary-dark); transform:translateY(-2px); }
.ct-btn--outline{ background:#fff; color:var(--ct-primary); border:2px solid var(--ct-primary); }
.ct-btn--outline:hover{ background:var(--ct-primary); color:#fff; }

/* =====================================================================
   2. 헤더 / 로고 / 네비게이션
   ===================================================================== */
.site-header{
	background:#FDFAF5;            /* 로고 webp 배경색과 정합 → 박스 안 보이게 */
	border-bottom:1px solid var(--ct-line);
}
/* 로고 이미지가 곧 워드마크이므로 사이트명 텍스트/태그라인은 숨김(중복 제거) */
.site-header .main-title,
.site-header .site-description{
	position:absolute !important;
	width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);clip-path:inset(50%);white-space:nowrap;
}
/* 로고를 읽기 좋은 크기로 (GP의 width:50px 기본값 덮어쓰기) */
.site-header .site-logo img,
.site-header img.header-image{
	height:46px;width:auto;max-width:260px;border-radius:0;
}
@media (max-width:768px){
	.site-header .site-logo img,
	.site-header img.header-image{ height:38px; }
}

.main-navigation,
.main-navigation ul{ background:transparent; }
.main-navigation .main-nav ul li a{
	font-weight:600;
	color:var(--ct-ink);
	transition:color var(--ct-trans);
}
/* 비정상적으로 긴 메뉴 라벨이 헤더를 망가뜨리지 않도록 말줄임 상한 */
.main-navigation .main-nav > ul > li > a{
	max-width:16em;
	overflow:hidden;
	text-overflow:ellipsis;
	white-space:nowrap;
}
.main-navigation .main-nav ul li:hover > a,
.main-navigation .main-nav ul li.current-menu-item > a{
	color:var(--ct-primary);
}
/* 메뉴 hover 언더라인 */
.main-navigation .main-nav ul li > a{ position:relative; }
.main-navigation .main-nav ul li > a::after{
	content:"";position:absolute;left:20px;right:20px;bottom:12px;height:2px;
	background:var(--ct-accent);transform:scaleX(0);transform-origin:left;
	transition:transform var(--ct-trans);
}
.main-navigation .main-nav ul li:hover > a::after,
.main-navigation .main-nav ul li.current-menu-item > a::after{ transform:scaleX(1); }

/* 메뉴 안의 CTA 버튼 — 네비 높이를 채우지 않는 적당한 버튼 크기로 세로 중앙 정렬 */
.main-navigation .main-nav ul li.ct-cta{
	display:flex;
	align-items:center;
}
.main-navigation .main-nav ul li.ct-cta > a{
	display:inline-flex;align-items:center;gap:.42em;
	margin-left:12px;
	padding:.62em 1.2em;
	line-height:1;height:auto;min-height:0;
	background:var(--ct-accent);
	color:#fff !important;
	border-radius:10px;
	font-size:.9rem;font-weight:700;
	box-shadow:0 6px 14px rgba(255,122,89,.30);
	transition:background var(--ct-trans),transform var(--ct-trans),box-shadow var(--ct-trans);
}
.main-navigation .main-nav ul li.ct-cta > a::after{ display:none; }
.main-navigation .main-nav ul li.ct-cta > a:hover{
	background:var(--ct-accent-dark);
	color:#fff !important;
	transform:translateY(-2px);
	box-shadow:0 9px 20px rgba(242,97,63,.40);
}
.ct-cta__ico{ font-size:.95em;transform:translateY(-1px); }

/* 스티키 헤더 미세 그림자 + 배경 정합 */
.is-sticky .main-navigation,
#sticky-navigation{ background:#FDFAF5; box-shadow:0 4px 18px rgba(15,40,48,.07); }

/* 모바일 햄버거 토글 — 로고 오른쪽 같은 줄(우상단 고정), 메뉴는 그 아래로 펼침 */
@media (max-width:768px){
	.has-inline-mobile-toggle .inside-header{ position:relative; align-items:center; min-height:62px; }
	/* 중복되는 인라인 래퍼 토글은 숨기고 사이트 네비의 토글만 사용 */
	.has-inline-mobile-toggle .mobile-menu-control-wrapper{ display:none !important; }
	.has-inline-mobile-toggle #site-navigation{ flex-basis:100%; position:static; }
	.has-inline-mobile-toggle #site-navigation .menu-toggle{
		display:flex !important; align-items:center;
		position:absolute; top:50%; right:14px; transform:translateY(-50%); margin:0;
		color:var(--ct-primary); padding:.4em .6em;
	}
	.has-inline-mobile-toggle #site-navigation .menu-toggle .gp-icon{ font-size:1.85rem; }
}

/* =====================================================================
   3. 히어로 (프론트 전용)
   ===================================================================== */
.ct-hero{
	position:relative;
	margin-bottom:48px;
	padding:96px 24px 110px;
	text-align:center;
	color:#fff;
	background:#0A5E66;
	overflow:hidden;
}
/* 배경 사진 레이어 */
.ct-hero__photo{
	position:absolute;inset:0;z-index:0;
	background-size:cover;background-position:center;
	transform:scale(1.04);
}
/* 그라데이션 오버레이(사진 위) */
.ct-hero::before{
	content:"";position:absolute;inset:0;z-index:1;
	background:
		radial-gradient(900px 460px at 82% -12%, rgba(255,122,89,.5), transparent 60%),
		linear-gradient(135deg, rgba(14,124,134,.93) 0%, rgba(10,94,102,.9) 52%, rgba(17,75,99,.94) 100%);
}
.ct-hero::after{
	content:"";position:absolute;left:0;right:0;bottom:-1px;height:60px;z-index:2;
	background:var(--ct-paper);
	clip-path:polygon(0 100%,100% 100%,100% 0,0 60%);
}
.ct-hero__inner{ position:relative; z-index:3; max-width:820px; margin:0 auto; }
.ct-hero__eyebrow{
	display:inline-block;
	padding:.4em 1.1em;margin-bottom:20px;
	font-size:.85rem;font-weight:700;letter-spacing:.02em;
	background:rgba(255,255,255,.15);
	border:1px solid rgba(255,255,255,.35);
	border-radius:999px;
	backdrop-filter:blur(4px);
}
.ct-hero__title{
	color:#fff;
	font-size:clamp(2rem,4.6vw,3.3rem);
	font-weight:800;
	line-height:1.25;
	margin:0 0 18px;
}
.ct-hero__title .accent{ color:#FFD7C9; }
.ct-hero__sub{
	font-size:clamp(1rem,1.6vw,1.2rem);
	color:rgba(255,255,255,.92);
	margin:0 auto 32px;
	max-width:620px;
}
.ct-hero__actions{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* 4기둥 카드 */
.ct-pillars{
	position:relative;
	z-index:3;
	max-width:1100px;
	margin:-70px auto 56px;
	padding:0 24px;
	display:grid;
	grid-template-columns:repeat(4,1fr);
	gap:18px;
}
.ct-pillar{
	position:relative;
	display:block;
	border-radius:var(--ct-radius);
	overflow:hidden;
	min-height:200px;
	color:#fff;
	text-decoration:none;
	box-shadow:var(--ct-shadow);
	transition:transform var(--ct-trans),box-shadow var(--ct-trans);
	background:#0A5E66;
}
.ct-pillar:hover{ transform:translateY(-6px); box-shadow:var(--ct-shadow-lg); color:#fff; }
.ct-pillar__img{
	position:absolute;inset:0;
	background-size:cover;background-position:center;
	transition:transform .5s ease;
}
.ct-pillar:hover .ct-pillar__img{ transform:scale(1.08); }
.ct-pillar::after{
	content:"";position:absolute;inset:0;
	background:linear-gradient(180deg,rgba(10,60,66,.15) 0%,rgba(8,40,48,.82) 100%);
}
/* 이미지 없는 기둥(휴양) — 사진 카드와 톤을 맞춘 그라데이션 + 큰 워터마크 아이콘 */
.ct-pillar--noimg{
	background:
		radial-gradient(120px 120px at 78% 26%, rgba(255,122,89,.32), transparent 70%),
		linear-gradient(150deg,#0E7C86 0%,#0A5E66 60%,#0b4853 100%);
}
.ct-pillar--noimg::after{
	background:linear-gradient(180deg,rgba(8,40,48,.05) 0%,rgba(8,40,48,.55) 100%);
}
.ct-pillar__wm{
	position:absolute;top:-14px;right:-8px;z-index:1;
	font-size:7rem;line-height:1;opacity:.18;transform:rotate(-12deg);
	transition:transform .5s ease;
}
.ct-pillar--noimg:hover .ct-pillar__wm{ transform:rotate(-12deg) scale(1.08); }
.ct-pillar__body{ position:absolute;left:0;right:0;bottom:0;z-index:2;padding:20px; }
.ct-pillar__icon{ font-size:1.7rem; }
.ct-pillar__name{ display:block; font-size:1.18rem; font-weight:800; margin-top:4px; }
.ct-pillar__desc{ display:block; font-size:.82rem; opacity:.9; margin-top:2px; }
.ct-pillar__count{
	position:absolute;top:14px;right:14px;z-index:2;
	font-size:.72rem;font-weight:700;
	background:rgba(255,255,255,.22);
	border:1px solid rgba(255,255,255,.35);
	padding:.2em .7em;border-radius:999px;
	backdrop-filter:blur(3px);
}

/* 섹션 제목 (홈) */
.ct-section-head{ max-width:1320px;margin:10px auto 22px;padding:0 24px; }
.ct-section-head h2{ font-size:1.6rem;margin:0; }
.ct-section-head p{ color:var(--ct-muted);margin:.3em 0 0; }
.ct-section-head .bar{ display:inline-block;width:42px;height:4px;background:var(--ct-accent);border-radius:3px;margin-bottom:10px; }

/* =====================================================================
   4. 글 목록 카드형
   ===================================================================== */
/* 아카이브/홈 본문을 그리드로 */
.blog .site-main,
.archive .site-main,
.search-results .site-main{
	display:grid;
	grid-template-columns:repeat(3,1fr);
	gap:26px;
	background:transparent !important;
}
.blog .site-main > *,
.archive .site-main > *{ grid-column:auto; }
/* 그리드를 깨는 페이지네이션/헤더는 전체폭 */
.blog .site-main > .paging-navigation,
.archive .site-main > .paging-navigation,
.blog .site-main > .page-header,
.archive .site-main > .page-header,
.archive .site-main > .generate-columns-activated{ grid-column:1 / -1; }

.blog .site-main .post,
.archive .site-main .post,
.search .site-main .post{
	margin-bottom:0 !important;
	border-radius:var(--ct-radius);
	overflow:hidden;
	background:var(--ct-card);
	box-shadow:var(--ct-shadow);
	border:1px solid var(--ct-line);
	transition:transform var(--ct-trans),box-shadow var(--ct-trans);
	display:flex;flex-direction:column;
}
.blog .site-main .post:hover,
.archive .site-main .post:hover{ transform:translateY(-6px); box-shadow:var(--ct-shadow-lg); }
.blog .inside-article,
.archive .inside-article{ padding:0; display:flex; flex-direction:column; height:100%; }

/* 카드 이미지 */
.blog .post-image,
.archive .post-image{ margin:0 !important; overflow:hidden; }
.blog .post-image img,
.archive .post-image img{
	width:100%;height:200px;object-fit:cover;display:block;
	border-radius:0;transition:transform .5s ease;
}
.blog .post:hover .post-image img,
.archive .post:hover .post-image img{ transform:scale(1.06); }

/* 카드 내부 텍스트 영역 */
.blog .inside-article .entry-header,
.archive .inside-article .entry-header,
.blog .inside-article .entry-summary,
.archive .inside-article .entry-summary,
.blog .inside-article .entry-meta,
.archive .inside-article .entry-meta,
.blog .inside-article footer.entry-meta,
.archive .inside-article footer.entry-meta{ padding-left:22px;padding-right:22px; }
.blog .inside-article .entry-header,
.archive .inside-article .entry-header{ padding-top:20px; }
.blog .entry-title,
.archive .entry-title{ font-size:1.22rem;line-height:1.4;margin:.2em 0 .4em; }
.blog .entry-title a,
.archive .entry-title a{ color:var(--ct-ink); }
.blog .entry-title a:hover,
.archive .entry-title a:hover{ color:var(--ct-primary); }
.blog .entry-summary,
.archive .entry-summary{ color:var(--ct-muted);font-size:.95rem;flex:1 0 auto; }
.blog .entry-summary p,
.archive .entry-summary p{ margin-bottom:0; }

/* 카드 메타 (날짜·카테고리) */
.blog .entry-meta,
.archive .entry-meta{ font-size:.8rem;color:var(--ct-muted); }
.blog .posted-on,
.archive .posted-on{ color:var(--ct-muted); }
.blog .cat-links a,
.archive .cat-links a{
	display:inline-block;font-size:.72rem;font-weight:700;
	color:var(--ct-primary);background:var(--ct-primary-soft);
	padding:.2em .7em;border-radius:999px;text-decoration:none;
}
/* read-more 버튼 */
.blog .read-more,
.archive .read-more{ margin:14px 22px 22px; }
.blog .read-more a,
.archive .read-more a,
a.read-more{
	display:inline-flex;align-items:center;gap:.4em;
	background:var(--ct-primary);color:#fff !important;
	padding:.5em 1.1em;border-radius:999px;font-size:.85rem;font-weight:700;
	text-decoration:none;transition:background var(--ct-trans);
}
.blog .read-more a:hover,
.archive .read-more a:hover,
a.read-more:hover{ background:var(--ct-accent); }

/* =====================================================================
   5. 사이드바 (커스텀 블록)
   ===================================================================== */
.ct-widget{
	background:var(--ct-card);
	border:1px solid var(--ct-line);
	border-radius:var(--ct-radius);
	padding:22px;
	margin-bottom:24px;
	box-shadow:var(--ct-shadow);
}
.ct-widget__title{
	font-size:1.02rem;font-weight:800;margin:0 0 14px;
	display:flex;align-items:center;gap:.5em;
}
.ct-widget__title::before{
	content:"";width:5px;height:1.1em;background:var(--ct-accent);border-radius:3px;
}
/* 소개 위젯 */
.ct-about{ text-align:center; }
.ct-about img{ width:72px;height:72px;border-radius:50%;object-fit:cover;margin-bottom:10px;box-shadow:var(--ct-shadow); }
.ct-about p{ color:var(--ct-muted);font-size:.9rem;margin:.4em 0 0; }
/* 스타일 리스트 */
.ct-styles a{
	display:flex;align-items:center;gap:.6em;
	padding:.6em .2em;border-bottom:1px dashed var(--ct-line);
	color:var(--ct-ink);text-decoration:none;font-weight:600;font-size:.95rem;
	transition:color var(--ct-trans),padding var(--ct-trans);
}
.ct-styles a:last-child{ border-bottom:0; }
.ct-styles a:hover{ color:var(--ct-primary); padding-left:.5em; }
.ct-styles .emoji{ font-size:1.15rem; }
.ct-styles .arrow{ margin-left:auto;color:var(--ct-accent);font-weight:700; }
/* 인기글 썸네일 */
.ct-posts a{ display:flex;gap:12px;padding:.55em 0;border-bottom:1px dashed var(--ct-line);text-decoration:none; }
.ct-posts a:last-child{ border-bottom:0; }
.ct-posts img{ width:62px;height:62px;object-fit:cover;border-radius:10px;flex:0 0 auto; }
.ct-posts .t{ color:var(--ct-ink);font-weight:600;font-size:.9rem;line-height:1.4; }
.ct-posts a:hover .t{ color:var(--ct-primary); }
/* CTA 위젯 */
.ct-cta-card{
	background:linear-gradient(135deg,var(--ct-primary),var(--ct-primary-dark));
	color:#fff;text-align:center;border:0;
}
.ct-cta-card .ct-widget__title{ color:#fff;justify-content:center; }
.ct-cta-card .ct-widget__title::before{ background:#FFD7C9; }
.ct-cta-card p{ color:rgba(255,255,255,.9);font-size:.9rem;margin:0 0 16px; }
/* 태그 클라우드 */
.ct-tags{ display:flex;flex-wrap:wrap;gap:8px; }
.ct-tags a{
	font-size:.8rem;color:var(--ct-primary);background:var(--ct-primary-soft);
	padding:.3em .8em;border-radius:999px;text-decoration:none;transition:var(--ct-trans);
}
.ct-tags a:hover{ background:var(--ct-primary);color:#fff; }

.inside-right-sidebar,.inside-left-sidebar{ position:sticky; top:90px; }

/* =====================================================================
   6. 푸터
   ===================================================================== */
.ct-footer{
	background:#0C2A30;
	color:rgba(255,255,255,.82);
	padding:56px 24px 40px;
}
.ct-footer__grid{
	max-width:1320px;margin:0 auto;
	display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:36px;
}
.ct-footer h4{ color:#fff;font-size:1rem;margin:0 0 16px; }
.ct-footer__brand .logo{ font-size:1.4rem;font-weight:800;color:#fff;letter-spacing:-.02em; }
.ct-footer__brand p{ color:rgba(255,255,255,.62);font-size:.92rem;margin:.8em 0 0;max-width:320px; }
.ct-footer ul{ list-style:none;margin:0;padding:0; }
.ct-footer li{ margin-bottom:.6em; }
.ct-footer a{ color:rgba(255,255,255,.78);text-decoration:none;font-size:.92rem;transition:color var(--ct-trans); }
.ct-footer a:hover{ color:#FF9C82; }
.ct-footer__contact p{ font-size:.92rem;margin:.4em 0;color:rgba(255,255,255,.7); }
.ct-footer__social{ display:flex;gap:10px;margin-top:14px; }
.ct-footer__social a{
	width:38px;height:38px;display:flex;align-items:center;justify-content:center;
	background:rgba(255,255,255,.08);border-radius:10px;
}
.ct-footer__social a:hover{ background:var(--ct-accent);color:#fff; }

/* GP 기본 카피라이트 바 톤 맞춤 */
.site-info{ background:#081E22 !important;color:rgba(255,255,255,.6);text-align:center; }
.site-info a{ color:rgba(255,255,255,.8); }

/* =====================================================================
   7. 도움 페이지 (소개/체크리스트/FAQ 공통)
   ===================================================================== */
.ct-page-hero{
	background:linear-gradient(135deg,var(--ct-primary-soft),#fff);
	border:1px solid var(--ct-line);
	border-radius:var(--ct-radius);
	padding:34px 32px;
	margin-bottom:30px;
}
.ct-page-hero .eyebrow{ color:var(--ct-accent-dark);font-weight:800;font-size:.85rem;letter-spacing:.03em; }
.ct-page-hero h2{ margin:.2em 0 .3em;font-size:1.8rem; }
.ct-page-hero p{ color:var(--ct-muted);margin:0;font-size:1.02rem; }

.ct-grid-2{ display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:24px 0; }
.ct-feature{
	background:var(--ct-card);border:1px solid var(--ct-line);border-radius:var(--ct-radius);
	padding:24px;box-shadow:var(--ct-shadow);
}
.ct-feature .ico{ font-size:1.8rem; }
.ct-feature h3{ margin:.4em 0 .3em;font-size:1.12rem; }
.ct-feature p{ color:var(--ct-muted);margin:0;font-size:.95rem; }

/* 체크리스트 */
.ct-check{ list-style:none;margin:0 0 24px;padding:0; }
.ct-check li{
	background:var(--ct-card);border:1px solid var(--ct-line);border-radius:var(--ct-radius-sm);
	padding:14px 18px 14px 50px;margin-bottom:10px;position:relative;box-shadow:var(--ct-shadow);
}
.ct-check li::before{
	content:"✓";position:absolute;left:16px;top:50%;transform:translateY(-50%);
	width:24px;height:24px;display:flex;align-items:center;justify-content:center;
	background:var(--ct-primary);color:#fff;border-radius:50%;font-size:.8rem;font-weight:800;
}
.ct-check li strong{ color:var(--ct-ink); }
.ct-check li span{ color:var(--ct-muted);font-size:.92rem; }

/* FAQ 아코디언 */
.ct-faq{ margin:8px 0 24px; }
.ct-faq details{
	background:var(--ct-card);border:1px solid var(--ct-line);border-radius:var(--ct-radius-sm);
	padding:0;margin-bottom:12px;box-shadow:var(--ct-shadow);overflow:hidden;
}
.ct-faq summary{
	cursor:pointer;list-style:none;padding:18px 22px;font-weight:700;color:var(--ct-ink);
	display:flex;justify-content:space-between;align-items:center;gap:12px;
}
.ct-faq summary::-webkit-details-marker{ display:none; }
.ct-faq summary::after{ content:"+";color:var(--ct-primary);font-size:1.4rem;font-weight:700;transition:transform var(--ct-trans); }
.ct-faq details[open] summary::after{ transform:rotate(45deg); }
.ct-faq details[open] summary{ color:var(--ct-primary); }
.ct-faq .a{ padding:0 22px 20px;color:var(--ct-muted);line-height:1.8; }
.ct-faq .q-cat{
	display:inline-block;font-size:.72rem;font-weight:700;color:var(--ct-accent-dark);
	background:#FFEDE6;padding:.15em .6em;border-radius:999px;margin-right:.5em;
}

.ct-cta-band{
	margin:36px 0 8px;padding:34px;text-align:center;border-radius:var(--ct-radius);
	background:linear-gradient(135deg,var(--ct-primary),var(--ct-primary-dark));color:#fff;
}
.ct-cta-band h3{ color:#fff;margin:0 0 8px; }
.ct-cta-band p{ color:rgba(255,255,255,.9);margin:0 0 18px; }

/* =====================================================================
   7b. 히어로 검색바
   ===================================================================== */
.ct-hero__search{
	display:flex;align-items:center;gap:8px;
	max-width:540px;margin:0 auto 26px;
	background:#fff;border-radius:999px;padding:6px 6px 6px 18px;
	box-shadow:0 12px 30px rgba(8,40,48,.28);
}
.ct-hero__search-ico{ font-size:1rem;opacity:.6; }
.ct-hero__search input{
	flex:1;border:0;outline:0;background:transparent;
	font-size:1rem;color:var(--ct-ink);padding:.5em .3em;min-width:0;
}
.ct-hero__search input::placeholder{ color:#9aa6ab; }
.ct-hero__search button{
	flex:0 0 auto;border:0;cursor:pointer;
	background:var(--ct-accent);color:#fff;font-weight:700;
	padding:.7em 1.4em;border-radius:999px;transition:background var(--ct-trans);
}
.ct-hero__search button:hover{ background:var(--ct-accent-dark); }

/* =====================================================================
   7c. 읽기 진행 바
   ===================================================================== */
#ct-progress{
	position:fixed;top:0;left:0;height:3px;width:0;z-index:9999;
	background:linear-gradient(90deg,var(--ct-primary),var(--ct-accent));
	transition:width .1s linear;
}

/* =====================================================================
   7d. 빵부스러기 / 읽기시간 (단일 글)
   ===================================================================== */
.ct-crumbs{
	font-size:.85rem;color:var(--ct-muted);margin:0 0 14px;
	display:flex;flex-wrap:wrap;align-items:center;gap:6px;
}
.ct-crumbs a{ color:var(--ct-primary);text-decoration:none; }
.ct-crumbs a:hover{ color:var(--ct-accent-dark); }
.ct-crumbs .sep{ color:var(--ct-line); }
.ct-crumbs .current{ color:var(--ct-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:18em; }
.ct-readtime{
	display:inline-flex;align-items:center;gap:.4em;
	margin:8px 0 2px;font-size:.85rem;font-weight:600;color:var(--ct-primary-dark);
	background:var(--ct-primary-soft);padding:.25em .8em;border-radius:999px;
}

/* =====================================================================
   7e. 목차 (TOC)
   ===================================================================== */
.ct-toc{
	background:linear-gradient(135deg,var(--ct-primary-soft),#fff);
	border:1px solid var(--ct-line);border-left:4px solid var(--ct-primary);
	border-radius:var(--ct-radius-sm);padding:18px 22px;margin:0 0 28px;
}
.ct-toc__head{ font-weight:800;margin-bottom:8px;color:var(--ct-ink); }
.ct-toc ul{ list-style:none;margin:0;padding:0; }
.ct-toc li{ margin:0; }
.ct-toc a{
	display:block;padding:.32em 0;color:var(--ct-muted);text-decoration:none;
	font-size:.95rem;border-left:2px solid transparent;padding-left:10px;
	transition:color var(--ct-trans),border-color var(--ct-trans);
}
.ct-toc a:hover,.ct-toc a.is-active{ color:var(--ct-primary);border-left-color:var(--ct-accent);font-weight:700; }
.ct-toc__l3 a{ padding-left:26px;font-size:.9rem; }
.entry-content h2,.entry-content h3{ scroll-margin-top:90px; }

/* =====================================================================
   7f. 글 하단 — 공유 / 브랜드 박스 / 관련 글
   ===================================================================== */
.ct-postend{
	margin-top:38px;padding-top:24px;border-top:1px solid var(--ct-line);
	display:flex;flex-wrap:wrap;gap:20px;align-items:flex-start;justify-content:space-between;
}
.ct-share{ display:flex;align-items:center;gap:10px;flex-wrap:wrap; }
.ct-share__label{ font-weight:700;font-size:.9rem;color:var(--ct-muted); }
.ct-share__btn{
	width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;
	border-radius:50%;border:1px solid var(--ct-line);background:#fff;cursor:pointer;
	font-weight:800;color:var(--ct-ink);text-decoration:none;font-size:1rem;
	transition:transform var(--ct-trans),background var(--ct-trans),color var(--ct-trans);
}
.ct-share__btn:hover{ transform:translateY(-2px); }
.ct-share__btn.x:hover{ background:#000;color:#fff;border-color:#000; }
.ct-share__btn.fb:hover{ background:#1877F2;color:#fff;border-color:#1877F2; }
.ct-share__copy.copied{ background:var(--ct-primary);color:#fff;border-color:var(--ct-primary); }
.ct-brandbox{
	display:flex;gap:14px;align-items:center;
	background:var(--ct-card);border:1px solid var(--ct-line);border-radius:var(--ct-radius);
	padding:16px 20px;box-shadow:var(--ct-shadow);flex:1 1 320px;
}
.ct-brandbox img{ width:54px;height:54px;border-radius:50%;object-fit:cover;flex:0 0 auto; }
.ct-brandbox strong{ font-size:1rem; }
.ct-brandbox p{ margin:.2em 0 .3em;font-size:.88rem;color:var(--ct-muted); }
.ct-brandbox a{ font-size:.85rem;font-weight:700;text-decoration:none; }

.ct-related{ margin-top:40px; }
.ct-related__head,.ct-404__pop .ct-related__head{ display:flex;align-items:center;gap:10px;margin-bottom:18px; }
.ct-related__head .bar{ width:22px;height:4px;background:var(--ct-accent);border-radius:3px; }
.ct-related__head h2{ font-size:1.3rem;margin:0;padding:0;border:0; }
.ct-related__head h2::before{ display:none; }
.ct-related__grid{ display:grid;grid-template-columns:repeat(3,1fr);gap:18px; }
.ct-rel-card{
	display:flex;flex-direction:column;border-radius:var(--ct-radius);overflow:hidden;
	background:var(--ct-card);border:1px solid var(--ct-line);box-shadow:var(--ct-shadow);
	text-decoration:none;transition:transform var(--ct-trans),box-shadow var(--ct-trans);
}
.ct-rel-card:hover{ transform:translateY(-5px);box-shadow:var(--ct-shadow-lg); }
.ct-rel-card__img{ height:130px;background-size:cover;background-position:center; }
.ct-rel-card__body{ padding:14px 16px 16px; }
.ct-rel-card__title{ display:block;font-weight:700;color:var(--ct-ink);font-size:.98rem;line-height:1.45; }
.ct-rel-card__more{ display:block;margin-top:8px;color:var(--ct-primary);font-size:.82rem;font-weight:700; }

/* =====================================================================
   7g. 맨 위로 버튼 / 모바일 플로팅 CTA
   ===================================================================== */
#ct-top{
	position:fixed;right:22px;bottom:22px;z-index:900;
	width:46px;height:46px;border:0;border-radius:50%;cursor:pointer;
	background:var(--ct-primary);color:#fff;font-size:1.3rem;line-height:1;
	box-shadow:var(--ct-shadow-lg);opacity:0;visibility:hidden;transform:translateY(10px);
	transition:opacity var(--ct-trans),transform var(--ct-trans),background var(--ct-trans);
}
#ct-top.is-shown{ opacity:1;visibility:visible;transform:none; }
#ct-top:hover{ background:var(--ct-accent); }
.ct-fab{ display:none; }

/* =====================================================================
   7h. 푸터 뉴스레터
   ===================================================================== */
.ct-news{ margin-top:14px; }
.ct-news__row{ display:flex;gap:8px;background:rgba(255,255,255,.08);border-radius:999px;padding:5px 5px 5px 16px; }
.ct-news__row input{
	flex:1;border:0;outline:0;background:transparent;color:#fff;font-size:.9rem;min-width:0;
}
.ct-news__row input::placeholder{ color:rgba(255,255,255,.5); }
.ct-news__row button{
	flex:0 0 auto;border:0;cursor:pointer;background:var(--ct-accent);color:#fff;
	font-weight:700;padding:.5em 1.1em;border-radius:999px;transition:background var(--ct-trans);
}
.ct-news__row button:hover{ background:var(--ct-accent-dark); }
.ct-news__ok{ display:block;margin-top:10px;font-size:.85rem;color:#9be8cf; }

/* =====================================================================
   7i. 404
   ===================================================================== */
.ct-404{ text-align:center;max-width:760px;margin:30px auto;padding:20px; }
.ct-404__badge{ font-size:3rem; }
.ct-404__code{
	font-size:clamp(3.4rem,12vw,6rem);line-height:1;margin:.1em 0 0;font-weight:800;
	background:linear-gradient(135deg,var(--ct-primary),var(--ct-accent));
	-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.ct-404__title{ margin:.2em 0 .3em;font-size:1.6rem; }
.ct-404__desc{ color:var(--ct-muted);margin:0 0 24px; }
.ct-404__search{ margin-bottom:18px; }
.ct-404__actions{ display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:40px; }
.ct-404__pop{ text-align:left;margin-top:20px; }

/* =====================================================================
   7j. 스크롤 등장 애니메이션 (JS 활성 시에만)
   ===================================================================== */
.ct-js .ct-reveal{ opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease; }
.ct-js .ct-reveal.is-visible{ opacity:1;transform:none; }
@media (prefers-reduced-motion:reduce){
	.ct-js .ct-reveal{ opacity:1 !important;transform:none !important; }
	.ct-hero__photo{ transform:none; }
}

/* =====================================================================
   8. 반응형
   ===================================================================== */
@media (max-width:1024px){
	.ct-pillars{ grid-template-columns:repeat(2,1fr); margin-top:-50px; }
	.blog .site-main,.archive .site-main,.search-results .site-main{ grid-template-columns:repeat(2,1fr); }
	.ct-footer__grid{ grid-template-columns:1fr 1fr; gap:28px; }
	.ct-grid-2{ grid-template-columns:1fr; }
}
@media (max-width:768px){
	.ct-hero{ padding:64px 20px 84px; }
	.ct-hero__title{ font-size:clamp(1.7rem,7vw,2.2rem); }
	.ct-hero__actions{ flex-direction:column; align-items:center; }
	.ct-hero__actions .ct-btn{ width:100%; max-width:320px; justify-content:center; }
	.ct-pillars{ grid-template-columns:1fr 1fr; gap:14px; }
	.blog .site-main,.archive .site-main,.search-results .site-main{ grid-template-columns:1fr; }
	.ct-footer__grid{ grid-template-columns:1fr; }
	.inside-right-sidebar,.inside-left-sidebar{ position:static; }
	/* 관련/인기 글 그리드 */
	.ct-related__grid{ grid-template-columns:1fr; }
	/* 글 하단 공유/브랜드 세로 정렬 */
	.ct-postend{ flex-direction:column; }
	/* 모바일 플로팅 CTA 노출 (맨 위로 버튼과 겹치지 않게 좌측) */
	.ct-fab{
		display:inline-flex;align-items:center;gap:.4em;
		position:fixed;left:16px;right:74px;bottom:18px;z-index:899;
		justify-content:center;
		background:var(--ct-accent);color:#fff;text-decoration:none;font-weight:700;font-size:.95rem;
		padding:.9em 1em;border-radius:999px;box-shadow:var(--ct-shadow-lg);
	}
	#ct-top{ right:16px;bottom:18px;width:50px;height:50px; }
}
@media (max-width:1024px){
	.ct-related__grid{ grid-template-columns:repeat(2,1fr); }
}
