/* ============================================================
   갤러리아치과 (잠실) — GEO 최적화 홈페이지
   디자인: 네이비/화이트, 모바일 우선, 경량
   ============================================================ */
:root{
  /* 웜톤 팔레트 — 매장 인테리어(베이지·우드·골드 조명)와 로고 컬러 기반 */
  --navy:#48372a;         /* 딥 에스프레소 — 헤더/푸터/제목 (구 네이비 대체) */
  --navy-2:#5e4631;       /* 미드 브라운 */
  --blue:#9a7639;         /* 웜 브론즈 — 링크·강조 (구 블루 대체) */
  --blue-light:#cdb083;   /* 라이트 골드 — hero eyebrow 등 */
  --accent:#b98c4e;       /* 골드 포인트(권위) */
  --bg:#fdfaf5;           /* 크림 */
  --bg-soft:#f6efe3;      /* 웜 베이지 */
  --bg-soft-2:#efe6d4;    /* 딥 베이지 */
  --text:#3b3026;         /* 웜 다크 브라운 */
  --text-soft:#736353;    /* 소프트 브라운 */
  --line:#e8ddc9;         /* 웜 라인 */
  --radius:14px;
  --radius-sm:10px;
  --shadow:0 6px 24px rgba(72,55,42,.08);
  --shadow-lg:0 14px 40px rgba(72,55,42,.14);
  --max:1120px;
  --font:'Pretendard','Apple SD Gothic Neo','Malgun Gothic',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font);
  color:var(--text);
  background:var(--bg);
  line-height:1.7;
  font-size:17px;
  word-break:keep-all;
  letter-spacing:-.01em;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{line-height:1.3;font-weight:800;color:var(--navy);letter-spacing:-.02em}
.container{max-width:var(--max);margin:0 auto;padding:0 20px}
section{padding:64px 0}
.muted{color:var(--text-soft)}

/* ---------- Header ---------- */
header.site{
  position:sticky;top:0;z-index:50;
  background:rgba(253,250,245,.92);
  backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid var(--line);
}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  height:64px;
}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;color:var(--navy);font-size:19px}
.brand img{height:30px;width:auto}
.brand small{display:block;font-size:11px;font-weight:600;color:var(--text-soft);letter-spacing:0}
.gnb{display:flex;gap:6px;align-items:center}
.gnb a{
  padding:8px 13px;border-radius:8px;font-weight:600;font-size:15.5px;color:var(--text);
  transition:background .15s,color .15s;
}
.gnb a:hover,.gnb a.active{background:var(--bg-soft-2);color:var(--navy)}
.gnb .call{background:var(--navy);color:#fff}
.gnb .call:hover{background:var(--navy-2)}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--navy);margin:5px 0;transition:.2s}

