
.contact-container {
  max-width: 820px;
  margin: 0 auto;
  padding: 0 20px;
}
@media (max-width: 768px) {
  .contact-container {
    max-width: 100%;
    margin: 0;
  }
}

@import url("https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.css");
:root{
 --inkMuted:rgba(29,53,87,0.68);
 --primary:#006D77;--secondary:#FF9F1C;--accent:#83C5BE;--bg:#F8F9FA;--text:#1D3557;--border:rgba(0,109,119,0.12);--shadow:0 20px 40px rgba(0,109,119,0.06);

 --radius:14px;--radiusLg:16px;
}
body{margin:0;font-family:Pretendard,sans-serif;background:var(--bg);color:var(--text);letter-spacing:-0.02em;}
.header{display:flex;justify-content:space-between;align-items:center;padding:20px 40px;background:#fff;border-bottom:1px solid var(--border);}
.nav{display:flex;align-items:center;gap:16px;}
.logo{font-weight:900;color:var(--primary);font-size:32px;letter-spacing:-0.02em;text-decoration:none;display:inline-flex;align-items:baseline;--no-color:var(--secondary);--frailty-color:var(--primary);}
.logo:hover{--no-color:var(--primary);--frailty-color:var(--secondary);}
.logo-no{color:var(--no-color);}
.logo-frailty{color:rgba(0,109,119,0.3);animation:frailtySolid 1.8s ease forwards;animation-delay:0.3s;}
@keyframes frailtySolid{from{color:rgba(0,109,119,0.3);}to{color:var(--frailty-color);}}
@media (max-width:768px){.logo{font-size:24px;}}
.nav a{margin-left:16px;text-decoration:none;color:var(--text);}
.nav .cta{background:var(--secondary);color:#fff;padding:10px 18px;border-radius: var(--radius);}
.hero{padding:140px 40px;background:linear-gradient(135deg,#006D77,#054a51);color:#fff;}
.heroInner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:60px;}
.heroLeft{max-width:640px;position:relative;z-index:1;}
.heroRight{flex:0 0 520px;display:flex;justify-content:flex-end;position:relative;z-index:1;}
.highlight{color:var(--secondary);}
.section{padding:120px 40px;}
.section.alt{background:#fff;}
.sectionHead{margin-bottom:40px;}
.eyebrow{color:var(--secondary);font-weight:800;font-size:14px;}
h2{font-size:42px;font-weight:900;color:var(--primary);}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.moduleCard,.impactCard{background:#fff;padding:32px;box-shadow:var(--shadow);}
.impactGrid{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
/* impactCompare는 2열 전체를 사용 */
.impactGrid .impactCompare{grid-column:1 / -1;}
.num{font-family:Montserrat,sans-serif;font-size:48px;font-weight:800;color:var(--secondary);}
.stepList li{margin-bottom:12px;}

/* Hero: why frailty block */
.whyFrailty{margin-top:28px;max-width:900px;padding:8px 0 0 0;}
.whyTitle{font-weight:900;font-size:20px;letter-spacing:-0.02em;}
.whyLead{margin:8px 0 12px 0;opacity:0.92;}
.whyQuotes{margin:0;padding-left:18px;opacity:0.9;}
.whyQuotes li{margin:6px 0;}

/* Module muted card */
.moduleCardMuted{background:var(--bg);border:1px solid var(--border);box-shadow:none;}


/* Impact section 전체 덩어리화 */
#impact{
  margin-top:64px;
}

#impact .impactWrap{
  max-width:1200px;
  margin:0 auto;
  padding:32px 24px;
  background:#ffffff;
  border-radius:28px;
  box-shadow:0 12px 32px rgba(0,0,0,0.04);
}
/* 성과 섹션 제목과 카드 간 리듬 정리 */
#impact h2{
  margin-top:0;
  margin-bottom:24px;
}

.impactCompare{
  margin-top:32px;
}

/* Impact units */
.impactNum{
  display:flex;
  align-items:baseline;
  gap:6px;
}

/* 화살표는 CSS에서만 제어 */
.impactNum::after{
  margin-left:6px;
  font-size:16px;
  font-weight:800;
  line-height:1;
}

/* 증가 / 감소 명확 분리 */
.impactNum.up::after{
  content:"▲";
  color:var(--secondary);
}

.impactNum.down::after{
  content:"▼";
  color:var(--secondary);
  opacity:0.6;
}

.impactUnit{
  font-family:Montserrat,sans-serif;
  font-size:20px;
  font-weight:800;
  color:var(--secondary);
}

.impactSuffix{
  font-size:18px;
  font-weight:700;
  color:var(--text);
  opacity:0.9;
}

/* Impact units */
.impactNum{display:flex;align-items:baseline;gap:6px;}
.impactUnit{font-family:Montserrat,sans-serif;font-size:20px;font-weight:800;color:var(--secondary);}
.impactSuffix{font-size:18px;font-weight:700;color:var(--text);opacity:0.9;}

/* Process note */
.processNote{margin-top:18px;font-size:18px;line-height:1.6;color:var(--text);}

/* Reveal */
.reveal{opacity:0;transform:translateY(40px);transition:0.8s ease;}
.reveal.active{opacity:1;transform:none;}


/* Why frailty: no box, just accent rail */
.whyFrailty{position:relative;padding-left:18px;}
.whyFrailty:before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:3px;background:rgba(255,159,28,0.95);border-radius:3px;}
.whyQuotes{list-style:disc;}
.whyQuotes li{margin:10px 0;}

/* Module sub line */
.moduleCard .sub{margin-top:10px;color:rgba(29,53,87,0.75);font-size:16px;line-height:1.5;}

/* Process subtitle */
.processSub{margin-top:14px;font-size:20px;line-height:1.6;color:rgba(29,53,87,0.9);}


/* Left aligned section head (used in contact & policy) */
.sectionHeadLeft{max-width:820px;margin:0 auto;padding:0 20px;text-align:left;}
.sectionHeadLeft h2{margin-bottom:0;}

/* Contact form (v4) */

.contact-desc{margin-top:14px;font-size:18px;line-height:1.6;color:rgba(29,53,87,0.85);}
#inquiryForm{margin-top:22px;background:#fff;border-radius: var(--radiusLg);padding:28px 28px;box-shadow:var(--shadow);border:1px solid var(--border);}
.input-group{display:flex;flex-direction:column;gap:8px;margin-bottom:18px;}
.input-group label{font-size:14px;font-weight:800;color:rgba(29,53,87,0.9);}
/* Required field indicator (Form UX) */
.input-group:has(input[required]) label::after,
.input-group:has(textarea[required]) label::after,
.input-group:has(select[required]) label::after{
  content:" *";
  color:#c1121f;
  font-weight:800;
  display:inline-block;
  margin-left:4px;
}
.input-group input{height:48px;border-radius:12px;border:1px solid var(--border);padding:0 14px;font-size:16px;outline:none;background:#fff;}
.input-group input:focus{border-color:rgba(0,109,119,0.45);box-shadow:0 0 0 4px rgba(131,197,190,0.25);}
.hint{font-size:13px;color:var(--inkMuted);}

.consent-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin:4px 0 14px 0;}
.consent-label{display:flex;align-items:center;gap:10px;font-size:14px;color:rgba(29,53,87,0.9);font-weight:700;}
.consent-label input{width:18px;height:18px;}
.consent-link{font-size:14px;color:var(--primary);text-decoration:none;border-bottom:1px solid rgba(0,109,119,0.25);}
.consent-link:hover{color:rgba(0,109,119,0.9);}

.cta-submit{margin-top:6px;width:100%;height:52px;border:0;border-radius: var(--radius);background:var(--secondary);color:#fff;font-size:16px;font-weight:900;cursor:pointer;transition:transform .18s ease, filter .18s ease;}
.cta-submit:hover{filter:brightness(0.97);box-shadow:0 12px 26px rgba(0,0,0,0.08);}
.cta-submit:disabled{opacity:0.6;cursor:default;transform:none;}

.form-message{margin-top:14px;font-size:16px;min-height:22px;}
.form-message.ok{color:var(--primary);}
.form-message.err{color:#c1121f;}

/* Disclaimer (small muted) */
.legal-note{margin-top:16px;font-size:12.5px;line-height:1.65;color:var(--inkMuted);}

/* Footer (v4) */
.site-footer{padding:34px 40px;background:#fff;border-top:1px solid var(--border);}
.footer-inner{max-width:1100px;margin:0 auto;display:flex;align-items:flex-start;justify-content:space-between;gap:18px;flex-wrap:wrap;}
.footer-powered{font-size:14px;color:rgba(29,53,87,0.85);font-weight:900;}
.footer-powered a{color:var(--primary);text-decoration:none;border-bottom:1px solid rgba(0,109,119,0.25);}
.footer-meta{display:flex;flex-direction:column;gap:6px;}
.footer-line{font-size:13px;line-height:1.6;color:rgba(29,53,87,0.85);}
.footer-links a{font-size:13px;color:rgba(29,53,87,0.85);text-decoration:none;}
.footer-links a:hover{color:var(--primary);}

@media (max-width:768px){
  #inquiryForm{padding:22px;}
  .site-footer{padding:28px 20px;}
}


/* Privacy policy (v4) */
.policyCard{max-width:920px;margin:0 auto;padding:0 20px;background:#fff;border-radius:var(--radiusLg);padding:28px 28px;box-shadow:var(--shadow);border:1px solid var(--border);}
.policyCard h3{margin-top:0;margin-bottom:14px;font-size:18px;color:var(--primary);font-weight:900;}
.policyCard ul{margin:0 0 10px 18px;color:rgba(29,53,87,0.9);}



#inquiryForm{
  width: 100%;
}



/* Emphasized form message */
.form-message{
  padding:10px 14px;
  border-radius:10px;
}
.form-message.ok{
  background:rgba(0,109,119,0.08);
  border:1px solid rgba(0,109,119,0.25);
}
.form-message.err{
  background:rgba(193,18,31,0.06);
  border:1px solid rgba(193,18,31,0.25);
}


/* Centered contact/privacy layout (v9) */





/* Contact section distinct panel (v9) */
.contact-panel{
  background:linear-gradient(180deg, rgba(0,109,119,0.06), rgba(248,249,250,0.0));
  border:1px solid rgba(0,109,119,0.14);
  border-radius: var(--radiusLg);
  padding:34px 34px;
  box-shadow:0 18px 50px rgba(29,53,87,0.08);
}
@media (max-width:768px){
  .contact-panel{padding:26px 18px;border-radius:22px;}
}


/* Simple footer layout (v9) */
.footer-simple{
  flex-direction:column;
  align-items:flex-start;
  gap:8px;
}
.footer-simple .footer-links a{
  color:rgba(29,53,87,0.85);
}
.footer-simple a{
  color:var(--primary);
  text-decoration:none;
  border-bottom:1px solid rgba(0,109,119,0.25);
}

/* Reference gallery */
.refGrid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap:16px;
  margin-top:18px;
}
.refCard{
  border:1px solid rgba(0,0,0,0.08);
  background:#fff;
  border-radius:16px;
  overflow:hidden;
  padding:0;
  text-align:left;
  cursor:pointer;
  box-shadow: 0 8px 20px rgba(0,0,0,0.05);
  transition: transform 160ms ease, box-shadow 160ms ease;
}
.refCard:hover{
  transform: translateY(-2px);
  box-shadow: 0 12px 26px rgba(0,0,0,0.08);
}
.refThumb{
  width:100%;
  height:140px;
  object-fit:cover;
  display:block;
  background:#f3f4f6;
}
.refMeta{
  padding:14px 14px 16px;
}
.refTitle{
  font-weight:800;
  letter-spacing:-0.02em;
  font-size:16px;
  color:#0f172a;
}
.refSub{
  margin-top:6px;
  font-size:13px;
  color:#475569;
  line-height:1.45;
}

/* Reference modal */
.refModal{
  position:fixed;
  inset:0;
  display:none;
  z-index:2000;
}
.refModal.open{ display:block; }
.refModalOverlay{
  position:absolute;
  inset:0;
  background: rgba(15,23,42,0.56);
}
.refModalPanel{
  position:relative;
  width:min(720px, calc(100% - 32px));
  margin: 9vh auto 0;
  background:#fff;
  border-radius:18px;
  box-shadow: 0 24px 80px rgba(0,0,0,0.24);
  border:1px solid rgba(255,255,255,0.18);
}
.refModalClose{
  position:absolute;
  right:10px;
  top:10px;
  width:42px;
  height:42px;
  border-radius:12px;
  border:1px solid rgba(0,0,0,0.08);
  background:#fff;
  cursor:pointer;
  font-size:22px;
  line-height:40px;
  color:#0f172a;
}
.refModalBody{
  padding:26px 22px 22px;
}
.refModalTitle{
  font-size:20px;
  font-weight:800;
  letter-spacing:-0.02em;
  color:#0f172a;
}
.refModalSubtitle{
  margin-top:8px;
  font-size:14px;
  color:#334155;
}
.refModalDesc{
  margin-top:14px;
  font-size:14px;
  color:#0f172a;
  line-height:1.7;
  white-space:pre-line;
}
body.modal-open{
  overflow:hidden;
}

@media (max-width: 520px){
  .refThumb{ height:160px; }
  .refModalPanel{ margin-top: 10vh; }
}


/* v10 UI refinements (preserve v9 structure) */
.heroInner{position:relative;}
.heroMedia{
  position:absolute;
  right:0;
  top:10px;
  width:min(520px,40%);
  height:min(360px,48vh);
  border-radius:24px;
  opacity:0.22;
  pointer-events:none;
  background:
    radial-gradient(120% 120% at 20% 10%, rgba(255,162,26,0.28) 0%, rgba(255,162,26,0) 55%),
    linear-gradient(135deg, rgba(255,255,255,0.12), rgba(255,255,255,0));
  overflow:hidden;
}
.heroMedia::before{
  content:"";
  position:absolute; inset:0;
  background-image:url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%20width%3D%27900%27%20height%3D%27620%27%20viewBox%3D%270%200%20900%20620%27%3E%0A%3Cdefs%3E%0A%3ClinearGradient%20id%3D%27g%27%20x1%3D%270%27%20y1%3D%270%27%20x2%3D%271%27%20y2%3D%271%27%3E%0A%3Cstop%20offset%3D%270%27%20stop-color%3D%27%23ffffff%27%20stop-opacity%3D%27.18%27/%3E%0A%3Cstop%20offset%3D%271%27%20stop-color%3D%27%23ffffff%27%20stop-opacity%3D%270%27/%3E%0A%3C/linearGradient%3E%0A%3C/defs%3E%0A%3Crect%20width%3D%27900%27%20height%3D%27620%27%20fill%3D%27url%28%23g%29%27/%3E%0A%3Cg%20fill%3D%27none%27%20stroke%3D%27%23ffffff%27%20stroke-opacity%3D%27.22%27%20stroke-width%3D%276%27%3E%0A%3Cpath%20d%3D%27M80%20520%20C220%20420%20260%20360%20360%20300%20C470%20235%20560%20230%20700%20150%27/%3E%0A%3Cpath%20d%3D%27M120%20560%20C240%20470%20300%20430%20420%20360%20C540%20290%20650%20250%20820%20210%27%20stroke-opacity%3D%27.16%27/%3E%0A%3C/g%3E%0A%3Cg%20fill%3D%27%23ffffff%27%20fill-opacity%3D%27.14%27%3E%0A%3Ccircle%20cx%3D%27650%27%20cy%3D%27160%27%20r%3D%2734%27/%3E%0A%3Ccircle%20cx%3D%27720%27%20cy%3D%27220%27%20r%3D%2718%27/%3E%0A%3Ccircle%20cx%3D%27560%27%20cy%3D%27250%27%20r%3D%2714%27/%3E%0A%3C/g%3E%0A%3C/svg%3E");
  background-size:cover;
  filter:blur(0.2px);
}
@media (max-width: 900px){
  .heroMedia{display:none;}
}

.whyFrailty{margin-top:22px;}
.whyCards{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:12px;}
.whyCard{display:flex;gap:12px;align-items:flex-start;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.14);border-radius:18px;padding:14px 14px;}
.whyIcon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:10px;background:rgba(255,162,26,0.16);flex:0 0 auto;}
.whyText{font-size:14px;line-height:1.55;opacity:0.95;}
@media (max-width: 900px){
  .whyCards{grid-template-columns:1fr;gap:10px;}
}

.moduleHead{display:flex;align-items:center;gap:10px;margin-bottom:10px;}
.moduleIcon{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:12px;background:rgba(0,121,121,0.08);border:1px solid rgba(0,121,121,0.14);}
.moduleHead h3{margin:0;flex:1;}
.brandTag{font-size:12px;line-height:1;border-radius:999px;padding:6px 10px;border:1px solid rgba(0,0,0,0.08);background:rgba(255,255,255,0.7);}

.impactMeta{font-size:13px;color:#6b7280;margin-top:6px;}
.impactViz{height:10px;border-radius:999px;background:rgba(255,162,26,0.18);overflow:hidden;margin-top:14px;}
.impactViz::before{content:"";display:block;height:100%;border-radius:999px;background:#ffa21a;width:0;animation:impactGrow 1.4s ease-out forwards;}
.impactViz.up::before{width:78%;}
.impactViz.down::before{width:62%;}
@keyframes impactGrow{from{width:0}to{width:var(--w,70%);}}
.impactCompare{
  margin-top:22px;
  border-radius:20px;
  border:1px solid rgba(0,0,0,0.06);
 background:#f9fafb;  
  padding:20px; /* 여백 살짝 증가 */
}

.compareHead{
  font-size:14px;
  color:#6b7280;
  margin-bottom:16px;      /* 헤드 아래 여백 증가 */
  line-height:1.45;        /* 긴 문장 대응 */
}

.compareGrid{
  display:grid;
  grid-template-columns:1.05fr 1.15fr;
  gap:16px;                /* 카드 간격 소폭 증가 */
  align-items:stretch;     /* 좌우 카드 높이 강제 정렬 */
}

.compareCol{
  border-radius:18px;
  border:1px solid rgba(0,0,0,0.06);
  padding:14px 18px;       /* 내부 여백 증가 */
  background:#fafafa;
  display:flex;            /* 내부 정렬 안정화 */
  flex-direction:column;
}

.highlightCol{
  background:rgba(0,121,121,0.06);
  border-color:rgba(0,121,121,0.18);
}

.compareTitle{
  font-size:14px;
  margin-bottom:10px;      /* 타이틀과 리스트 분리감 */
  font-weight:600;         /* 시각적 구분 강화 */
}

.compareList{
  margin:0;
  padding-left:18px;
  color:#334155;
  line-height:1.6;         /* 줄바꿈 안정 */
}
@media (min-width: 1200px){
  .impactCompare{
    padding-left:28px;
    padding-right:28px;
  }
}

@media (max-width: 900px){
  .compareGrid{
    grid-template-columns:1fr;
    gap:12px;              /* 모바일에서 카드 간격 축소 */
  }
}

}

.refThumb{width:100%;height:220px;object-fit:cover;border-radius:16px;}
.refCard{position:relative;}
.refBadge{
  position:absolute;top:12px;left:12px;
  font-size:12px;line-height:1;
  padding:6px 10px;border-radius:999px;
  background:rgba(255,255,255,0.9);
  border:1px solid rgba(0,0,0,0.08);
}
.refCard[data-badge] .refBadge::before{content:attr(data-badge);}
.refCard[data-badge] .refBadge{ }
.refCard[data-badge="우수 사례"] .refBadge{background:rgba(255,162,26,0.16);border-color:rgba(255,162,26,0.25);}
.refCard[data-badge="병원 도입"] .refBadge{background:rgba(0,121,121,0.12);border-color:rgba(0,121,121,0.22);}

.refModalPanel{max-width:960px;}
.refModalImageWrap{width:100%;border-radius:18px;overflow:hidden;border:0;background:transparent;margin-bottom:14px;}
.refModalImageWrap img{width:100%;height:auto;display:block;}

.floating-cta{
  position:fixed;right:18px;bottom:18px;z-index:999;
  background:#ffa21a;color:#fff;text-decoration:none;
  padding:14px 18px;border-radius:999px;
  box-shadow:0 14px 30px rgba(0,0,0,0.18);
  font-size:14px;
}
.floating-cta:hover{filter:brightness(0.98);}
@media (max-width: 480px){
  .floating-cta{right:14px;bottom:14px;padding:14px 16px;}
}

.trustNote{
  margin:10px auto 18px;
  max-width:920px;
  text-align:center;
  color:#334155;
  background:rgba(0,121,121,0.06);
  border:1px solid rgba(0,121,121,0.14);
  border-radius:16px;
  padding:12px 14px;
}



/* v10.1 mobile readability fixes (preserve existing structure) */
@media (max-width: 900px){
  .header{padding:16px 20px;}
}
@media (max-width: 768px){
  .header{flex-wrap:wrap;gap:16px;padding:16px 20px;}
  .nav{width:100%;order:3;display:flex;justify-content:space-between;gap:12px;border-top:1px solid var(--border);padding-top:16px;}
  .nav a{margin-left:0;font-size:14px;font-weight:600;white-space:nowrap;}
  .nav .cta{background:var(--primary);color:#fff !important;}
.hero{padding:110px 20px 80px;}
  .heroMedia{display:none;}
  .heroInner{position:relative;}
  .hero h1{font-size:38px;line-height:1.15;word-break:keep-all;letter-spacing:-0.03em;}
  .lead{font-size:16px;line-height:1.7;max-width:34em;}
  .whyCards{grid-template-columns:1fr;gap:12px;}
  .whyCard{padding:14px 14px;}
  h2{font-size:34px;line-height:1.15;word-break:keep-all;}
  .grid3{grid-template-columns:1fr;gap:16px;}
  .moduleCard,.impactCard{padding:24px;}
  .moduleHead h3{font-size:20px;word-break:keep-all;}
}
@media (max-width: 420px){
  .logo{font-size:22px;}
  .hero h1{font-size:34px;}
  .section{padding:90px 18px;}
  .contact-panel{padding:22px 16px;}
  .floating-cta{right:14px;bottom:14px;padding:12px 18px;}
}

.frailty-why{margin:60px auto;max-width:1100px;padding:0 20px}
.frailty-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-top:20px}
.fcard{background:#f3fbfb;border-radius:14px;padding:16px;font-size:15px;line-height:1.6}
@media (max-width: 768px) {
  .nav {
    display: flex;
    width: 100%;
    overflow-x: auto;
    white-space: nowrap;
    padding-bottom: 10px;
    -webkit-overflow-scrolling: touch;
    border-top: 1px solid var(--border);
    padding-top: 10px;
    order: 3;
  }
  .nav a {
    font-size: 14px;
    margin: 0 12px;
    flex: 0 0 auto;
    padding: 12px 0;
    display: inline-flex;
    align-items: center;
  }
}


/* v10.3: frailty rationale placed under Solution cards */
.frailty-why{margin:28px auto 0;max-width:1100px;padding:0 20px}
.frailty-why h3{font-size:20px;margin:0 0 10px;color:#0f2943}
.frailty-why p{margin:0 0 14px;color:#3b4b5a;line-height:1.7}
.frailty-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.fcard{background:#f3fbfb;border:1px solid rgba(10,107,107,.12);border-radius:14px;padding:14px 14px;font-size:14px;line-height:1.55;display:flex;gap:10px;align-items:flex-start}
.ficon{font-size:18px;line-height:1;margin-top:2px}
.ftitle{font-size:13px;color:#0a6b6b;margin-bottom:4px}
.fdesc{color:#1f2d3a}
@media(max-width:900px){
  .frailty-cards{grid-template-columns:1fr}
}

.frailty-wrap{background:linear-gradient(180deg,#ffffff,#f4fbfb);padding:40px 20px;border-radius:20px}


}

/* Frailty explanation block: support text only, not competing with service cards */
.frailty-why{ padding: 10px 0 0; }
.frailty-wrap{
  max-width: 1120px;
  margin: 28px auto 0;
  padding: 28px 24px;
  background: #f8fbfb;
  border-radius: 22px;
  border: 1px solid rgba(10,70,70,0.10);
}
.frailty-wrap h3{ margin: 0 0 10px; font-size: 22px; }
.frailty-lead{ margin: 0 0 18px; color: #24313a; line-height: 1.55; }
.frailty-points{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.frailty-point{
  background: rgba(255,255,255,0.75);
  border: 1px solid rgba(10,70,70,0.10);
  border-radius: 16px;
  padding: 14px 14px;
}
.frailty-point-title{ font-size: 14px; color: #0b3b3b; margin-bottom: 6px; }
.frailty-point-body{ font-size: 13px; color: #334155; line-height: 1.5; }
@media (max-width: 900px){
  .frailty-points{ grid-template-columns: 1fr; }
  .frailty-wrap{ margin-top: 18px; padding: 20px 16px; }
}

/* Floating CTA label consistency */
.floating-cta, .floating-button, .floating-contact { }


/* Hero map (Static) */
.hero{ position: relative; overflow: hidden; }
.hero-inner{ position: relative; }
.hero-map{
  position:absolute;
  right: 56px;
  top: 50%;
  transform: translateY(-50%);
  width: 360px;
  height: 260px;           /* hard cap to prevent full-screen blow-up */
  max-width: 40vw;
  max-height: 60%;
  opacity: 0.9;
  pointer-events: none;
  z-index: 0;

  overflow: hidden;}
.hero-map-img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;

}
.hero-content{ position: relative; z-index: 1; }

@media (max-width: 900px){
  .hero-map{
    position: relative;
    right:auto;
    top:auto;
    transform:none;
    margin: 22px 0 0;
    width: 260px;
    height: 200px;
    max-width: 100%;
  }
}

/* Hero map card (Leaflet + OSM) */
.hero{ position: relative; overflow: hidden; }
.heroMapWrap{
  position: relative;
  width: min(520px, 42vw);
  height: 260px;
  border-radius: 26px;
  overflow: hidden;
  background: rgba(255,255,255,0.10);
  border: 1px solid rgba(255,255,255,0.18);
  box-shadow: 0 18px 46px rgba(0,0,0,0.18);
}
#heroMap{
  position: absolute;
  inset: 0;
}
/* dim + blur outside 5km radius (within the card only) */
.heroMapMask{
  position:absolute;
  inset:0;
  z-index: 5;
  pointer-events:none;
  background: transparent;
  -webkit-mask-image: none;
  mask-image: none;
}
/* A dedicated blurred tile pane for the outside-of-5km area.
   This avoids using backdrop-filter (which can rasterize the whole map at low resolution
   on some browsers) while keeping inside-the-radius tiles crisp. */
.heroMap .leaflet-blurPane-pane{
  filter: none;
  -webkit-mask-image: none;
  mask-image: none;
}
@media (max-width: 900px){
  .heroMapWrap{ width: 100%; height: 220px; border-radius: 22px; }
}

/* Leaflet tile softening to match existing hero vibe */
/* keep map legible; avoid over-softening tiles (users perceived this as low-res) */
.leaflet-tile{ filter: none; }

/* UI controls styled to blend with current hero */
.hero-map-ui{ margin-top: 14px; }
.hero-map-ui-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
}
.hero-map-ui-sep{
  font-size: 13px;
  color: rgba(255,255,255,0.85);
}
.hero-map-input{
  min-width: 240px;
  max-width: 420px;
  flex: 1 1 260px;
  height: 40px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.35);
  background: rgba(255,255,255,0.12);
  color: #fff;
  outline: none;
}
.hero-map-input::placeholder{ color: rgba(255,255,255,0.72); }
.hero-map-hint{
  margin-top: 8px;
  font-size: 12px;
  color: rgba(255,255,255,0.80);
}
@media (max-width: 768px){
  .hero-map-input{ min-width: 180px; }
}


/* Hero map legend (distance guide) */
.heroMapLegend{
  position:absolute;
  left:14px;
  top:14px;
  z-index: 800; /* above tiles, below zoom ok */
  display:flex;
  flex-direction:column;
  gap:6px;
  padding:10px 12px;
  border-radius:14px;
  background: rgba(255,255,255,0.88);
  border: 1px solid rgba(0,0,0,0.08);
  box-shadow: 0 10px 26px rgba(0,0,0,0.12);
  font-size:12px;
  color:#0f172a;
}
.heroMapLegendRow{display:flex;align-items:center;gap:8px;white-space:nowrap;}
.heroMapLegendSwatch{width:18px;height:10px;border-radius:999px;border:2px solid #ff9f1c;background:transparent;}
.heroMapLegendSwatch.outer{border-width:2px;opacity:0.55;}
.heroMapLegendSwatch.inner{border-width:3px;opacity:0.95;}


/* ---------- Content pages (v10.2 content-only) ---------- */
.moduleLink{display:block;color:inherit;text-decoration:none;}
.moduleLink:hover{transform:translateY(-2px);box-shadow:0 26px 55px rgba(0,109,119,0.12);}
.moduleLink:focus{outline:3px solid rgba(255,159,28,0.35);outline-offset:4px;}

.page{padding:56px 40px 80px;background:var(--bg);}
.pageInner{max-width:980px;margin:0 auto;}
.backLink{display:inline-flex;align-items:center;gap:8px;color:var(--primary);text-decoration:none;font-weight:700;margin:6px 0 18px;}
.pageTitle h1{margin:8px 0 6px;font-size:40px;font-weight:900;color:var(--primary);}
.pageSubtitle{margin:0 0 28px;color:rgba(29,53,87,0.7);font-size:16px;line-height:1.6;}

.contentBlock{background:#fff;border:1px solid var(--border);border-radius:16px;padding:22px 22px;margin:16px 0;box-shadow:var(--shadow);}
.contentBlock h2{margin:0 0 10px;font-size:22px;}
.contentBlock h3{margin:14px 0 8px;font-size:18px;color:var(--primary);}
.contentBlock p{margin:10px 0;line-height:1.75;}
.contentBlock ul,.contentBlock ol{margin:10px 0 0 18px;line-height:1.75;}
.contentBlock li{margin:6px 0;}
.callout{border-left:6px solid var(--secondary);}

.kvGrid{display:grid;grid-template-columns:1fr;gap:10px;margin-top:8px;}
.kv{display:grid;grid-template-columns:160px 1fr;gap:14px;padding:12px 12px;border-radius:12px;background:rgba(0,109,119,0.04);border:1px solid rgba(0,109,119,0.10);}
.k{color:rgba(29,53,87,0.75);font-weight:800;}
.v{color:var(--text);}

.twoCol{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.panel{background:rgba(248,250,252,0.9);border:1px solid rgba(0,0,0,0.06);border-radius:14px;padding:14px 14px;}
.steps{padding-left:18px;}

@media (max-width:820px){
  .pageTitle h1{font-size:32px;}
  .kv{grid-template-columns:1fr;gap:6px;}
  .twoCol{grid-template-columns:1fr;}
}


/* Link cards: clearer affordance */
.moduleLink{position:relative;display:block;color:inherit;text-decoration:none;}
.moduleLink:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(0,0,0,0.10);}
.moduleLink:focus-visible{outline:3px solid rgba(0,150,136,0.35);outline-offset:4px;}
.moduleLink::after{
  content:"자세히 보기 →";
  position:absolute;
  top:14px;
  right:14px;
  font-size:12px;
  padding:6px 10px;
  border-radius:999px;
  background:rgba(0,150,136,0.10);
  border:1px solid rgba(0,150,136,0.25);
}


/* Check-up page media */
.mediaStack{display:grid;gap:16px;margin-top:14px;}
.mediaFigure{margin:0;padding:0;border:1px solid var(--border);background:#fff;border-radius:16px;overflow:hidden;box-shadow:var(--shadow);}
.mediaFigure img{display:block;width:100%;height:auto;}

.subTitle{margin:18px 0 10px 0;font-size:18px;font-weight:900;letter-spacing:-0.02em;}
.galleryGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:10px;}
.galleryGrid.single{grid-template-columns:1fr;}
.galleryItem{margin:0;border:1px solid var(--border);background:#fff;border-radius:16px;overflow:hidden;box-shadow:var(--shadow);}
.galleryItem img{display:block;width:100%;height:auto;}
@media (max-width: 820px){
  .galleryGrid{grid-template-columns:1fr;}
}


/* --- Community Cases (interactive cards + modal) --- */
.caseCardGrid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  margin-top: 14px;
}
@media (max-width: 980px){
  .caseCardGrid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px){
  .caseCardGrid{ grid-template-columns: 1fr; }
}

.caseCard{
  display:flex;
  flex-direction:column;
  gap: 12px;
  width:100%;
  text-align:left;
  border: 1px solid rgba(15, 23, 42, 0.10);
  background: #fff;
  border-radius: 16px;
  padding: 14px;
  box-shadow: 0 10px 24px rgba(2, 6, 23, 0.06);
  transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
  cursor:pointer;
  position:relative;
}
.caseCard img{
  width:100%;
  height: 160px;
  object-fit: cover;
  border-radius: 12px;
  background: #f1f5f9;
}
.caseMeta h3{
  margin:0;
  font-size: 16px;
}
.caseMeta p{
  margin: 6px 0 0 0;
  color: rgba(15, 23, 42, 0.78);
  font-size: 13px;
  line-height: 1.45;
}
.caseCta{
  display:inline-block;
  margin-top: 10px;
  font-size: 12px;
  color: rgba(2, 132, 199, 0.95);
}

.caseCard:hover{
  transform: translateY(-2px);
  box-shadow: 0 16px 34px rgba(2, 6, 23, 0.10);
  border-color: rgba(2, 132, 199, 0.25);
}
.caseCard:focus-visible{
  outline: 3px solid rgba(2, 132, 199, 0.35);
  outline-offset: 3px;
}

/* Modal */
html.modalOpen, html.modalOpen body{
  overflow:hidden;
}
.caseModal{
  position: fixed;
  inset: 0;
  z-index: 9999;
}
.caseModalOverlay{
  position:absolute;
  inset:0;
  background: rgba(2, 6, 23, 0.55);
}
.caseModalPanel{
  position: relative;
  width: min(920px, calc(100% - 28px));
  max-height: calc(100% - 28px);
  margin: 14px auto;
  background: #fff;
  border-radius: 18px;
  border: 1px solid rgba(15, 23, 42, 0.12);
  box-shadow: 0 18px 60px rgba(2, 6, 23, 0.28);
  padding: 18px;
  overflow:auto;
}
.caseModalPanel h3{
  margin: 2px 36px 12px 2px;
  font-size: 18px;
}
.caseModalClose{
  position:absolute;
  top: 10px;
  right: 12px;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  border: 1px solid rgba(15, 23, 42, 0.14);
  background: #fff;
  font-size: 20px;
  line-height: 32px;
  cursor: pointer;
}
.caseModalBody img{
  width:100%;
  height:auto;
  border-radius: 14px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: #f8fafc;
}
.caseText{
  margin: 14px 4px 0 4px;
  color: rgba(15, 23, 42, 0.86);
  line-height: 1.6;
}
.caseLink{
  margin: 10px 4px 0 4px;
}
.caseLink a{
  color: rgba(2, 132, 199, 0.95);
  text-decoration: none;
}
.caseLink a:hover{
  text-decoration: underline;
}


/* Reference modal image quality */
.refModalImg{width:100%;height:auto;max-height:78vh;object-fit:contain;border-radius:14px;background:#fff;}


/* Checkup detail page layout tweaks (do not affect map) */
.checkupPage .contentWrap{max-width:1080px;margin:0 auto;}
.checkupPage .contentBlock{margin-left:auto;margin-right:auto;}
.checkupPage .whyBodyAgeFigure{max-width:900px;margin:28px auto 0;display:block;}
.checkupPage .whyBodyAgeFigure img{width:100%;height:auto;display:block;border-radius:16px;}

/* Checkup event page tweaks: center and scale the bottom visual section */
.checkupPage .contentBlock{max-width:1100px;margin:0 auto;}
.checkupPage .mediaStack{justify-content:center;gap:22px;flex-wrap:wrap;}
.checkupPage .mediaFigure{max-width:420px;}
.checkupPage .mediaFigure svg{width:100%;height:auto;display:block;}

@media(max-width:700px){
  .checkupPage .mediaFigure{max-width:320px;}
}
.impactNum {
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 800;
}

.impactArrow {
  font-size: 26px;
  animation: arrowBounce 1.4s infinite;
}

.impactArrow.up {
  color: #ff9f1c;
}

.impactArrow.down {
  color: #1c6cff;
  animation-direction: reverse;
}

@keyframes arrowBounce {
  0% { transform: translateY(0); }
  50% { transform: translateY(-6px); }
  100% { transform: translateY(0); }
}
/* 숫자 옆에 화살표 하나만 표시 */
.impactNum::after {
  content: " ▲";
  font-size: 28px;
  font-weight: 900;
  margin-left: 6px;
  animation: arrowUp 1.2s ease-in-out infinite alternate;
  color: #ff9f1c;
}

/* 두 번째 카드(마케팅 비용 절감)는 ↓ */
.impactCard:last-child .impactNum::after {
  content: " ▼";
  color: #2f80ed;
  animation: arrowDown 1.2s ease-in-out infinite alternate;
}

@keyframes arrowUp {
  from { transform: translateY(6px); opacity: 0.6; }
  to   { transform: translateY(-6px); opacity: 1; }
}

@keyframes arrowDown {
  from { transform: translateY(-6px); opacity: 0.6; }
  to   { transform: translateY(6px); opacity: 1; }
}


.impactLabel {
  font-size: 26px;
  font-weight: 900;
  color: #022f2f;
  letter-spacing: -0.4px;
  margin-bottom: 6px;
    line-height: 1.3;
}

.impactNum {
  margin-top: 6px;
}


/* v11 mobile-first layout fixes (do not change map behavior/UI) */
@media (max-width: 768px){
  /* Stack hero content to prevent map cropping and improve readability */
  .heroInner{flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:22px;}
  .heroLeft{max-width:100%;}
  .heroRight{flex:0 0 auto;width:100%;justify-content:flex-start;}
  .heroMapWrap{height:240px;} /* slightly taller for legend + circles */
  /* Keep content accessible under the floating CTA on small screens */
  body{padding-bottom:96px;}
  .floating-cta{bottom:max(14px, env(safe-area-inset-bottom));}
  /* Move "자세히 보기 →" badge away from the title area */
  .moduleLink{padding-bottom:56px;}
  .moduleLink::after{top:auto;bottom:14px;}
}
@media (max-width: 420px){
  body{padding-bottom:104px;}
  .heroMapWrap{height:250px;}
  .moduleLink{padding-bottom:60px;}
}

@media (max-width: 768px) {

/* 1. Hero 영역 구조 재정렬 – 지도 잘림 해결 */
.heroInner {
flex-direction: column;
align-items: stretch;
gap: 24px;
}

.heroCopy {
max-width: 100%;
}

.heroMapWrap {
width: 100%;
height: 280px;
margin-top: 8px;
}

/* 2. Solution 카드 제목 + ‘자세히 보기’ 겹침 제거 */
.moduleLink::after {
position: static;
display: inline-block;
margin-top: 12px;
float: right;
}

.moduleHead {
padding-right: 0 !important;
}

/* 3. 플로팅 CTA 버튼이 폼 / ROI / 푸터 가리지 않도록 */
body {
padding-bottom: 120px;
}

.floating-cta {
bottom: calc(16px + env(safe-area-inset-bottom));
}

/* 4. ROI 카드 모바일 1열 정렬 */
.roiGrid {
grid-template-columns: 1fr;
gap: 16px;
}

/* 5. Contact 폼 하단 여백 확보 */
.contactCard {
margin-bottom: 40px;
}

/* 6. 섹션 상단 텍스트 잘림 방지 */
.section {
padding-top: 48px;
}

}
.caseCard.caseTextOnly{
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:28px;
}

/* Text-only cards become standard cards when a representative thumbnail is present */
#communityCases .caseCard.caseTextOnly.caseWithThumb{
  align-items: stretch;
  justify-content: flex-start;
  text-align: left;
  padding: 14px;
  gap: 12px;
}

.caseCard.caseTextOnly h3{
  margin:0;
}


/* Case modal carousel (scoped to modal only) */
.caseModal .caseModalBody.caseCarousel {
  position: relative;
  overflow: hidden;
  max-height: 78vh;
}

.caseModal .caseCarouselTrack {
  display: flex;
  width: 100%;
  transition: transform 240ms ease;
  will-change: transform;
}

.caseModal .caseCarouselSlide {
  flex: 0 0 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 8px 0;
}

.caseModal .caseCarouselSlide img {
  max-height: 72vh;
  width: 100%;
  height: auto;
  object-fit: contain;
  display: block;
}

.caseModal .caseCarouselNav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  border: 0;
  background: rgba(0,0,0,0.35);
  color: #fff;
  width: 36px;
  height: 36px;
  border-radius: 999px;
  cursor: pointer;
  z-index: 2;
}

.caseModal .caseCarouselNav:disabled {
  opacity: 0.25;
  cursor: default;
}

.caseModal .caseCarouselPrev { left: 10px; }
.caseModal .caseCarouselNext { right: 10px; }

.caseModal .caseCarouselDots {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 10px;
  display: flex;
  gap: 6px;
  justify-content: center;
  z-index: 2;
}

.caseModal .caseCarouselDot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  border: 0;
  background: rgba(255,255,255,0.45);
  cursor: pointer;
  padding: 0;
}

.caseModal .caseCarouselDot[aria-current="true"] {
  background: rgba(255,255,255,0.9);
}

/* ================================
   mediaReferences (FINAL FIX)
   - 기사 제목 줄바꿈 방지 + 말줄임 처리
================================ */

#mediaReferences{
  margin-top: 26px;
}

#mediaReferences .mediaGroup{
  margin-top: 18px;
}

#mediaReferences .mediaGroupTitle{
  margin: 0 0 10px 0;
  font-size: 1.05em;
}

/* Grid for video/blog */
#mediaReferences .mediaGrid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
@media (max-width: 900px){
  #mediaReferences .mediaGrid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 520px){
  #mediaReferences .mediaGrid{ grid-template-columns: 1fr; }
}

/* Card common */
#mediaReferences .mediaCard{
  display: flex;
  flex-direction: column;
  text-decoration: none;
  border-radius: 14px;
  overflow: hidden;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.10);
}

/* Thumbnail */
#mediaReferences .mediaThumb{
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: rgba(255,255,255,0.06);
  display: grid;
  place-items: center;
}
#mediaReferences .mediaThumb img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Video title overlay */
#mediaReferences .mediaCardVideo .mediaThumbTitle{
  position: absolute;
  left: 10px;
  right: 10px;
  top: 10px;
  padding: 8px 10px;
  border-radius: 10px;
  background: rgba(0,0,0,0.55);
  color: #fff;
  font-size: 0.98em;
  line-height: 1.25;
}

/* Hide meta for video */
#mediaReferences .mediaCardVideo .mediaMeta{
  display: none;
}

/* Blog image vertical center */
#mediaReferences .mediaCardBlog .mediaThumb img{
  object-fit: contain;
  object-position: center center;
}

/* Blog meta */
#mediaReferences .mediaMeta{
  padding: 12px 12px 14px 12px;
  display: grid;
  gap: 6px;
}
#mediaReferences .mediaTitle{
  font-size: 1.0em;
  line-height: 1.35;
}

