/* ========================================
   Global
======================================== */
:root{
  /* 세담 메인색(업로드 이미지 기준) */
  --primary-color:#217058;
  --secondary-color:#217058;

  /* 요청: 컬러 전부 통일 */
  --success-color:#217058;
  --danger-color:#217058;
  --warning-color:#217058;

  /* 이하 기존 그대로 */
  --dark-color:#0f172a;
  --light-color:#f8fafc;
  --bg:#ffffff;
  --muted:#64748b;
  --border:#e2e8f0;

  --radius:18px;
  --shadow:0 10px 30px rgba(2,6,23,.08);
  --shadow2:0 18px 50px rgba(2,6,23,.10);

  --container:1120px;
  --font: "Noto Sans KR", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;

  --kakao-yellow:#FEE500;
  --kakao-brown:#3C1E1E;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font);
  color:var(--dark-color);
  background:var(--bg);
  line-height:1.7;
}
a{color:inherit; text-decoration:none}
img{max-width:100%; display:block}
button,input,select,textarea{font:inherit}

.container{
  width:min(var(--container), calc(100% - 48px));
  margin:0 auto;
}

.sr-only{
  position:absolute; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}

.eyebrow{
  letter-spacing:.12em;
  font-weight:900;
  font-size:.78rem;
  color:var(--secondary-color);
  margin:0 0 10px;
}

/* ========================================
   Buttons
======================================== */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:12px 16px;
  border-radius:999px;
  border:1px solid transparent;
  cursor:pointer;
  transition:transform .12s ease, box-shadow .12s ease, background .12s ease, border-color .12s ease;
  user-select:none;
}
.btn:active{transform:translateY(1px)}

.btn-primary{
  background:var(--primary-color);
  color:#fff;
  box-shadow:0 10px 24px rgba(17,58,46,.22);
  font-weight:800;
}
.btn-primary:hover{background:color-mix(in srgb, var(--primary-color) 90%, black)}

.btn-ghost{
  background:transparent;
  border-color:var(--border);
  color:var(--dark-color);
  font-weight:800;
}
.btn-ghost:hover{border-color:color-mix(in srgb, var(--border) 60%, var(--primary-color))}

.btn-light{
  background:#fff;
  border-color:rgba(255,255,255,.45);
  color:var(--dark-color);
  font-weight:900;
}

.btn-kakao{
  background:var(--kakao-yellow);
  color:var(--kakao-brown);
  border-color:transparent;
  box-shadow:0 10px 24px rgba(254,229,0,.25);
  font-weight:900;
}
.btn-kakao:hover{
  background:color-mix(in srgb, var(--kakao-yellow) 92%, black);
}

/* ========================================
   Header / Nav
======================================== */
.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,.82);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(226,232,240,.7);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:14px 0;
}
.brand{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:900;
}
.brand-mark{
  width:28px; height:28px;
  border-radius:10px;
  background:linear-gradient(135deg, var(--primary-color), color-mix(in srgb, var(--primary-color) 70%, black));
  box-shadow:0 10px 18px rgba(17,58,46,.22);
}
.brand-name{font-size:1.05rem}

.nav{display:flex; align-items:center; gap:10px}
.nav-menu{
  display:flex;
  align-items:center;
  gap:18px;
}
.nav-menu a{
  font-weight: 800;
  font-size: 1.02rem;          /* 조금 키움 */
  color: var(--primary-color);  /* 메인색으로 통일 */
}

.nav-menu a:hover{
  color: color-mix(in srgb, var(--primary-color) 85%, black);
}

.nav-toggle{
  display:none;
  background:transparent;
  border:1px solid var(--border);
  width:42px; height:42px;
  border-radius:12px;
}
.burger{
  display:block;
  width:18px; height:2px;
  background:var(--dark-color);
  margin:0 auto;
  position:relative;
}
.burger::before,.burger::after{
  content:"";
  position:absolute;
  left:0;
  width:18px; height:2px;
  background:var(--dark-color);
}
.burger::before{top:-6px}
.burger::after{top:6px}

