/* ══════════════════════════════════════════════════════════
   CALee Acupuncture — clinic.css
   caleeacu.com · GitHub Pages ready
   Design system: Forest Sage + Bronze (from premium draft B)
   ══════════════════════════════════════════════════════════ */

:root{
  --bg:#f8f7f4;            /* oatmeal off-white */
  --ink:#1e2220;           /* deep charcoal green-black */
  --muted:#5a615c;         /* soft stone gray */
  --primary:#3d5043;       /* forest sage green */
  --primary-deep:#2b3930;
  --accent:#bfa38a;        /* muted bronze */
  --accent-soft:#f1ebd9;
  --border:#e3e2de;
  --panel:#ffffff;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Montserrat',system-ui,sans-serif;
  --nav-h:90px;
  --max:1200px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--sans);background:var(--bg);color:var(--ink);
  line-height:1.7;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:var(--primary);text-decoration:none;}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;}
.container{max-width:var(--max);margin:0 auto;padding:0 32px;}

/* ── HEADER ──────────────────────────────────────────────── */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background:rgba(248,247,244,.92);backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
}
.nav-wrapper{display:flex;justify-content:space-between;align-items:center;height:var(--nav-h);}
.brand{display:flex;align-items:center;gap:12px;}
.brand img{height:52px;width:auto;}
.brand-text{font-family:var(--serif);font-size:22px;letter-spacing:2px;color:var(--primary);line-height:1.1;}
.brand-text span{
  display:block;font-family:var(--sans);font-weight:300;font-size:10px;
  letter-spacing:4px;color:var(--accent);text-transform:uppercase;margin-top:2px;
}
.site-nav{display:flex;align-items:center;gap:40px;}
.site-nav a{
  font-size:13px;font-weight:400;text-transform:uppercase;letter-spacing:2px;
  color:var(--ink);position:relative;padding-bottom:4px;transition:color .3s;
}
.site-nav a::after{
  content:'';position:absolute;bottom:0;left:0;width:0;height:1px;
  background:var(--accent);transition:width .3s;
}
.site-nav a:hover,.site-nav a.active{color:var(--primary);}
.site-nav a:hover::after,.site-nav a.active::after{width:100%;}
.nav-research{
  font-size:11px!important;border:1px solid var(--border);padding:8px 14px 6px;
  color:var(--muted)!important;
}
.nav-research::after{display:none;}
.nav-research:hover{border-color:var(--accent);color:var(--primary)!important;}
.nav-toggle{
  display:none;background:none;border:none;color:var(--primary);
  font-size:26px;line-height:1;padding:6px;cursor:pointer;
}
main{margin-top:var(--nav-h);}

/* ── PAGE HERO (interior pages) ──────────────────────────── */
.page-hero{padding:90px 0 70px;text-align:center;border-bottom:1px solid var(--border);}
.page-hero .kicker{
  font-size:12px;text-transform:uppercase;letter-spacing:3px;
  color:var(--accent);margin-bottom:16px;font-weight:400;
}
.page-hero h1{
  font-family:var(--serif);font-size:clamp(38px,5vw,56px);
  font-weight:300;color:var(--primary);letter-spacing:1px;line-height:1.15;
}
.page-hero p{max-width:620px;margin:20px auto 0;color:var(--muted);font-weight:300;font-size:15px;}

/* ── SECTIONS ────────────────────────────────────────────── */
.section{padding:100px 0;}
.section-title{
  font-family:var(--serif);font-size:clamp(34px,4vw,48px);font-weight:300;
  color:var(--primary);margin-bottom:12px;text-align:center;letter-spacing:1px;
}
.section-subtitle{
  font-size:14px;text-transform:uppercase;letter-spacing:3px;
  color:var(--accent);text-align:center;margin-bottom:70px;font-weight:400;
}

/* ── HOME HERO ───────────────────────────────────────────── */
.hero-banner{
  position:relative;min-height:calc(100vh - var(--nav-h));
  display:flex;align-items:center;justify-content:center;text-align:center;
  color:#fff;background-size:cover;background-position:center;
  background-image:linear-gradient(rgba(30,34,32,.52),rgba(30,34,32,.32)),
    url('images/hero-still-life.jpg');
}
.hero-content{max-width:850px;padding:100px 24px;}
.hero-content h1{
  font-family:var(--serif);font-size:clamp(44px,6.5vw,68px);font-weight:300;
  line-height:1.15;margin-bottom:24px;letter-spacing:1px;
}
.hero-content h1 em{font-style:italic;font-weight:400;color:var(--accent-soft);}
.hero-content .hero-line{
  font-size:15px;letter-spacing:2.5px;font-weight:300;text-transform:uppercase;
  margin-bottom:44px;color:#e3e2de;
}
.hero-badges{
  display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:36px;
}
.hero-badges span{
  font-size:11px;letter-spacing:2px;text-transform:uppercase;
  border:1px solid rgba(255,255,255,.35);padding:8px 16px 6px;color:#f1ebd9;
}