/* ---------- Hero ---------- */
.hero{
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-2) 60%,var(--blue) 130%);
  color:#fff;padding:64px 0 56px;position:relative;overflow:hidden;
}
.hero .eyebrow{color:var(--blue-light);font-weight:700;font-size:15px;margin-bottom:14px;letter-spacing:.02em}
.hero h1{color:#fff;font-size:38px;line-height:1.28;margin-bottom:18px}
.hero h1 .hl{color:#fff;border-bottom:4px solid var(--accent);padding-bottom:2px}
.hero p.lead{font-size:18px;color:#dce5f2;max-width:680px;margin-bottom:28px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 22px;border-radius:12px;font-weight:700;font-size:16px;
  transition:transform .12s,box-shadow .15s,background .15s;cursor:pointer;border:0;
}
.btn:active{transform:translateY(1px)}
.btn svg{width:18px;height:18px;flex:0 0 auto}
.mobile-bar svg{width:17px;height:17px;vertical-align:-3px;margin-right:3px}
.btn-primary{background:var(--accent);color:#3a2c08}
.btn-primary:hover{background:#d8b25f}
.btn-light{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.3)}
.btn-light:hover{background:rgba(255,255,255,.2)}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-2)}
.btn-outline{background:#fff;color:var(--navy);border:1.5px solid var(--line)}
.btn-outline:hover{border-color:var(--blue);color:var(--blue)}

/* ---------- 핵심 요약 박스 (2단 균형 그리드) ---------- */
.summary{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-lg);margin-top:22px;position:relative;z-index:5;overflow:hidden;
  display:grid;grid-template-columns:1fr 1fr;
}

/* ---------- 원장 소개 하이라이트 (Hero ↔ 요약박스 사이) ---------- */
.doc-hero{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-lg);margin-top:-44px;position:relative;z-index:6;overflow:hidden;
  display:grid;grid-template-columns:248px 1fr;
}
.doc-hero .dh-photo{background:var(--bg-soft)}
.doc-hero .dh-photo img{width:100%;height:100%;object-fit:cover;object-position:center 25%;display:block}
.doc-hero .dh-body{padding:30px 34px}
.doc-hero .dh-tag{
  display:inline-block;background:var(--bg-soft);color:var(--accent);border:1px solid var(--line);
  font-weight:700;font-size:13px;padding:5px 13px;border-radius:20px;margin-bottom:13px;
}
.doc-hero h2{font-size:25px;line-height:1.32;margin-bottom:10px}
.doc-hero h2 b{color:var(--accent)}
.doc-hero .dh-desc{color:var(--text-soft);font-size:15.5px;margin-bottom:16px;max-width:640px}
.doc-hero .dh-creds{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:9px 22px;margin-bottom:20px}
.doc-hero .dh-creds li{padding-left:20px;position:relative;font-size:14.5px;color:var(--text)}
.doc-hero .dh-creds li::before{content:"";position:absolute;left:0;top:7px;width:9px;height:9px;border-radius:50%;background:var(--accent)}
.summary .srow{padding:18px 26px;border-bottom:1px solid var(--line)}
.summary .srow.full{grid-column:1 / -1;background:var(--bg-soft)}
.summary .srow:nth-child(2),
.summary .srow:nth-child(4){border-right:1px solid var(--line)}
.summary .srow:nth-child(4),
.summary .srow:nth-child(5){border-bottom:0}
.summary .label{
  display:flex;align-items:center;gap:8px;font-weight:700;color:var(--navy);
  font-size:15px;margin-bottom:6px;
}
.summary .label .sicon{flex:0 0 auto;width:19px;height:19px;color:var(--accent)}
.summary .label .sicon svg{width:100%;height:100%;display:block}
.summary .val{color:var(--text);font-size:15.5px;line-height:1.6}
.summary .val b{color:var(--blue)}

/* ---------- Sections ---------- */
.sec-head{text-align:center;max-width:720px;margin:0 auto 40px}
.sec-head .tag{display:inline-block;background:var(--bg-soft-2);color:var(--blue);font-weight:700;font-size:14px;padding:6px 14px;border-radius:20px;margin-bottom:14px}
.sec-head h2{font-size:30px;margin-bottom:12px}
.sec-head p{color:var(--text-soft);font-size:17px}
.bg-soft{background:var(--bg-soft)}