/* ========================================
   Sections common
======================================== */
.section-head{
  text-align:center;
  margin-bottom:26px;
}
.section-head h2{
  margin:0 0 8px;
  font-size:clamp(1.4rem, 1.2rem + 1vw, 2rem);
}
.section-head p{
  margin:0 auto;
  max-width:720px;
  color:var(--muted);
}

/* ========================================
   Hero (Full-bleed slider + translucent overlay)
======================================== */
.hero-full{
  position: relative;
  min-height: calc(100vh - 72px); /* 헤더 높이에 맞춰 조정 */
  display: flex;
  align-items: center;
  padding: 80px 0 64px;
  overflow: hidden;
  color: #fff;
  border-bottom: 3px solid var(--primary-color);
}

.hero-full .hero-inner{
  position: relative;
  z-index: 3;
}

.hero-copy{ max-width: 640px; }

.hero-pill{
  display:inline-flex;
  align-items:center;
  padding:10px 16px;
  border-radius:10px;
  font-weight:900;
  letter-spacing:.18em;
  font-size:.78rem;
  background:rgba(255,255,255,.92);
  color:var(--primary-color);
  margin-bottom:18px;
}

.hero-full h1{
  margin:0 0 18px;
  font-size:clamp(2.1rem, 1.6rem + 2.2vw, 3.4rem);
  line-height:1.12;
}

.hero-sub{
  display:flex;
  gap:14px;
  align-items:flex-start;
  margin-bottom:22px;
}
.hero-sub-bar{
  width:4px;
  height:56px;
  border-radius:999px;
  background:var(--primary-color);
  margin-top:4px;
}
.hero-sub-text{
  margin:0;
  color:rgba(255,255,255,.88);
  font-weight:700;
}

.hero-cta{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

/* Background slider fills whole hero */
.hero-bg{
  position:absolute;
  inset:0;
  z-index:0;
}
.hero-slider{ position:absolute; inset:0; }

.hero-track{
  display:flex;
  height:100%;
  width:300%;
  transform: translateX(0%);
  transition: transform .5s ease;
}
.hero-slide{
  position:relative;
  flex: 0 0 33.3333%;
  height:100%;
}
.hero-slide-bg{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  transform:scale(1);
}

/* Active zoom */
.hero-slide.is-active .hero-slide-bg{
  animation: heroZoom 6s ease both;
}
@keyframes heroZoom{
  from{ transform:scale(1); }
  to{ transform:scale(1.10); }
}

/* Translucent overlays */
.hero-overlay{
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
}
.hero-overlay-dim{ background: rgba(2, 6, 23, .35); }
.hero-overlay-left{
  background: linear-gradient(
    90deg,
    rgba(2, 6, 23, .62) 0%,
    rgba(2, 6, 23, .35) 45%,
    rgba(2, 6, 23, .08) 78%,
    rgba(2, 6, 23, 0) 100%
  );
}

/* Slider UI */
.hero-nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:44px; height:44px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.45);
  background:rgba(255,255,255,.12);
  color:#fff;
  cursor:pointer;
  z-index:2;
}
.hero-nav-prev{ left:14px; }
.hero-nav-next{ right:14px; }