/* ── BUTTONS ─────────────────────────────────────────────── */
.cta-button{
  display:inline-block;padding:18px 42px;background:transparent;color:#fff;
  border:1px solid rgba(255,255,255,.85);text-transform:uppercase;
  font-size:12px;letter-spacing:3px;transition:all .4s;cursor:pointer;
}
.cta-button:hover{background:#fff;color:var(--ink);border-color:#fff;}
.cta-solid{
  display:inline-block;padding:16px 38px;background:var(--primary);color:#fff;
  border:1px solid var(--primary);text-transform:uppercase;
  font-size:12px;letter-spacing:3px;transition:background .3s;cursor:pointer;
}
.cta-solid:hover{background:var(--primary-deep);}
.cta-ghost{
  display:inline-block;padding:16px 38px;background:transparent;color:var(--primary);
  border:1px solid var(--primary);text-transform:uppercase;
  font-size:12px;letter-spacing:3px;transition:all .3s;cursor:pointer;
}
.cta-ghost:hover{background:var(--primary);color:#fff;}

/* ── ABOUT / PHILOSOPHY SPLIT ────────────────────────────── */
.about-layout{
  display:grid;grid-template-columns:1.1fr .9fr;gap:80px;align-items:center;
}
.about-img-frame{position:relative;padding-right:30px;padding-bottom:30px;}
.about-img-frame::after{
  content:'';position:absolute;right:0;bottom:0;width:80%;height:80%;
  border:1px solid var(--accent);z-index:1;
}
.about-img-frame img{
  width:100%;aspect-ratio:4/5;object-fit:cover;position:relative;z-index:2;
  filter:grayscale(12%);
}
.about-text h3{
  font-family:var(--serif);font-size:clamp(28px,3vw,36px);font-weight:300;
  color:var(--primary);margin-bottom:24px;line-height:1.3;
}
.about-text p{color:var(--muted);font-size:15px;margin-bottom:24px;font-weight:300;line-height:1.8;}
.about-quote{
  font-family:var(--serif);font-style:italic;font-size:20px;color:var(--accent);
  border-left:2px solid var(--accent);padding-left:20px;margin:32px 0;line-height:1.6;
}

/* ── CREDENTIAL LIST (About page) ────────────────────────── */
.cred-list{list-style:none;margin:8px 0 24px;}
.cred-list li{
  position:relative;padding:10px 0 10px 26px;color:var(--muted);
  font-size:14px;font-weight:300;border-bottom:1px solid var(--border);
}
.cred-list li::before{
  content:'—';position:absolute;left:0;color:var(--accent);
}

/* ── SERVICE CARDS ───────────────────────────────────────── */
.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;}
.service-card{
  background:var(--panel);border:1px solid var(--border);
  overflow:hidden;transition:transform .4s ease,box-shadow .4s ease;
  display:flex;flex-direction:column;
}
.service-card:hover{transform:translateY(-8px);box-shadow:0 20px 40px rgba(61,80,67,.08);}
.service-img-wrapper{width:100%;height:280px;overflow:hidden;}
.service-img-wrapper img{
  width:100%;height:100%;object-fit:cover;transition:transform .6s ease;
}
.service-card:hover .service-img-wrapper img{transform:scale(1.05);}
.service-info{padding:40px 32px;flex:1;display:flex;flex-direction:column;}
.service-info h3{
  font-family:var(--serif);font-size:24px;font-weight:400;
  color:var(--primary);margin-bottom:16px;
}
.service-info p{font-size:14px;color:var(--muted);font-weight:300;line-height:1.7;flex:1;}
.service-info .tag-row{margin-top:22px;display:flex;flex-wrap:wrap;gap:8px;}
.service-info .tag{
  font-size:10px;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--primary);background:var(--accent-soft);padding:6px 12px 4px;
}

