@font-face{font-family:'S-CoreDream';font-weight:300;src:url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_six@1.2/S-CoreDream-3Light.woff') format('woff')}
@font-face{font-family:'S-CoreDream';font-weight:400;src:url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_six@1.2/S-CoreDream-4Regular.woff') format('woff')}
@font-face{font-family:'S-CoreDream';font-weight:500;src:url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_six@1.2/S-CoreDream-5Medium.woff') format('woff')}
@font-face{font-family:'S-CoreDream';font-weight:600;src:url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_six@1.2/S-CoreDream-6Bold.woff') format('woff')}
@font-face{font-family:'S-CoreDream';font-weight:700;src:url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_six@1.2/S-CoreDream-7ExtraBold.woff') format('woff')}
@font-face{font-family:'S-CoreDream';font-weight:800;src:url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_six@1.2/S-CoreDream-8Heavy.woff') format('woff')}
@font-face{font-family:'S-CoreDream';font-weight:900;src:url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_six@1.2/S-CoreDream-9Black.woff') format('woff')}


/* ═══════════ ROOT ═══════════ */
:root{
  --red:#d63031;--rl:#e55e5e;--rd:#a52020;
  --nv:#12203e;--nv2:#1d3060;--bg:#0d1929;
  --tx:#2e2e2e;--ts:#777;--tl:#aaa;
  --bd:#e4e4e4;--lt:#f2f2f2;--off:#f9f9f9;
  --r:8px;
  --sh:0 16px 56px rgba(0,0,0,.1);
  --sc:0 4px 24px rgba(0,0,0,.07);
  --tr:all .3s cubic-bezier(.4,0,.2,1);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:'S-CoreDream','Montserrat', 'Noto Sans KR', sans-serif;color:var(--tx);background:#fff;overflow-x:hidden;line-height:1.7}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}

/* ═══════════ UTILS ═══════════ */
.inn{max-width:1200px;margin:0 auto;padding:0 5%}
.lbl{font-size:.63rem;font-weight:700;letter-spacing:.25em;color:var(--red);text-transform:uppercase;margin-bottom:.9rem;display:block}
.ttl{font-size:clamp(1.75rem,3.5vw,2.6rem);font-weight:800;line-height:1.17;color:var(--tx);letter-spacing:-.02em;margin-bottom:1.75rem}
.ttl.wh{color:#fff}
.sub{font-size:.9rem;font-weight:300;color:var(--ts);line-height:1.95;max-width:560px}
.sub.wh{color:rgba(255,255,255,.6)}

/* ═══════════ 전화 팝업 ═══════════ */
#telPopupOverlay{
  position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:8000;
  animation:fadeIn .2s ease;
}
#telPopupBox{
  position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);
  z-index:8001;width:340px;border-radius:6px;overflow:hidden;
  box-shadow:0 16px 56px rgba(0,0,0,.25);
  animation:popUp .22s cubic-bezier(.4,0,.2,1);
}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes popUp{from{opacity:0;transform:translate(-50%,-48%) scale(.96)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}
#telPopupHeader{
  background:#e8a020;display:flex;align-items:center;
  justify-content:space-between;padding:14px 20px;
}
#telPopupHeader span{font-size:1rem;font-weight:700;color:#fff;letter-spacing:.04em}
#telPopupClose{
  background:none;border:none;color:#fff;font-size:1.1rem;
  cursor:pointer;padding:2px 6px;line-height:1;opacity:.85;transition:opacity .15s;
}
#telPopupClose:hover{opacity:1}
#telPopupBody{background:#fff;padding:24px 20px 20px}
.tel-popup-name{
  background:#f5f5f5;border-radius:4px;padding:12px 16px;
  font-size:.9rem;font-weight:700;color:#222;margin-bottom:16px;
}
.tel-popup-row{
  display:flex;align-items:center;gap:10px;
  padding:11px 0;border-bottom:1px solid #eee;
}
.tel-popup-row:last-of-type{border-bottom:none}
.tel-popup-icon svg{width:18px;height:18px;display:block}
.tel-popup-label{
  font-size:.78rem;font-weight:600;color:#888;
  letter-spacing:.08em;width:36px;flex-shrink:0;
}
.tel-popup-num{
  font-size:1rem;font-weight:700;color:#1a1a1a;
  margin-left:auto;letter-spacing:.04em;text-decoration:none;
}
a.tel-popup-num:hover{color:#e8a020;text-decoration:underline}
.tel-popup-hours{
  margin-top:14px;padding-top:14px;border-top:1px solid #eee;
  font-size:.8rem;font-weight:300;color:#888;line-height:1.9;text-align:center;
}

/* ═══════════ CURSOR / INTERACTION ═══════════ */
a, button, [role="button"],
.pfa, .pfd, .stab, .ht-tab, .ht-step, .ht-prog-dot,
.ht-mode-item, .fqq, .sp-tab, .fab, .target-card,
.bred, .bgho, .bwh, .bwho, .output-card, .sp-card,
.ht-cert-card, .bi, .principle-card {
  cursor: pointer;
}
a { text-decoration: none; color: inherit; }
a:hover { text-decoration: underline; text-underline-offset: 3px; }
.nmenu a:hover, .mnav a:hover, .flogo a:hover,
.ht-cert-links a:hover, footer a:hover { text-decoration: underline; }
.bred:hover, .bgho:hover, .bwh:hover, .bwho:hover,
.pfa:hover, .stab:hover, .ht-tab:hover,
.sp-tab:hover, .fab:hover { cursor: pointer; }
.rv       {opacity:0;transform:translateY(32px);transition:opacity .75s ease,transform .75s ease}
.rv-l     {opacity:0;transform:translateX(-40px);transition:opacity .75s ease,transform .75s ease}
.rv-r     {opacity:0;transform:translateX(40px);transition:opacity .75s ease,transform .75s ease}
.rv-s     {opacity:0;transform:scale(.94);transition:opacity .75s ease,transform .75s ease}
.rv.on,.rv-l.on,.rv-r.on,.rv-s.on{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}

/* ═══════════ NAV ═══════════ */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:2000;
  height:68px;display:flex;align-items:center;justify-content:space-between;
  padding:0 5%;background:rgba(255,255,255,.96);
  backdrop-filter:blur(14px);border-bottom:1px solid var(--bd);transition:var(--tr);
}
#nav.sc{box-shadow:0 4px 28px rgba(0,0,0,.07)}
.nlogo{font-family:'Montserrat',sans-serif;font-size:1.32rem;font-weight:900;letter-spacing:.14em;color:var(--tx);flex-shrink:0}
.nlogo em{color:var(--red);font-style:normal}
.nmenu{display:flex;align-items:center;gap:.3rem}
.nmenu a{
  position:relative;font-size:.98rem;font-weight:600;letter-spacing:.04em;
  color:var(--ts);padding:7px 14px;border-radius:100px;
  transition:color .22s,background .22s;white-space:nowrap;
}
.nmenu a::before{
  content:'';position:absolute;inset:0;border-radius:100px;
  background:#2b506d;opacity:0;transform:scale(.85);
  transition:opacity .22s,transform .22s;
}
.nmenu a:hover::before{opacity:1;transform:scale(1)}
.nmenu a:hover{color:#ffffff}
.nmenu a span{position:relative;z-index:1}
.nmenu a.act{color:var(--red)}
.nmenu a.act::before{opacity:1;transform:scale(1);background:rgba(214,48,49,.08)}
.hbg{display:none;flex-direction:column;gap:5px;padding:4px}
.hbg span{display:block;width:22px;height:2px;background:var(--tx);border-radius:2px;transition:var(--tr)}
.mnav{
  display:none;position:fixed;top:68px;left:0;right:0;z-index:1900;
  background:#fff;border-bottom:1px solid var(--bd);
  padding:1rem 5%;flex-direction:column;gap:.1rem;
  box-shadow:0 16px 32px rgba(0,0,0,.08);
}
.mnav a{display:block;padding:.8rem 1rem;font-size:.88rem;font-weight:600;color:var(--tx);border-radius:var(--r);transition:background .18s,color .18s}
.mnav a:hover{background:var(--lt);color:var(--red)}
.mnav.open{display:flex}

/* ═══════════ HERO ═══════════ */
#hero{
  min-height:750px;padding-top:68px;
  background-image: url('img/carerush_main.jpg');
  background-repeat: no-repeat;
  background-size:cover;
  background-position: center top; /* 이미지를 중앙 정렬 */
  display:flex;align-items:center;position:relative;overflow:hidden;
}
/* 배경 파티클 */
.hblob{position:absolute;border-radius:50%;pointer-events:none;animation:blobFloat 8s ease-in-out infinite}
.hblob.a{width:520px;height:520px;top:-120px;left:-80px;background:radial-gradient(circle,rgba(214,48,49,.06) 0%,transparent 65%);animation-duration:10s}
.hblob.b{width:380px;height:380px;bottom:-100px;right:5%;background:radial-gradient(circle,rgba(214,48,49,.07) 0%,transparent 60%);animation-duration:7s;animation-delay:-3s}
.hp{position:absolute;border-radius:50%;pointer-events:none;animation:float var(--dur,6s) ease-in-out infinite var(--del,0s)}
.hp1{width:8px;height:8px;background:rgba(214,48,49,.35);top:18%;left:14%;--dur:5s;--del:0s}
.hp2{width:5px;height:5px;background:rgba(214,48,49,.25);top:68%;left:8%;--dur:7s;--del:1s}
.hp3{width:10px;height:10px;background:rgba(214,48,49,.2);top:30%;right:18%;--dur:6s;--del:.5s}
.hp4{width:6px;height:6px;background:rgba(214,48,49,.3);top:72%;right:25%;--dur:8s;--del:1.5s}
.hp5{width:4px;height:4px;background:rgba(214,48,49,.22);top:50%;left:30%;--dur:9s;--del:.8s}
@keyframes blobFloat{0%,100%{transform:scale(1) translate(0,0)}50%{transform:scale(1.06) translate(12px,-16px)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}

.hin{
  display:flex;align-items:center;justify-content:space-between;
  width:100%;max-width:1300px;margin:0 auto;padding:0 5%;
  min-height:680px;position:relative;gap:4rem;
  box-sizing:border-box;
}
/* 좌측: 제품 이미지 */
.hvis{
  flex:0 0 48%;display:flex;align-items:center;justify-content:center;
  position:relative;
}
.hpwrap{
  width:100%;max-width:540px;aspect-ratio:1/1;
  background:linear-gradient(145deg,#f8f6f4,#f0ece8);
  border-radius:32px;
  display:flex;align-items:center;justify-content:center;position:relative;
  box-shadow:0 32px 80px rgba(214,48,49,.08),0 8px 24px rgba(0,0,0,.06);
}
/* 카드 내 배경 글로우 */
.hpwrap::before{
  content:'';position:absolute;inset:0;border-radius:32px;
  background:radial-gradient(ellipse at 55% 45%,rgba(214,48,49,.1) 0%,transparent 60%);
  pointer-events:none;
}
.hpbg,.hpglow,.hring{display:none}
.hsvg-main{
  width:72%;height:auto;
  filter:drop-shadow(8px 16px 32px rgba(180,60,30,.18));
  position:relative;z-index:2;
  animation:heroFloat 5s ease-in-out infinite;
}
@keyframes heroFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

/* 우측: 텍스트 */
.hcopy{flex:1;text-align:right;padding:0}

/* 태그 */
.htag{
  display:block;font-size:1.35rem;font-weight:500;letter-spacing:.1em;
  color:#8a7060;margin-bottom:1rem;animation:fU .5s ease both;
  border:none;padding:0;border-radius:0;background:none;
}



/* ── 히어로 텍스트 리뉴얼 ── */
.hline1, .hline2 {
  font-size: clamp(1.6rem, 3.2vw, 2.6rem);
  font-weight: 700;
  color: #fff;
  letter-spacing: .04em;
  line-height: 1.4;
  margin: 0 0 .3rem;
  text-shadow: 0 2px 12px rgba(0,0,0,.35);
  animation: fU .55s ease both;
}
.hline2 { animation-delay: .08s; }

.hdot {
  font-size: .6em;
  vertical-align: middle;
  margin: 0 .2em;
  color: #fff;
}

.hred {
  color: #e53935;
  font-weight: 800;
}

.hbrand {
  font-family: 'S-CoreDream', sans-serif;
  font-size: clamp(3.2rem, 7vw, 5.5rem);
  font-weight: 900;
  color: #2ec4b6;          /* 민트/그린 */
  letter-spacing: .02em;
  line-height: 1.1;
  margin: .4rem 0 1.4rem;
  text-shadow: 0 3px 16px rgba(0,0,0,.3);
  animation: fU .55s .14s ease both;
}

/* 기존 htag, hent, hkr 숨김 */
.htag, .hkr, .hdesc { display: none; }

@media(max-width:767px) {
  .hline1, .hline2 { font-size: clamp(1.1rem, 5vw, 1.6rem); }
  .hbrand { font-size: clamp(2.2rem, 10vw, 3.4rem); }
}


/* 대형 제목 */
.hent{
  font-family:'S-CoreDream',sans-serif;
  font-size:clamp(2.8rem,5vw,4.4rem);font-weight:900;
  line-height:1.05;letter-spacing:-.02em;color:#1a1410;
  animation:fU .55s .07s ease both;margin-bottom:.6rem;
}
.hent em{color:var(--red);font-style:normal}

/* 한글 서브타이틀 */
.hkr{
  display:block;font-size:1.5rem;font-weight:300;
  color:#666;letter-spacing:.04em;
  margin:.4rem 0 1.8rem;animation:fU .55s .12s ease both;
}

/* 설명 */
.hdesc{display:none}

/* 버튼 그룹 */
.hbtns{display:contents;gap:1rem;flex-wrap:wrap;justify-content:flex-start;animation:fU .55s .2s ease both;margin-bottom:0}

/* 상담 버튼 - 빨간 채움 */
.bred{
  background:var(--red);color:#fff;font-size:1.24rem;font-weight:700;
  padding:15px 34px;border-radius:var(--r);border:2px solid var(--red);
  transition:var(--tr);letter-spacing:.04em;
  display:inline-flex;align-items:center;gap:0;
}
.bred::after{content:none}
.bred:hover{background:var(--rd);border-color:var(--rd);transform:translateY(-2px);box-shadow:0 8px 24px rgba(214,48,49,.32);text-decoration:none}

/* 통계 숨김 */
.hstats{display:none}
.bgho{display:none}

/* 스크롤 인디케이터 - 빨간 점 */
.scroll-indicator{
  position:absolute;bottom:3.5rem;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
  animation:fU 1s .7s ease both;z-index:10;cursor:pointer;
}
.scroll-mouse{
  width:26px;height:42px;border:2px solid rgba(214,48,49,.35);
  border-radius:13px;position:relative;
}
.scroll-wheel{
  width:4px;height:8px;background:var(--red);
  border-radius:2px;position:absolute;top:7px;left:50%;transform:translateX(-50%);
  animation:scrollWheel 1.8s ease-in-out infinite;
}
.scroll-arrows{display:flex;flex-direction:column;align-items:center;gap:2px}
.scroll-arrows span{
  display:block;width:9px;height:9px;
  border-right:1.5px solid rgba(214,48,49,.4);border-bottom:1.5px solid rgba(214,48,49,.4);
  transform:rotate(45deg);animation:scrollArrow 1.8s ease-in-out infinite;
}
.scroll-arrows span:nth-child(2){animation-delay:.2s;opacity:.6}
.scroll-arrows span:nth-child(3){animation-delay:.4s;opacity:.3}
@keyframes scrollWheel{0%{top:7px;opacity:1}100%{top:22px;opacity:0}}
@keyframes scrollArrow{0%,100%{opacity:1}50%{opacity:.2}}

@media(max-width:900px){
  .hin{flex-direction:column-reverse;padding:3rem 1.4rem;gap:2.5rem;min-height:auto;padding-top:2rem}
  .hvis{flex:none;width:100%;max-width:340px;margin:0 auto}
  .hpwrap{border-radius:24px}
  .hcopy{text-align:left}
  .hstats{gap:2rem}
  .hstat span{font-size:1.6rem}
  .hdesc{max-width:100%}
  .scroll-indicator{display:none}
}




/* ═══════════ PRODUCT FEATURES SLIDER ═══════════ */
#features{padding:80px 0 0; overflow:hidden}
#features .inn{margin-bottom:2.5rem;text-align:center}
#features .lbl{display:block;text-align:center;font-family:'Montserrat',sans-serif;font-size:2.5rem;font-weight:700;letter-spacing:.12em;color:#2a2a2a;text-transform:uppercase;margin-bottom:0}
#features .ttl{display:none}

/* 슬라이더 래퍼 */
.pfsw{position:relative;display:flex;align-items:center;width:100%}
.pfto{width:100%;overflow:hidden;padding:0}
.pft{display:flex;will-change:transform;align-items:center}

/* 슬라이드 - 원형 이미지 스타일 */
.pfs{flex:0 0 auto;padding:10px 8px;display:flex;justify-content:center;align-items:center;transition:opacity .4s;box-sizing:border-box}
.pfs:not(.act){opacity:.55}
.pfc{
  width:100%;aspect-ratio:1/1;border-radius:50%;overflow:hidden;
  background:#e8e6e2;position:relative;
  box-shadow:none;border:none;padding:0;
  display:flex;align-items:center;justify-content:center;
  max-width:100%;
}
.pfcpoint{
  width:80%;aspect-ratio:1.2/1;border-radius:28% / 50%;overflow:hidden;
  position:relative;background:#ebebea;
  box-shadow:none;border:none;padding:0;
  display:flex;align-items:center;justify-content:center;
  max-width:100%;
  transition:border-radius .4s cubic-bezier(.4,0,.2,1);
}
/* 활성 슬라이드: 원형 */
.pfs.act .pfcpoint{
  aspect-ratio:1/1;
  border-radius:50%;
  box-shadow:0 0 10px 0 rgba(0,0,0,.12);
  background:#ffffff;
}

/* 카드 내부 원형 이미지 영역 */
.pf-img{width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden}
.pf-img svg{width:80%;height:80%;object-fit:contain}
.pf-img img{width:100%;height:100%;object-fit:cover;display:block}

/* 화살표 - 심플 텍스트형 */
.pfa{
  position:absolute;top:50%;transform:translateY(-50%);z-index:10;
  width:auto;height:auto;border-radius:0;background:transparent;
  border:none;box-shadow:none;
  display:flex;align-items:center;gap:.4rem;
  font-family:'Montserrat',sans-serif;font-size:.75rem;font-weight:500;
  color:#555;letter-spacing:.06em;transition:color .2s;
  padding:1rem 2.5%;
}
.pfa:hover{background:transparent;border:none;box-shadow:none;color:#111;transform:translateY(-50%)}
.pfa svg{display:none}
.pfa.prev{left:0}
.pfa.prev::before{content:'←';font-size:1.4rem;line-height:1}
.pfa.next{right:0}
.pfa.next::after{content:'→';font-size:1.4rem;line-height:1}

/* 도트 */
.pfds{display:flex;justify-content:center;gap:.5rem;margin-top:0;padding:1.5rem 0}
.pfd{width:7px;height:7px;border-radius:50%;background:#bbb;transition:var(--tr);cursor:pointer;border:none}
.pfd.on{background:#333;width:20px;border-radius:3.5px}

/* 하단 설명 영역 */
.pf-caption{padding:2.5rem 5% 5rem;text-align:center}
.pf-caption h3{font-family:'Montserrat',sans-serif;font-size:2.5rem;font-weight:700;color:#1a1a1a;letter-spacing:.04em;margin-bottom:1.2rem}
.pf-caption p{font-size:1.1rem;font-weight:300;line-height:1.95;color:#555;max-width:820px;margin:0 auto}

/* ═══════════ PRODUCT SECTION ═══════════ */
#product{padding:0}
.prod-row{
  display:flex;align-items:stretch;min-height:600px; 
}
.prod-row.rev{flex-direction:row-reverse}
/* 좌측: 이미지 영역 */
.prod-vis{
  flex:0 0 50%;background-image:url('img/product_led.jpg'); background-position: center center;
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;min-height:540px;
}
.prod-vis-ld {
  background-image: url('img/product_ld.jpg');
}
.prod-vis::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 40% 50%,rgba(214,48,49,.06) 0%,transparent 60%);
  pointer-events:none;
}
.prod-vis svg{
  width:75%;max-width:420px;height:auto;
  filter:drop-shadow(12px 20px 40px rgba(0,0,0,.12));
  position:relative;z-index:1;
}
/* 우측: 텍스트 영역 */
.prod-txt{
  flex:0 0 50%;background:#fff;
  display:flex;align-items:center;
  padding:80px 7%;
}
.prod-txt-inner{max-width:480px}
.prod-txt-inner h2{
  font-size:clamp(1.7rem,2.8vw,2.4rem);font-weight:800;
  color:#1a1a1a;letter-spacing:-.02em;line-height:1.2;
  margin-bottom:1.8rem;
}
.prod-txt-inner p{
  font-size:1.05rem;font-weight:300;line-height:2.1;color:#555;
}
@media(max-width:900px){
  .prod-row,.prod-row.rev{flex-direction:column}
  .prod-vis{flex:none;min-height:320px;width:100%}
  .prod-vis svg{width:55%;max-width:260px}
  .prod-txt{flex:none;padding:3rem 1.5rem}
}
.dic svg{width:12px;height:12px}

/* ═══════════ SPECS ═══════════ */
#specs{padding:100px 5%;background:#fff}
.specs-layout{display:grid;grid-template-columns:1fr 1fr;align-items:start;max-width:1200px;margin:0 auto}
.specs-left{max-width:600px;}
.specs-title{font-size:clamp(1.8rem,3vw,2.8rem);font-weight:900;color:#1a1a1a;letter-spacing:-.02em;margin-bottom:2rem;padding-bottom:1.6rem;border-bottom:2px solid #1a1a1a}
.specs-table{width:100%;border-collapse:collapse}
.specs-table tr{border-bottom:1px solid #e8e8e8}
.specs-table tr:last-child{border-bottom:none}
.specs-table td{padding:14px 0;font-size:1.01rem;line-height:1.6;vertical-align:top}
.specs-table td:first-child{font-weight:700;color:#1a1a1a;width:39%;padding-right:2rem}
.specs-table td:last-child{font-weight:300;color:#444}
/* 우측 제품 이미지 */
.specs-right{display:flex;align-items:center;justify-content:center}
.specs-img{width:100%;max-width:480px}
@media(max-width:900px){
  .specs-layout{grid-template-columns:1fr;gap:3rem}
  .specs-right{order:-1}
  .specs-img{max-width:280px;margin:0 auto}
}

/* ═══════════ HOW TO USE — 3파트 ═══════════ */
#howto{padding:0}

/* PART1: 인증 정보 */
.ht-cert-sec{padding:60px 0;background:#fff}
.ht-cert-row{display:flex;align-items:flex-start;gap:5rem;max-width:1200px;margin:0 auto}
.ht-cert-left{flex:0 0 340px}
.ht-cert-tabs{display:flex;gap:.5rem;margin-bottom:2rem}
.ht-tab{font-size:.82rem;font-weight:700;padding:7px 20px;border-radius:100px;border:1.5px solid var(--bd);color:var(--ts);background:#fff;transition:var(--tr);cursor:pointer}
.ht-tab.on{background:var(--nv);color:#fff;border-color:var(--nv)}
.ht-tab:not(.on):hover{border-color:var(--nv);color:var(--nv)}
.ht-tab-panel{display:none}
.ht-tab-panel.on{display:block}
.ht-cert-desc{font-size:.88rem;font-weight:300;line-height:1.95;color:var(--tx);margin-bottom:1.6rem}
.ht-cert-links{display:flex;flex-direction:column;gap:.4rem}
.ht-cert-links a{font-size:.78rem;font-weight:400;color:#3a6cbf;text-decoration:underline;text-underline-offset:3px;transition:color .2s;word-break:break-all}
.ht-cert-links a:hover{color:var(--red)}
.ht-cert-right{flex:1}
.ht-cert-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.ht-cert-card{background:#fff;border:1px solid var(--bd);border-radius:8px;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.06);transition:var(--tr)}
.ht-cert-card:hover{transform:translateY(-3px);box-shadow:0 8px 28px rgba(0,0,0,.1)}
.ht-cert-img{padding:1.4rem 1.2rem;background:linear-gradient(145deg,#fafcff,#f0f4fb);min-height:180px;display:flex;align-items:center;justify-content:center}
.kc-doc{width:100%;max-width:160px;background:#fff;border:1px solid #d0ddf0;border-radius:4px;padding:1rem .9rem;box-shadow:0 2px 8px rgba(58,108,191,.1)}
.kc-logo{display:flex;align-items:center;justify-content:center;margin-bottom:.5rem}
.kc-title{font-family:'S-CoreDream',sans-serif;font-size:.72rem;font-weight:700;color:#1a3a6a;text-align:center;letter-spacing:.1em;margin-bottom:.8rem}
.kc-lines{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.8rem}
.kc-line{height:4px;background:#e8edf5;border-radius:2px;width:100%}
.kc-line.w60{width:60%}.kc-line.w70{width:70%}.kc-line.w80{width:80%}
.kc-stamp{display:flex;justify-content:flex-end;margin-top:.5rem}
.kc-stamp-inner{font-size:.5rem;font-weight:600;color:#4a90d9;text-align:center;line-height:1.4;border:1px solid #4a90d9;border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;padding:4px}

/* PART2: 사용 방법 */
.ht-how-sec{padding:80px 0;background:#f4f4f4}
.ht-how-title{font-size:clamp(1.4rem,2.8vw,2rem);font-weight:700;color:var(--tx);text-align:center;margin-bottom:3rem;letter-spacing:-.01em}
.ht-how-title span{font-weight:400;color:var(--ts)}
.ht-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;max-width:1100px;margin:0 auto 2.5rem}
.ht-step{background:#fff;border-radius:12px;padding:2.2rem 1.6rem;display:flex;flex-direction:column;gap:.6rem;border:2px solid transparent;box-shadow:0 2px 12px rgba(0,0,0,.05);transition:var(--tr);cursor:pointer}
.ht-step.active{background:var(--nv);border-color:var(--nv);box-shadow:0 8px 28px rgba(18,32,62,.25)}
.ht-step.active .ht-step-ico{color:#fff}
.ht-step.active .ht-step-name{color:#fff}
.ht-step.active .ht-step-sub{color:rgba(255,255,255,.55)}
.ht-step:not(.active):hover{border-color:var(--bd);transform:translateY(-3px)}
.ht-step-ico{color:var(--nv);margin-bottom:.4rem;transition:color .25s}
.ht-step-name{font-size:.95rem;font-weight:700;color:var(--tx);transition:color .25s}
.ht-step-sub{font-size:.76rem;font-weight:300;color:var(--ts);transition:color .25s}
.ht-progress{max-width:1100px;margin:0 auto;position:relative;padding:1.5rem 0 2rem}
.ht-prog-line{position:absolute;top:1.5rem;left:0;right:0;height:2px;background:var(--bd)}
.ht-prog-fill{height:100%;background:var(--red);transition:width .4s ease;width:0%}
.ht-prog-dots{display:flex;justify-content:space-between;position:relative;z-index:1}
.ht-prog-dot{display:flex;flex-direction:column;align-items:center;gap:.5rem;cursor:pointer}
.ht-prog-dot::before{content:'';width:12px;height:12px;border-radius:50%;background:var(--bd);border:2px solid #fff;box-shadow:0 0 0 2px var(--bd);transition:var(--tr)}
.ht-prog-dot.active::before{background:var(--red);box-shadow:0 0 0 2px var(--red)}
.ht-prog-label{font-family:'Montserrat',sans-serif;font-size:.7rem;font-weight:600;color:var(--ts);letter-spacing:.04em;transition:color .25s}
.ht-prog-dot.active .ht-prog-label{color:var(--red)}

/* PART3: 모드 선택 */
.ht-mode-sec{padding:80px 0;background:#fff}
.ht-mode-row{display:flex;align-items:center;gap:5rem;max-width:1200px;margin:0 auto}
.ht-mode-left{flex:1;max-width:440px}
.ht-mode-title{font-size:clamp(1.5rem,2.8vw,2rem);font-weight:800;color:var(--tx);margin-bottom:1.2rem;letter-spacing:-.02em}
.ht-mode-desc{font-size:.88rem;font-weight:300;line-height:1.95;color:var(--ts);margin-bottom:2rem}
.ht-mode-list{display:flex;flex-direction:column;gap:0}
.ht-mode-item{display:flex;align-items:center;gap:1rem;padding:1.1rem 1.4rem;border:1px solid var(--bd);border-bottom:none;cursor:pointer;transition:var(--tr);font-size:.86rem}
.ht-mode-item:first-child{border-radius:8px 8px 0 0}
.ht-mode-item:last-child{border-bottom:1px solid var(--bd);border-radius:0 0 8px 8px}
.ht-mode-item.active{background:var(--nv);border-color:var(--nv)}
.ht-mode-item:not(.active):hover{background:var(--off)}
.ht-mode-num{font-family:'Montserrat',sans-serif;font-size:.78rem;font-weight:700;color:var(--ts);min-width:74px;flex-shrink:0;transition:color .25s}
.ht-mode-item.active .ht-mode-num{color:rgba(255,255,255,.6)}
.ht-mode-name{flex:1;font-weight:600;color:var(--tx);transition:color .25s}
.ht-mode-item.active .ht-mode-name{color:#fff}
.ht-mode-arr{font-family:'Montserrat',sans-serif;font-size:.78rem;font-weight:300;color:var(--ts);letter-spacing:.06em;transition:color .25s}
.ht-mode-item.active .ht-mode-arr{color:rgba(255,255,255,.5)}
.ht-mode-right{flex:1;display:flex;align-items:center;justify-content:center}
.ht-mode-img-wrap{filter:drop-shadow(0 20px 40px rgba(0,0,0,.12));animation:floatY 5s ease-in-out infinite}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}



/* ═══════════ TECHNOLOGY ═══════════ */
#tech{background:var(--bg);padding:110px 5%;position:relative;overflow:hidden}
#tech::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:900px;height:900px;background:radial-gradient(circle,rgba(58,108,191,.15) 0%,transparent 55%);pointer-events:none}
.tech-row{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center;max-width:1200px;margin:0 auto}
/* 좌측 텍스트 */
.tech-txt .lbl{color:rgba(255,255,255,.45)}
.tech-txt h2{font-size:clamp(1.8rem,3vw,2.6rem);font-weight:800;color:#fff;letter-spacing:-.02em;line-height:1.2;margin:.8rem 0 2rem}
.tech-txt p{font-size:1.05rem;font-weight:300;line-height:2.1;color:rgba(255,255,255,.55);margin-bottom:1.4rem}
.tech-txt p:last-child{margin-bottom:0}
/* 우측 오브 */
.tech-vis{display:flex;align-items:center;justify-content:center;position:relative}
.tech-orb-wrap{position:relative;width:340px;height:340px;display:flex;align-items:center;justify-content:center}
/* 동심원 3개 */
.tech-orb-wrap::before{content:'';position:absolute;width:340px;height:340px;border-radius:50%;border:1px solid rgba(255,255,255,.07)}
.tech-orb-wrap::after{content:'';position:absolute;width:240px;height:240px;border-radius:50%;border:1px solid rgba(255,255,255,.06)}
.torb-ring3{position:absolute;width:150px;height:150px;border-radius:50%;border:1px solid rgba(255,255,255,.05)}
/* 중앙 코어 */
.torb-core{width:90px;height:90px;border-radius:50%;background:rgba(255,255,255,.04);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-family:'Montserrat',sans-serif;font-size:.57rem;font-weight:700;letter-spacing:.12em;color:rgba(255,255,255,.4);position:relative;z-index:2}
/* 궤도 + 빨간 점 */
.torb-orbit{position:absolute;width:240px;height:240px;border-radius:50%;animation:rs 6s linear infinite}
.torb-dot{position:absolute;width:14px;height:14px;border-radius:50%;background:var(--red);top:-7px;left:50%;transform:translateX(-50%);box-shadow:0 0 20px rgba(214,48,49,.9),0 0 40px rgba(214,48,49,.4)}
@media(max-width:900px){
  .tech-row{grid-template-columns:1fr;gap:3rem}
  .tech-vis{order:1}
  .tech-orb-wrap{width:260px;height:260px}
  .tech-orb-wrap::before{width:260px;height:260px}
  .tech-orb-wrap::after{width:185px;height:185px}
  .torb-orbit{width:185px;height:185px}
}

/* ═══════════ MEDIA / 협찬 ═══════════ */
#media{padding:0;background-image:url('img/sponsorship.jpg');background-size:cover;background-position: center center;position:relative;overflow:hidden;display:flex;align-items:center;min-height:700px;justify-content:center}

/* 배경 다크 오버레이 */
#media::before{content:'';position:absolute;inset:0;background:rgba(10, 12, 18, 0.082);z-index:1}
/* 중앙 콘텐츠 */
.media-hero{position:relative;z-index:2;text-align:center;padding:80px 5%;max-width:950px;margin:0 auto}
.media-hero h2{font-size:clamp(1.8rem,4vw,2.8rem);font-weight:900;color:#fff;letter-spacing:-.02em;margin-bottom:1.4rem}
.media-hero p{font-size:1.01rem;font-weight:300;color:rgba(255,255,255,.78);line-height:1.95;margin-bottom:2.4rem;max-width:950px;margin-left:auto;margin-right:auto}
.media-hero-btn{display:inline-block;padding:14px 40px;border:1.5px solid rgba(255,255,255,.7);color:#fff;font-size:1.01rem;font-weight:600;letter-spacing:.06em;background:transparent;transition:var(--tr);border-radius:2px}
.media-hero-btn:hover{background:rgba(255,255,255,.12);border-color:#fff;text-decoration:none}
@media(max-width:768px){
  #media{min-height:360px}
  .media-hero{padding:60px 1.4rem}
}
.sp-tabs{display:flex;gap:.5rem;flex-wrap:wrap}
.sp-tab{padding:8px 22px;font-size:.78rem;font-weight:600;border-radius:100px;letter-spacing:.04em;background:rgba(255,255,255,.08);color:rgba(255,255,255,.55);border:1.5px solid rgba(255,255,255,.12);transition:var(--tr)}
.sp-tab.on{background:var(--red);color:#fff;border-color:var(--red)}
.sp-tab:hover:not(.on){background:rgba(255,255,255,.14);color:rgba(255,255,255,.8)}
.sp-panel{display:none;padding-top:2.5rem}
.sp-panel.on{display:block}
.sp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.sp-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:14px;overflow:hidden;transition:var(--tr)}
.sp-card:hover{transform:translateY(-5px);border-color:rgba(214,48,49,.5);box-shadow:0 16px 48px rgba(0,0,0,.3)}
.sp-thumb{height:140px;display:flex;align-items:center;justify-content:center;gap:.8rem;position:relative;font-size:2rem}
.sp-yt{background:linear-gradient(135deg,#1a0000,#3d0000)}
.sp-ig{background:linear-gradient(135deg,#2d0031,#1a0049)}
.sp-nv{background:linear-gradient(135deg,#003d1a,#024019)}
.sp-tv{background:linear-gradient(135deg,#0d1929,#1d3060)}
.sp-news{background:linear-gradient(135deg,#1a1a0a,#2a2a10)}
.sp-pod{background:linear-gradient(135deg,#0d0d1a,#1a0d2a)}
.sp-hospital{background:linear-gradient(135deg,#001a1a,#002a2a)}
.sp-badge{position:absolute;top:10px;right:12px;font-size:.62rem;font-weight:700;letter-spacing:.1em;background:rgba(255,255,255,.12);color:rgba(255,255,255,.7);padding:3px 8px;border-radius:100px}
.sp-info{padding:1.4rem}
.sp-ch{font-size:.9rem;font-weight:700;color:#fff;margin-bottom:.5rem}
.sp-stat{display:flex;gap:1rem;font-size:.72rem;font-weight:300;color:rgba(255,255,255,.4);margin-bottom:.7rem;flex-wrap:wrap}
.sp-stat strong{color:var(--red)}
.sp-info p{font-size:.78rem;font-weight:300;color:rgba(255,255,255,.5);line-height:1.75}
.sp-info p strong{color:rgba(255,255,255,.8)}
/* benefits strip */
.bstrip{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5px;max-width:900px;margin:4rem auto 0;border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,.06)}
.bi{padding:3.2rem 2rem;background:rgba(255,255,255,.03);text-align:center;transition:background .3s}
.bi:hover{background:rgba(255,255,255,.07)}
.bnum{font-family:'Montserrat',sans-serif;font-size:3rem;font-weight:900;color:var(--red);line-height:1;margin-bottom:.5rem;letter-spacing:-.02em}
.bi h3{font-size:.9rem;font-weight:600;color:#fff;margin-bottom:.5rem}
.bi p{font-size:.78rem;font-weight:300;line-height:1.75;color:rgba(255,255,255,.45)}

/* ═══════════ FAQ ═══════════ */
#faq{padding:110px 5%;background:#fff}
.fqw{max-width:800px;margin:2.5rem auto 0}
.fq{border-bottom:1.5px solid var(--bd);overflow:hidden;display:grid;grid-template-rows:auto 0fr;transition:grid-template-rows .38s cubic-bezier(.4,0,.2,1)}
.fqq{display:flex;justify-content:space-between;align-items:center;padding:1.4rem 0;cursor:pointer;font-size:1.15rem;font-weight:600;color:var(--tx);gap:1rem;transition:color .2s}
.fqq:hover{color:var(--red)}
.fqic{width:28px;height:28px;border-radius:50%;background:var(--lt);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:var(--tr)}
.fqic svg{width:14px;height:14px;transition:transform .3s}
.fq.open .fqic{background:var(--red)}
.fq.open .fqic svg{transform:rotate(45deg)}
.fq.open .fqic svg path{stroke:#fff}
.fqa{min-height:0;overflow:hidden;font-size:0.99rem;font-weight:300;line-height:1.9;color:#333333;transition:padding .38s cubic-bezier(.4,0,.2,1)}
.fq.open{grid-template-rows:auto 1fr}
.fq.open .fqa{padding-bottom:1.6rem}
/* FAQ 답변 내 불릿 */
.fqa-list{list-style:none;margin-top:.6rem;display:flex;flex-direction:column;gap:.3rem}
.fqa-list li{display:flex;align-items:flex-start;gap:.5rem}
.fqa-list li::before{content:'*';font-weight:600;color:var(--tx);flex-shrink:0}
.fqa-note{margin-top:.7rem;font-size:.78rem;color:#999}
/* 제목 중앙 정렬 */
#faq .inn{text-align:center}
#faq .fqw{text-align:left}

/* ═══════════ CTA BAND ═══════════ */
.cta-band{
  background:linear-gradient(135deg,#1a0808 0%,var(--nv2) 50%,#200d0d 100%);
  padding:52px 24%;display:flex;align-items:center;
  justify-content:space-between;gap:2rem;
  position:relative;overflow:hidden;
}
.cta-band::before{content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.022'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/svg%3E");
  pointer-events:none}
.cta-band-txt{
  font-size:clamp(1rem,1.8vw,1.4rem);font-weight:700;
  color:#fff;letter-spacing:-.01em;line-height:1.4;
}
.cta-band-btns{display:flex;gap:.8rem;flex-shrink:0;flex-wrap:wrap}
.cta-band-btn{
  padding:13px 32px;border:1.8px solid rgba(255,255,255,.75);
  color:#fff;font-size:.85rem;font-weight:600;
  background:transparent;border-radius:3px;
  transition:all .25s;letter-spacing:.04em;white-space:nowrap;
  cursor:pointer;text-decoration:none;display:inline-block;
}
.cta-band-btn:hover{background:rgba(255,255,255,.15);border-color:#fff;text-decoration:none}
.ctabt{display:none}
@media(max-width:768px){
  .cta-band{flex-direction:column;text-align:center;padding:48px 1.4rem}
  .cta-band-btns{justify-content:center}
}
.bwh{display:inline-block;background:#fff;color:var(--red);font-size:.82rem;font-weight:700;padding:14px 40px;border-radius:var(--r);border:2px solid #fff;transition:var(--tr);letter-spacing:.04em;cursor:pointer;position:relative;z-index:2}
.bwh:hover{background:transparent;color:#fff;transform:translateY(-2px);text-decoration:none}
.bwho{display:inline-block;background:transparent;color:#fff;font-size:.82rem;font-weight:600;padding:14px 40px;border-radius:var(--r);border:2px solid rgba(255,255,255,.35);transition:var(--tr);letter-spacing:.04em;cursor:pointer;position:relative;z-index:2}
.bwho:hover{border-color:#fff;transform:translateY(-2px);text-decoration:none}

/* ═══════════ 사용방법 & 모드선택 ═══════════ */
#howto-new{padding:120px 5%;background:#f0efed}
#howto-new .howto-title{font-size:clamp(1.5rem,2.8vw,2.2rem);font-weight:900;color:#1a1a1a;letter-spacing:-.02em;text-align:center;margin-bottom:3rem}

/* 스텝 카드 */
.howto-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;max-width:1100px;margin:0 auto 0}
.howto-step{background:#fff;border-radius:10px;padding:2rem 1.6rem;position:relative;border:1.5px solid #e4e4e4;transition:var(--tr);cursor:pointer}
.howto-step.active,.howto-step:hover{background:#5a87b0;border-color:#5a87b0}
.howto-step-ico{width:2.6rem;height:2.6rem;margin:0 0 1.2rem auto;opacity:.85;display:flex;align-items:center;justify-content:flex-end;color:#1a1a1a}.howto-step-ico svg{width:100%;height:100%}
.howto-step.active .howto-step-ico,.howto-step:hover .howto-step-ico{opacity:1;color:#fff;filter:none}
.howto-step h3{font-size:1.5rem;font-weight:500;color:#1a1a1a;margin-bottom:.4rem;letter-spacing:-.01em}
.howto-step p{font-size:1.1rem;font-weight:300;color:#888;line-height:1.7}
.howto-step.active h3,.howto-step:hover h3{color:#fff}
.howto-step.active p,.howto-step:hover p{color:rgba(255,255,255,.75)}

/* 프로그레스 바 */
.howto-progress{max-width:1100px;margin:2rem auto 0;position:relative}
.howto-prog-line{height:1px;background:#ccc;position:relative}
.howto-prog-dots{display:flex;justify-content:space-between;position:absolute;top:50%;transform:translateY(-50%);width:100%}
.howto-prog-dot{width:10px;height:10px;border-radius:50%;background:#ccc;transition:var(--tr);cursor:pointer}
.howto-prog-dot.active{background:#5a87b0}
.howto-prog-labels{display:flex;justify-content:space-between;margin-top:1rem}
.howto-prog-label{font-family:'Montserrat',sans-serif;font-size:.68rem;font-weight:700;color:#aaa;letter-spacing:.08em;transition:color .3s}
.howto-prog-label.active{color:#5a87b0}

/* 모드선택 */
#mode-select{padding:100px 0;background:#fff;overflow:hidden}
.mode-layout{display:grid;grid-template-columns:1fr 1fr;align-items:stretch;max-width:1200px;margin:0 auto}
.mode-vis{display:flex;align-items:center;justify-content:center;background:#f0efed;min-height:480px;overflow:hidden}
.mode-txt{padding:0 8% 0 10%}
.mode-txt h2{font-size:clamp(1.6rem,2.8vw,2.4rem);font-weight:900;color:#1a1a1a;letter-spacing:-.02em;margin-bottom:1.4rem}
.mode-txt p{font-size:1.01rem;font-weight:300;color:#333;line-height:1.95;margin-bottom:2.4rem}
.mode-list{display:flex;flex-direction:column;gap:.7rem}
.mode-item{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.4rem;border:1.5px solid #ddd;border-radius:4px;cursor:pointer;transition:var(--tr);touch-action:manipulation;-webkit-tap-highlight-color:transparent;user-select:none;-webkit-user-select:none}
.mode-item.active,.mode-item:hover{background:#1a1a1a;border-color:#1a1a1a}
.mode-item-left{display:flex;align-items:center;gap:1rem}
.mode-num{font-family:'Montserrat',sans-serif;font-size:.72rem;font-weight:700;color:#888;letter-spacing:.1em}
.mode-name{font-size:.88rem;font-weight:400;color:#1a1a1a}
.mode-item.active .mode-num,.mode-item:hover .mode-num{color:rgba(255,255,255,.5)}
.mode-item.active .mode-name,.mode-item:hover .mode-name{color:#fff}
.mode-arrow-svg{flex-shrink:0;color:#aaa;transition:color .3s}
.mode-item.active .mode-arrow-svg,.mode-item:hover .mode-arrow-svg{color:rgba(255,255,255,.7)}

@media(max-width:900px){
  .howto-steps{grid-template-columns:repeat(2,1fr)}
  .mode-layout{grid-template-columns:1fr}
  .mode-vis{background:#f0efed;height:100%;min-height:600px;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}
  .mode-vis{min-height:300px;justify-content:center}
  .mode-vis svg{margin-right:0;width:70%}
  .mode-txt{padding:3rem 1.5rem}
}
@media(max-width:560px){
  .howto-steps{grid-template-columns:1fr 1fr}
  #howto-new{padding:60px 1.2rem}
}

/* ═══════════ 인증 정보 ═══════════ */
#cert-info{padding:140px 0;background:#fff}
.cert-info-inner{display:grid;grid-template-columns:260px 1fr;gap:5rem;align-items:start;max-width:1200px;margin:0 auto}
.cert-info-left h2.ttl{margin-bottom:1.2rem}
.cert-info-desc{font-size:1.05rem;font-weight:300;line-height:1.95;color:#333333;margin-bottom:1.4rem}
.cert-info-links{display:flex;flex-direction:column;gap:.35rem}
.cert-info-links a{font-size:.78rem;color:#3a6cbf;text-decoration:underline;text-underline-offset:3px;transition:color .2s}
.cert-info-links a:hover{color:var(--red)}
.cert-info-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  grid-template-rows:auto auto;
  gap:1.2rem;
  align-items:start;
}
/* 좌열(홀수): 위에서 시작 */
.ci-img-card:nth-child(odd){ margin-top:0; }
/* 우열(짝수): 아래로 오프셋 */
.ci-img-card:nth-child(even){ margin-top:2.8rem; }
.ci-card{background:#fff;border:1px solid #d8e4f0;border-radius:6px;padding:1.2rem 1.4rem;box-shadow:0 2px 16px rgba(58,108,191,.08);transition:var(--tr);font-size:.72rem;color:#2a3a4a}
.ci-card:hover{transform:translateY(-3px);box-shadow:0 8px 32px rgba(58,108,191,.14)}
/* 이미지 기반 인증서 카드 */
.ci-img-card{
  background:#fff;border:1px solid #d8e4f0;border-radius:8px;
  overflow:hidden;box-shadow:0 2px 16px rgba(58,108,191,.08);
  transition:var(--tr);aspect-ratio:3/4;position:relative;
  display:flex;align-items:stretch;
}
.ci-img-card:hover{transform:translateY(-4px);box-shadow:0 10px 36px rgba(58,108,191,.15)}
.ci-img-card img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.ci-img-placeholder{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:.8rem;width:100%;min-height:240px;
  background:linear-gradient(145deg,#fafcff,#f0f4fb);
  color:#7a9cbd;text-align:center;font-size:.78rem;font-weight:300;line-height:1.6;
}
.ci-img-placeholder small{font-size:.68rem;color:#a0b4c8}
.ci-card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:.8rem;font-size:.65rem;color:#888;border-bottom:1px solid #e8eef8;padding-bottom:.6rem}
.ci-num{font-weight:600;color:#555}
.ci-date{color:#999}
.ci-logo-wrap{display:flex;justify-content:center;margin-bottom:.6rem}
.ci-title{text-align:center;font-size:.82rem;font-weight:700;color:#1a3a6a;letter-spacing:.12em;margin-bottom:1rem;padding-bottom:.6rem;border-bottom:1.5px solid #c8d8f0}
.ci-body{display:flex;flex-direction:column;gap:.3rem;margin-bottom:1rem}
.ci-row{display:flex;gap:.5rem;font-size:.68rem;line-height:1.6;color:#3a4a5a}
.ci-row.indent{padding-left:.8rem}
.ci-label{flex-shrink:0;font-weight:600;color:#2a3a6a;min-width:60px}
.ci-footer-text{font-size:.62rem;color:#888;line-height:1.7;border-top:1px solid #e8eef8;padding-top:.8rem;margin-bottom:.8rem}
.ci-date-bottom{text-align:center;font-size:.72rem;font-weight:600;color:#2a3a6a;margin-bottom:.8rem}
.ci-institute{display:flex;align-items:center;gap:.7rem;justify-content:center}
.ci-institute span{font-size:.65rem;color:#2a4a8a;line-height:1.5;font-weight:600}
.ci-institute em{font-style:normal;font-size:.58rem;color:#666;font-weight:400}
.ci-bottom-note{text-align:right;font-size:.6rem;color:#aaa;margin-top:.5rem}
@media(max-width:900px){
  .cert-info-inner{grid-template-columns:1fr;gap:2.5rem}
  .cert-info-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .cert-info-grid{grid-template-columns:1fr}
}

/* ═══════════ 주의사항 ═══════════ */
#caution{padding:100px 5%;background:#f0efed}
.caution-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 2fr;gap:6rem;align-items:start}
.caution-left h2{font-size:clamp(1.5rem,3vw,2.0rem);font-weight:900;color:#1a1a1a;letter-spacing:-.02em;line-height:1.25;margin-bottom:1.4rem}
.caution-left p{font-size:1.05rem;font-weight:400;color:#333;line-height:1.95;text-align:left;}
.caution-box{background:#fff;border-radius:12px;padding:2.8rem 3rem;box-shadow:0 4px 24px rgba(0,0,0,.06)}
.caution-list{list-style:none;display:flex;flex-direction:column;gap:1.2rem}
.caution-list li{display:flex;align-items:flex-start;gap:.9rem;font-size:1.0rem;font-weight:300;color:#333;line-height:1.8}
.caution-list li::before{content:'▪';color:#1a1a1a;font-size:.75rem;flex-shrink:0;margin-top:.3rem}
@media(max-width:900px){
  .caution-inner{grid-template-columns:1fr;gap:2.5rem}
  .caution-left p{text-align:left}
}
@media(max-width:768px){
  .caution-inner{grid-template-columns:1fr;gap:2rem}
  .caution-box{padding:2rem 1.5rem}
}

/* ═══════════ CONSULT ═══════════ */
/* 개인정보 동의 체크박스 */
.privacy-agree{display:flex;align-items:center;gap:.5rem;cursor:pointer;margin-top:.6rem;flex-wrap:nowrap;width:100%;border:none;border-radius:0;overflow:visible;background:transparent;padding:.2rem 0}
.privacy-agree input[type=checkbox]{display:none}
/* 파란색 체크박스 */
.privacy-box{width:17px;height:17px;border:1.8px solid #5a87b0;border-radius:3px;flex-shrink:0;position:relative;transition:all .2s;background:#fff;margin-left:0}
.privacy-agree input:checked~.privacy-box{background:#5a87b0;border-color:#5a87b0}
.privacy-agree input:checked~.privacy-box::after{content:'';position:absolute;left:3px;top:1px;width:7px;height:10px;border:2px solid #fff;border-top:none;border-left:none;transform:rotate(45deg)}
.privacy-txt{font-size:.82rem;font-weight:400;color:#333;white-space:nowrap;padding:0}
.privacy-spacer{display:none}
/* [ 내용보기 ] - 텍스트 바로 옆, 배경 없는 링크 스타일 */
.privacy-view-btn{
  background:none;color:#555;border:none;
  padding:0;font-size:.82rem;font-weight:400;
  cursor:pointer;white-space:nowrap;flex-shrink:0;
  letter-spacing:0;transition:color .2s;
  align-self:auto;display:inline;
  text-decoration:none;
}
.privacy-view-btn:hover{color:#1a1a1a}
.privacy-warn{font-size:.75rem;color:#e53935;margin-top:.4rem;display:none}
.privacy-warn.show{display:block}
/* 팝업 */
#privacyOverlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:9000;animation:fadeIn .2s ease}
#privacyBox{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:9001;width:min(640px,92vw);border-radius:8px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.3);animation:popUp .22s cubic-bezier(.4,0,.2,1)}
#privacyBoxHead{background:var(--nv);padding:16px 22px;display:flex;justify-content:space-between;align-items:center}
#privacyBoxHead span{font-size:.95rem;font-weight:700;color:#fff;letter-spacing:.04em}
#privacyClose{background:none;border:none;color:rgba(255,255,255,.7);font-size:1.1rem;cursor:pointer;padding:2px 6px;transition:color .2s}
#privacyClose:hover{color:#fff}
#privacyBoxBody{background:#fff;padding:24px 28px;max-height:60vh;overflow-y:auto;font-size:.83rem;color:#444;line-height:1.85}
#privacyBoxBody h4{font-size:.88rem;font-weight:700;color:#1a1a1a;margin:1.4rem 0 .6rem;padding-bottom:.4rem;border-bottom:1px solid #eee}
#privacyBoxBody h4:first-child{margin-top:0}
#privacyBoxBody p{margin-bottom:.6rem}
.priv-table{width:100%;border-collapse:collapse;margin-bottom:.8rem;font-size:.78rem}
.priv-table th{background:#f4f6fa;padding:9px 12px;font-weight:600;color:#333;border:1px solid #e4e8f0;text-align:left}
.priv-table td{padding:9px 12px;border:1px solid #e4e8f0;color:#555;vertical-align:top}
.priv-list{padding-left:1.2rem;margin-bottom:.6rem}
.priv-list li{margin-bottom:.3rem}
#privacyBoxFoot{background:#f8f9fa;padding:14px 22px;display:flex;justify-content:flex-end;gap:.7rem;border-top:1px solid #eee}
#privacyBoxFoot button,#privacyBoxFoot button:first-child,#privacyBoxFoot button:last-child{width:auto!important;padding:10px 26px!important;border-radius:5px!important;font-size:0.99rem!important;font-weight:600!important;cursor:pointer;transition:var(--tr);letter-spacing:0!important;transform:none!important;box-shadow:none!important}
#privacyBoxFoot button:first-child{background:var(--red)!important;color:#fff!important;border:none!important}
#privacyBoxFoot button:first-child:hover{background:var(--rd)!important;transform:none!important;box-shadow:none!important}
#privacyBoxFoot button:last-child{background:#fff!important;color:#555!important;border:1.5px solid #ddd!important}
#privacyBoxFoot button:last-child:hover{border-color:#999!important;color:#333!important;transform:none!important;box-shadow:none!important}
#consult{padding:110px 5%;background:var(--off)}
.cgrd{display:grid;grid-template-columns:1fr 1fr;gap:4.5rem;max-width:1200px;margin:2rem auto 0;align-items:start}
.cinfo h3,.cform h3{font-size:1rem;font-weight:700;color:var(--tx);margin-bottom:1.6rem;margin-top:0}
.cinfo{padding-top:.2rem}
.crow{display:flex;gap:.85rem;align-items:flex-start;margin-bottom:1.2rem;font-size:0.95rem;font-weight:300;color:#333}
.cico{width:32px;height:32px;border-radius:50%;background:rgba(214,48,49,.08);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.9rem}
.cform input,.cform textarea,.cform select{width:100%;padding:13px 16px;border:1.5px solid var(--bd);border-radius:var(--r);font-family:'S-CoreDream','Montserrat',sans-serif;font-size:.82rem;font-weight:400;color:var(--tx);background:#fff;margin-bottom:.8rem;resize:none;outline:none;transition:border-color .2s;appearance:none}
.cform input:focus,.cform textarea:focus,.cform select:focus{border-color:var(--red);box-shadow:0 0 0 3px rgba(214,48,49,.08)}
.cform textarea{height:120px}
.cform .row2{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
.cform .submit-btn{margin-top:30px;width:100%;padding:15px;background:var(--red);color:#fff;font-family:'S-CoreDream','Montserrat',sans-serif;font-size:.86rem;font-weight:700;border-radius:var(--r);transition:var(--tr);letter-spacing:.04em;border:none;cursor:pointer}
.cform .submit-btn:hover{background:var(--rd);transform:translateY(-1px);box-shadow:0 8px 24px rgba(214,48,49,.3)}

/* ═══════════ MAP ═══════════ */
#map-section{padding:0 0 100px;background:#fff}
#map-section .inn{padding-top:80px}
.map-wrap-outer{max-width:1200px;margin:0 auto;padding:0 5%}
.map-kakao{width:100%;height:480px;border-radius:12px;overflow:hidden;border:1.5px solid var(--bd);box-shadow:var(--sc);position:relative}
.map-kakao iframe{width:100%;height:100%;border:none;display:block}
/* 지도 핀 오버레이 */
.map-pin-overlay{
  position:absolute;
  /* 지도 MX/MY 좌표 = 이미지 정중앙 → left:50% top:50% */
  top:50%;left:50%;
  transform:translate(-50%,-100%);
  z-index:10;pointer-events:none;
  filter:drop-shadow(0 3px 6px rgba(0,0,0,.35));
  animation:pinBounce 2.2s ease-in-out infinite;
}
@keyframes pinBounce{0%,100%{transform:translate(-50%,-100%) translateY(0)}50%{transform:translate(-50%,-100%) translateY(-8px)}}
.map-pin-overlay svg{display:block}
.map-addr-bar{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:1.2rem;font-size:.88rem;font-weight:400;color:#555}
@media(max-width:768px){.map-kakao{height:320px}.map-wrap-outer{padding:0 1.2rem}}

/* ═══════════ FOOTER ═══════════ */
footer{background:#fff;color:#555;padding:3.5rem 5% 2rem;border-top:1px solid #eee}
.finn{max-width:1100px;margin:0 auto}
.finn-top{display:flex;align-items:flex-start;gap:3rem;padding-bottom:2rem;border-bottom:1px solid #eee;margin-bottom:1.4rem}
.finn-logo-wrap{flex-shrink:0;display:flex;align-items:center;justify-content:center}
.finn-logo-wrap svg{width:72px;height:72px}
.finn-info{flex:1}
.finn-info-row{font-size:.85rem;color:#333;line-height:1.95;margin-bottom:.2rem}
.finn-info-row strong{font-weight:700;color:#1a1a1a;margin-right:.5rem}
.finn-info-row .sep{margin:0 .7rem;color:#ccc}
.finn-info-tel{font-size:.85rem;color:#333;line-height:1.9}
.finn-info-tel strong{font-weight:700;color:#1a1a1a;margin-right:.3rem}
.finn-info-tel .sep{margin:0 .8rem;color:#ccc}
.fcp{font-size:.75rem;color:#aaa;margin-left:11%; margin-top:0}
@media(max-width:768px){
  .finn-top{flex-direction:column;gap:1.5rem}
  .finn-logo-wrap svg{width:56px;height:56px}
}

/* ═══════════ FLOATING BUTTONS ═══════════ */
#fabGroup{position:fixed;right:24px;bottom:28px;z-index:3000;display:flex;flex-direction:column;align-items:center;gap:10px}
.fab{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;box-shadow:0 4px 18px rgba(0,0,0,.18);transition:all .28s cubic-bezier(.4,0,.2,1);text-decoration:none;position:relative;flex-shrink:0}
.fab:hover{transform:translateY(-4px);box-shadow:0 10px 28px rgba(0,0,0,.22)}
.fab-tel{background:#25d366}.fab-tel:hover{background:#1da853}
.fab-talk{background:#03c75a}.fab-talk:hover{background:#02a84c}
.fab-top{background:var(--red);opacity:0;pointer-events:none;transform:translateY(12px) scale(.85);transition:opacity .3s,transform .3s,background .2s,box-shadow .2s}
.fab-top.show{opacity:1;pointer-events:auto;transform:translateY(0) scale(1)}
.fab-top:hover{background:var(--rd) !important;transform:translateY(-4px) scale(1) !important;box-shadow:0 10px 28px rgba(214,48,49,.5) !important}
.fab-label{position:absolute;right:58px;background:rgba(20,20,20,.88);color:#fff;font-size:.68rem;font-weight:500;padding:5px 10px;border-radius:6px;white-space:nowrap;pointer-events:none;opacity:0;transform:translateX(6px);transition:opacity .2s,transform .2s;letter-spacing:.02em}
.fab-label::after{content:'';position:absolute;left:100%;top:50%;transform:translateY(-50%);border:5px solid transparent;border-left-color:rgba(20,20,20,.88)}
.fab:hover .fab-label{opacity:1;transform:translateX(0)}
.fab svg{width:22px;height:22px}
.fab-top svg path{stroke:#fff;stroke-width:2.4;fill:none;stroke-linecap:round;stroke-linejoin:round}
.blog-n{font-family:'Montserrat',sans-serif;font-size:1.08rem;font-weight:900;color:#fff}

/* ═══════════ KEYFRAMES ═══════════ */
@keyframes fU{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes fL{from{opacity:0;transform:translateX(-32px)}to{opacity:1;transform:translateX(0)}}
@keyframes fR{from{opacity:0;transform:translateX(32px)}to{opacity:1;transform:translateX(0)}}
@keyframes rs{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes pulse{0%,100%{opacity:.55;transform:scale(1)}50%{opacity:1;transform:scale(1.06)}}

/* ═══════════ RESPONSIVE ═══════════ */
@media(max-width:1024px){
  /* pfs flex는 JS(slideW)가 제어하므로 CSS에서 제거 */
  .bstrip{grid-template-columns:1fr}
  .sp-grid{grid-template-columns:repeat(2,1fr)}
  .ht-cert-row{flex-direction:column;gap:2.5rem}
  .ht-cert-left{flex:none;width:100%}
  .ht-steps{grid-template-columns:repeat(2,1fr)}
  .ht-mode-row{flex-direction:column;gap:2.5rem}
  .ht-mode-right{order:-1}


}
@media(max-width:768px){
  #nav{padding:0 1.2rem}
  .nmenu{display:none}
  .hbg{display:flex}
  .hin{flex-direction:column-reverse;padding:3.5rem 1.2rem;text-align:center;gap:2.5rem}
  .hvis{width:100%;max-width:280px;margin:0 auto}
  .hpwrap{width:100%;max-width:240px;height:auto;aspect-ratio:1/1}
  .hstats{justify-content:center}
  .hbtns{justify-content:center}
  .hring{width:300px;height:300px}
  #features{padding:60px 0}
  #features .inn{padding:0 1.2rem}
  #specs,#tech,#media,#faq,#consult,.cta-band{padding:64px 1.2rem}
  /* pfs는 JS slideW 계산으로 제어 */
  .pfs{padding:8px 4px}
  .pfa.prev{left:0}.pfa.next{right:0}
  .drow,.drow.rev{flex-direction:column;gap:2rem}
  .sp-grid{grid-template-columns:1fr}
  .cgrd{grid-template-columns:1fr}
  .cform .row2{grid-template-columns:1fr}
  .map-wrap-outer{padding:0 1.2rem}
  .finn{flex-direction:column}
  #fabGroup{right:14px;bottom:18px;gap:8px}
  .fab{width:44px;height:44px}
  .fab-label{display:none}
  #map-section{padding:0 0 60px}
  #map-section .inn{padding-top:60px}
}
@media(max-width:480px){
  .pfs{padding:6px 2px}
  .bstrip{border-radius:0}
}
/* ═══════════ 출력 / 타이머 / 기술원리 / 사용대상 / 상병코드 / 건강보험 ═══════════ */

/* 출력 섹션 */
#output{padding:0;background:#ebebea;position:relative;overflow:hidden}
.output-hero{
  position:relative;width:100%;
  display:flex;flex-direction:column;align-items:center;justify-content:flex-start;
}
/* 상단 중앙 타이틀 */
.output-title-wrap{
  position:relative;z-index:2;
  padding:72px 5% 0;text-align:center;width:100%;
}
.output-title-wrap .lbl{color:#888;letter-spacing:.2em;font-size:.65rem}
.output-title-wrap h2{
  font-size:clamp(1.5rem,2.8vw,2.5rem);font-weight:800;
  color:#1a1a1a;letter-spacing:-.01em;margin-top:.5rem;
}
/* 제품 이미지 (중앙) */
.output-img-wrap{
  flex:1;display:flex;align-items:center;justify-content:center;
  width:100%; padding-top:40px;
}
.output-img-wrap svg{
  width:min(55vw,620px);height:auto;
  filter:drop-shadow(0 30px 80px rgba(0,0,0,.14));
}
@media(max-width:768px){
  .output-hero{min-height:auto}
  .output-title-wrap{padding:48px 5% 0}
  .output-img-wrap svg{width:85vw}
}

/* ═══════════ 10분 타이머 케어 ═══════════ */
#timer-care{padding:80px 5%;background:#0a0a0a;position:relative;overflow:hidden}
.timer-player{max-width:1100px;margin:0 auto;background:#111;border-radius:12px;overflow:hidden;box-shadow:0 32px 80px rgba(0,0,0,.7);position:relative}
.timer-player-top{padding:14px 18px;display:flex;align-items:center;gap:10px;background:#1a1a1a;border-bottom:1px solid rgba(255,255,255,.06)}
.timer-player-dot{width:12px;height:12px;border-radius:50%}
.timer-player-dot:nth-child(1){background:#ff5f57}
.timer-player-dot:nth-child(2){background:#febc2e}
.timer-player-dot:nth-child(3){background:#28c840}
.timer-content{position:relative;min-height:520px;display:flex;flex-direction:column;align-items:center;justify-content:center;background:radial-gradient(ellipse at 50% 50%,#1a1a1a 0%,#000 70%);overflow:hidden;padding:60px 5%}
.timer-bg-text{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:'Montserrat',sans-serif;font-size:clamp(120px,22vw,280px);font-weight:900;color:rgba(255,255,255,.04);letter-spacing:-.04em;user-select:none;pointer-events:none;white-space:nowrap;animation:bgTextDrift 8s ease-in-out infinite alternate}
@keyframes bgTextDrift{from{letter-spacing:-.04em}to{letter-spacing:.02em}}
.timer-ring-wrap{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:min(55vw,480px);aspect-ratio:1/1;animation:timerWrapFloat 4s ease-in-out infinite}
@keyframes timerWrapFloat{0%,100%{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-52%) scale(1.02)}}
.timer-svg{width:100%;height:100%}
.timer-center-txt{position:relative;z-index:10;text-align:center}
.timer-center-txt h2{font-family:'S-CoreDream',sans-serif;font-size:clamp(1.4rem,3vw,2.2rem);font-weight:800;color:#fff;letter-spacing:-.01em;margin-bottom:1.4rem;text-shadow:0 2px 20px rgba(0,0,0,.8);animation:glitchMain 5s infinite}
@keyframes glitchMain{0%,90%,100%{text-shadow:0 2px 20px rgba(0,0,0,.8)}92%{text-shadow:-2px 0 #00ffff,2px 0 #ff0040,0 2px 20px rgba(0,0,0,.8)}94%{text-shadow:2px 0 #00ffff,-2px 0 #ff0040,0 2px 20px rgba(0,0,0,.8)}96%{text-shadow:-1px 0 #00ffff,1px 0 #ff0040,0 2px 20px rgba(0,0,0,.8)}98%{text-shadow:0 2px 20px rgba(0,0,0,.8)}}
.timer-center-txt p{font-size:clamp(.82rem,1.4vw,1rem);font-weight:300;color:rgba(255,255,255,.75);line-height:1.9;text-shadow:0 1px 12px rgba(0,0,0,.9);max-width:600px}
.timer-controls{background:#1a1a1a;padding:10px 18px;display:flex;align-items:center;gap:14px;border-top:1px solid rgba(255,255,255,.06)}
.timer-play-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:rgba(255,255,255,.8);flex-shrink:0}
.timer-play-btn svg{width:18px;height:18px;fill:currentColor}
.timer-time{font-family:'Montserrat',sans-serif;font-size:.72rem;color:rgba(255,255,255,.55);white-space:nowrap}
.timer-progress{flex:1;height:3px;background:rgba(255,255,255,.15);border-radius:2px;cursor:pointer}
.timer-progress-fill{height:100%;border-radius:2px;background:var(--red);animation:progressGrow 10s linear infinite}
@keyframes progressGrow{from{width:0%}to{width:100%}}
.timer-ctrl-right{display:flex;align-items:center;gap:12px;margin-left:auto}
.timer-ctrl-ico{color:rgba(255,255,255,.55);cursor:pointer;display:flex;align-items:center}
.timer-ctrl-ico svg{width:16px;height:16px;fill:currentColor}
/* 링 회전 애니메이션 */
@keyframes ringRot{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes ringRotR{from{transform:rotate(0deg)}to{transform:rotate(-360deg)}}
@keyframes ringPulse{0%,100%{opacity:.35}50%{opacity:.65}}
@media(max-width:768px){
  #timer-care{padding:48px 1.2rem}
  .timer-content{min-height:360px;padding:40px 4%}
  .timer-ring-wrap{width:min(80vw,300px)}
  .timer-bg-text{font-size:clamp(80px,28vw,140px)}
}

/* 기술원리 */
#principle{background-image:url(img/technical_principle.jpg);background-repeat:no-repeat;background-position:center center;background-size: cover;padding:0;position:relative;overflow:hidden;min-height:600px;display:flex;align-items:stretch}
#principle::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 50%,rgba(180,220,240,.45) 0%,transparent 60%);pointer-events:none}
.principle-layout{display:flex;width:100%;min-height:600px}
.principle-vis{flex:0 0 48%;position:relative;overflow:hidden;min-height:600px}
.principle-dna{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.principle-dna svg{width:100%;height:100%;object-fit:cover}
.principle-content{flex:1;display:flex;align-items:center;padding:80px 6% 80px 4%}
.principle-text{max-width:490px}
.principle-text h2{font-size:clamp(1.8rem,3vw,2.4rem);font-weight:800;color:#1a2a3a;letter-spacing:-.02em;margin-bottom:2rem;line-height:1.2}
.principle-text .p-block{margin-bottom:1.6rem}
.principle-text .p-block p{font-size:1.02rem;font-weight:300;line-height:2;color:#222222}
@media(max-width:768px){
  .principle-layout{flex-direction:column}
  .principle-vis{flex:0 0 280px;min-height:280px}
  .principle-content{padding:3rem 1.5rem}
}
@keyframes waveBar{from{height:6px;opacity:.4}to{height:22px;opacity:1}}

/* ═══════════ 사용 대상 ═══════════ */
#target{padding:80px 0 0;background:#fff;overflow:hidden}
.target-header{text-align:center;padding:0 5% 60px}
.target-header h2{font-size:clamp(1.8rem,3vw,2.8rem);font-weight:900;color:#1a1a1a;letter-spacing:-.02em;margin-bottom:1.2rem}
.target-header p{font-size:1.05rem;font-weight:300;color:#666;line-height:1.9;max-width:900px;margin:0 auto}
/* 패널 슬라이더 */
.target-slider{display:flex;width:100%;overflow:hidden}
.target-slide{
  flex:0 0 33.333%;min-height:520px;position:relative;
  display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-end;overflow:hidden;
  transition:flex .5s cubic-bezier(.4,0,.2,1);cursor:pointer;
}
.target-slide:hover{flex:0 0 50%}
/* 배경 */
.target-slide-bg{position:absolute;inset:0;transition:transform .5s cubic-bezier(.4,0,.2,1)}
.target-slide:hover .target-slide-bg{transform:scale(1.04)}

/* 슬라이드별 배경 */
.ts1 .target-slide-bg{background-image:url('img/for_use1.jpg');background-size:cover;background-position:center center;}
.ts2 .target-slide-bg{background-image:url('img/for_use2.jpg');background-size:cover;background-position:center center;}
.ts3 .target-slide-bg{background-image:url('img/for_use3.jpg');background-size:cover;background-position:center center;}

/* SVG 일러스트 */
.target-slide-img{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  transition:transform .5s cubic-bezier(.4,0,.2,1);
}
.target-slide:hover .target-slide-img{transform:scale(1.05)}
.target-slide-img svg{width:88%;height:88%;object-fit:contain;opacity:.6}
.ts3 .target-slide-img svg{opacity:.5}
/* 오버레이 */
.target-slide-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.28) 40%,transparent 90%);
  transition:background .4s;
}
.ts2 .target-slide-overlay{background:linear-gradient(to top,rgba(0,0,0,.4) 0%,rgba(40,80,120,.15) 50%)}
.target-slide:hover .target-slide-overlay{background:linear-gradient(rgba(28, 64, 160, 0.384) 0%)}
/* 텍스트 */
.target-slide-txt{position:relative;z-index:2;padding:1.6rem 1.6rem;width:100%;margin-top:auto}
.target-slide-txt h3{
  font-size:clamp(1rem,1.6vw,1.4rem);font-weight:800;
  color:#1a1a1a;letter-spacing:-.01em;margin-bottom:.7rem;
  text-shadow:none;
}
.ts1 .target-slide-txt h3,
.ts3 .target-slide-txt h3{color:#1a1a1a;text-shadow:none;}
.target-slide-txt p{
  font-size:.9rem;font-weight:300;line-height:1.75;
  color:rgba(255,255,255,.88);
  opacity:0;transform:translateY(10px);
  transition:opacity .35s .05s,transform .35s .05s;
  text-shadow:0 1px 8px rgba(0,0,0,.35);
}
.ts1 .target-slide-txt p,
.ts3 .target-slide-txt p{color:#fff;text-shadow:none;}
.ts2 .target-slide-txt p{color:#fff;text-shadow:none;}
/* 기본 상태: 피부병변(ts2)만 텍스트 표시 */
.ts2 .target-slide-txt p{opacity:1;transform:translateY(0)}
/* hover된 슬라이드 텍스트 표시 */
.target-slide:hover .target-slide-txt p{color: #ffffff; opacity:1;transform:translateY(0)}
.target-slide:hover .target-slide-txt h3{color: #ffffff; opacity:1;transform:translateY(0)}
/* hover 중일 때, hover되지 않은 슬라이드 텍스트 숨김 */
.target-slider:hover .target-slide:not(:hover) .target-slide-txt p{opacity:0;transform:translateY(10px)}


@media(max-width:768px){
  .target-slider{flex-direction:column}
  .target-slide{flex:none!important;min-height:240px;width:100%}
}

/* 상병코드 */
#icd{padding:0;background:#fff;overflow:hidden}
.icd-layout{display:grid;grid-template-columns:1fr 1fr;align-items:center;min-height:620px}
/* 좌측: 일러스트 */
.icd-vis{height:100%;min-height:620px;display:flex;align-items:center;justify-content:center;padding:60px 5%}

/* 우측: 테이블 */
.icd-tbl-wrap{padding:100px 8% 100px 6%}
.icd-tbl-title{font-size:clamp(1.6rem,2.8vw,2.4rem);font-weight:900;color:#1a1a1a;letter-spacing:-.02em;margin-bottom:2rem}
.icd-new-tbl{width:100%;border-collapse:collapse;font-size:.92rem}
.icd-new-tbl thead tr{background:#5a87b0}
.icd-new-tbl th{padding:16px 24px;color:#fff;font-weight:600;font-size:.88rem;text-align:center;letter-spacing:.04em}
.icd-new-tbl th:first-child{width:36%;border-right:1px solid rgba(255,255,255,.2)}
.icd-new-tbl td{padding:18px 24px;border-bottom:1px solid #e8e8e8;color:#333;vertical-align:middle;text-align:center;line-height:1.65}
.icd-new-tbl td:first-child{font-family:'Montserrat',sans-serif;font-weight:700;color:#1a1a1a;font-size:.95rem;border-right:1px solid #e8e8e8}
.icd-new-tbl tr:last-child td{border-bottom:none}
.icd-new-tbl tr:hover td{background:#f8f9fc}
@media(max-width:900px){
  .icd-layout{grid-template-columns:1fr}
  .icd-vis{min-height:300px}
  .icd-tbl-wrap{padding:3rem 1.5rem}
}
.icd-code{font-family:'Montserrat',sans-serif;font-weight:700;color:var(--red);font-size:.82rem;white-space:nowrap}
.icd-badge{display:inline-block;font-size:.6rem;font-weight:700;letter-spacing:.08em;padding:2px 8px;border-radius:100px;background:rgba(18,32,62,.08);color:var(--nv)}
.icd-note{max-width:1000px;margin:1.2rem auto 0;padding:1rem 1.4rem;background:rgba(214,48,49,.05);border-left:3px solid var(--red);border-radius:0 8px 8px 0;font-size:.78rem;font-weight:300;color:var(--ts);line-height:1.8}

/* 건강보험적용 */
/* ═══════════ 건강보험 적용 ═══════════ */
#insurance{padding:0;background-image:url(img/insurance_application.jpg); background-size:cover; background-position: center center; position:relative;overflow:hidden;min-height:680px;display:flex;align-items:center}

/* 배경 인물 SVG */
.ins-bg-fig{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none}
.ins-hero{position:relative;z-index:1;width:100%;max-width:1100px;margin:0 auto;padding:100px 5%}
.ins-hero-header{text-align:center;margin-bottom:3.5rem}
.ins-hero-header h2{font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:900;color:#fff;letter-spacing:-.02em;margin-bottom:1.2rem}
.ins-hero-header p{font-size:1.1rem;font-weight:300;color:rgba(255,255,255,.65);line-height:1.9;max-width:580px;margin:0 auto}
/* 카드 2개 */
.ins-cards-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;max-width:860px;margin:0 auto}
.ins-cards-single{grid-template-columns:1fr;max-width:420px}
.ins-box{padding:3rem 2.8rem;border-radius:4px;cursor:default}
.ins-box-blue{background:rgba(90,135,180,.75);backdrop-filter:blur(4px)}
.ins-box-outline{background:rgba(255,255,255,.06);border:1.5px solid rgba(255,255,255,.35);backdrop-filter:blur(4px)}
.ins-box h3{font-size:1.6rem;font-weight:400;color:#fff;letter-spacing:-.01em;margin-bottom:1.2rem;text-align:center}
.ins-box p{font-size:.1.1rem;font-weight:300;color:rgba(255,255,255,.82);line-height:1.9;text-align:center}


/* ── 보험 섹션 내 상병코드 카드 ── */
.ins-icd-card {
  max-width: 560px;
  margin: 2.5rem auto 0;
  background: rgba(255,255,255,.1);
  backdrop-filter: blur(6px);
  border-radius: 6px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.15);
}

.ins-icd-header {
  padding: 1.2rem 2rem;
  font-size: 1.05rem;
  font-weight: 600;
  color: rgba(255,255,255,.85);
  letter-spacing: .04em;
  border-bottom: 1px solid rgba(255,255,255,.15);
}

.ins-icd-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.ins-icd-list li {
  display: flex;
  align-items: flex-start;
  gap: 2rem;
  padding: 1.1rem 2rem;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.ins-icd-list li:last-child {
  border-bottom: none;
}

.ins-icd-code {
  font-family: 'Montserrat', sans-serif;
  font-size: .95rem;
  font-weight: 700;
  color: #fff;
  min-width: 80px;
  flex-shrink: 0;
}

.ins-icd-desc {
  font-size: .95rem;
  font-weight: 300;
  color: rgba(255,255,255,.82);
  line-height: 1.7;
}

@media (max-width: 767px) {
  .ins-icd-card { margin-top: 1.8rem; }
  .ins-icd-header { padding: .9rem 1.2rem; font-size: .92rem; }
  .ins-icd-list li { padding: .9rem 1.2rem; gap: 1.2rem; }
  .ins-icd-code { font-size: .85rem; min-width: 65px; }
  .ins-icd-desc { font-size: .85rem; }
}






/* ── 미디어 협찬 이미지 ── */
.media-img-wrap{margin:2rem auto 2.2rem;max-width:540px;width:100%;border-radius:8px;overflow:hidden;box-shadow:0 8px 40px rgba(0,0,0,.35)}
.media-img{width:100%;height:auto;display:block}

@media(max-width:768px){
  .ins-cards-row{grid-template-columns:1fr}
  .ins-hero{padding:64px 1.4rem}
}

@media(max-width:1024px){
  .output-grid{grid-template-columns:repeat(2,1fr)}
  .timer-row{flex-direction:column;gap:3rem}
  .timer-vis{flex:none;width:100%;max-width:300px;margin:0 auto}

  .target-grid{grid-template-columns:repeat(2,1fr)}
  .ins-row{flex-direction:column;gap:2.5rem}
  .ins-right{flex:none;width:100%}

  #media{min-height: 410px;}
}
@media(max-width:768px){
  #output,#timer-care,#target,#icd,#insurance{padding:64px 1.2rem}
  .output-grid{grid-template-columns:1fr}
  .target-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:480px){
  .target-grid{grid-template-columns:1fr}
  .output-grid{grid-template-columns:1fr}
}

/* ═══════════════════════════════════════════════════
   슬라이더 + 전체 반응형 완전 수정판
   (태블릿 768~1024px / 모바일 ~767px / 소형 ~480px)
═══════════════════════════════════════════════════ */

/* ── 슬라이더 기본: 흰 배경, 양쪽 잘림 ── */
.pfsw{
  overflow:hidden;
  background:#ffffff;
  padding:50px 0;
}
.pfto{overflow:visible; width:100%}
.pft{display:flex; will-change:transform; align-items:center}

.pfs{
  flex:0 0 auto;
  padding:0;
  display:flex; justify-content:center; align-items:center;
  box-sizing:border-box;
  transition:opacity .4s;
}
.pfs:not(.act){opacity:1}

/* pfcpoint 비활성: 회색 원 */
.pfcpoint{
  width:85%;
  aspect-ratio:1/1;
  border-radius:50%;
  overflow:hidden;
  position:relative;
  background:#e3e1de;
  box-shadow:none; border:none; padding:0;
  display:flex; align-items:center; justify-content:center;
  transition:background .45s ease, box-shadow .45s ease;
}
/* pfcpoint 활성: 흰색 원 */
.pfs.act .pfcpoint{
  background:#ffffff;
  box-shadow:0 4px 32px rgba(0,0,0,.09);
}
.pf-img{width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden}
.pf-img img{width:100%;height:100%;object-fit:cover;display:block}
.pf-img svg{width:80%;height:80%;object-fit:contain}


/* ════════════════════════════
   태블릿 (768px ~ 1024px)
════════════════════════════ */
@media(max-width:1024px){

  /* NAV */
  #nav{padding:0 3%}

  /* Hero */
  .hin{flex-direction:column-reverse; padding:3rem 4% 2rem; gap:2rem; min-height:auto}
  .hvis{flex:none; width:100%; max-width:380px; margin:0 auto}
  .hcopy{text-align:center; flex:none; width:100%}
  .htag{font-size:1rem}
  .hent{font-size:clamp(2.2rem,5vw,3.2rem)}
  .hkr{font-size:1.1rem}
  .bred{font-size:1rem; padding:13px 28px}
  .hbtns{display:flex; justify-content:center}
  .scroll-indicator{display:none}

  /* 슬라이더 */
  #features{padding:60px 0 0}
  #features .lbl{font-size:1.8rem; letter-spacing:.1em}
  .pfsw{padding:40px 0}

  /* Product */
  .prod-row,.prod-row.rev{flex-direction:column}
  .prod-vis{flex:none; min-height:400px; width:100%; background-size:cover}
  .prod-txt{flex:none; padding:3rem 5%}
  .prod-txt-inner h2{font-size:clamp(1.5rem,3vw,2rem)}
  .prod-txt-inner p{font-size:.95rem}
  .prod-row{margin-bottom:60px}

  /* Specs */
  #specs{padding:80px 5%}
  .specs-layout{grid-template-columns:1fr; gap:3rem}
  .specs-right{order:-1}
  .specs-img{max-width:320px; margin:0 auto}
  .specs-table td{font-size:.92rem}

  /* Howto steps */
  .ht-steps{grid-template-columns:repeat(2,1fr); max-width:100%; padding:0 4%}
  .ht-cert-row{flex-direction:column; gap:2.5rem; padding:0 4%}
  .ht-cert-left{flex:none; width:100%}
  .ht-mode-row{flex-direction:column; gap:2.5rem; padding:0 4%}
  .ht-mode-right{order:-1}

  /* howto-new */
  #howto-new{padding:80px 4%}
  .howto-steps{grid-template-columns:repeat(2,1fr)}
  .howto-step h3{font-size:1.2rem}
  .howto-step p{font-size:.95rem}

  /* mode-select */
  #mode-select{padding:80px 0}
  .mode-layout{grid-template-columns:1fr}
  .mode-txt{padding:3rem 5%}
  .mode-txt h2{font-size:clamp(1.4rem,3vw,2rem)}
 

  /* cert-info */
  #cert-info{padding:80px 4%}
  .cert-info-inner{grid-template-columns:1fr; gap:2.5rem}

  /* icd */
  .icd-layout{grid-template-columns:1fr}
  .icd-vis{min-height:280px; padding:40px 5%}
  .icd-tbl-wrap{padding:2.5rem 5%}
  .icd-tbl-title{font-size:clamp(1.4rem,3vw,2rem)}
  .icd-new-tbl th,.icd-new-tbl td{padding:12px 14px; font-size:.85rem}

  /* insurance */
  .ins-hero{padding:80px 5%}
  .ins-cards-row{grid-template-columns:1fr; max-width:480px}
  .ins-cards-single{max-width:360px}
  .ins-box{padding:2rem 2rem}
  .ins-box h3{font-size:1.3rem}

  /* caution */
  #caution{padding:80px 4%}
  .caution-inner{grid-template-columns:1fr; gap:2rem}

  /* consult */
  #consult{padding:80px 4%}
  .cgrd{grid-template-columns:1fr; gap:2.5rem}

  /* CTA */
  .cta-band{padding:48px 5%}

  /* bstrip */
  .bstrip{grid-template-columns:1fr}

  /* sp-grid */
  .sp-grid{grid-template-columns:repeat(2,1fr)}

  /* FAQ */
  #faq{padding:80px 4%}
  .fqq{font-size:1rem}
}


/* ════════════════════════════
   모바일 (~ 767px)
════════════════════════════ */
@media(max-width:767px){

  /* NAV */
  #nav{padding:0 1rem; height:58px}
  .nmenu{display:none}
  .hbg{display:flex}
  .nlogo{font-size:1.1rem}

  /* Hero - 배경 이미지 잘림 방지 */
  #hero{
    min-height:520px;
    background-position:left center;
    background-size:cover;
  }
  .hin{
    flex-direction:column-reverse;
    padding:2rem 1rem 2rem;
    gap:1.5rem; min-height:auto;
    text-align:center;
  }
  .hvis{width:100%; max-width:240px; margin:0 auto}
  .hpwrap{width:220px; height:auto; aspect-ratio:1/1}
  .hcopy{text-align:center; width:100%}
  .htag{font-size:.85rem}
  .hent{font-size:clamp(1.8rem,7vw,2.6rem)}
  .hkr{font-size:.9rem; margin-bottom:1rem}
  .bred{font-size:.88rem; padding:11px 22px}
  .hbtns{display:flex; justify-content:center}

  /* 슬라이더 */
  #features{padding:44px 0 0}
  #features .lbl{font-size:1.3rem; letter-spacing:.08em}
  #features .inn{padding:0 1rem; margin-bottom:1.5rem}
  .pfsw{padding:28px 0; overflow:hidden}
  .pfto{overflow:visible}
  .pfs{padding:0 3px}
  .pfcpoint{width:88%}
  .pfs.act .pfcpoint{width:88%}
  .pfa.prev{left:2px; padding:.8rem 1.5%}
  .pfa.next{right:2px; padding:.8rem 1.5%}
  .pf-caption{padding:1.8rem 1rem 3rem}
  .pf-caption h3{font-size:1.6rem}
  .pf-caption p{font-size:.88rem}

  /* Product - 이미지 잘림 방지 */
  #product{padding:0}
  .prod-row,.prod-row.rev{flex-direction:column; margin-bottom:0}
  .prod-vis{
    flex:none; width:100%; min-height:280px;
    background-size:cover; background-position:center;
  }
  .prod-txt{flex:none; padding:2rem 1rem}
  .prod-txt-inner h2{font-size:clamp(1.3rem,5vw,1.7rem); margin-bottom:1rem}
  .prod-txt-inner p{font-size:.88rem; line-height:1.9}

  /* Specs */
  #specs{padding:56px 1rem}
  .specs-layout{grid-template-columns:1fr; gap:2rem}
  .specs-right{order:-1}
  .specs-img{max-width:220px; margin:0 auto}
  .specs-title{font-size:1.4rem}
  .specs-table td{font-size:.82rem; padding:10px 0}
  .specs-table td:first-child{width:42%; padding-right:1rem}

  /* howto-new - 사용방법 */
  #howto-new{padding:48px 1rem}
  #howto-new .howto-title{font-size:1.2rem; margin-bottom:1.5rem}
  .howto-steps{grid-template-columns:1fr 1fr; gap:.6rem}
  .howto-step{padding:1.2rem .9rem; border-radius:8px}
  .howto-step-ico{width:1.8rem;height:1.8rem; margin-bottom:.6rem}
  .howto-step h3{font-size:1rem}
  .howto-step p{font-size:.78rem}

  /* mode-select */
  #mode-select{padding:48px 0}
  .mode-layout{grid-template-columns:1fr}
  .mode-txt{padding:2rem 1rem}
  .mode-txt h2{font-size:1.3rem; margin-bottom:1rem}
  .mode-txt p{font-size:.88rem; margin-bottom:1.5rem}
  

  /* cert-info */
  #cert-info{padding:48px 1rem}
  .cert-info-inner{grid-template-columns:1fr; gap:1.8rem}
  .cert-info-desc{font-size:.88rem}
  .cert-info-grid{grid-template-columns:1fr 1fr}
  .ci-img-card:nth-child(even){margin-top:1.5rem}

  /* output */
  #output{padding:0}
  .output-hero{min-height:auto}
  .output-title-wrap{padding:40px 1rem 0}
  .output-title-wrap h2{font-size:1.3rem}
  .output-img-wrap svg{width:92vw}

  /* timer */
  #timer-care{padding:40px 1rem}
  .timer-content{min-height:280px; padding:28px 3%}
  .timer-ring-wrap{width:min(75vw,260px)}
  .timer-bg-text{font-size:clamp(70px,26vw,120px)}
  .timer-center-txt h2{font-size:1.2rem}
  .timer-center-txt p{font-size:.82rem}

  /* principle - 이미지 잘림 방지 */
  #principle{
    background-position:center;
    background-size:cover;
    min-height:auto;
  }
  .principle-layout{flex-direction:column; min-height:auto}
  .principle-vis{flex:0 0 200px; min-height:200px}
  .principle-content{padding:2rem 1rem}
  .principle-text h2{font-size:1.3rem; margin-bottom:1rem}
  .principle-text .p-block p{font-size:.88rem}

  /* target - 이미지 잘림 방지 */
  #target{padding:48px 0 0}
  .target-header{padding:0 1rem 32px}
  .target-header h2{font-size:1.5rem}
  .target-header p{font-size:.88rem}
  .target-slider{flex-direction:column}
  .target-slide{
    flex:none !important; width:100%;
    min-height:200px;
    background-size:cover !important;
    background-position:center !important;
  }

  /* icd */
  #icd{padding:0}
  .icd-layout{grid-template-columns:1fr}
  .icd-vis{min-height:200px; padding:2rem 1rem}
  .icd-tbl-wrap{padding:2rem 1rem}
  .icd-tbl-title{font-size:1.2rem; margin-bottom:1.2rem}
  .icd-new-tbl th,.icd-new-tbl td{padding:10px 8px; font-size:.78rem}

  /* insurance - 이미지 잘림 방지 */
  #insurance{
    background-position:center;
    background-size:cover;
    min-height:auto;
  }
  .ins-hero{padding:48px 1rem}
  .ins-hero-header h2{font-size:1.4rem; margin-bottom:.8rem}
  .ins-hero-header p{font-size:.88rem}
  .ins-hero-header{margin-bottom:2rem}
  .ins-cards-row{grid-template-columns:1fr; max-width:100%; gap:1rem}
  .ins-box{padding:1.5rem 1.2rem}
  .ins-box h3{font-size:1.1rem; margin-bottom:.8rem}
  .ins-box p{font-size:.88rem}

  /* media */
  #media{min-height:280px; background-size:cover; background-position:center}
  .media-hero{padding:40px 1rem}
  .media-hero h2{font-size:1.4rem}
  .media-hero p{font-size:.88rem; margin-bottom:1.5rem}
  .sp-grid{grid-template-columns:1fr}
  .bstrip{grid-template-columns:1fr; border-radius:0}
  .bnum{font-size:2.4rem}

  /* caution */
  #caution{padding:48px 1rem}
  .caution-inner{grid-template-columns:1fr; gap:1.5rem}
  .caution-left h2{font-size:1.3rem}
  .caution-left p{font-size:.88rem}
  .caution-box{padding:1.5rem 1rem}
  .caution-list li{font-size:.88rem}

  /* FAQ */
  #faq{padding:56px 1rem}
  .fqq{font-size:.92rem; padding:1.1rem 0}
  .fqa{font-size:.85rem}

  /* CTA */
  .cta-band{flex-direction:column; text-align:center; padding:36px 1rem}
  .cta-band-btns{justify-content:center}
  .cta-band-txt{font-size:.95rem}

  /* Consult */
  #consult{padding:56px 1rem}
  .cgrd{grid-template-columns:1fr; gap:2rem}
  .cform .row2{grid-template-columns:1fr}
  .crow{font-size:.88rem}

  /* Map */
  #map-section{padding:0 0 48px}
  #map-section .inn{padding-top:48px; padding-left:1rem; padding-right:1rem}
  .map-kakao{height:260px; border-radius:8px}
  .map-addr-bar{font-size:.8rem}

  /* Footer */
  footer{padding:2rem 1rem 1.2rem}
  .finn-top{flex-direction:column; gap:1rem}
  .finn-logo-wrap svg{width:48px; height:48px}
  .finn-info-row,.finn-info-tel{font-size:.78rem}
  .fcp{font-size:.68rem; margin-left:0; margin-top:.5rem}

  /* FAB */
  #fabGroup{right:12px; bottom:16px; gap:7px}
  .fab{width:42px; height:42px}
  .fab-label{display:none}
  .fab svg{width:19px; height:19px}
}


/* ════════════════════════════
   소형 모바일 (~ 480px)
════════════════════════════ */
@media(max-width:480px){

  #hero{min-height:460px}
  .hent{font-size:clamp(1.6rem,8vw,2.2rem)}
  .htag{font-size:.78rem}
  .hkr{font-size:.82rem}
  .bred{font-size:.82rem; padding:10px 18px}

  #features .lbl{font-size:1.1rem}
  .pfsw{padding:22px 0}

  .howto-steps{grid-template-columns:1fr 1fr}
  .howto-step{padding:1rem .7rem}
  .howto-step h3{font-size:.9rem}
  .howto-step p{font-size:.72rem}

  .cert-info-grid{grid-template-columns:1fr}

  .icd-new-tbl{font-size:.72rem}
  .icd-new-tbl th,.icd-new-tbl td{padding:8px 6px}

  .ins-box h3{font-size:1rem}

  .target-slide{min-height:160px}

  .bnum{font-size:2rem}
  .bi{padding:1.8rem 1rem}

  .cform input,.cform textarea,.cform select{font-size:.8rem}

  .map-kakao{height:220px}
}

/* ══ 흔들림(가로 스크롤) 방지 패치 ══ */

/* 루트 레벨에서 완전 차단 */
html, body {
  overflow-x: hidden;
  max-width: 100%;
}

/* 히어로: 배경 파티클이 밖으로 못 나가게 */
#hero {
  overflow: hidden;
  max-width: 100vw;
}

/* 히어로 내부 컨테이너 너비 제한 */
.hin {
  width: 100%;
  box-sizing: border-box;
  overflow: hidden;
}

/* hblob 파티클 — 모바일에서 완전 숨김 */
@media(max-width:1024px){
  .hblob { display: none; }
  .hp    { display: none; }
}

/* 모바일 히어로 완전 수정 */
@media(max-width:767px){

  #hero {
    min-height: 460px;
    background-position: center center;
    background-size: cover;
  }

  .hin {
    flex-direction: column;          /* 텍스트 위, 이미지 아래 */
    padding: 5rem 1rem 2rem;
    gap: 1.2rem;
    min-height: auto;
    text-align: center;
    justify-content: center;
    overflow: hidden;
  }

  /* 이미지 카드 — 모바일에서 숨김 (배경이미지로 대체) */
  .hvis { display: none; }

  /* 텍스트 영역 전체 너비 */
  .hcopy {
    flex: none;
    width: 100%;
    text-align: center;
    padding: 0;
  }

  .htag  { font-size: .85rem; }
  .hent  { font-size: clamp(1.9rem, 8vw, 2.6rem); }
  .hkr   { font-size: .9rem; margin-bottom: 1.2rem; }
  .bred  { font-size: .88rem; padding: 11px 24px; }
  .hbtns { display: flex; justify-content: center; }

  /* 스크롤 인디케이터 숨김 */
  .scroll-indicator { display: none; }
}

@media(max-width:480px){
  .hin { padding: 4.5rem .8rem 1.5rem; }
  .hent { font-size: clamp(1.7rem, 9vw, 2.2rem); }
  .htag { font-size: .8rem; }
  .hkr  { font-size: .82rem; }
}



/* 모바일/태블릿에서 레이아웃 */
@media(max-width:1024px){
  #mode-select { padding: 60px 0; }
  .mode-layout {
    grid-template-columns: 1fr;
    gap: 0;
  }

  /* 이미지를 위, 텍스트를 아래 */
  .mode-vis {
    order: -1;
    min-height: 280px;
    justify-content: center;
    background: #f0efed;
  }

  .mode-txt {
    padding: 2.5rem 5%;
  }

  /* 클릭 영역 충분히 확보 */
  .mode-item {
    padding: 1.2rem 1.4rem;
    cursor: pointer;
    -webkit-tap-highlight-color: rgba(0,0,0,.05);
    user-select: none;
  }
}

@media(max-width:767px){
  #mode-select { padding: 48px 0; }
  .mode-vis { min-height: 220px; }
  .mode-txt  { padding: 2rem 1rem; }
  .mode-txt h2 { font-size: 1.3rem; margin-bottom: .8rem; }
  .mode-txt p  { font-size: .88rem; margin-bottom: 1.5rem; }
  .mode-item   { padding: 1rem 1rem; }
  .mode-num    { font-size: .72rem; min-width: 60px; }
  .mode-name   { font-size: .88rem; }
}

/* ══════════════════════════════════════
   3가지 수정 패치
   1) 피부질환 슬라이드 잘림
   2) 지도 핀 중앙
   3) mode-vis 이미지 중앙
══════════════════════════════════════ */

/* ── 1. 사용대상 슬라이드 태블릿 잘림 방지 ── */
@media(max-width:1024px) and (min-width:768px){
  .target-slider{
    flex-direction: column;   /* 태블릿도 세로로 쌓기 */
    overflow: visible;
  }
  .target-slide{
    flex: none !important;
    width: 100%;
    min-height: 260px;
    background-size: cover !important;
    background-position: center !important;
  }
  .target-slide:hover{ flex: none !important; }
  .target-slide-txt h3{ font-size: 1.2rem; }
  .target-slide-txt p{
    opacity: 1 !important;
    transform: translateY(0) !important;
    font-size: .9rem;
  }
}

/* ── 2. 지도 핀 정중앙 (카카오 정적지도 MX/MY = 이미지 정중앙) ── */
.map-pin-overlay{
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -100%);
  z-index: 10;
  pointer-events: none;
  filter: drop-shadow(0 3px 6px rgba(0,0,0,.35));
  animation: pinBounce 2.2s ease-in-out infinite;
}
@keyframes pinBounce{
  0%,100%{ transform: translate(-50%,-100%) translateY(0) }
  50%    { transform: translate(-50%,-100%) translateY(-8px) }
}

/* ── 3. mode-vis 이미지 완전 중앙 정렬 ── */
.mode-vis{
  justify-content: center !important;
  background: #f0efed;
}


/* 태블릿/모바일 mode-vis 중앙 강제 */
@media(max-width:1024px){
  .mode-vis{
    order: -1;
    justify-content: center !important;
    align-items: center;
    min-height: 280px;
    width: 100%;
  }
}
@media(max-width:767px){
  .mode-vis{ min-height: 220px; }
}

/* ══════════════════════════════════════
   사용대상 슬라이드 텍스트 위치 + 지도 수정
══════════════════════════════════════ */

/* ── 사용대상: 텍스트 항상 하단 왼쪽 고정 ── */
.target-slide{
  display: flex;
  flex-direction: column;
  justify-content: flex-end;   /* 텍스트를 항상 하단 */
  align-items: flex-start;
}
.target-slide-txt{
  width: 100%;
  padding: 1.6rem 1.8rem;
  margin-top: auto;
}
.target-slide-txt h3{
  font-size: clamp(.95rem,1.4vw,1.3rem);
  font-weight: 800;
  color: #fff;
  text-shadow: 0 2px 8px rgba(0,0,0,.5);
  margin-bottom: .4rem;
}
/* 모든 슬라이드 텍스트 흰색 */
.ts1 .target-slide-txt h3,
.ts2 .target-slide-txt h3,
.ts3 .target-slide-txt h3{ color:#fff; text-shadow:0 2px 8px rgba(0,0,0,.5); }

/* 기본 상태: p 모두 숨김 → hover 시 표시 */
.target-slide-txt p{
  font-size: .88rem;
  font-weight: 300;
  line-height: 1.75;
  color: rgba(255,255,255,.88);
  text-shadow: 0 1px 6px rgba(0,0,0,.5);
  opacity: 0;
  transform: translateY(8px);
  transition: opacity .3s ease, transform .3s ease;
}
.target-slide:hover .target-slide-txt p{
  opacity: 1;
  transform: translateY(0);
}

/* 태블릿: 세로 쌓기 + 텍스트 항상 표시 */
@media(max-width:1024px){
  .target-slider{ flex-direction: column; overflow: visible; }
  .target-slide{
    flex: none !important;
    width: 100%;
    min-height: 220px;
  }
  .target-slide:hover{ flex: none !important; }
  .target-slide-txt{ padding: 1.4rem 1.4rem; }
  .target-slide-txt p{
    opacity: 1 !important;
    transform: translateY(0) !important;
  }
}

/* 모바일: 높이 축소 */
@media(max-width:767px){
  .target-slide{ min-height: 180px; }
  .target-slide-txt{ padding: 1.2rem 1rem; }
  .target-slide-txt h3{ font-size: .95rem; }
  .target-slide-txt p{ font-size: .82rem; }
}

/* ── 카카오맵 컨테이너 ── */
#kakaoMap{
  width: 100%;
  height: 100%;
  min-height: 480px;
}
@media(max-width:768px){
  #kakaoMap{ min-height: 320px; }
}
@media(max-width:480px){
  #kakaoMap{ min-height: 260px; }
}

/* 지도 핀 오버레이 숨김 (API 지도 사용 시 불필요) */
.map-pin-overlay{ display: none; }

/* ══════════════════════════════════════════
   지도 핀 복원 + 조사면적/LED 정렬 수정
══════════════════════════════════════════ */

/* ── 지도 핀: 복원 및 중앙 정렬 ── */
.map-pin-overlay{
  display: flex !important;     /* 이전 패치의 display:none 해제 */
  flex-direction: column;
  align-items: center;
  position: absolute;
  top: 73%;
  left: 50%;
  transform: translate(-50%, -100%);
  z-index: 10;
  pointer-events: none;
  filter: drop-shadow(0 3px 6px rgba(0,0,0,.35));
  animation: pinBounce2 2.2s ease-in-out infinite;
}
@keyframes pinBounce2{
  0%,100%{ transform: translate(-50%,-100%) translateY(0) }
  50%    { transform: translate(-50%,-100%) translateY(-7px) }
}

/* ── #tech (조사면적): 태블릿/모바일 정렬 ── */
@media(max-width:1024px){
  #tech{ padding: 80px 5%; }
  .tech-row{
    grid-template-columns: 1fr;
    gap: 2.5rem;
    padding: 0;
  }
  .tech-txt{
    /* specs 제목과 같은 왼쪽 정렬, padding 통일 */
    padding: 0;
    text-align: left;
  }
  .tech-txt h2{ margin-bottom: 1.2rem; }
  .tech-txt p{ font-size: .95rem; }
  .tech-vis{
    order: 1;
    justify-content: center;
  }
}
@media(max-width:767px){
  #tech{ padding: 56px 1rem; }
  .tech-txt h2{ font-size: clamp(1.3rem,5vw,1.7rem); }
  .tech-txt p{ font-size: .88rem; line-height: 1.9; }
  .tech-orb-wrap{ width: 220px; height: 220px; }
  .tech-orb-wrap::before{ width: 220px; height: 220px; }
  .tech-orb-wrap::after{ width: 158px; height: 158px; }
  .torb-orbit{ width: 158px; height: 158px; }
}

/* ── #product (발광다이오드 LED): 태블릿/모바일 정렬 ── */
@media(max-width:1024px){
  .prod-row,.prod-row.rev{ flex-direction: column; margin-bottom: 40px; }
  .prod-vis{
    flex: none;
    width: 100%;
    min-height: 540px;
    background-size: cover;
    background-position: center;
  }
  .prod-txt{
    flex: none;
    /* specs 제목 위치와 동일하게 padding 맞춤 */
    padding: 2.5rem 5%;
    width: 100%;
  }
  .prod-txt-inner{
    max-width: 100%;
  }
  .prod-txt-inner h2{
    font-size: clamp(1.4rem,3vw,2rem);
    margin-bottom: 1rem;
  }
  .prod-txt-inner p{ font-size: .92rem; line-height: 1.95; }
}
@media(max-width:767px){
  .prod-txt{ padding: 2rem 1rem; }
  .prod-txt-inner h2{ font-size: clamp(1.2rem,5vw,1.6rem); }
  .prod-txt-inner p{ font-size: .88rem; }
}

/* ── mode-svg 이미지 전환 (PC / 태블릿 / 모바일 공통) ── */
.mode-svg {
  display: none;
  width: 100%;
  text-align: center;
}
.mode-svg.active {
  display: block;
}
.mode-svg img {
  width: 100%;
  max-width: 480px;
  height: auto;
  display: block;
  margin: 0 auto;
}
@media (max-width: 1024px) {
  .mode-svg img { max-width: 380px; }
}
@media (max-width: 767px) {
  .mode-svg img { max-width: 280px; }
}

/* ── 미디어 이미지 반응형 ── */
@media(max-width:768px){
  .media-img-wrap{max-width:100%;margin:1.4rem auto 1.8rem;border-radius:6px}
}
@media(max-width:480px){
  .media-img-wrap{margin:1rem auto 1.4rem}
}
