:root{
  --navy:#0B1F3A; --navy-2:#0E2A52; --blue:#1B4D8F; --blue-br:#2E6FD6;
  --gold:#C7A24A; --gold-soft:#E3CB85;
  --ink:#101A2B; --muted:#5C6B82; --line:#E6ECF4;
  --bg:#FFFFFF; --soft:#F4F8FD;
  --shadow:0 18px 50px rgba(11,31,58,.10);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Pretendard','Apple SD Gothic Neo','Malgun Gothic','Segoe UI',sans-serif;
  color:var(--ink);background:var(--bg);line-height:1.75;
  -webkit-font-smoothing:antialiased;font-size:16px;
}
.serif{font-family:'Noto Serif KR','Nanum Myeongjo',Georgia,serif}
.wrap{max-width:1120px;margin:0 auto;padding:0 24px}
a{color:inherit;text-decoration:none}
.eyebrow{
  display:inline-block;font-size:12.5px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold);font-weight:700;margin-bottom:18px;
}
.eyebrow::before{content:"";display:inline-block;width:26px;height:1px;background:var(--gold);vertical-align:middle;margin-right:12px;opacity:.8}

/* ===== NAV ===== */
header.nav{position:sticky;top:0;z-index:50;background:rgba(11,31,58,.92);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.08)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:70px}
.brand{display:flex;align-items:center;gap:11px;color:#fff;font-weight:800;font-size:19px;letter-spacing:-.01em}
.menu{display:flex;gap:28px;font-size:14.5px;font-weight:600;color:#c7d3e6}
.menu a:hover{color:#fff}
.menu a.active{color:#fff;position:relative}
.menu a.active::after{content:"";position:absolute;left:0;bottom:-6px;width:100%;height:2px;background:var(--gold)}
.nav-cta{background:linear-gradient(135deg,var(--gold-soft),var(--gold));color:#0B1F3A;padding:10px 18px;border-radius:10px;font-weight:800;font-size:14px;box-shadow:0 6px 16px rgba(199,162,74,.35);white-space:nowrap}
.nav-cta:hover{transform:translateY(-1px)}
@media(max-width:860px){
  .nav .wrap{height:auto;flex-wrap:wrap;padding-top:11px;padding-bottom:11px;gap:10px}
  .menu{order:3;width:100%;gap:20px;font-size:13.5px;overflow-x:auto;white-space:nowrap;padding-bottom:4px;-webkit-overflow-scrolling:touch}
}

/* ===== HERO (home) ===== */
.hero{position:relative;color:#fff;overflow:hidden;background-color:var(--navy);
  background-image:
    radial-gradient(1200px 600px at 80% -10%, rgba(46,111,214,.30), transparent 60%),
    linear-gradient(160deg, rgba(11,31,58,.92) 0%, rgba(14,42,82,.80) 50%, rgba(10,24,48,.94) 100%),
    url('images/dragonhillspa-hero.webp');
  background-size:cover,cover,cover;background-position:center;background-repeat:no-repeat;
}
.hero::after{content:"";position:absolute;inset:0;background-image:
  linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
  linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:46px 46px;mask-image:radial-gradient(circle at 70% 20%,#000,transparent 75%);pointer-events:none}
.hero .wrap{position:relative;z-index:2;padding:104px 24px 110px;max-width:920px}
.hero h1{font-size:clamp(38px,6vw,68px);line-height:1.12;font-weight:800;letter-spacing:-.02em}
.hero h1 .accent{background:linear-gradient(120deg,var(--gold-soft),var(--gold));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p.sub{margin-top:24px;font-size:clamp(16px,2.1vw,19px);color:#c8d4e8;max-width:680px;line-height:1.85}
.hero .cta-row{margin-top:38px;display:flex;gap:14px;flex-wrap:wrap}
.hero .meta{margin-top:46px;display:flex;gap:34px;flex-wrap:wrap;font-size:13.5px;color:#9fb0cb}
.hero .meta b{display:block;color:#fff;font-size:19px;font-weight:800;margin-bottom:3px;font-family:'Noto Serif KR',serif}

/* ===== SUBPAGE HERO ===== */
.subhero{position:relative;color:#fff;overflow:hidden;background-color:var(--navy);background-size:cover;background-position:center;background-repeat:no-repeat}
.subhero::before{content:"";position:absolute;inset:0;background:linear-gradient(160deg,rgba(11,31,58,.90),rgba(14,42,82,.78) 60%,rgba(10,24,48,.93))}
.subhero .wrap{position:relative;z-index:2;padding:64px 24px 58px;max-width:900px}
.subhero h1{font-size:clamp(28px,4.4vw,44px);font-weight:800;letter-spacing:-.02em;line-height:1.18}
.subhero p{margin-top:15px;color:#c8d4e8;font-size:clamp(15px,2vw,17.5px);max-width:640px;line-height:1.8}
.crumb{font-size:12.5px;color:#9fb0cb;margin-bottom:15px;letter-spacing:.02em}
.crumb a:hover{color:#fff}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;gap:8px;padding:15px 26px;border-radius:12px;font-weight:800;font-size:15.5px;transition:.18s}
.btn-gold{background:linear-gradient(135deg,var(--gold-soft),var(--gold));color:#0B1F3A;box-shadow:0 10px 26px rgba(199,162,74,.36)}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(199,162,74,.46)}
.btn-ghost{border:1px solid rgba(255,255,255,.32);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.08)}

/* ===== SECTIONS ===== */
section{padding:80px 0}
section.soft{background:var(--soft)}
.sec-head{max-width:720px;margin-bottom:44px}
.sec-head h2{font-size:clamp(26px,3.4vw,38px);font-weight:800;letter-spacing:-.02em;line-height:1.25}
.sec-head p{margin-top:16px;color:var(--muted);font-size:16.5px}

/* status callout */
.status{display:grid;grid-template-columns:1.15fr .85fr;gap:30px;align-items:stretch}
@media(max-width:820px){.status{grid-template-columns:1fr}}
.status-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:34px;box-shadow:var(--shadow)}
.badge{display:inline-flex;align-items:center;gap:8px;background:#FEF2F2;color:#B42318;font-weight:800;font-size:13.5px;padding:8px 14px;border-radius:999px;border:1px solid #FCD9D6}
.badge .dot{width:8px;height:8px;border-radius:50%;background:#E5483B;box-shadow:0 0 0 4px rgba(229,72,59,.18)}
.status-card h3{font-size:22px;margin:18px 0 12px;font-weight:800}
.status-card p{color:#3c4a60}
.facts{background:linear-gradient(160deg,var(--navy),var(--navy-2));border-radius:18px;padding:34px;color:#fff;box-shadow:var(--shadow)}
.facts h4{font-size:14px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:18px;font-weight:700}
.facts li{list-style:none;display:flex;justify-content:space-between;gap:14px;padding:13px 0;border-bottom:1px solid rgba(255,255,255,.1);font-size:15px}
.facts li:last-child{border-bottom:0}
.facts li span:first-child{color:#a9b8d2}
.facts li span:last-child{font-weight:700;text-align:right}

/* timeline */
.timeline{margin-top:8px;border-left:2px solid var(--line);padding-left:26px;display:grid;gap:26px}
.tl{position:relative}
.tl::before{content:"";position:absolute;left:-33px;top:4px;width:13px;height:13px;border-radius:50%;background:#fff;border:3px solid var(--blue-br)}
.tl .yr{font-weight:800;color:var(--blue);font-size:14px;letter-spacing:.04em}
.tl h4{font-size:17px;margin:3px 0 5px}
.tl p{color:var(--muted);font-size:15px}

/* card grid */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:900px){.grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.grid{grid-template-columns:1fr}}
.fcard{background:#fff;border:1px solid var(--line);border-radius:16px;padding:26px;transition:.18s}
.fcard:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:#d4e0f0}
.fcard .fl{font-family:'Noto Serif KR',serif;font-size:13px;font-weight:700;color:var(--gold);letter-spacing:.1em}
.fcard h3{font-size:18.5px;margin:8px 0 10px;font-weight:800}
.fcard p{color:var(--muted);font-size:14.5px;line-height:1.7}

/* prose */
.prose{max-width:780px}
.prose p{margin:0 0 18px;color:#3c4a60;font-size:16.5px;line-height:1.85}
.prose h3{font-size:21px;font-weight:800;margin:34px 0 12px}
.prose ul{margin:0 0 18px;padding-left:20px;color:#3c4a60}
.prose li{margin:6px 0;line-height:1.7}

/* split content + image */
.split{display:grid;grid-template-columns:1fr 1fr;gap:38px;align-items:center}
@media(max-width:820px){.split{grid-template-columns:1fr}}
.split img{width:100%;border-radius:18px;box-shadow:var(--shadow);display:block;aspect-ratio:16/11;object-fit:cover}

/* photo grid */
.photos{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
@media(max-width:560px){.photos{grid-template-columns:1fr}}
.photos figure{margin:0}
.photos img{width:100%;border-radius:14px;display:block;aspect-ratio:16/10;object-fit:cover;box-shadow:var(--shadow)}
.photos figcaption{font-size:13px;color:var(--muted);margin-top:9px;text-align:center}

/* price table */
.ptable{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:var(--shadow)}
.ptable caption{caption-side:top;text-align:left;font-weight:800;font-size:18px;margin-bottom:12px}
.ptable th,.ptable td{padding:15px 18px;text-align:left;border-bottom:1px solid var(--line);font-size:15px}
.ptable th{background:var(--soft);font-weight:800;color:var(--ink)}
.ptable td:last-child{font-weight:700;color:var(--blue);text-align:right}
.ptable tr:last-child td{border-bottom:0}
.note{font-size:13px;color:var(--muted);margin-top:12px}

/* info cards */
.irow{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:760px){.irow{grid-template-columns:1fr}}
.icard{background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px;box-shadow:var(--shadow)}
.icard .k{font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);font-weight:700}
.icard h3{font-size:18px;margin:8px 0 8px;font-weight:800}
.icard p{color:var(--muted);font-size:14.5px;line-height:1.7}

/* map */
.mapframe{width:100%;aspect-ratio:16/10;border:0;border-radius:18px;box-shadow:var(--shadow);display:block}
@media(max-width:820px){.mapframe{aspect-ratio:4/3}}

/* location list */
.loc{display:grid;grid-template-columns:1fr 1fr;gap:34px;align-items:start}
@media(max-width:820px){.loc{grid-template-columns:1fr}}
.loc ul{list-style:none;margin-top:18px;display:grid;gap:14px}
.loc ul li{display:flex;gap:12px;font-size:15.5px;color:#3c4a60}
.loc ul li .ic{flex:0 0 26px;height:26px;border-radius:8px;background:var(--soft);color:var(--blue);display:grid;place-items:center;font-weight:800;border:1px solid var(--line)}

/* FAQ */
.faq{max-width:840px;margin:0 auto}
details{background:#fff;border:1px solid var(--line);border-radius:14px;padding:4px 22px;margin-bottom:12px;transition:.15s}
details[open]{box-shadow:var(--shadow);border-color:#d4e0f0}
summary{cursor:pointer;list-style:none;font-weight:700;font-size:16.5px;padding:18px 0;display:flex;justify-content:space-between;align-items:center}
summary::-webkit-details-marker{display:none}
summary .pl{color:var(--blue-br);font-size:22px;transition:.2s}
details[open] summary .pl{transform:rotate(45deg)}
details p{padding:0 0 20px;color:var(--muted);font-size:15.5px;line-height:1.8}

/* CTA band */
.cta-band{background:linear-gradient(135deg,var(--navy),var(--blue));color:#fff;border-radius:22px;padding:54px 44px;text-align:center;box-shadow:var(--shadow);position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(500px 240px at 80% 0%,rgba(199,162,74,.22),transparent 60%)}
.cta-band h2{position:relative;font-size:clamp(24px,3.2vw,33px);font-weight:800;letter-spacing:-.02em}
.cta-band p{position:relative;margin:14px auto 28px;color:#cbd7ec;max-width:560px}
.cta-band .btn-gold{position:relative}

/* footer */
footer{background:var(--navy);color:#9fb0cb;padding:54px 0 40px;font-size:14px}
footer .ft{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:26px;margin-bottom:22px}
footer .brand{font-size:18px}
footer a:hover{color:#fff}
footer .links{display:flex;gap:22px;flex-wrap:wrap;align-items:center}
.disclaimer{font-size:12.5px;color:#6b7c99;line-height:1.7;max-width:760px}