.hero-dots{
  position:absolute;
  left:50%;
  bottom:16px;
  transform:translateX(-50%);
  display:flex;
  gap:8px;
  z-index:2;
}
.hero-dot{
  width:10px; height:10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.55);
  background:transparent;
  cursor:pointer;
}
.hero-dot.active{ background:#fff; border-color:#fff; }

/* Placeholder backgrounds (swap to real images later) */

.bg-1{ background-image: url("../img/hero/hero-01.png"); }
.bg-2{ background-image: url("../img/hero/hero-02.png"); }
.bg-3{ background-image: url("../img/hero/hero-03.png"); }

/* ========================================
   Feature panels
======================================== */
.feature-panels{ padding:28px 0 10px; }
.panel{
  border-radius:calc(var(--radius) + 10px);
  padding:28px;
  margin-bottom:14px;
  color:#fff;
  position:relative;
  overflow:hidden;
  box-shadow:var(--shadow2);
  border:1px solid rgba(255,255,255,.14);
}
.panel::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(15,23,42,.86), rgba(15,23,42,.25));
}
.panel-a{ background:linear-gradient(135deg, var(--primary-color), #0b3a2e); }
.panel-b{ background:linear-gradient(135deg, var(--primary-color), #0a2c25); }
.panel-meta{ position:relative; max-width:60ch; }
.panel h2{
  margin:0 0 10px;
  font-size:clamp(1.4rem, 1.2rem + 1vw, 2.2rem);
}
.panel p{ margin:0 0 14px; color:rgba(255,255,255,.84); }

/* ========================================
   About
======================================== */
.about{ padding:54px 0; }
.about-inner{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:22px;
  align-items:start;
}
.about-copy h2{
  margin:0 0 10px;
  font-size:clamp(1.4rem, 1.2rem + 1vw, 2.2rem);
}
.about-copy p{ margin:0; color:var(--muted); }

.stats{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:12px;
}
.stat{
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:16px;
  background:#fff;
  box-shadow:var(--shadow);
}
.stat-num{
  font-weight:900;
  font-size:1.6rem;
  color:var(--primary-color);
}
.stat-label{ color:var(--muted); font-weight:800; margin-top:6px; }

/* ========================================
   Services
======================================== */
.services{ padding:54px 0; }

.card-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:12px;
}
.card{
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:16px;
  background:#fff;
  box-shadow:var(--shadow);
  display:flex;
  flex-direction:column;
  gap:10px;
  min-height:210px;
}
.card-icon{ font-size:1.4rem; }
.card h3{ margin:0; font-size:1.05rem; }
.card p{ margin:0; color:var(--muted); font-size:.95rem; }
.card-link{
  margin-top:auto;
  font-weight:900;
  color:var(--primary-color);
}

/* ========================================
   Before / After
======================================== */
.change{ padding:54px 0; background:linear-gradient(180deg, #ffffff, #f8fafc); }

.ba-wrap{
  border:1px solid var(--border);
  border-radius:calc(var(--radius) + 10px);
  background:#fff;
  box-shadow:var(--shadow2);
  overflow:hidden;
}
.ba-stage{
  position:relative;
  aspect-ratio:12/7;
  background:#0f172a;
}
.ba-img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
}
.ba-after-mask{
  position:absolute;
  inset:0;
  width:50%;
  overflow:hidden;
  border-right:2px solid rgba(255,255,255,.9);
}
.ba-handle{
  position:absolute;
  top:0; bottom:0;
  left:50%;
  width:0;
}
.ba-handle::before{
  content:"";
  position:absolute;
  top:50%;
  left:-18px;
  transform:translateY(-50%);
  width:36px; height:36px;
  border-radius:999px;
  background:#fff;
  box-shadow:0 10px 18px rgba(2,6,23,.22);
  border:1px solid rgba(226,232,240,.9);
}
.ba-controls{
  padding:16px;
  display:grid;
  gap:10px;
}
.ba-controls input[type="range"]{ width:100%; }
.ba-caption strong{ display:block; }
.ba-caption span{ color:var(--muted); display:block; margin-top:4px; }

/* ========================================
   Portfolio
======================================== */
.portfolio{ padding:54px 0; }

.gallery{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:12px;
}
.gallery-item{
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:#fff;
  padding:0;
  overflow:hidden;
  cursor:pointer;
  box-shadow:var(--shadow);
  text-align:left;
}
.thumb{
  height:170px;
  background:linear-gradient(135deg, rgba(17,58,46,.12), rgba(15,23,42,.08));
}
.thumb-2{ background:linear-gradient(135deg, rgba(17,58,46,.14), rgba(15,23,42,.05)); }
.thumb-3{ background:linear-gradient(135deg, rgba(15,23,42,.08), rgba(17,58,46,.10)); }
.thumb-4{ background:linear-gradient(135deg, rgba(17,58,46,.10), rgba(15,23,42,.06)); }

.caption{ padding:12px 14px; font-weight:900; }

/* Lightbox */
.lightbox{ position:fixed; inset:0; z-index:80; }
.lightbox-backdrop{
  position:absolute;
  inset:0;
  background:rgba(2,6,23,.58);
}
.lightbox-dialog{
  position:relative;
  width:min(920px, calc(100% - 48px));
  margin:8vh auto 0;
  background:#fff;
  border-radius:calc(var(--radius) + 10px);
  box-shadow:var(--shadow2);
  overflow:hidden;
}
.lightbox-close{
  position:absolute;
  right:10px; top:10px;
  width:38px; height:38px;
  border-radius:12px;
  border:1px solid var(--border);
  background:#fff;
  cursor:pointer;
}
.lightbox-body{ padding:16px; }
.lightbox-img{
  height:420px;
  border-radius:var(--radius);
  background:linear-gradient(135deg, rgba(17,58,46,.12), rgba(15,23,42,.08));
  border:1px solid var(--border);
}
.lightbox-title{ margin-top:12px; font-weight:900; }

/* ========================================
   Process
======================================== */
.process{ padding:54px 0; background:linear-gradient(180deg, #ffffff, #f8fafc); }

.steps{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  grid-template-columns:repeat(5, 1fr);
  gap:12px;
}
.step{
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:#fff;
  box-shadow:var(--shadow);
  padding:16px;
}
.step-no{
  font-weight:900;
  color:var(--primary-color);
  font-size:1.1rem;
}
.step h3{ margin:10px 0 6px; font-size:1rem; }
.step p{ margin:0; color:var(--muted); font-size:.92rem; }

/* ========================================
   Reviews
======================================== */

.slider-controls{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:14px 16px;
  border-top:1px solid var(--border);
}
.dots{ display:flex; gap:8px; align-items:center; }
.dot{
  width:10px; height:10px;
  border-radius:999px;
  border:1px solid var(--border);
  background:transparent;
}
.dot.active{
  background:var(--primary-color);
  border-color:var(--primary-color);
}

/* (선택) 모바일에서 peek 줄이기 */
@media (max-width: 980px){
  .review-page{ flex-basis: 96%; min-width: 96%; }
}
/* responsive */
@media (max-width: 980px){
  .review-page{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 520px){
  .review-page{ grid-template-columns: 1fr; }
}
/* ========================================
   Footer
======================================== */
.site-footer{
  background: var(--primary-color);
  color: rgba(255,255,255,.92);
}
.footer-inner{
  padding:28px 0;
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:18px;
}
.footer-title{ font-weight:900; font-size:1.05rem; }
.footer-desc{ margin:8px 0 10px; color:rgba(255,255,255,.72); }
.footer-meta{ margin:0; color:rgba(255,255,255,.68); font-size:.92rem; }

.footer-links{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}
.footer-h{ font-weight:900; margin-bottom:8px; }
.footer-links a{
  display:block;
  padding:6px 0;
  color:rgba(255,255,255,.78);
}
.footer-links a:hover{ color:#fff; }
.footer-small{ display:block; color:rgba(255,255,255,.62); font-size:.9rem; }

.footer-bottom{
  border-top:1px solid rgba(255,255,255,.12);
  padding:14px 0;
  color:rgba(255,255,255,.62);
  font-size:.92rem;
}

/* ========================================
   Responsive
======================================== */
@media (max-width: 980px){
  .about-inner{ grid-template-columns:1fr; }
  .gallery{ grid-template-columns:repeat(2, 1fr); }
  .steps{ grid-template-columns:1fr; }
  .card-grid{ grid-template-columns:repeat(2, 1fr); }

  .hero-full{
    min-height: 72vh;
    padding: 64px 0 44px;
  }
  .hero-sub-bar{ height:44px; }

  .nav-toggle{ display:inline-flex; align-items:center; justify-content:center; }
  .nav-menu{
    position:absolute;
    right:24px;
    top:64px;
    flex-direction:column;
    align-items:stretch;
    gap:12px;
    background:#fff;
    border:1px solid var(--border);
    border-radius:16px;
    box-shadow:var(--shadow2);
    padding:14px;
    width:min(340px, calc(100vw - 48px));
    display:none;
  }
  .nav-menu.is-open{ display:flex; }
}

@media (max-width: 520px){
  .card-grid{ grid-template-columns:1fr; }
  .gallery{ grid-template-columns:1fr; }
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  .hero-track, .review-track{ transition:none; }
  .hero-slide.is-active .hero-slide-bg{ animation:none; }
}

/* ========================================
   Scroll Reveal (once per page load)
======================================== */
.reveal{
  opacity: 0;
  transform: translateY(28px);
  transition:
    opacity .7s ease,
    transform .7s ease;
  transition-delay: var(--reveal-delay, 0ms);
  will-change: opacity, transform;
}

.reveal.is-revealed{
  opacity: 1;
  transform: translateY(0);
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  .reveal{
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}

/* ========================================
   Hover Lift (cards)
======================================== */

/* 공통: 기본 상태 */
.card,
.stat,
.gallery-item,
.step,
.review-slider,
.panel{
  transition:
    transform .18s ease,
    box-shadow .18s ease,
    border-color .18s ease;
  will-change: transform, box-shadow;
}

/* 공통: hover 시 살짝 띄움 */
@media (hover: hover) and (pointer: fine){
  .card:hover,
  .stat:hover,
  .gallery-item:hover,
  .step:hover,
  .review-slider:hover,
  .panel:hover{
    transform: translateY(-6px);
    box-shadow: 0 18px 48px rgba(2,6,23,.14);
    border-color: color-mix(in srgb, var(--primary-color) 28%, var(--border));
  }

  /* 갤러리 썸네일/카드 안쪽도 같이 살짝 강조 */
  .gallery-item:hover .thumb{
    transform: scale(1.03);
    transition: transform .22s ease;
  }
}

/* 터치 환경에서는 과한 hover 효과 방지 */
@media (hover: none){
  .card,
  .stat,
  .gallery-item,
  .step,
  .review-slider,
  .panel{
    transition: none;
  }
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  .card,
  .stat,
  .gallery-item,
  .step,
  .review-slider,
  .panel{
    transition: none !important;
    transform: none !important;
  }
}

/* ========================================
   Hover Lift (cards)
======================================== */

/* 공통: 기본 상태 */
.card,
.stat,
.gallery-item,
.step,
.review-slider,
.panel{
  transition:
    transform .18s ease,
    box-shadow .18s ease,
    border-color .18s ease;
  will-change: transform, box-shadow;
}

/* 공통: hover 시 살짝 띄움 */
@media (hover: hover) and (pointer: fine){
  .card:hover,
  .stat:hover,
  .gallery-item:hover,
  .step:hover,
  .review-slider:hover,
  .panel:hover{
    transform: translateY(-6px);
    box-shadow: 0 18px 48px rgba(2,6,23,.14);
    border-color: color-mix(in srgb, var(--primary-color) 28%, var(--border));
  }

  /* 갤러리 썸네일/카드 안쪽도 같이 살짝 강조 */
  .gallery-item:hover .thumb{
    transform: scale(1.03);
    transition: transform .22s ease;
  }
}

/* 터치 환경에서는 과한 hover 효과 방지 */
@media (hover: none){
  .card,
  .stat,
  .gallery-item,
  .step,
  .review-slider,
  .panel{
    transition: none;
  }
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  .card,
  .stat,
  .gallery-item,
  .step,
  .review-slider,
  .panel{
    transition: none !important;
    transform: none !important;
  }
}

/* ========================================
   Work Links (Blog / YouTube)
======================================== */
.work-links{
  padding: 54px 0;
}

.work-card{
  display:block;
  width: min(820px, 100%);
  margin: 0 auto;
  border-radius: calc(var(--radius) + 10px);
  overflow:hidden;
  border: 1px solid var(--border);
  background: #fff;
  box-shadow: var(--shadow2);
}

.work-banner{
  width: 100%;
  height: auto;
  display:block;
}

/* 버튼 2개 */
.work-actions{
  margin-top: 18px;
  display:flex;
  gap: 16px;
  justify-content:center;
  flex-wrap: wrap;
}

.link-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  min-width: 210px;
  padding: 14px 18px;
  border-radius: 14px;
  border: 2px solid #1f2937;
  background: #fff;
  color: #0f172a;
  font-weight: 900;
  transition: transform .18s ease, box-shadow .18s ease;
}

.link-ico{
  width: 26px;
  height: 26px;
  border-radius: 8px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight: 1000;
  font-size: .95rem;
}

.link-ico-naver{
  background: #e5e7eb;
  color: #0f172a;
}

.link-ico-yt{
  background: #e5e7eb;
  color: #0f172a;
}

/* hover lift (이 섹션에도 적용) */
@media (hover: hover) and (pointer: fine){
  .work-card:hover,
  .link-btn:hover{
    transform: translateY(-6px);
    box-shadow: 0 18px 48px rgba(2,6,23,.14);
  }
}

@media (max-width: 520px){
  .link-btn{ min-width: 100%; }
}

/* ========================================
   Service Detail Pages (wipemans-like)
======================================== */
.service-hero{
  position: relative;
  min-height: 72vh;
  display:flex;
  align-items:center;
  padding: 90px 0 64px;
  overflow:hidden;
  color:#fff;
  border-bottom: 3px solid var(--primary-color);
}
.service-hero .container{ position:relative; z-index:3; }
.service-hero-copy{ max-width: 760px; }

.service-hero-kicker{
  display:inline-flex;
  padding:10px 16px;
  border-radius:10px;
  font-weight:900;
  letter-spacing:.18em;
  font-size:.78rem;
  background: rgba(255,255,255,.92);
  color: var(--primary-color);
  margin-bottom: 18px;
}

.service-hero h1{
  margin:0 0 14px;
  font-size: clamp(2.1rem, 1.6rem + 2.2vw, 3.4rem);
  line-height:1.12;
}
.service-hero p{
  margin:0;
  color: rgba(255,255,255,.90);
  font-weight:700;
  max-width: 60ch;
}

.svc-hero-bg{
  position:absolute;
  inset:0;
  background-size: cover;
  background-position: center;
  transform: scale(1);
  animation: svcZoom 10s ease both;
}
@keyframes svcZoom{
  from{ transform: scale(1); }
  to{ transform: scale(1.08); }
}

.service-cta{
  margin-top: 18px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.service-section{
  padding: 54px 0;
}
.service-section.alt{
  background: linear-gradient(180deg, #ffffff, #f8fafc);
}

.service-lead{
  max-width: 860px;
  margin: 0 auto 18px;
  color: var(--muted);
  text-align:center;
}

/* 범위/포인트 카드 */
.scope-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.scope-card{
  border:1px solid var(--border);
  border-radius: var(--radius);
  background:#fff;
  box-shadow: var(--shadow);
  padding: 16px;
}
.scope-card h3{ margin:0 0 8px; font-size:1.05rem; }
.scope-card ul{ margin:0; padding-left: 18px; color: var(--muted); font-weight:700; }
.scope-card li{ margin: 6px 0; }

.feature-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.feature-card{
  border:1px solid var(--border);
  border-radius: var(--radius);
  background:#fff;
  box-shadow: var(--shadow);
  padding: 16px;
}
.feature-card .t{ font-weight:900; margin:0 0 8px; }
.feature-card .d{ margin:0; color:var(--muted); font-weight:700; }

.note-box{
  margin-top: 16px;
  border:1px dashed color-mix(in srgb, var(--primary-color) 30%, var(--border));
  border-radius: var(--radius);
  padding: 14px;
  background: color-mix(in srgb, var(--primary-color) 6%, #fff);
  color: color-mix(in srgb, var(--dark-color) 84%, var(--muted));
  font-weight:700;
}

/* FAQ accordion */
.faq{
  max-width: 920px;
  margin: 0 auto;
}
.faq-item{
  border:1px solid var(--border);
  border-radius: calc(var(--radius) + 2px);
  background:#fff;
  box-shadow: var(--shadow);
  overflow:hidden;
}
.faq-item + .faq-item{ margin-top: 10px; }

.faq-q{
  width:100%;
  display:flex;
  justify-content: space-between;
  align-items:center;
  gap: 10px;
  padding: 16px;
  border:0;
  background: transparent;
  cursor:pointer;
  text-align:left;
  font-weight: 900;
}
.faq-q .chev{
  width: 28px;
  height: 28px;
  border-radius: 10px;
  border:1px solid var(--border);
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.faq-a{
  padding: 0 16px 16px;
  color: var(--muted);
  font-weight: 700;
  line-height: 1.8;
}
.faq-item[data-open="true"] .faq-q .chev{
  transform: rotate(180deg);
  transition: transform .18s ease;
}

/* current menu highlight */
.nav-menu a[aria-current="page"]{
  text-decoration: underline;
  text-underline-offset: 6px;
  color: var(--primary-color);
}

/* Responsive */
@media (max-width: 980px){
  .scope-grid{ grid-template-columns: 1fr; }
  .feature-grid{ grid-template-columns: 1fr; }
  .service-hero{ min-height: 68vh; padding: 72px 0 48px; }
}

@media (prefers-reduced-motion: reduce){
  .svc-hero-bg{ animation:none; transform:none; }
}

/* 서비스 히어로 오버레이(절반 정도 어두움) */
.svc-hero-overlay{
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
}

.svc-hero-overlay-dim{
  background: rgba(2,6,23,.10); /* 전체 딤: 0.18 정도 */
}

.svc-hero-overlay-left{
  background: linear-gradient(
    90deg,
    rgba(2,6,23,.38) 0%,
    rgba(2,6,23,.22) 45%,
    rgba(2,6,23,.06) 78%,
    rgba(2,6,23,0) 100%
  );
}
/* =========================================================
   REVIEWS
========================================================= */

.reviews {
  padding-top: 72px;
}

.reviews .review-slider {
  position: relative;
  overflow: hidden;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  transform: none !important;
  transition: none !important;
}

@media (hover: hover) and (pointer: fine) {
  .reviews .review-slider:hover {
    transform: none !important;
    box-shadow: none !important;
    border-color: transparent !important;
  }
}

.reviews .review-track {
  display: flex;
  gap: 0;
  transition: transform .35s ease;
  will-change: transform;
  align-items: flex-start; /* 각 페이지 높이 독립 */
}

.reviews .review-page {
  flex: 0 0 100%;
  min-width: 100%;
  box-sizing: border-box;
  padding: 10px 0 24px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  transform: scale(0.96);
  transform-origin: top center;
}

.reviews .review-card {
  background: #fff;
  border: 1px solid rgba(226,232,240,.9);
  border-radius: 22px;
  padding: 18px 18px 16px;
  box-shadow: none !important;
  transform: none !important;
  transition: none !important;
}

.reviews .review-card-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
}

.reviews .review-name {
  font-weight: 900;
  font-size: 1.02rem;
  color: var(--dark-color);
}

.reviews .review-meta {
  margin-top: 6px;
  font-size: .75rem;
  white-space: nowrap;
  color: color-mix(in srgb, var(--muted) 80%, #94a3b8);
  font-weight: 700;
}

.reviews .review-stars {
  color: #C9A24F;
  letter-spacing: .14em;
  font-size: .95rem;
  margin-top: 2px;
  white-space: nowrap;
}

.reviews .review-body {
  margin: 14px 0 0;
  font-size: .85rem;
  line-height: 1.85;
  color: var(--dark-color);
  font-weight: 700;
  display: block !important;
  overflow: visible !important;
  max-height: none !important;
}

.reviews .review-body .hl {
  color: var(--primary-color);
  font-weight: 900;
}

.reviews .review-card-bottom {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 16px;
  color: color-mix(in srgb, var(--muted) 85%, #94a3b8);
  font-size: .85rem;
  font-weight: 700;
}

.reviews .review-check {
  width: 18px;
  height: 18px;
  border-radius: 999px;
  background: var(--primary-color);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: .85rem;
  line-height: 1;
}

.reviews .slider-controls {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 18px 0 0;
  border-top: 0;
}

.reviews .dots {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: center;
}

.reviews .dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: transparent;
  cursor: pointer;
}

.reviews .dot.active {
  background: var(--primary-color);
  border-color: var(--primary-color);
}

@media (max-width: 980px) {
  .reviews .review-page {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 520px) {
  .reviews .review-page {
    grid-template-columns: 1fr;
  }
}

@media (prefers-reduced-motion: reduce) {
  .reviews .review-track { transition: none; }
}

.process {
  padding-bottom: 84px;
}

.brand-logo {
  width: 60px;
  height: 60px;
  object-fit: contain;
}
.btn-white{
  background:#fff;
  color: var(--dark-color);
  border-color: rgba(226,232,240,.9);
  box-shadow: 0 10px 24px rgba(2,6,23,.10);
}
.btn-white:hover{
  background: color-mix(in srgb, #fff 92%, black);
}