/* Articles list */
#mediaReferences .mediaList{
  margin-top: 6px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

#mediaReferences .mediaRow{
  display: block;
  text-decoration: none;
}

/* mediaReferences: Articles = full text + natural wrap */
#mediaReferences .mediaList{
  display: flex;
  flex-direction: column;
  gap: 10px;          /* 항목 사이 간격 */
  margin-top: 6px;
}

#mediaReferences .mediaRow{
  display: inline;    /* 문장처럼 보이게 */
  padding: 0;
  margin: 0;
  border: 0;
  background: transparent;
  text-decoration: none;
}

#mediaReferences .mediaRowTitle{
  display: inline;
  white-space: normal;     /* 핵심: 자연 줄바꿈 */
  overflow: visible;       /* 핵심 */
  text-overflow: clip;     /* 핵심 */
  line-height: 1.55;
  word-break: keep-all;    /* 한글 단어 단위 줄바꿈 */
}
/* 기사 섹션은 영상 아래에서 전체 폭 사용 */
#mediaReferences .mediaGroupArticles{
  grid-column: 1 / -1; /* 혹시 상위가 grid여도 강제로 전체폭 */
  width: 100%;
  margin-top: 22px;
}

/* 기사 링크: 풀 텍스트 + 자연 줄바꿈 */
#mediaReferences .mediaRowTitle{
  display: inline;
  white-space: normal;      /* 줄바꿈 허용 */
  word-break: keep-all;     /* 한글 단어 중간 끊김 최소화 */
  overflow-wrap: anywhere;  /* 아주 긴 영문/URL이 있으면 안전하게 줄바꿈 */
  line-height: 1.6;
}