/* ── CONDITIONS BAND ─────────────────────────────────────── */
.conditions-band{background:var(--panel);border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.conditions-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);}
.condition-cell{background:var(--panel);padding:44px 36px;}
.condition-cell h4{
  font-family:var(--serif);font-size:21px;font-weight:400;color:var(--primary);margin-bottom:10px;
}
.condition-cell p{font-size:13.5px;color:var(--muted);font-weight:300;}

/* ── INSURANCE STRIP ─────────────────────────────────────── */
.insurance-strip{background:var(--primary);color:#fff;padding:56px 0;text-align:center;}
.insurance-strip h3{
  font-family:var(--serif);font-size:28px;font-weight:300;margin-bottom:10px;letter-spacing:.5px;
}
.insurance-strip p{color:rgba(255,255,255,.75);font-weight:300;font-size:14px;max-width:640px;margin:0 auto 28px;}

/* ── RESEARCH STRIP (cross-link) ─────────────────────────── */
.research-strip{background:var(--ink);color:#fff;padding:64px 0;}
.research-strip .container{
  display:flex;flex-wrap:wrap;gap:28px;align-items:center;justify-content:space-between;
}
.research-strip .kicker{
  font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--accent);margin-bottom:12px;
}
.research-strip h3{
  font-family:var(--serif);font-size:clamp(24px,3vw,32px);font-weight:300;line-height:1.3;max-width:560px;
}
.research-strip p{color:rgba(255,255,255,.6);font-weight:300;font-size:14px;max-width:560px;margin-top:12px;}
.research-strip a.cta-button{border-color:rgba(255,255,255,.5);}

/* ── CONTACT ─────────────────────────────────────────────── */
.contact-layout{display:grid;grid-template-columns:.9fr 1.1fr;gap:80px;}
.contact-details h3{
  font-family:var(--serif);font-size:32px;font-weight:300;color:var(--primary);margin-bottom:36px;
}
.contact-item{margin-bottom:36px;}
.contact-item label{
  display:block;font-size:11px;text-transform:uppercase;letter-spacing:2px;
  color:var(--accent);margin-bottom:8px;font-weight:500;
}
.contact-item p{font-size:15px;color:var(--ink);font-weight:300;}
.contact-item a{color:var(--primary);border-bottom:1px solid var(--accent);}
.contact-form-panel{background:var(--panel);border:1px solid var(--border);padding:48px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:24px;}
.form-group label{
  font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);font-weight:400;
}
.form-group input,.form-group textarea{
  padding:14px;border:1px solid var(--border);background:#fafaf9;
  font-family:var(--sans);font-size:14px;color:var(--ink);outline:none;transition:all .3s;
}
.form-group input:focus,.form-group textarea:focus{border-color:var(--accent);background:#fff;}
.submit-btn{
  width:100%;padding:18px;background:var(--primary);color:#fff;border:none;
  text-transform:uppercase;font-size:12px;letter-spacing:2px;
  transition:background-color .3s;cursor:pointer;font-family:var(--sans);
}
.submit-btn:hover{background:var(--primary-deep);}
.map-frame{margin-top:56px;border:1px solid var(--border);}
.map-frame iframe{display:block;width:100%;height:380px;border:0;}

/* ── FOOTER ──────────────────────────────────────────────── */
.site-footer{border-top:1px solid var(--border);background:#f2f1ed;padding:64px 0 48px;}
.footer-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:48px;margin-bottom:44px;}
.footer-grid h4{
  font-size:11px;text-transform:uppercase;letter-spacing:2.5px;
  color:var(--accent);margin-bottom:16px;font-weight:500;
}
.footer-grid p,.footer-grid a{
  display:block;font-size:13.5px;color:var(--muted);font-weight:300;line-height:1.9;
}
.footer-grid a:hover{color:var(--primary);}
.footer-brand{font-family:var(--serif);font-size:20px;letter-spacing:2px;color:var(--primary);margin-bottom:10px;}
.footer-bottom{
  border-top:1px solid var(--border);padding-top:24px;text-align:center;
  font-size:12px;letter-spacing:1px;color:var(--muted);font-weight:300;
}

/* ── RESPONSIVE ──────────────────────────────────────────── */
@media(max-width:992px){
  .service-grid{grid-template-columns:1fr;gap:32px;}
  .about-layout,.contact-layout{grid-template-columns:1fr;gap:50px;}
  .conditions-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;gap:32px;}
}
@media(max-width:860px){
  :root{--nav-h:76px;}
  .nav-toggle{display:block;}
  .site-nav{
    display:none;position:absolute;top:var(--nav-h);left:0;right:0;
    flex-direction:column;align-items:flex-start;gap:0;
    background:var(--bg);border-bottom:1px solid var(--border);padding:12px 32px 20px;
  }
  .site-nav.open{display:flex;}
  .site-nav a{width:100%;padding:13px 0;}
  .nav-research{margin-top:8px;}
  .brand img{height:42px;}
  .brand-text{font-size:18px;}
  .section{padding:72px 0;}
  .contact-form-panel{padding:32px 24px;}
  .form-row{grid-template-columns:1fr;gap:0;}
}
@media(prefers-reduced-motion:reduce){
  *{transition:none!important;animation:none!important;}
  html{scroll-behavior:auto;}
}

