/* V19 family-health — warm cream/brown serif theme */
:root {
  --cream:#f9efe0; --cream-2:#ede0c8; --cream-3:#e3d4b6;
  --brown:#7a4a2a; --brown-d:#3d2615; --brown-l:#a87858;
  --gold:#c9a574; --text:#2b1b10; --muted:#6b5240;
  --line:rgba(122,74,42,.18); --line-2:rgba(122,74,42,.32);
  --banner-h:0px; --warning-h:0px;
  --serif:'Cormorant Garamond', serif;
  --korean:'Noto Serif KR', serif;
  --sans:'Inter','Pretendard',-apple-system,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--korean);color:var(--text);background:var(--cream);line-height:1.6;font-size:16px;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
em{font-family:var(--serif);font-style:italic;color:var(--brown);font-weight:500}

/* BANNERS */
.medical-warning-banner{
  position:fixed; top:0; left:0; right:0;
  background:#9b2f25; color:#fff; font-size:11px; font-weight:600;
  padding:7px 16px; text-align:center; z-index:130; letter-spacing:.04em;
}
.demo-banner{
  position:fixed; top:var(--warning-h, 32px); left:0; right:0;
  background:var(--brown-d); color:var(--cream); font-size:11px; font-weight:500;
  padding:6px 16px; text-align:center; z-index:120; letter-spacing:.03em;
  font-family:var(--sans);
}
.demo-disclaimer{
  display:inline-block; margin-left:6px; padding:2px 8px;
  background:rgba(155,47,37,.1); color:#9b2f25; font-size:10px;
  font-weight:600; letter-spacing:.08em; border-radius:2px; vertical-align:middle;
  font-family:var(--sans);
}

body.has-banner{padding-top:calc(var(--banner-h) + var(--warning-h))}

/* NAV — warm beige strip + serif italic + dot accent */
.nav-cream-serif{
  position:fixed; left:0; right:0; top:calc(var(--banner-h) + var(--warning-h));
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 36px; background:var(--cream-2);
  border-bottom:1px solid var(--gold); z-index:100;
  font-family:var(--korean);
}
.nav-brand{display:flex;align-items:baseline;gap:10px}
.brand-mark{font-family:var(--serif); font-size:30px; line-height:1; color:var(--brown); letter-spacing:.02em; font-weight:600}
.brand-mark em{font-style:italic; color:var(--brown-d)}
.brand-mark sup{font-size:.55em; color:var(--gold); font-weight:700}
.brand-sub{font-family:var(--sans); font-size:10px; color:var(--brown-l); letter-spacing:.16em; text-transform:uppercase}

.nav-list{display:flex; list-style:none; gap:0; flex:1; justify-content:center}
.nav-list li{position:relative; padding:0 18px}
.nav-list li:not(:last-child)::after{
  content:'·'; position:absolute; right:-3px; top:50%; transform:translateY(-50%);
  color:var(--gold); font-size:18px; font-weight:700;
}
.nav-list a{
  font-family:var(--korean); font-size:14px; color:var(--brown-d); font-weight:500;
  letter-spacing:.04em; padding:6px 0; position:relative;
  transition:color .25s;
}
.nav-list a::before{
  content:''; position:absolute; bottom:0; left:50%; transform:translateX(-50%);
  width:0; height:2px; background:var(--gold); transition:width .3s;
}
.nav-list a:hover{color:var(--brown)}
.nav-list a:hover::before{width:100%}

.nav-actions{display:flex;align-items:center;gap:12px}
.nav-tel{font-family:var(--sans); font-size:13px; color:var(--brown-d); letter-spacing:.02em}
.nav-login{font-family:var(--korean); font-size:13px; padding:7px 14px; border:1px solid var(--brown); color:var(--brown); border-radius:2px; transition:all .25s}
.nav-login:hover{background:var(--brown); color:var(--cream)}
.nav-signup{font-family:var(--korean); font-size:13px; padding:7px 14px; background:var(--gold); color:var(--brown-d); border-radius:2px; font-weight:600; transition:all .25s}
.nav-signup:hover{background:var(--brown); color:var(--cream)}
.nav-cta{font-family:var(--korean); font-size:13px; padding:8px 18px; background:var(--brown); color:var(--cream); border-radius:2px; font-weight:600; letter-spacing:.04em; transition:all .25s}
.nav-cta:hover{background:var(--brown-d)}