/* 기사 리스트: “우측 칼럼 느낌” 없애기 */
#mediaReferences .mediaList{
  display: flex;
  flex-direction: column;
  gap: 12px;
}
/* 블로그 카드도 영상과 동일하게 타이틀 오버레이 허용 */
#mediaReferences .mediaCardOverlay .mediaThumbTitle{
  position: absolute;
  inset: auto 10px 10px 10px;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(0,0,0,0.6);
  color: #fff;
  font-size: 0.95em;
  line-height: 1.35;
  word-break: keep-all;
}

/* 블로그 썸네일은 세로 이미지 대응 */
#mediaReferences .mediaCardBlog .mediaThumb img{
  object-fit: cover;
}

/* Contact container responsive */
@media (max-width:768px){
  
  .sectionHeadLeft{max-width:100%;padding:0 16px;}
  .policyCard{max-width:100%;margin:0 auto;}
}


/* Mobile touch target spacing (Micro-Spacing UI) */
@media (max-width: 768px){
  .footer-simple{gap:12px;}
  .footer-links a{padding:6px 0;display:inline-block;}
  .floating-cta{
    bottom: calc(16px + env(safe-area-inset-bottom));
  }
}

/* Respect reduced motion preferences (Accessibility UX) */
@media (prefers-reduced-motion: reduce) {
  .impactArrow, .logo-frailty, .impactViz::before{
    animation: none !important;
    transition: none !important;
    width: 70%;
  }
}

