/* =========================================================
   home.css — 홈페이지 전용 스타일
   ========================================================= */

/* ---------- Hero ---------- */
.hero {
  position: relative;
  width: 100%;
  /* min-height로 전환: 콘텐츠가 많을 때 hero가 늘어나도록 허용 */
  min-height: min(56.25vw, 100vh);
  /* overflow 제거: 텍스트/폼 콘텐츠 하단 클립 방지 */
  background: #000 url('../../img/hero-1.jpg') center/cover no-repeat;
  display: flex;
  justify-content: center;
  align-items: center;
}

.hero__video-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  /* overflow는 video-bg 레이어에만 적용 — hero 자체는 클립하지 않음 */
  overflow: hidden;
}

.hero__video-bg iframe {
  /* [PC/Ultrawide] Cover logic: max-width/max-height 제약 제거하여 우측 검정 방지 */
  position: absolute;
  top: 50%;
  left: 50%;
  /* 뷰포트 기준 cover: 너비·높이 중 큰 쪽이 컨테이너를 덮도록 */
  width: max(100vw, 177.78vh);
  height: max(56.25vw, 100vh);
  transform: translate(-50%, -60%);
  border: none;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.7s ease;
}

.hero.is-video-ready .hero__video-bg iframe {
  opacity: 1;
}


.hero__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.15);
  z-index: 2;
}

@media (max-width: 767px) {
  .hero {
    min-height: calc(100vh - var(--header-height));   /* dvh 미지원 브라우저 폴백 */
    min-height: calc(100dvh - var(--header-height));
    max-height: none;
    aspect-ratio: auto;
    background-image: url('../../img/doctor-02.jpg');
    background-position: center top;
  }
  /* 모바일 portrait에서 영상은 가로가 너무 넓어져 자막이 좌우로 잘림 → 배경이미지만 표시 */
  .hero__video-bg {
    display: none;
  }
}

.hero__inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-12);
  align-items: center;
  padding-top: calc(var(--header-height) + var(--space-12));
  padding-bottom: var(--space-16);
}

@media (min-width: 1024px) {
  .hero__inner {
    grid-template-columns: 1fr 360px;
    padding-top: calc(var(--header-height) + var(--space-16));
    padding-bottom: var(--space-20);
  }
}

.hero__content { color: #fff; }

.hero__title {
  font-size: var(--fs-display);
  font-weight: var(--fw-bold);
  line-height: 1.2;
  margin-bottom: var(--space-6);
  letter-spacing: -0.03em;
}

.hero__desc {
  font-size: 1.1rem;
  opacity: 0.88;
  line-height: 1.8;
  margin-bottom: var(--space-8);
}

.hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  margin-bottom: var(--space-8);
}

.hero__meta {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.hero__meta span {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--fs-small);
  opacity: 0.7;
}

.hero__meta svg { flex-shrink: 0; }

/* 원장 카드 */
.hero__visual { display: none; }

@media (min-width: 1024px) {
  .hero__visual { display: block; }
}

.hero__doctor-card {
  background: rgba(255,255,255,.15);
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,.2);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.hero__doctor-img {
  aspect-ratio: 3/4;
  background: rgba(255,255,255,.05);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

.hero__doctor-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  inset: 0;
}

.hero__doctor-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  color: rgba(255,255,255,.4);
}

.hero__doctor-info {
  padding: var(--space-4) var(--space-6);
  display: flex;
  flex-direction: column;
  gap: 2px;
  color: #fff;
}

.hero__doctor-info strong { font-size: var(--fs-h3); font-weight: var(--fw-bold); }
.hero__doctor-info span   { font-size: var(--fs-small); opacity: 0.7; }

/* 스크롤 유도 */
.hero__scroll {
  position: absolute;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  color: rgba(255,255,255,.5);
  animation: bounce 2s ease-in-out infinite;
  z-index: 4;
}

@keyframes bounce {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50%       { transform: translateX(-50%) translateY(6px); }
}

/* ---------- 슬로건 섹션 ---------- */
.slogan-section__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-12);
  align-items: center;
}

@media (min-width: 1024px) {
  .slogan-section__inner { grid-template-columns: 1fr 1fr; }
}

.slogan-section__main {
  font-size: clamp(2rem, 3.5vw, 3rem);
  font-weight: var(--fw-bold);
  line-height: 1.2;
  margin-bottom: var(--space-3);
  letter-spacing: -0.03em;
}