/* ══ v2 additions — real content components ══════════════════ */

/* ── HERO trigger box ── */
.hero-trigger{
  max-width:640px;margin:0 auto 40px;text-align:left;
  font-size:14.5px;font-weight:300;line-height:1.75;color:#e9e7e1;
  padding:18px 22px;border-left:2px solid var(--accent);
  background:rgba(30,34,32,.45);
}
.hero-trigger strong{display:block;font-family:var(--serif);font-weight:400;font-size:19px;color:var(--accent-soft);margin-bottom:6px;letter-spacing:.5px;}

/* ── CONDITION TAGS ── */
.condition-tags{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;}
.condition-tag{
  font-family:var(--sans);font-size:12px;font-weight:400;
  letter-spacing:1.5px;text-transform:uppercase;
  padding:10px 20px 8px;border:1px solid var(--border);
  background:var(--panel);color:var(--muted);cursor:pointer;
  transition:all .3s;
}
.condition-tag:hover{border-color:var(--accent);color:var(--primary);background:var(--accent-soft);}

/* ── GOOD FIT GRID ── */
.fit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);}
.fit-cell{background:var(--panel);padding:36px 30px;}
.fit-cell h4{font-family:var(--serif);font-size:20px;font-weight:400;color:var(--primary);margin-bottom:8px;}
.fit-cell p{font-size:13.5px;color:var(--muted);font-weight:300;line-height:1.7;}

/* ── FIRST VISIT ── */
.first-visit{
  border:1px solid var(--accent);background:var(--accent-soft);
  padding:44px 40px;margin-bottom:56px;
}
.first-visit h3{font-family:var(--serif);font-size:26px;font-weight:400;color:var(--primary);margin-bottom:10px;}
.first-visit>p{font-size:14px;color:var(--muted);font-weight:300;max-width:720px;margin-bottom:28px;}
.fv-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;}
.fv-step{display:flex;gap:14px;align-items:flex-start;}
.fv-num{
  font-family:var(--serif);font-size:22px;color:var(--accent);
  border:1px solid var(--accent);border-radius:50%;
  width:38px;height:38px;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.fv-text{font-size:13.5px;color:var(--muted);font-weight:300;line-height:1.6;}
.fv-text strong{display:block;font-family:var(--serif);font-weight:400;font-size:17px;color:var(--ink);margin-bottom:4px;}

/* ── PRICING CARDS ── */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;}
.price-card{
  background:var(--panel);border:1px solid var(--border);
  padding:36px 32px 28px;display:flex;flex-direction:column;
  transition:transform .4s ease,box-shadow .4s ease;
}
.price-card:hover{transform:translateY(-6px);box-shadow:0 20px 40px rgba(61,80,67,.08);}
.price-card.featured{border-color:var(--primary);border-top:3px solid var(--primary);}
.badge-top{
  align-self:flex-start;font-size:10px;letter-spacing:2px;text-transform:uppercase;
  padding:6px 12px 4px;border:1px solid var(--border);color:var(--muted);
  margin-bottom:20px;
}
.price-card.featured .badge-top{background:var(--primary);border-color:var(--primary);color:#fff;}
.svc-name{font-family:var(--serif);font-size:24px;font-weight:400;color:var(--primary);line-height:1.25;margin-bottom:12px;}
.svc-desc{font-size:13.5px;color:var(--muted);font-weight:300;line-height:1.75;flex:1;margin-bottom:20px;}
.svc-conditions{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:22px;}
.svc-tag{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--primary);background:var(--accent-soft);padding:5px 10px 3px;}
.svc-footer{
  display:flex;align-items:baseline;justify-content:space-between;
  padding-top:18px;border-top:1px solid var(--border);margin-top:auto;
}
.svc-price{font-family:var(--serif);font-size:30px;font-weight:400;color:var(--ink);}
.svc-price small{font-family:var(--sans);font-size:11px;font-weight:300;color:var(--muted);letter-spacing:1px;text-transform:uppercase;margin-left:6px;}
.svc-price.by-consult{font-size:16px;font-family:var(--sans);font-weight:300;color:var(--muted);}
.svc-duration{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);}