/* Mobile nav scroll affordance */
@media (max-width: 768px){
  nav{
    padding-right:20px;
  }
}
/* Module card active feedback on touch */
.moduleCard:active{
  filter: brightness(0.97);
}


/* Sub-page bottom CTA (no inline styles) */
.ctaSectionBottom{
  text-align:center;
  padding:40px 20px;
}
.ctaSectionBottom .ctaLead{
  margin:0 0 24px;
}
.ctaSectionBottom .cta-submit{
  display:inline-block;
  width:auto;
  padding:14px 32px;
  text-decoration:none;
}
.ctaSectionBottom .ctaHint{
  margin:16px 0 0;
  font-size:14px;
  color:var(--inkMuted);
}
.ctaSectionBottom .emailLink{
  color:var(--primary);
}
@media (max-width: 768px){
  .ctaSectionBottom{ padding:32px 16px; }
  .ctaSectionBottom .cta-submit{ width:100%; max-width:420px; }
}

@media (max-width: 768px){
  .refModalClose{
    right:14px;
    top:14px;
    width:46px;
    height:46px;
    font-size:24px;
    line-height:44px;
  }
  .caseModalClose{
    right:14px;
    top:14px;
    width:44px;
    height:44px;
    font-size:24px;
    line-height:42px;
  }
}
/* --- impactCompare: 카드 대조 레이아웃 (기존 구조 유지, 디자인만 개선) --- */
.impactCompare .compareHead{
  text-align: center;
  margin-bottom: 28px;
}
.impactCompare .compareHead h3{
  font-size: 2rem;
  margin: 0 0 10px;
  color: #222;
  line-height: 1.2;
}
.impactCompare .compareHead .highlight-text{
  color: #006D77;
}
.impactCompare .compareHead .compare-sub{
  color: #666;
  font-size: 1rem;
  margin: 0;
}