/* BURGER */
.nav-burger{
  display:none; position:fixed; top:calc(var(--banner-h) + var(--warning-h) + 14px); right:20px;
  width:44px; height:44px; background:var(--brown); border:1.5px solid var(--gold); border-radius:50%;
  flex-direction:column; align-items:center; justify-content:center; gap:5px;
  cursor:pointer; z-index:110; box-shadow:0 4px 14px rgba(61,38,21,.35);
}
.burger-line{display:block; width:18px; height:2px; background:var(--cream); border-radius:1px}

/* DRAWER */
.drawer{
  position:fixed; top:0; right:-100%; width:min(360px,90vw); height:100vh; height:100dvh;
  background:var(--cream); z-index:140; transition:right .35s ease;
  overflow-y:auto; box-shadow:-8px 0 30px rgba(0,0,0,.18);
}
.drawer.open{right:0}
.drawer-close{
  position:absolute; top:calc(var(--banner-h) + var(--warning-h) + 18px); right:18px;
  width:44px; height:44px; background:var(--gold); color:var(--brown-d);
  border:none; border-radius:50%; font-size:30px; font-weight:300; line-height:1;
  cursor:pointer; z-index:2; box-shadow:0 4px 14px rgba(61,38,21,.3);
  transition:transform .3s, background .3s;
}
.drawer-close:hover{transform:rotate(90deg); background:var(--brown); color:var(--cream)}
.drawer-inner{padding:calc(var(--banner-h) + var(--warning-h) + 80px) 36px 40px}
.drawer-brand{font-family:var(--serif); font-size:28px; color:var(--brown); margin-bottom:30px}
.drawer-brand em{font-style:italic; color:var(--brown-d)}
.drawer-brand sup{font-size:.55em; color:var(--gold); font-weight:700}
.drawer-brand span{display:block; font-family:var(--sans); font-size:10px; color:var(--brown-l); letter-spacing:.16em; margin-top:6px; text-transform:uppercase}
.drawer-list{list-style:none}
.drawer-list li{border-bottom:1px solid var(--line)}
.drawer-list a{display:flex; align-items:center; gap:10px; padding:14px 0; font-family:var(--korean); font-size:16px; color:var(--brown-d); transition:padding-left .25s}
.drawer-list a::before{content:'·'; color:var(--gold); font-size:24px; font-weight:700; line-height:0}
.drawer-list a:hover{padding-left:8px; color:var(--brown)}
.drawer-rule{margin:24px 0; border:0; border-top:1px solid var(--line)}
.drawer-auth{display:flex; gap:12px; margin-bottom:24px}
.drawer-auth a{flex:1; text-align:center; padding:11px 0; font-family:var(--korean); font-size:14px; border:1px solid var(--brown); color:var(--brown); border-radius:2px}
.drawer-auth a:last-child{background:var(--gold); color:var(--brown-d); border-color:var(--gold); font-weight:600}
.drawer-foot{font-family:var(--sans); font-size:12px; color:var(--brown-l); letter-spacing:.04em}

body.drawer-open{overflow:hidden}
body.drawer-open .nav-cream-serif{display:none !important}

/* MAIN */
main{padding-top:0}

/* COMMON SECTION */
section{padding:80px 36px; max-width:1280px; margin:0 auto}
.sec-head{text-align:center; margin-bottom:48px}
.eyebrow{font-family:var(--sans); font-size:11px; color:var(--gold); letter-spacing:.18em; text-transform:uppercase; font-weight:600}
.eyebrow-light{color:var(--cream-2)}
.sec-title{font-family:var(--serif); font-size:clamp(36px,5vw,56px); color:var(--brown-d); font-weight:500; letter-spacing:.01em; margin:14px 0 12px; line-height:1.1}
.sec-sub{font-family:var(--korean); font-size:15px; color:var(--muted)}