/* ── WHY DIFFERENT (dark) ── */
.why-strip{background:var(--ink);color:#fff;padding:100px 0;}
.why-strip .container{display:grid;grid-template-columns:1.1fr .9fr;gap:72px;align-items:start;}
.why-strip h2{font-family:var(--serif);font-size:clamp(30px,3.5vw,42px);font-weight:300;line-height:1.25;margin-bottom:20px;}
.why-strip p{color:rgba(255,255,255,.65);font-weight:300;font-size:14.5px;line-height:1.8;margin-bottom:16px;}
.why-strip a{color:var(--accent);border-bottom:1px solid var(--accent);padding-bottom:2px;}
.why-points{display:flex;flex-direction:column;}
.why-point{
  display:flex;gap:16px;align-items:baseline;
  padding:16px 0;border-bottom:1px solid rgba(255,255,255,.1);
  font-size:14px;font-weight:300;color:rgba(255,255,255,.8);
}
.why-point::before{content:'—';color:var(--accent);flex-shrink:0;}

/* ── DECISION ANCHOR ── */
.decision-anchor{
  max-width:680px;margin:0 auto 48px;text-align:left;
  padding:32px 36px;background:var(--panel);border:1px solid var(--border);
  border-left:2px solid var(--accent);
  font-size:14.5px;font-weight:300;color:var(--muted);line-height:1.8;
}
.decision-anchor strong{
  display:block;font-family:var(--serif);font-weight:400;font-size:22px;
  color:var(--primary);margin-bottom:8px;
}

/* ── CONTACT ACTIONS ── */
.contact-actions{display:flex;flex-direction:column;gap:14px;}
.ca{
  display:flex;align-items:center;gap:18px;
  padding:22px 26px;border:1px solid var(--border);background:var(--panel);
  transition:all .3s;
}
.ca:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 12px 28px rgba(61,80,67,.07);}
.ca.primary{border-color:var(--primary);border-left:3px solid var(--primary);}
.ca-icon{font-size:22px;flex-shrink:0;}
.ca-label{display:block;font-family:var(--serif);font-size:19px;font-weight:400;color:var(--ink);line-height:1.3;}
.ca.primary .ca-label{color:var(--primary);}
.ca-sub{display:block;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);font-weight:300;margin-top:3px;}
.ins-note{
  margin-top:6px;padding:20px 24px;border:1px dashed var(--accent);
  font-size:13px;font-weight:300;color:var(--muted);line-height:1.75;
}
.ins-note strong{color:var(--primary);font-weight:500;}

/* ── INSURANCE 3-CARD ── */
.ins-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-bottom:32px;}
.ins-card{background:var(--panel);border:1px solid var(--border);padding:32px 28px;}
.ins-card h4{font-family:var(--serif);font-size:20px;font-weight:400;color:var(--primary);margin-bottom:8px;}
.ins-card p{font-size:13.5px;color:var(--muted);font-weight:300;line-height:1.7;}

/* ── DIRECTIONS (지도 iframe 대체) ── */
.directions-panel{
  background:var(--panel);border:1px solid var(--border);
  padding:44px 40px;margin-top:56px;
  display:flex;flex-wrap:wrap;gap:36px;align-items:center;justify-content:space-between;
}
.directions-panel h3{font-family:var(--serif);font-size:26px;font-weight:300;color:var(--primary);margin-bottom:8px;}
.directions-panel p{font-size:14px;font-weight:300;color:var(--muted);line-height:1.8;}
.directions-panel .entrance{color:var(--accent);}

/* responsive for v2 */
@media(max-width:992px){
  .pricing-grid,.ins-grid{grid-template-columns:1fr;gap:24px;}
  .fit-grid{grid-template-columns:1fr;}
  .fv-steps{grid-template-columns:1fr;gap:20px;}
  .why-strip .container{grid-template-columns:1fr;gap:44px;}
  .first-visit{padding:32px 24px;}
}