.slogan-section__accent {
  color: var(--color-primary-500);
}

.slogan-section__accent ruby {
  font-size: 1.25em;
}

.slogan-section__accent rt {
  font-size: 0.4em;
  color: var(--color-text-sub);
  font-weight: var(--fw-regular);
}

.slogan-section__sub {
  font-size: var(--fs-body);
  color: var(--color-text-sub);
  margin-bottom: var(--space-2);
}

.slogan-section__note {
  font-size: var(--fs-small);
  color: var(--color-primary-500);
  font-weight: var(--fw-semibold);
  margin-bottom: var(--space-6);
}

.slogan-section__body {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  font-size: var(--fs-body);
  color: var(--color-text-sub);
  line-height: 1.8;
}

.slogan-section__card {
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  padding: var(--space-8);
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.slogan-section__item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
}

.slogan-section__num {
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--color-primary-500);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--fs-tiny);
  font-weight: var(--fw-bold);
}

.slogan-section__item p {
  font-size: var(--fs-small);
  color: var(--color-text);
  line-height: 1.7;
  padding-top: 6px;
}

/* ---------- 자가진단 배너 ---------- */
.self-check-banner {
  background:
    linear-gradient(rgba(237,247,239,0.80),rgba(209,237,213,0.80)),
    url('../../img/symptom-ankle-swelling-new.webp?v=20260531') center/cover;
  padding: var(--space-12) 0;
  border-top: 2px solid var(--color-primary-300);
  border-bottom: 2px solid var(--color-primary-300);
}

.self-check-banner__inner {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  align-items: flex-start;
}

@media (min-width: 768px) {
  .self-check-banner__inner {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
  }
}

.self-check-banner__title {
  font-size: var(--fs-h2);
  font-weight: var(--fw-bold);
  color: var(--color-primary-700);
  margin-bottom: var(--space-2);
}

.self-check-banner__desc {
  font-size: var(--fs-body);
  color: var(--color-text-sub);
  line-height: 1.7;
}

/* ---------- 특별함 카드 ---------- */
.special-grid { gap: var(--space-6); }

/* 특별함 카드 — 이미지 좌측 / 텍스트 우측 분리 */
.special-card {
  display: flex;
  flex-direction: row;
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.special-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
}

.special-card__img {
  width: 42%;
  flex-shrink: 0;
  object-fit: cover;
  object-position: center 20%;
  display: block;
}

.special-card__body {
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: var(--space-3);
}

.special-card__title {
  font-size: var(--fs-h3);
  font-weight: var(--fw-bold);
  color: var(--color-text);
  line-height: 1.4;
}

.special-card__desc {
  font-size: var(--fs-small);
  color: var(--color-text-sub);
  line-height: 1.8;
}

@media (max-width: 767px) {
  .special-card {
    flex-direction: column;
  }
  .special-card__img {
    width: 100%;
    aspect-ratio: 4/3;
    object-position: center 20%;
  }
}

/* ---------- 시술 탭 ---------- */
/* 시술 5개 그리드 */
.treatment-grid {
  grid-template-columns: repeat(5, 1fr);
}

@media (max-width: 1023px) {
  .treatment-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 767px) {
  .treatment-grid { grid-template-columns: repeat(2, 1fr); }
}

/* 시술 아이템 — 이미지 상단, 텍스트 하단 */
.treat-item {
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  text-decoration: none;
  color: var(--color-text);
  transition: transform var(--transition-base), box-shadow var(--transition-base),
              border-color var(--transition-fast);
}

.treat-item:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  border-color: var(--color-primary-300);
}

.treat-item__img {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  display: block;
}

.treat-item__body {
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  flex: 1;
}

.treat-item__name {
  font-size: var(--fs-small);
  font-weight: var(--fw-bold);
  line-height: 1.4;
}

.treat-item__en {
  display: block;
  font-size: var(--fs-tiny);
  font-weight: var(--fw-regular);
  color: var(--color-text-sub);
}

.treat-item__desc {
  font-size: var(--fs-tiny);
  color: var(--color-text-sub);
  line-height: 1.7;
}

