/* =========================
   Invitation (초대문구 전용)
   + Greeting Modal/공유카드 공통 헤더/서약
   ========================= */

/* 1) 폰트 (초대문구 전용) */
@font-face {
  font-family: 'Ownglyph_corncorn';
  src: url('https://cdn.jsdelivr.net/gh/projectnoonnu/2412-1@1.0/Ownglyph_corncorn-Rg.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

/* 2) 색/테마 변수 (공통에서 씀) – 한 곳에 통합 */
:root{
  --invite-hl:#ee2d8e;

  /* 모던 톤 공통 */
  --g-bg:#f7f8fa;
  --g-soft:#fdfdfd;
  --g-border:#e5e7eb;
  --g-text:#1f2937;
  --g-sub:#6b7280;
  --g-accent:#4f46e5;
  --g-shadow:0 10px 30px rgba(0,0,0,.06);
  --g-radius:16px;

  --gap-2:8px;
  --gap-3:12px;
  --gap-4:16px;
  --gap-6:24px;

  /* 타이핑 효과용 회색 팔레트 */
  --c-gray1:#9aa0a6;
  --c-black:#222;
  --c-gray2:#7f8a94;
}

/* 3) 초대문구 카드(구 버전 호환: .invitation-text) */
#invitation .invitation-text{
  background:rgba(255,255,255,.9);
  backdrop-filter:blur(10px);
  border-radius:15px;
  padding:30px;
  margin:30px 0;
  box-shadow:0 8px 25px rgba(0,0,0,.1);
  font-size:1.2rem;
  line-height:1.8;
  text-align:center;
}
.invitation-text .hl{ color:var(--invite-hl); font-weight:700; }

/* 4) 타이핑 효과 (줄 단위) */
#invitation .line{ margin:.6rem 0; }
#invitation .typewrap{
  display:inline-block; overflow:hidden; max-width:0;
  white-space:nowrap; will-change:max-width;
}
#invitation .typewrap.typing{
  animation: invite-type var(--duration,3s) steps(var(--steps,40)) forwards;
}
#invitation .caret{
  display:inline-block; width:1px; height:1em; background:currentColor;
  margin-left:3px; opacity:0; vertical-align:bottom;
}
#invitation .caret.on{ opacity:1; animation: invite-blink 1s step-end infinite; }
@keyframes invite-type{ to{ max-width:var(--fullpx,100%); } }
@keyframes invite-blink{ 50%{ opacity:0; } }

/* 5) 글자 단위 색 전환 (JS가 .char, .stageN 클래스를 붙임) */
.char{ color:var(--c-gray1); transition:color .18s ease; }
.char.stage1{ color:var(--c-black); }
.char.stage2{ color:var(--c-gray2); }
.char.stage3-main{ color:var(--c-black); }
.char.stage3-hl{ color:var(--invite-hl); font-weight:700; }

/* 6) 캡션 */
.invite-caption{
  opacity:0; transform:translateY(6px);
  transition:opacity .6s ease, transform .6s ease;
  margin-top:16px; color:#555;
}
.invite-caption.show{ opacity:1; transform:translateY(0); }

/* 7) 접근성 */
@media (prefers-reduced-motion:reduce){
  #invitation .typewrap{ max-width:none !important; }
  #invitation .typewrap.typing{ animation:none !important; }
  #invitation .caret{ display:none !important; }
  .char{ transition:none !important; }
  .invite-caption{ opacity:1 !important; transform:none !important; }
}

/* =======================================
   Greeting Header (모달/공유 페이지 공통)
   ======================================= */
.g-card-header{
  display:grid;
  grid-template-columns:120px 1fr 1.25fr; /* 사진 / 이름영역 / 첫인상 */
  gap:var(--gap-4);
  align-items:center;
  background:var(--g-soft);
  border:1px solid var(--g-border);
  border-radius:var(--g-radius);
  padding:var(--gap-4);
  box-shadow:var(--g-shadow);
}
@media (max-width:768px){
  .g-card-header{ grid-template-columns:1fr; }
}
.g-hd-photo{ display:flex; justify-content:center; }
.g-photo.rectangular{
  width:120px; height:120px; object-fit:cover;
  border-radius:18px; box-shadow:0 6px 20px rgba(0,0,0,.08);
}
.g-hd-main .g-role{ color:var(--g-sub); margin-bottom:6px; }
.g-hd-main .g-name-row{ display:flex; align-items:center; gap:8px; }
.g-hd-main h3{ font-size:1.5rem; margin:0; color:var(--g-text); }
.g-pill{
  display:inline-block; padding:4px 10px;
  background:#eef2ff; color:#4f46e5; border-radius:999px; font-weight:600;
}
.g-first-quote{
  margin:0; background:#fff; border:1px solid var(--g-border);
  border-radius:14px; padding:12px 14px;
}
.g-quote-mark{ color:var(--g-accent); margin-right:6px; }
.g-first-text{ color:var(--g-text); }
.g-quote-author{ display:block; color:var(--g-sub); margin-top:6px; font-style:normal; }

/* =========================
   Vow (서약 카드)
   ========================= */