/* HERO */
.sec-hero{position:relative; min-height:88vh; padding:120px 36px 80px; max-width:none; display:flex; align-items:center}
.hero-bg{position:absolute; inset:0; background:linear-gradient(135deg,var(--cream) 0%,var(--cream-2) 60%,var(--cream-3) 100%); z-index:0}
.hero-bg::after{
  content:''; position:absolute; inset:0;
  background-image:url(/themes/_shared/family-health-img/hero.jpg);
  background-size:cover; background-position:center;
  opacity:.5; mix-blend-mode:multiply;
}
.hero-veil{position:absolute; inset:0; background:linear-gradient(180deg,transparent 0%,rgba(249,239,224,.4) 60%,var(--cream) 100%); z-index:1}
.hero-inner{position:relative; z-index:2; max-width:1100px; margin:0 auto; text-align:center; padding:0 20px}
.hero-tag{font-family:var(--sans); font-size:11px; color:var(--brown); letter-spacing:.22em; text-transform:uppercase; margin-bottom:24px; font-weight:600}
.hero-title{font-family:var(--serif); font-size:clamp(48px,8vw,96px); color:var(--brown-d); font-weight:600; line-height:1.05; margin-bottom:24px; letter-spacing:.005em}
.hero-title em{display:block; color:var(--brown); font-style:italic; font-weight:500}
.hero-sub{font-family:var(--korean); font-size:18px; color:var(--muted); margin-bottom:36px; max-width:600px; margin-left:auto; margin-right:auto}
.hero-cta-row{display:flex; gap:18px; justify-content:center; align-items:center; flex-wrap:wrap; margin-bottom:60px}
.hero-cta{padding:14px 32px; background:var(--brown); color:var(--cream); font-family:var(--korean); font-size:15px; font-weight:600; border-radius:2px; letter-spacing:.04em; transition:all .25s; box-shadow:0 4px 14px rgba(61,38,21,.18)}
.hero-cta:hover{background:var(--brown-d); transform:translateY(-2px); box-shadow:0 6px 20px rgba(61,38,21,.25)}
.hero-link{font-family:var(--korean); font-size:14px; color:var(--brown); border-bottom:1px solid var(--gold); padding-bottom:2px}
.hero-link:hover{color:var(--brown-d)}
.hero-meta{display:flex; gap:42px; justify-content:center; flex-wrap:wrap}
.hm{text-align:center}
.hm strong{display:block; font-family:var(--serif); font-size:36px; color:var(--brown-d); font-weight:600; line-height:1}
.hm span{font-family:var(--sans); font-size:10px; color:var(--brown-l); letter-spacing:.16em; text-transform:uppercase; margin-top:6px; display:inline-block}

/* CARE GRID */
.care-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:24px}
.care-card{background:var(--cream-2); border:1px solid var(--line); border-radius:4px; overflow:hidden; transition:all .35s; position:relative}
.care-card::before{content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--gold); transform:scaleX(0); transform-origin:left; transition:transform .4s}
.care-card:hover{transform:translateY(-4px); box-shadow:0 12px 32px rgba(61,38,21,.18)}
.care-card:hover::before{transform:scaleX(1)}
.care-img{aspect-ratio:4/3; background:var(--cream-3); overflow:hidden}
.care-img img{width:100%; height:100%; object-fit:cover; transition:transform .5s}
.care-card:hover .care-img img{transform:scale(1.05)}
.care-body{padding:22px 24px}
.care-label{font-family:var(--serif); font-size:26px; color:var(--brown-d); font-weight:500; margin-bottom:8px}
.care-desc{font-family:var(--korean); font-size:13px; color:var(--muted); margin-bottom:14px; line-height:1.6}
.care-items{list-style:none}
.care-items li{font-family:var(--korean); font-size:13px; color:var(--brown-d); padding:5px 0 5px 14px; position:relative}
.care-items li::before{content:'·'; position:absolute; left:0; color:var(--gold); font-weight:700; font-size:18px; line-height:.6; top:6px}

/* CHECKUP CALENDAR */
.checkup-cal{display:grid; grid-template-columns:repeat(4,1fr); gap:14px}
.cu-cell{background:var(--cream-2); border:1px solid var(--line); border-radius:3px; padding:18px; cursor:pointer; transition:all .25s; position:relative}
.cu-cell:hover{background:var(--gold); border-color:var(--gold)}
.cu-cell .m{font-family:var(--serif); font-size:20px; color:var(--brown); font-weight:600; margin-bottom:6px; font-style:italic}
.cu-cell .rec{font-family:var(--korean); font-size:13px; color:var(--brown-d); margin-bottom:8px; line-height:1.5}
.cu-cell .vac{font-family:var(--sans); font-size:10px; color:var(--brown-l); letter-spacing:.08em; padding:3px 8px; background:var(--cream); border-radius:2px; display:inline-block}
.cu-cell.open{background:var(--gold); border-color:var(--gold)}
.cu-cell.open .vac{background:var(--brown); color:var(--cream)}