/* 약속 카드 — 배경 이미지 다크 버전 */
.card--img {
  background-size: cover !important;
  background-position: center !important;
  position: relative;
  min-height: 240px;
}
.card--img::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.35);
  z-index: 0;
  border-radius: inherit;
}
.card--img .card__body { position: relative; z-index: 1; }
.card--img .card__icon { background: rgba(255,255,255,0.15) !important; color: #fff !important; }
.card--img .card__title { color: #fff; }
.card--img .card__desc  { color: rgba(255,255,255,0.82); }

/* 슬로건 섹션 배경 이미지 */
.slogan-section {
  background-image:
    linear-gradient(rgba(8,24,12,0.58),rgba(8,24,12,0.58)),
    url('../../img/sandan-bg.jpg') !important;
  background-size: cover !important;
  background-position: center !important;
}
.slogan-section .slogan-section__main,
.slogan-section .slogan-section__accent,
.slogan-section .slogan-section__sub,
.slogan-section .slogan-section__note { color: #fff; }
.slogan-section .slogan-section__body p { color: rgba(255,255,255,0.85); }
.slogan-section .slogan-section__card {
  background: rgba(255,255,255,0.10);
  border-color: rgba(255,255,255,0.20);
}
.slogan-section .slogan-section__item p { color: rgba(255,255,255,0.85); }
.slogan-section .slogan-section__num  { color: var(--color-primary-300); }
.slogan-section .btn--secondary {
  background: rgba(255,255,255,0.15);
  color: #fff;
  border-color: rgba(255,255,255,0.4);
}
.slogan-section .btn--secondary:hover { background: rgba(255,255,255,0.25); }

/* ---------- 원장 소개 띠 ---------- */
.doctor-strip {
  background: linear-gradient(135deg, var(--color-primary-500) 0%, var(--color-primary-700) 100%);
  color: #fff;
}
.doctor-strip .doctor-strip__title { color: #fff; }
.doctor-strip .doctor-strip__role  { color: rgba(255,255,255,0.8); }
.doctor-strip .doctor-strip__list li { color: rgba(255,255,255,0.85); }
.doctor-strip .doctor-strip__list li::before { color: rgba(255,255,255,0.6); }
.doctor-strip .doctor-strip__list li strong { color: #fff; }
.doctor-strip .section-header__label { color: rgba(255,255,255,0.7); }
.doctor-strip .section-header__title { color: #fff; }
.doctor-strip .doctor-strip__img { background: rgba(255,255,255,0.1); }

.doctor-strip__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-12);
  align-items: stretch;
}

@media (min-width: 1024px) {
  .doctor-strip__inner { grid-template-columns: 1fr 320px; }
}

.doctor-strip__title {
  font-size: var(--fs-h1);
  font-weight: var(--fw-bold);
  color: var(--color-text);
  margin-bottom: var(--space-1);
}

.doctor-strip__role {
  font-size: var(--fs-small);
  color: var(--color-text-sub);
  margin-bottom: var(--space-6);
}

.doctor-strip__list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.doctor-strip__list li {
  font-size: var(--fs-body);
  color: var(--color-text-sub);
  padding-left: var(--space-4);
  position: relative;
  line-height: 1.6;
}

.doctor-strip__list li::before {
  content: '·';
  position: absolute;
  left: 4px;
  color: var(--color-primary-500);
  font-weight: var(--fw-bold);
}

.doctor-strip__list li strong { color: var(--color-primary-700); }

.doctor-strip__img-wrap { display: none; }

@media (min-width: 1024px) { .doctor-strip__img-wrap { display: block; } }

.doctor-strip__img {
  border-radius: var(--radius-lg);
  overflow: hidden;
  aspect-ratio: 3/4;
  background: var(--color-bg-alt);
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

.doctor-strip__img img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}

.doctor-strip__img-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-mute);
}

/* ---------- 공지 섹션 ---------- */
.notice-section__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-6);
}

/* ---------- 오시는 길 미니 ---------- */
.location-mini {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
}

@media (min-width: 768px) {
  .location-mini { grid-template-columns: 1fr 1fr; }
}

.location-mini__map {
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  position: relative;
  height: 320px;
}

.location-mini__map iframe {
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  height: 100%;
  border: none;
}

.location-mini__map-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: var(--space-12);
  text-align: center;
}

.location-mini__info {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.location-mini__item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
}

.location-mini__item svg {
  flex-shrink: 0;
  color: var(--color-primary-500);
  margin-top: 2px;
}

.location-mini__item strong {
  display: block;
  font-size: var(--fs-small);
  font-weight: var(--fw-semibold);
  color: var(--color-text);
  margin-bottom: 4px;
}

.location-mini__item p {
  font-size: var(--fs-small);
  color: var(--color-text-sub);
  line-height: 1.7;
}