.g-vow{
  margin:18px 0 22px;
  background:linear-gradient(180deg,#f9fafb 0%,#ffffff 100%);
  border:1px solid var(--g-border);
  border-radius:var(--g-radius);
  padding:18px 20px;
  box-shadow:var(--g-shadow);
}
.g-vow .vow-title{
  font-weight:600; color:var(--g-accent);
  letter-spacing:.04em; font-size:.95rem; margin-bottom:8px;
}
.g-vow .vow-body{
  color:var(--g-text);
  line-height:1.7;
  white-space:pre-line; /* 줄바꿈 유지 */
}
.g-vow .vow-sign{
  margin-top:12px; color:var(--g-sub);
  text-align:right; font-style:italic;
}

/* ===== Invitation (새 구조) ===== */

/* 박스 밖 상단 중앙 타이틀 */
.invitation-heading{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:'Paperlogy', sans-serif;
  font-weight:700;
  font-size:1.25rem;
  line-height:1.2;
  margin:0 auto 12px;
  color:#2b2f36;
}
/* 이모지(💌) 사이즈 */
.invitation-heading :first-child{
  font-size:1.3rem; line-height:1;
}

/* 본문 카드 박스 — 중앙 고정 + 폭 제한(와이드에서도 퍼지지 않음) */
.invitation-card{
  background:#fff; border-radius:16px;
  box-shadow:0 8px 24px rgba(17,23,41,.08);

  /* ✅ 중앙 고정 & 고정 폭 */
  width:100%;
  max-width:720px;         /* 필요 시 680~760 사이로만 조정하세요 */
  margin:0 auto;

  padding:24px 20px;
  font-size:.98rem; line-height:1.65; color:#2b2f36;
}
.invitation-card .line{ margin-bottom:.9rem; }
.invitation-card .line:last-child{ margin-bottom:0; }

/* 강조 색상 */
.invitation-card .hl{ color:#e91e63; font-weight:600; }

/* 좁은 화면에서 여백 미세 조정 */
@media (max-width:380px){
  .invitation-card{ font-size:.94rem; padding:18px 16px; }
}

/* (과거 규칙) 앱 여백을 상쇄하던 블리드 — 원본 유지 */
.card-wide{
  width: calc(100% + 24px);
  margin-left: -12px;
  margin-right: -12px;
}
@media (max-width: 360px){
  .card-wide{ width: calc(100% + 16px); margin-left:-8px; margin-right:-8px; }
}

/* ✅ 하지만 초대장에서는 블리드를 무력화해 항상 중앙 고정(오버라이드) */
#invitation .invitation-card.card-wide{
  width:100% !important;
  max-width:720px !important;
  margin-left:auto !important;
  margin-right:auto !important;
}

/* ===== Invitation: 카드 안 문장들만 Ownglyph ===== */
#invitation .invitation-card,
#invitation .invitation-card *{
  font-family:'Ownglyph_corncorn', 'Paperlogy', "Noto Sans KR", sans-serif !important;
  font-weight:400;
  letter-spacing:0;
}
/* 타이틀(“💌 소중한 분들께”)은 Paperlogy 유지 */
#invitation .invitation-heading,
#invitation .invitation-heading span{
  font-family:'Paperlogy', "Noto Sans KR", sans-serif;
  font-weight:700;
}

/* ✅ 초대문구 본문(내부 여백 + 중앙 정렬 + 줄간격 보정) */
#invitation .invitation-card .invitation-body{
  padding-inline:20px;          /* 좌우 여백 */
  box-sizing:border-box;
}
#invitation .invitation-card .invitation-body .line{
  display:block;
  text-align:center !important; /* 중앙 정렬 강제 */
  line-height:1.5 !important;   /* 줄간격 촘촘히 */
  margin:8px 0 !important;      /* 문단 간격 */
}

/* 아주 작은 화면에서 더 타이트하게 */
@media (max-width:480px){
  #invitation .invitation-card .invitation-body{ padding-inline:14px; }
  #invitation .invitation-card .invitation-body .line{ margin:6px 0 !important; }
}


/* map css 설정 */
/* ========== Wedding Info (심플/모던) ========== */
.wedding-info{
  display:flex;
  justify-content:center;
  padding: 8px 0;
}
.wedding-info .info-wrap{
  width:100%;
  max-width:640px;          /* 중앙 고정 폭 */
  text-align:center;        /* 중앙 정렬 */
  padding:24px 18px;
  box-sizing:border-box;
  margin: 0 auto;           /* 혹시 모를 상속 충돌 대비 */
}
.wedding-info .info-row{
  background:#fff;
  border-radius:16px;
  box-shadow:0 8px 24px rgba(17,23,41,.06);
  padding:16px 14px;
  margin:18px 0;
}
.wedding-info .info-title{
  font-family:'Paperlogy', "Noto Sans KR", sans-serif;
  font-weight:700;
  font-size:1.1rem;
  margin:0 0 6px;
  color:#2b2f36;
}
.wedding-info .info-text{
  margin:0 0 12px;
  color:#475569;
  line-height:1.7;
  font-size:0.98rem;
}

/* 버튼형 "예식 장소 자세히 보기" */
.wedding-info .btn-info{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 16px;
  border-radius:999px;
  border:1px solid #e5e7eb;
  background:#f8fafc;
  color:#334155;
  font-weight:600;
  text-decoration:none;
  transition:all .18s ease;
  margin-top: 4px;
}
.wedding-info .btn-info:hover{
  background:#eef2ff;
  color:#3730a3;
  border-color:#c7d2fe;
  transform:translateY(-1px);
}

@media (min-width:768px){
  .wedding-info .info-wrap{ padding:28px 24px; }
  .wedding-info .info-row{ padding:18px 18px; }
}