/* VACCINE SCHEDULE */
.vaccine-tabs{display:flex; gap:0; justify-content:center; margin-bottom:32px; border-bottom:1px solid var(--line)}
.vt-btn{padding:14px 32px; font-family:var(--korean); font-size:15px; color:var(--muted); background:transparent; border:none; border-bottom:2px solid transparent; cursor:pointer; transition:all .3s; font-weight:500}
.vt-btn.active{color:var(--brown-d); border-bottom-color:var(--gold); font-weight:700}
.vt-btn:hover{color:var(--brown)}
.vaccine-content{max-width:800px; margin:0 auto}
.vc-row{display:grid; grid-template-columns:140px 1fr; gap:24px; padding:18px 0; border-bottom:1px solid var(--line); align-items:start}
.vc-age{font-family:var(--serif); font-size:18px; color:var(--brown); font-weight:600; font-style:italic}
.vc-items{display:flex; flex-wrap:wrap; gap:8px}
.vc-tag{padding:5px 12px; background:var(--cream-2); color:var(--brown-d); font-family:var(--korean); font-size:13px; border-radius:2px; border:1px solid var(--line)}

/* DOCTORS MAGAZINE */
.doctors-mag{display:grid; gap:48px}
.dm-card{display:grid; grid-template-columns:340px 1fr; gap:40px; align-items:center; padding:36px 0; border-bottom:1px solid var(--line)}
.dm-card:nth-child(even){grid-template-columns:1fr 340px}
.dm-card:nth-child(even) .dm-img{order:2}
.dm-img{aspect-ratio:3/4; overflow:hidden; border:1px solid var(--line); background:var(--cream-2)}
.dm-img img{width:100%; height:100%; object-fit:cover}
.dm-name{font-family:var(--serif); font-size:36px; color:var(--brown-d); font-weight:600; margin-bottom:8px; font-style:italic}
.dm-spec{font-family:var(--sans); font-size:11px; color:var(--gold); letter-spacing:.14em; text-transform:uppercase; margin-bottom:18px; font-weight:600}
.dm-career{list-style:none; margin-bottom:18px}
.dm-career li{font-family:var(--korean); font-size:14px; color:var(--brown-d); padding:5px 0 5px 16px; position:relative}
.dm-career li::before{content:'—'; position:absolute; left:0; color:var(--gold)}
.dm-quote{font-family:var(--serif); font-size:18px; font-style:italic; color:var(--muted); border-left:3px solid var(--gold); padding-left:16px; line-height:1.5}

/* FACILITY */
.facility-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:18px}
.fc-card{background:var(--cream-2); border:1px solid var(--line); border-radius:3px; overflow:hidden}
.fc-img{aspect-ratio:4/3; overflow:hidden}
.fc-img img{width:100%; height:100%; object-fit:cover; transition:transform .4s}
.fc-card:hover .fc-img img{transform:scale(1.04)}
.fc-body{padding:14px 16px}
.fc-label{font-family:var(--serif); font-size:20px; color:var(--brown-d); margin-bottom:4px; font-weight:600}
.fc-desc{font-family:var(--korean); font-size:12px; color:var(--muted)}

/* VIDEO ROW */
.video-row{display:grid; grid-template-columns:repeat(3,1fr); gap:24px}
.vr-card{position:relative; aspect-ratio:16/10; border-radius:3px; overflow:hidden; background:var(--brown-d); cursor:pointer}
.vr-card img{width:100%; height:100%; object-fit:cover; opacity:.7; transition:opacity .35s}
.vr-card:hover img{opacity:.9}
.vr-overlay{position:absolute; inset:0; background:linear-gradient(180deg,transparent 50%,rgba(61,38,21,.85)); padding:20px; display:flex; flex-direction:column; justify-content:flex-end; color:var(--cream)}
.vr-play{position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:56px; height:56px; background:var(--gold); color:var(--brown-d); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:22px; font-weight:700; transition:transform .3s}
.vr-card:hover .vr-play{transform:translate(-50%,-50%) scale(1.12)}
.vr-label{font-family:var(--serif); font-size:18px; font-weight:600; margin-bottom:4px}
.vr-meta{font-family:var(--sans); font-size:11px; letter-spacing:.1em; opacity:.85}
.vr-text{font-family:var(--korean); font-size:12px; opacity:.85; margin-top:6px}