/* 그리드 레이아웃 */
.impactCompare .compareGrid.new-layout{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 30px;
  margin-top: 18px;
}

/* 카드 공통 */
.impactCompare .compareCard{
  background: #fff;
  padding: 30px;
  border-radius: 16px;
  box-shadow: 0 4px 15px rgba(0,0,0,0.05);
  text-align: left;
}
.impactCompare .compareCard .cardHeader{
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: 18px;
  margin-bottom: 18px;
  border-bottom: 1px solid #eee;
}
.impactCompare .compareCard h4{
  font-size: 1.25rem;
  margin: 0;
  font-weight: 700;
}
.impactCompare .compareCard .badge{
  font-size: 0.8rem;
  padding: 4px 10px;
  border-radius: 999px;
  font-weight: 600;
}

/* 리스트 */
.impactCompare .compareCard .compareList{
  list-style: none;
  padding: 0;
  margin: 0;
}
.impactCompare .compareCard .compareList li{
  display: flex;
  align-items: flex-start;
  gap: 14px;
  margin-bottom: 18px;
}
.impactCompare .compareCard .compareList li:last-child{
  margin-bottom: 0;
}
.impactCompare .compareCard .icon{
  font-size: 1.5rem;
  line-height: 1;
  flex: 0 0 auto;
  margin-top: 2px;
}
.impactCompare .compareCard .text .itemTitle{
  display: block;
  font-size: 1.05rem;
  color: #333;
  margin-bottom: 4px;
  font-weight: 650;
}
.impactCompare .compareCard .text p{
  font-size: 0.92rem;
  color: #777;
  margin: 0;
  line-height: 1.4;
}

/* 왼쪽: 기존 방식 */
.impactCompare .old-way{
  background-color: #f8f9fa;
  border: 1px solid #e9ecef;
}
.impactCompare .old-way h4{ color: #555; }
.impactCompare .old-way .badge.bad{
  background: #e9ecef;
  color: #666;
}
.impactCompare .old-way .icon{ opacity: 0.8; }

/* 오른쪽: NOFRAILTY 방식 강조 */
.impactCompare .new-way{
  border: 2px solid #006D77;
  background-color: #fff;
  transform: translateY(-5px);
  box-shadow: 0 10px 30px rgba(0, 109, 119, 0.15);
  position: relative;
  z-index: 2;
}
.impactCompare .new-way h4{ color: #006D77; }
.impactCompare .new-way .badge.good{
  background: #E0F7FA;
  color: #006064;
}

/* 모바일 */
@media (max-width: 768px){
  .impactCompare .compareGrid.new-layout{
    grid-template-columns: 1fr;
  }
  .impactCompare .new-way{
    transform: none;
    margin-top: 10px;
  }
}