/* 진료 카드 그리드 */
.grid{display:grid;gap:18px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;
  transition:transform .15s,box-shadow .15s,border-color .15s;display:block;
}
a.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--blue-light)}
.card .ico{width:50px;height:50px;border-radius:13px;background:var(--bg-soft);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.card .ico svg{width:27px;height:27px;color:var(--accent)}
a.card:hover .ico{background:var(--accent);}
a.card:hover .ico svg{color:#fff}
.card h3{font-size:20px;margin-bottom:8px}
.card.rank1{border-color:var(--accent);border-width:1.5px}
.card .badge{display:inline-block;font-size:12px;font-weight:700;color:var(--accent);background:#fbf6ea;padding:3px 9px;border-radius:6px;margin-bottom:10px}
.card p{color:var(--text-soft);font-size:15.5px}
.card .more{display:inline-block;margin-top:14px;color:var(--blue);font-weight:700;font-size:15px}

/* 강점/USP */
.feature{display:flex;gap:16px;align-items:flex-start}
.feature .n{flex:0 0 auto;width:44px;height:44px;border-radius:12px;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px}
.feature h3{font-size:19px;margin-bottom:6px}
.feature p{color:var(--text-soft);font-size:15.5px}

/* 원장/약력 */
.doctor-wrap{display:grid;grid-template-columns:340px 1fr;gap:40px;align-items:center}
.doctor-photo{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg)}
.cred-list{list-style:none;display:grid;gap:10px}
.cred-list li{padding-left:28px;position:relative;color:var(--text);font-size:16px}
.cred-list li::before{content:"";position:absolute;left:0;top:9px;width:14px;height:14px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px #fbf6ea}

/* 인증/명패 갤러리 */
.proof{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.proof figure{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.proof img{width:100%;aspect-ratio:4/3;object-fit:cover;background:var(--bg-soft)}
.proof figcaption{padding:12px 14px;font-size:14px;color:var(--text-soft);text-align:center}

/* 시설 갤러리 */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.gallery figure{border-radius:var(--radius);overflow:hidden;position:relative}
.gallery img{width:100%;aspect-ratio:4/3;object-fit:cover}
.gallery figcaption{position:absolute;left:0;right:0;bottom:0;padding:16px 14px 10px;color:#fff;font-size:14px;font-weight:600;background:linear-gradient(transparent,rgba(11,31,59,.8))}

/* 장비 */
.equip{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.equip .item{text-align:center;padding:22px 14px;background:#fff;border:1px solid var(--line);border-radius:var(--radius)}
.equip .item .ico{width:48px;height:48px;margin:0 auto 12px;border-radius:50%;background:var(--bg-soft);display:flex;align-items:center;justify-content:center}
.equip .item .ico svg{width:25px;height:25px;color:var(--accent)}
.equip .item h4{font-size:16px;margin-bottom:4px}
.equip .item p{font-size:13.5px;color:var(--text-soft)}

/* FAQ */
.faq{max-width:820px;margin:0 auto}
.faq details{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);margin-bottom:12px;overflow:hidden}
.faq summary{
  padding:18px 22px;font-weight:700;cursor:pointer;list-style:none;display:flex;
  justify-content:space-between;align-items:center;gap:14px;color:var(--navy);font-size:17px;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:24px;color:var(--blue);font-weight:400;flex:0 0 auto}
.faq details[open] summary::after{content:"−"}
.faq summary .q{flex:1}
.faq .a{padding:0 22px 20px;color:var(--text-soft);font-size:16px}
.faq .a b{color:var(--text)}

/* 시간표 */
.hours{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line)}
.hours th,.hours td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--line);font-size:16px}
.hours th{background:var(--bg-soft);color:var(--navy);font-weight:700;width:120px}
.hours tr:last-child th,.hours tr:last-child td{border-bottom:0}
.hours .off{color:#c0392b;font-weight:700}

/* 오시는 길 */
.map-embed{width:100%;border:0;border-radius:var(--radius);box-shadow:var(--shadow);background:var(--bg-soft);min-height:380px}
.map-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--text-soft);padding:60px 20px;border:1.5px dashed var(--line);border-radius:var(--radius);background:var(--bg-soft)}

/* 콘텐츠(서브페이지 본문) */
.prose{max-width:820px;margin:0 auto}
.prose h2{font-size:26px;margin:40px 0 14px}
.prose h3{font-size:20px;margin:28px 0 10px}
.prose p{margin-bottom:14px;color:var(--text)}
.prose ul,.prose ol{margin:0 0 16px 22px}
.prose li{margin-bottom:8px}
.prose .lead{font-size:19px;color:var(--text-soft);margin-bottom:24px}
.callout{background:var(--bg-soft);border-left:4px solid var(--blue);padding:18px 22px;border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin:22px 0}
.callout.gold{border-color:var(--accent);background:#fdfaf1}
.price-table{width:100%;border-collapse:collapse;margin:18px 0;font-size:16px}
.price-table th,.price-table td{padding:13px 16px;border-bottom:1px solid var(--line);text-align:left}
.price-table th{background:var(--bg-soft);color:var(--navy)}
.price-table caption{font-size:13px;color:var(--text-soft);text-align:left;margin-bottom:8px}

/* Breadcrumb */
.crumb{font-size:14px;color:var(--text-soft);padding:18px 0 0}
.crumb a:hover{color:var(--blue)}
.crumb span{margin:0 6px;color:var(--line)}

/* 페이지 헤더(서브) */
.pagehead{background:var(--bg-soft);border-bottom:1px solid var(--line);padding:34px 0 40px}
.pagehead .tag{display:inline-block;background:#fff;color:var(--blue);border:1px solid var(--line);font-weight:700;font-size:13px;padding:5px 12px;border-radius:20px;margin-bottom:14px}
.pagehead h1{font-size:32px;margin-bottom:12px}
.pagehead p{color:var(--text-soft);font-size:17px;max-width:720px}

/* 관련 진료 링크 */
.related{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
.related a{background:#fff;border:1px solid var(--line);border-radius:20px;padding:8px 16px;font-size:15px;font-weight:600;color:var(--navy)}
.related a:hover{border-color:var(--blue);color:var(--blue)}

/* CTA 배너 */
.cta-band{background:linear-gradient(135deg,var(--navy),var(--blue));color:#fff;border-radius:var(--radius);padding:44px;text-align:center}
.cta-band h2{color:#fff;font-size:28px;margin-bottom:10px}
.cta-band p{color:#dce5f2;margin-bottom:24px}
.cta-band .hero-cta{justify-content:center}

/* ---------- Footer ---------- */
footer.site{background:var(--navy);color:#c3cee0;padding:48px 0 32px;font-size:15px}
footer.site .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:32px;margin-bottom:28px}
footer.site h4{color:#fff;font-size:16px;margin-bottom:14px}
footer.site a:hover{color:#fff}
footer.site ul{list-style:none;display:grid;gap:8px}
footer.site .brand-f{display:flex;align-items:center;gap:10px;margin-bottom:14px}
footer.site .brand-f img{height:28px}
footer.site .brand-f span{color:#fff;font-weight:800;font-size:18px}
footer.site .legal{border-top:1px solid rgba(255,255,255,.12);padding-top:20px;font-size:13.5px;color:#8ea1c0;line-height:1.8}

/* 모바일 하단 고정 CTA */
.mobile-bar{display:none}

/* ---------- 반응형 ---------- */
@media(max-width:880px){
  .grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}
  .doctor-wrap{grid-template-columns:1fr;gap:24px}
  .doctor-photo{max-width:300px;margin:0 auto}
  .proof,.gallery,.equip{grid-template-columns:repeat(2,1fr)}
  footer.site .cols{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  body{font-size:16px}
  section{padding:48px 0}
  .hero{padding:48px 0}
  .hero h1{font-size:29px}
  .hero p.lead{font-size:16.5px}
  .sec-head h2,.cta-band h2{font-size:25px}
  .pagehead h1{font-size:26px}
  .nav-toggle{display:block}
  .gnb{
    display:none;position:absolute;top:64px;left:0;right:0;background:#fff;
    flex-direction:column;align-items:stretch;padding:10px 16px 16px;gap:4px;
    border-bottom:1px solid var(--line);box-shadow:var(--shadow);
  }
  .gnb.open{display:flex}
  .gnb a{padding:13px 12px;font-size:16.5px}
  .doc-hero{grid-template-columns:1fr;margin-top:-26px}
  .doc-hero .dh-photo img{height:260px;object-position:center 22%}
  .doc-hero .dh-body{padding:22px 20px}
  .doc-hero h2{font-size:21px}
  .doc-hero .dh-creds{grid-template-columns:1fr;gap:7px}
  .summary{margin-top:16px;grid-template-columns:1fr}
  .summary .srow{padding:15px 20px}
  .summary .srow:nth-child(2),.summary .srow:nth-child(4){border-right:0}
  .summary .srow:nth-child(4){border-bottom:1px solid var(--line)}
  .summary .label{font-size:14px}
  .summary .val{font-size:14.5px}
  .grid-3,.grid-4,.grid-2,.proof,.gallery,.equip{grid-template-columns:1fr}
  footer.site .cols{grid-template-columns:1fr}
  .cta-band{padding:32px 22px}
  /* 모바일 하단 고정 CTA */
  .mobile-bar{
    display:flex;position:fixed;left:0;right:0;bottom:0;z-index:60;
    background:#fff;border-top:1px solid var(--line);box-shadow:0 -4px 16px rgba(0,0,0,.08);
  }
  .mobile-bar a{flex:1;text-align:center;padding:14px 6px;font-weight:700;font-size:15px;color:var(--navy)}
  .mobile-bar a.primary{background:var(--navy);color:#fff}
  .mobile-bar a+a{border-left:1px solid var(--line)}
  body{padding-bottom:56px}
}