/* MAP */
.map-card{display:grid; grid-template-columns:1.4fr 1fr; gap:32px; background:var(--cream-2); border:1px solid var(--line); border-radius:3px; overflow:hidden; padding:0}
.map-img{aspect-ratio:16/10; background:var(--cream-3); overflow:hidden}
.map-img img{width:100%; height:100%; object-fit:cover}
.map-info{padding:32px}
.mi-label{font-family:var(--serif); font-size:24px; color:var(--brown-d); font-weight:600; font-style:italic; margin-bottom:18px}
.mi-list{list-style:none; margin-bottom:18px}
.mi-list li{display:grid; grid-template-columns:60px 1fr auto; gap:12px; padding:10px 0; border-bottom:1px dotted var(--line); font-family:var(--korean); font-size:14px}
.mi-list .t{color:var(--gold); font-family:var(--sans); font-size:11px; letter-spacing:.1em; font-weight:600; text-transform:uppercase; align-self:center}
.mi-list .n{color:var(--brown-d); font-weight:500}
.mi-list .d{color:var(--muted); font-size:12px; align-self:center}
.mi-park{font-family:var(--korean); font-size:13px; color:var(--muted); padding:12px; background:var(--cream); border-left:3px solid var(--gold)}

/* TESTIMONIALS */
.testi-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:24px}
.te-card{background:#fbf5e6; border:1px solid var(--line); border-radius:3px; padding:28px 30px; position:relative; box-shadow:0 4px 14px rgba(61,38,21,.06)}
.te-card::before{content:'"'; position:absolute; top:8px; left:18px; font-family:var(--serif); font-size:64px; color:var(--gold); line-height:1; font-style:italic; opacity:.5}
.te-text{font-family:var(--korean); font-size:15px; color:var(--brown-d); line-height:1.7; margin:18px 0 14px; padding-left:30px}
.te-meta{display:flex; align-items:center; gap:12px; padding-left:30px; padding-top:14px; border-top:1px solid var(--line)}
.te-who{font-family:var(--serif); font-size:15px; color:var(--brown-d); font-weight:600; font-style:italic}
.te-area{font-family:var(--sans); font-size:10px; color:var(--gold); letter-spacing:.1em; text-transform:uppercase; padding:3px 8px; background:var(--cream); border-radius:2px; font-weight:600}

/* STATS */
.sec-stats{background:var(--cream-2); padding:60px 36px; max-width:none; border-top:1px solid var(--line); border-bottom:1px solid var(--line)}
.stats-inner{max-width:1200px; margin:0 auto; display:grid; grid-template-columns:repeat(4,1fr); gap:24px}
.st-card{text-align:center; padding:20px}
.st-num{font-family:var(--serif); font-size:54px; color:var(--brown); font-weight:600; line-height:1; font-style:italic}
.st-label{font-family:var(--sans); font-size:11px; color:var(--brown-l); letter-spacing:.16em; text-transform:uppercase; margin-top:10px; font-weight:600}
.stats-foot{text-align:center; font-family:var(--korean); font-size:12px; color:var(--muted); margin-top:24px}

/* CTA */
.sec-cta{background:linear-gradient(180deg,var(--brown-d) 0%,var(--brown) 100%); padding:80px 36px; max-width:none; color:var(--cream); margin-top:0}
.cta-inner{max-width:720px; margin:0 auto; text-align:center}
.sec-cta .sec-title{color:var(--cream)}
.sec-cta .sec-title em{color:var(--gold)}
.cta-form{display:grid; gap:14px; margin-top:32px; text-align:left}
.cta-form label{display:flex; flex-direction:column; gap:6px; font-family:var(--korean); font-size:12px; color:var(--cream-2); letter-spacing:.04em; text-transform:uppercase; font-weight:600}
.cta-form input,.cta-form select,.cta-form textarea{
  padding:12px 14px; background:rgba(255,255,255,.07); border:1px solid rgba(201,165,116,.3); color:var(--cream);
  border-radius:2px; font-family:var(--korean); font-size:16px; transition:border-color .25s
}
.cta-form input:focus,.cta-form select:focus,.cta-form textarea:focus{outline:none; border-color:var(--gold); background:rgba(255,255,255,.12)}
.cta-form select option{background:var(--brown-d); color:var(--cream)}
.cta-submit{padding:16px; background:var(--gold); color:var(--brown-d); border:none; font-family:var(--korean); font-size:15px; font-weight:700; letter-spacing:.06em; border-radius:2px; cursor:pointer; transition:all .25s; margin-top:6px}
.cta-submit:hover{background:var(--cream); transform:translateY(-2px)}
.cta-foot{font-family:var(--sans); font-size:11px; color:rgba(255,255,255,.6); text-align:center; margin-top:8px}

/* FOOTER */
.footer{background:var(--brown-d); color:var(--cream-2); padding:48px 36px; text-align:center; font-family:var(--korean); font-size:13px; letter-spacing:.04em}
.footer .ft-brand{font-family:var(--serif); font-size:30px; color:var(--cream); font-style:italic; margin-bottom:14px; font-weight:600}
.footer .ft-brand sup{font-size:.55em; color:var(--gold)}
.footer .ft-info{display:flex; justify-content:center; gap:32px; flex-wrap:wrap; margin-bottom:18px; opacity:.85}
.footer .ft-info span{padding:0 14px; border-right:1px solid rgba(201,165,116,.3)}
.footer .ft-info span:last-child{border-right:none}
.footer .ft-line{font-family:var(--sans); font-size:11px; color:rgba(255,255,255,.45); margin-top:14px}

/* MOBILE */
@media (max-width:1024px){
  .care-grid{grid-template-columns:repeat(2,1fr)}
  .checkup-cal{grid-template-columns:repeat(3,1fr)}
  .doctors-mag .dm-card,.doctors-mag .dm-card:nth-child(even){grid-template-columns:1fr; gap:24px; text-align:center}
  .doctors-mag .dm-card:nth-child(even) .dm-img{order:0}
  .dm-quote{text-align:left}
  .facility-grid{grid-template-columns:repeat(2,1fr)}
  .video-row{grid-template-columns:repeat(2,1fr)}
  .map-card{grid-template-columns:1fr}
  .testi-grid{grid-template-columns:1fr}
  .stats-inner{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:768px){
  body{font-size:15px}
  .nav-cream-serif{display:none}
  .nav-burger{display:flex}
  main{padding-top:0}
  section{padding:60px 20px}
  .sec-hero{padding:100px 20px 60px; min-height:auto}
  .care-grid{grid-template-columns:1fr}
  .checkup-cal{grid-template-columns:repeat(2,1fr); gap:10px}
  .vaccine-tabs{flex-direction:column; align-items:stretch}
  .vt-btn{padding:12px 16px; text-align:left; border-bottom:1px solid var(--line)}
  .vt-btn.active{border-bottom-color:var(--gold); border-left:3px solid var(--gold)}
  .vc-row{grid-template-columns:1fr; gap:8px; padding:14px 0}
  .facility-grid{grid-template-columns:1fr}
  .video-row{grid-template-columns:1fr}
  .stats-inner{grid-template-columns:repeat(2,1fr); gap:14px}
  .st-num{font-size:42px}
  .footer .ft-info{flex-direction:column; gap:8px}
  .footer .ft-info span{border-right:none; border-bottom:1px dotted rgba(201,165,116,.3); padding:6px 0}
  .cta-form input,.cta-form select,.cta-form textarea{font-size:16px}
}

/* ===== 1C-1 nav-cream-serif unique override (2026-04-28 retrofit) ===== */
.nav-cream-serif{
  background:linear-gradient(180deg, var(--cream-2) 0%, var(--cream) 100%) !important;
  border-bottom:none !important;
  box-shadow:0 2px 0 var(--gold), 0 4px 0 var(--cream-2), 0 5px 0 var(--gold), 0 16px 32px -16px rgba(122,74,42,.18);
  padding:18px 44px !important;
}
.nav-cream-serif .nav-list a{font-family:var(--serif) !important; font-style:italic; font-size:16px !important; letter-spacing:.01em}
.nav-cream-serif .nav-list li:not(:last-child)::after{
  content:'·' !important; font-family:var(--serif) !important; font-size:22px !important;
  animation:nav-cream-dot 2.4s ease-in-out infinite;
}
@keyframes nav-cream-dot{0%,100%{opacity:.4;transform:translateY(-50%) scale(1)}50%{opacity:1;transform:translateY(-50%) scale(1.3)}}
.nav-cream-serif .brand-mark em{text-decoration:underline; text-decoration-color:var(--gold); text-decoration-thickness:2px; text-underline-offset:6px}

/* 1D 인터랙션 추가 (universal patch 2026-04-28) */
.reveal-init{opacity:0; transform:translateY(20px); transition:opacity .8s ease, transform .8s ease}
.reveal-in{opacity:1 !important; transform:none !important}
.hero-bg{transition:transform .4s ease-out}
@keyframes pulse-anim{0%,100%{opacity:.85}50%{opacity:1}}
[class*="brand-stamp"], [class*="brand-glyph"], [class*="brand-orb"], [class*="brand-tag"], [class*="brand-frame"], [class*="brand-icon"]{animation:pulse-anim 3s ease-in-out infinite; display:inline-block}

/* 1D 강화 — 시각적 cursor follower + magnetic CTA + card tilt (universal patch v2) */
.cursor-follower{position:fixed; top:0; left:0; width:32px; height:32px; border:2px solid currentColor; border-radius:50%; pointer-events:none; z-index:9999; transform:translate(-50%,-50%); transition:transform .15s ease-out, width .25s, height .25s, background .25s; mix-blend-mode:difference; opacity:.85}
.cursor-follower.cursor-grow{width:60px; height:60px; background:rgba(255,255,255,.1)}
.cursor-follower.cursor-shrink{width:8px; height:8px}
.nav-cta, .nav-signup, [class*="-form-submit"], [class*="-cta"] a{transition:transform .25s cubic-bezier(.34,1.56,.64,1), box-shadow .3s !important}
[class*="-card"]{transition:transform .35s cubic-bezier(.2,.85,.4,1.275), box-shadow .35s, border-color .25s !important}
@media (max-width:768px){.cursor-follower{display:none !important}}

/* 1D-2 cursor diversify — warm cream serif dot */
.cursor-follower{border-color:var(--gold,#d4a574); mix-blend-mode:normal; box-shadow:0 0 18px rgba(212,165,116,.4)}
.cursor-follower::before{content:""; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:4px; height:4px; background:var(--pink-deep,#c44a78); border-radius:50%}

/* 1D-4 mobile interaction — touch ripple + particle (universal) */
@media (max-width:768px){
  .touch-ripple{position:fixed; pointer-events:none; z-index:9998; border-radius:50%; transform:translate(-50%,-50%); animation:touch-ripple-anim .6s ease-out forwards; mix-blend-mode:multiply}
  @keyframes touch-ripple-anim{
    0%{width:10px; height:10px; opacity:.7; border:2px solid currentColor; background:transparent}
    100%{width:80px; height:80px; opacity:0; border:1px solid currentColor; background:transparent}
  }
  .touch-particle{position:fixed; pointer-events:none; z-index:9998; transform:translate(-50%,-50%); transition:all 1.2s ease-out; opacity:.9; font-size:14px}
  /* iOS smooth scroll + active feedback */
  a, button, [class*="-card"]{-webkit-tap-highlight-color:transparent}
  a:active, button:active, [class*="-card"]:active{transform:scale(.97); transition:transform .1s}
}


/* ===========================================
   RETROFIT v1.27 — motionsites integration
   slug: family-health
   effects: N, U
   =========================================== */
/* === retrofit v1.27 motionsites liquid-glass (MIT) === */
.btn, .cta-btn, .nav-cta, [class*="-btn"], [class*="-cta"], button[type="submit"] {
  position: relative;
  overflow: hidden;
}
.btn::before, .cta-btn::before, .nav-cta::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(180deg, rgba(255,255,255,0.18), rgba(255,255,255,0) 50%, rgba(255,255,255,0.12));
  opacity: 0.7; border-radius: inherit;
  transition: opacity 0.3s;
}
.btn:hover::before, .cta-btn:hover::before, .nav-cta:hover::before { opacity: 1; }/* === retrofit v1.27 motionsites scroll-driven-reveal (MIT) === */
@supports (animation-timeline: view()) {
  @media (prefers-reduced-motion: no-preference) {
    .section, [class*="-section"], .card, [class*="-card"], article {
      animation: rt-reveal-up linear forwards;
      animation-timeline: view();
      animation-range: entry 0% cover 30%;
    }
    @keyframes rt-reveal-up {
      from { opacity: 0; transform: translateY(28px); }
      to { opacity: 1; transform: translateY(0); }
    }
  }
}