/* ── v3: compact portrait & contact image ── */
.about-img-frame.compact{max-width:340px;margin:0 auto;}
@media(min-width:993px){
  .about-layout.portrait-row{grid-template-columns:340px 1fr;align-items:start;}
}
.contact-photo{position:relative;margin-top:40px;padding-left:26px;padding-bottom:26px;}
.contact-photo::before{
  content:'';position:absolute;left:0;bottom:0;width:80%;height:80%;
  border:1px solid var(--accent);
}
.contact-photo img{
  width:100%;aspect-ratio:1/1;object-fit:cover;position:relative;filter:grayscale(10%);
}

/* ── v4: smaller portrait, team grid, contact hero bg ── */
.about-img-frame.compact{max-width:480px;}
@media(min-width:993px){
  .about-layout.portrait-row{grid-template-columns:500px 1fr;}
}
.about-img-frame.compact img{aspect-ratio:1/1;}

/* TEAM */
.team-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:48px;max-width:820px;margin:0 auto;}
.team-card{text-align:center;}
.team-card .team-photo{
  position:relative;max-width:250px;margin:0 auto 26px;
  padding-right:18px;padding-bottom:18px;
}
.team-card .team-photo::after{
  content:'';position:absolute;right:0;bottom:0;width:82%;height:82%;
  border:1px solid var(--accent);z-index:1;
}
.team-card .team-photo img{
  width:100%;aspect-ratio:4/5;object-fit:cover;object-position:top;
  position:relative;z-index:2;filter:grayscale(12%);
}
.team-card h3{font-family:var(--serif);font-size:26px;font-weight:400;color:var(--primary);margin-bottom:14px;}
.team-card ul{list-style:none;padding:0;}
.team-card li{
  font-size:13.5px;color:var(--muted);font-weight:300;padding:7px 0;
  border-bottom:1px solid var(--border);
}
.team-card li:last-child{border-bottom:none;color:var(--primary);letter-spacing:1px;}
@media(max-width:680px){.team-grid{grid-template-columns:1fr;gap:40px;}}

/* CONTACT HERO with background image */
.page-hero.with-bg{
  border-bottom:none;color:#fff;padding:130px 0 110px;
  background-size:cover;background-position:center;
  background-image:linear-gradient(rgba(30,34,32,.55),rgba(30,34,32,.4)),
    url('images/hero-still-life.jpg');
}
.page-hero.with-bg h1{color:#fff;}
.page-hero.with-bg p{color:#e3e2de;}
.page-hero.with-bg .kicker{color:var(--accent-soft);}

/* ── v5: nav book button & footer socials ── */
.nav-book{
  border-color:var(--primary)!important;background:var(--primary);
  color:#fff!important;
}
.nav-book:hover{background:var(--primary-deep);border-color:var(--primary-deep)!important;color:#fff!important;}
.footer-social{display:flex;gap:14px;margin-top:18px;}
.footer-social a{
  display:inline-flex;align-items:center;justify-content:center;
  width:38px;height:38px;border:1px solid var(--border);border-radius:50%;
  color:var(--muted);transition:all .3s;
}
.footer-social a:hover{border-color:var(--accent);color:var(--primary);transform:translateY(-2px);}

/* ── v6: mobile optimization ── */
/* 모바일 주소창 변화에 흔들리지 않는 히어로 높이 (svh 지원 브라우저) */
@supports (height:100svh){
  .hero-banner{min-height:calc(100svh - var(--nav-h));}
}
/* 소셜 아이콘 탭 타겟 44px (Apple/Google 권장) */
.footer-social a{width:44px;height:44px;}
/* 소형 화면 타이포/여백 미세조정 */
@media(max-width:480px){
  .hero-content{padding:80px 20px;}
  .hero-content h1{font-size:clamp(34px,9vw,44px);}
  .hero-badges{gap:8px;}
  .hero-badges span{font-size:10px;padding:7px 12px 5px;letter-spacing:1.5px;}
  .hero-trigger{font-size:13.5px;padding:16px 18px;}
  .page-hero{padding:64px 0 52px;}
  .page-hero.with-bg{padding:90px 0 76px;}
  .section-title{font-size:30px;}
  .container{padding:0 20px;}
  .cta-button,.cta-solid,.cta-ghost{display:block;text-align:center;padding:16px 24px;}
  .svc-name{font-size:22px;}
  .contact-actions .ca{padding:18px 20px;}
  .directions-panel{padding:32px 24px;}
  .directions-panel .cta-ghost{width:100%;}
}
