*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--green:#129E7B;--green-h:#1DAC86;--green-50:#EDFCF6;--green2:#76BE57;--blue:#19B5FE;--blue-50:#F0F9FF;--bg:#FFFFFF;--bg2:#F7F7F5;--fg1:#111111;--fg2:#6B7280;--muted:#AAAAAA;--border:#E8E8E6;--font:'Pretendard Variable','Pretendard',-apple-system,sans-serif;--max-w:1400px}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--fg1);-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
nav{position:sticky;top:0;z-index:300;background:rgba(255,255,255,.92);backdrop-filter:blur(20px);border-bottom:.5px solid var(--border);padding:0 80px;height:68px;display:flex;align-items:center}
.nav-logo{flex-shrink:0}
.nav-center{display:flex;align-items:center;gap:104px;flex:1;justify-content:center}
.nav-btn{font-size:15px;font-weight:500;color:var(--fg2);padding:8px 14px;border-radius:9px;cursor:pointer;transition:color 150ms,background 150ms;background:none;border:none;font-family:var(--font);display:flex;align-items:center;gap:5px;white-space:nowrap;text-decoration:none}
.nav-btn:hover{color:var(--green);background:var(--green-50)}
.nav-btn.active{color:var(--green);background:var(--green-50)}
.nav-right{display:flex;align-items:center;gap:24px;flex-shrink:0}
.nav-cta{padding:11px 24px;background:var(--green);color:#fff;border:none;border-radius:999px;font-family:var(--font);font-size:15px;font-weight:500;cursor:pointer;transition:background 150ms}
.nav-cta:hover{background:var(--green-h)}
.mega-wrap{position:fixed;top:68px;left:0;right:0;z-index:299}
.mega-panel{position:relative;z-index:2;background:#fff;border-bottom:.5px solid var(--border);box-shadow:0 12px 32px rgba(0,0,0,.07);padding:20px 0 24px;display:none}
.mega-wrap.open .mega-panel{display:block;animation:megaSlide 180ms ease}
@keyframes megaSlide{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.mega-inner{max-width:var(--max-w);margin:0 auto;position:relative;padding:4px 80px 20px;min-height:20px}
.mega-col{position:absolute;top:0;min-width:160px;display:none;box-sizing:border-box;padding-right:12px}
.mega-col:first-child{min-width:170px}
.mega-col .mega-item,.mega-col .mega-simple{word-break:keep-all;overflow-wrap:break-word}
.mega-wrap.open .mega-col{display:block}
.mega-item{display:block;padding:10px 12px;border-radius:10px;transition:background 180ms,color 180ms;color:var(--fg1);font-size:14px;font-weight:500;margin-bottom:2px;line-height:1.3;position:relative;text-decoration:none;cursor:pointer}
.mega-item:hover{background:var(--green-50);color:var(--green)}
.mega-item:hover .mega-item-sub{color:rgba(18,158,123,.75)}
.mega-item-sub{display:block;font-size:12px;color:rgba(0,0,0,.35);margin-top:3px;font-weight:400;transition:color 180ms}
.mega-simple{display:block;padding:10px 12px;border-radius:10px;transition:background 180ms,color 180ms;font-size:14px;font-weight:500;color:var(--fg1);margin-bottom:2px;text-decoration:none;cursor:pointer}
.mega-simple:hover{background:var(--green-50);color:var(--green)}
.mega-overlay{position:fixed;inset:0;top:0;z-index:1;display:none}
.mega-wrap.open .mega-overlay{display:block}
.nav-burger{display:none;background:none;border:none;width:40px;height:40px;align-items:center;justify-content:center;cursor:pointer;flex-direction:column;gap:4px;padding:0}
.nav-burger span{display:block;width:22px;height:1.5px;background:var(--fg1);border-radius:2px;transition:transform 200ms,opacity 150ms}
.nav-burger.open span:nth-child(1){transform:translateY(5.5px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-5.5px) rotate(-45deg)}
.mobile-drawer{display:none;position:fixed;top:60px;left:0;right:0;bottom:0;background:#fff;z-index:295;overflow-y:auto;padding:24px 20px 40px;flex-direction:column;gap:4px}
.mobile-drawer.open{display:flex;animation:megaSlide 200ms ease}
.md-group{padding:8px 0;border-bottom:.5px solid var(--border)}
.md-group:last-child{border-bottom:none}
.md-head{font-size:12px;font-weight:600;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;padding:6px 12px;margin-bottom:4px}
.md-link{display:block;font-size:16px;font-weight:500;color:var(--fg1);padding:12px;border-radius:10px}
.md-link:hover{background:var(--green-50);color:var(--green)}
.md-link-sub{display:block;font-size:12px;color:var(--muted);margin-top:2px;font-weight:400}
.md-cta{margin-top:24px;padding:14px;text-align:center;background:var(--green);color:#fff;border-radius:999px;font-weight:500;font-size:16px;display:block;text-decoration:none}

@media (max-width:768px){.nav-center{display:none}.nav-burger{display:flex}nav{padding:0 20px}}
footer{background:#111;padding:64px 80px}
.foot-inner{max-width:var(--max-w);margin:0 auto}
.foot-top{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:60px;margin-bottom:48px;padding-bottom:48px;border-bottom:.5px solid rgba(255,255,255,.07)}
.foot-tagline{font-size:14px;color:rgba(255,255,255,.35);line-height:1.8;margin-top:14px}
.foot-col-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.35);margin-bottom:18px}
.foot-links{display:flex;flex-direction:column;gap:12px}
.foot-links a{font-size:15px;color:rgba(255,255,255,.5);transition:color 150ms}
.foot-links a:hover{color:rgba(255,255,255,.85)}
.foot-bottom{display:flex;justify-content:space-between;align-items:flex-end}
.foot-info{font-size:12px;color:rgba(255,255,255,.22);line-height:1.9}
.foot-copy{font-size:12px;color:rgba(255,255,255,.18)}
.btn-p{padding:13px 28px;background:var(--green);color:#fff;border:none;border-radius:999px;font-family:var(--font);font-size:15px;font-weight:500;cursor:pointer;transition:background 150ms;display:inline-flex;align-items:center;gap:8px}
.btn-p:hover{background:var(--green-h)}
.btn-g{padding:13px 28px;background:transparent;color:var(--fg1);border:.5px solid var(--border);border-radius:999px;font-family:var(--font);font-size:15px;font-weight:500;cursor:pointer;transition:border-color 150ms;display:inline-flex;align-items:center;gap:8px}
.btn-g:hover{border-color:#999}
.page-hero{padding:200px 80px 80px; min-height: calc(100vh + 68px);max-width:var(--max-w);margin:0 auto;}
.page-hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.eyebrow{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--green);margin-bottom:20px}
.h1{font-size:64px;font-weight:700;letter-spacing:-0.03em;line-height:1.15;color:var(--fg1)}
.h1 .m{color:var(--muted)}
.lead{font-size:18px;color:var(--fg2);line-height:1.75;margin-top:24px;max-width:500px}
.btns{display:flex;gap:12px;margin-top:36px}
.tag{display:inline-flex;align-items:center;gap:6px;background:var(--green-50);border:.5px solid rgba(18,158,123,.2);border-radius:999px;padding:5px 14px;font-size:13px;font-weight:500;color:var(--green);margin-bottom:28px}
.tag .dot{width:6px;height:6px;border-radius:50%;background:var(--green)}
.pain-section{background:var(--bg2);padding:80px 80px;border-top:.5px solid var(--border);border-bottom:.5px solid var(--border)}
.pain-inner{max-width:var(--max-w);margin:0 auto}
.pain-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
.pain-card{background:#fff;border:.5px solid var(--border);border-radius:16px;padding:28px}
.pain-num{font-size:11px;font-weight:700;color:var(--green);text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px}
.pain-title{font-size:18px;font-weight:700;color:var(--fg1);margin-bottom:10px;letter-spacing:0.01em}
.pain-desc{font-size:14px;color:var(--fg2);line-height:1.7}
.feature-section{padding:100px 80px}
.feature-inner{max-width:var(--max-w);margin:0 auto}
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:56px}
.feat-card{background:var(--bg2);border:.5px solid var(--border);border-radius:16px;padding:28px;transition:border-color 200ms,transform 200ms}
.feat-card:hover{border-color:rgba(18,158,123,.3);transform:translateY(-2px)}
.feat-icon{width:44px;height:44px;border-radius:11px;background:var(--green-50);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.feat-title{font-size:17px;font-weight:700;color:var(--fg1);margin-bottom:8px}
.feat-desc{font-size:14px;color:var(--fg2);line-height:1.7}
.split-section{padding:100px 80px;background:var(--bg2)}
.split-inner{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.split-section.alt{background:#fff}
.stats-banner{padding:80px 80px;background:#fff;border-top:.5px solid var(--border);border-bottom:.5px solid var(--border)}
.stats-inner{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr)}
.stat-col{padding:0 40px;border-right:.5px solid var(--border)}
.stat-col:first-child{padding-left:0}
.stat-col:last-child{border-right:none;padding-right:0}
.stat-big{font-size:52px;font-weight:700;letter-spacing:-1.5px;line-height:1;color:var(--fg1)}
.stat-big .g{color:var(--green)}
.stat-arrow{font-size:28px;color:var(--muted)}
.stat-lbl{font-size:13px;color:var(--green);font-weight:500;margin-top:6px}
.stat-note{font-size:13px;color:var(--fg2);margin-top:4px;line-height:1.5}
.cta-banner{position:relative;overflow:hidden;padding:160px 80px;background:#FFFFFF url('/theme/basic/assets/Shadow.png') center center / cover no-repeat}
.cta-inner{max-width:var(--max-w);margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:40px}
.cta-h{font-size:40px;font-weight:700;letter-spacing:-0.03em;line-height:1.15;color:var(--fg1)}
.cta-m{font-size:40px;font-weight:700;letter-spacing:-0.03em;line-height:1.15;color:var(--muted)}
.cta-banner .sh{font-size:40px;font-weight:700;letter-spacing:-0.03em;line-height:1.15;color:var(--fg1)}
.cta-banner .sm{font-size:40px;font-weight:700;letter-spacing:-0.03em;line-height:1.15;color:var(--muted); text-align: center;}
.mockup{background:#fff;border:.5px solid var(--border);border-radius:16px;padding:24px;box-shadow:0 2px 24px rgba(0,0,0,.04)}
.mock-head{font-size:13px;font-weight:700;color:var(--fg1);margin-bottom:16px}
.mock-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:.5px solid var(--bg2)}
.mock-row:last-child{border-bottom:none}
.mock-label{font-size:13px;color:var(--fg2)}
.mock-val{font-size:13px;font-weight:600;color:var(--fg1)}
.bar-track{height:6px;background:var(--bg2);border-radius:999px;overflow:hidden;margin:4px 0}
.bar-fill{height:6px;border-radius:999px;background:var(--green)}
.pill{font-size:11px;font-weight:500;padding:4px 12px;border-radius:999px}
.pill-g{background:var(--green-50);color:var(--green)}
.pill-b{background:var(--blue-50);color:var(--blue)}
.pill-y{background:#FFF8E1;color:#D97706}
.sh{font-size:52px;font-weight:700;letter-spacing:-1.4px;line-height:1.05;color:var(--fg1)}
.sm{font-size:52px;font-weight:700;letter-spacing:-1.4px;line-height:1.05;color:var(--muted)}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.mob-br{display:none}
@media(max-width:768px){.mob-br{display:inline}}

.plan-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:56px}
.plan-card{background:#fff;border:1px solid var(--border);border-radius:20px;padding:36px;position:relative;text-align:left;transition:background 220ms ease,box-shadow 220ms ease,transform 220ms ease,border-color 220ms ease;cursor:pointer}
.plan-card:hover{transform:translateY(-4px)}
/* BASIC — blue */
.plan-card.plan-basic{border-color:#19B5FE;box-shadow:0 4px 32px rgba(25,181,254,.14)}
.plan-card.plan-basic:hover{background:#F0F9FF;border-color:#19B5FE;box-shadow:0 10px 40px rgba(25,181,254,.24)}
.plan-card.plan-basic .plan-price{color:#19B5FE}
.plan-card.plan-basic .plan-badge{background:#19B5FE}
.plan-card.plan-basic .plan-btn:hover,.plan-card.plan-basic:hover .plan-btn{background:#19B5FE;color:#fff;border-color:#19B5FE}
/* PRO — green */
.plan-card.plan-pro{border-color:var(--green);box-shadow:0 4px 32px rgba(18,158,123,.14)}
.plan-card.plan-pro:hover{background:var(--green-50);border-color:var(--green);box-shadow:0 10px 40px rgba(18,158,123,.24)}
.plan-card.plan-pro .plan-price{color:var(--green)}
.plan-card.plan-pro .plan-badge{background:var(--green)}
.plan-card.plan-pro .plan-btn:hover,.plan-card.plan-pro:hover .plan-btn{background:var(--green);color:#fff;border-color:var(--green)}
/* PCF — purple */
.plan-card.plan-pcf{border-color:#7C3AED;box-shadow:0 4px 32px rgba(124,58,237,.14)}
.plan-card.plan-pcf:hover{background:#F5F3FF;border-color:#7C3AED;box-shadow:0 10px 40px rgba(124,58,237,.24)}
.plan-card.plan-pcf .plan-price{color:#7C3AED}
.plan-card.plan-pcf .plan-badge{background:#7C3AED}
.plan-card.plan-pcf .plan-btn:hover,.plan-card.plan-pcf:hover .plan-btn{background:#7C3AED;color:#fff;border-color:#7C3AED}
.plan-card.featured{}
.plan-badge{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--green);color:#fff;font-size:13px;font-weight:600;padding:8px 22px;border-radius:999px;white-space:nowrap;box-shadow:0 2px 8px rgba(0,0,0,.08)}
/* 체크 아이콘 컬러: 플랜별 매칭 */
.plan-basic .plan-check{color:#19B5FE}
.plan-pro .plan-check{color:var(--green)}
.plan-pcf .plan-check{color:#7C3AED}
.plan-feat{align-items:flex-start !important;font-size: 15px;}
.plan-feat .plan-check{margin-top:1px}
.plan-title-row{text-align:center;margin-bottom:12px;margin-top: 20px;}
.plan-price{font-size:48px;font-weight:700;letter-spacing:-1.5px;color:var(--fg1)}
.plan-price sup{font-size:20px;vertical-align:top;margin-top:10px;display:inline-block}
.plan-period{font-size:14px;color:var(--fg2);margin-left:4px}

.plan-header{margin:-36px -36px 24px;padding:28px 36px 24px;border-radius:20px 20px 0 0}
.plan-card.plan-basic .plan-header{background:#EFF9FF}
.plan-card.plan-pro .plan-header{background:#EDFCF6}
.plan-card.plan-pcf .plan-header{background:#F5F3FF}
.plan-header .plan-desc{margin-bottom:0;margin-top:10px}
.plan-desc{font-size:14px;color:var(--fg2);margin-top:12px;margin-bottom:24px;line-height:1.6;text-align:center}
.plan-btn{width:100%;padding:13px;border-radius:999px;font-family:var(--font);font-size:15px;font-weight:500;cursor:pointer;margin-bottom:28px;justify-content:center;transition:background 200ms ease,color 200ms ease,border-color 200ms ease}
.plan-card .plan-btn:hover,.plan-card:hover .plan-btn{background:var(--green);color:#fff;border-color:var(--green)}
.plan-features{display:flex;flex-direction:column;gap:10px}
.plan-feat{display:flex;align-items:center;gap:10px;font-size:15px;color:var(--fg1)}
.plan-feat svg{flex-shrink:0}
.plan-feat-head{font-size:15px;font-weight:700;color:var(--fg1);margin-top:8px;margin-bottom:2px;letter-spacing:-.2px}
.plan-feat-head:first-child{margin-top:0}
.faq-item{border-bottom:.5px solid var(--border)}
.faq-q{width:100%;background:none;border:none;padding:24px 28px;font-family:var(--font);font-size:18px;font-weight:600;color:var(--fg1);cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:16px;text-align:left;transition:background 150ms}
.faq-q:hover{background:var(--bg2)}
.faq-arrow{flex-shrink:0;color:var(--fg2);transition:transform 250ms}
.faq-q.open .faq-arrow{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height 350ms ease,padding 250ms;font-size:16px;color:var(--fg2);line-height:1.75;padding:0 28px}
.faq-a.open{max-height:300px;padding:16px 28px 24px}

/* === Mobile common fixes (append-only) === */
@media (max-width: 1024px) {
  html, body { overflow-x: hidden; max-width: 100vw; }
  img, svg, video, canvas { max-width: 100%; height: auto; }
  h1, h2, h3, .h1, .h2, .h3, .page-hero .h1, .hero-title { white-space: normal; word-break: keep-all; }
}

/* === pricing carousel — 화살표 / 도트는 데스크톱에선 숨김 === */
.plan-carousel { position: relative; }
.plan-nav, .plan-dots { display: none; }

/* === pricing 모바일 (data 페이지 폰트 사이즈 통일 + 카드 carousel) === */
@media (max-width: 855px) {
  /* Plan grid → carousel */
  .plan-carousel { padding: 0 !important; margin-top: 8px !important; }
  .plan-grid {
    display: flex !important;
    grid-template-columns: none !important;
    overflow-x: auto !important;
    scroll-snap-type: x mandatory !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: none !important;
    gap: 0 !important;
    margin-top: 0 !important;
    padding: 26px 20px 8px !important;
    scroll-padding: 0 20px !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
  .plan-grid::-webkit-scrollbar { display: none !important; }
  .plan-card {
    flex: 0 0 calc(100% - 40px) !important;
    width: calc(100% - 40px) !important;
    scroll-snap-align: center !important;
    padding: 32px 22px 28px !important;
    border-radius: 16px !important;
    margin-right: 12px !important;
  }
  .plan-card:last-child { margin-right: 0 !important; }
  .plan-header { margin: -32px -22px 16px !important; padding: 14px 22px 14px !important; border-radius: 16px 16px 0 0 !important; }
  .plan-nav {
    display: flex !important;
    position: absolute !important;
    top: calc(50% + 40px) !important;
    transform: translateY(-50%) !important;
    width: 36px !important;
    height: 36px !important;
    border-radius: 50% !important;
    background: rgba(255,255,255,.96) !important;
    border: .5px solid var(--border) !important;
    box-shadow: 0 4px 14px rgba(0,0,0,.10) !important;
    color: var(--fg1) !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 10 !important;
    cursor: pointer !important;
    padding: 0 !important;
  }
  .plan-prev { left: 2px !important; }
  .plan-next { right: 2px !important; }
  .plan-dots {
    display: flex !important;
    justify-content: center !important;
    gap: 7px !important;
    margin-top: 18px !important;
    padding-bottom: 4px !important;
  }
  .plan-dot {
    width: 7px; height: 7px; border-radius: 50%;
    background: var(--border);
    transition: background 200ms, transform 200ms;
    cursor: pointer; border: none; padding: 0;
  }
  .plan-dot.active { background: var(--green); transform: scale(1.3); }
  .pricing-hero-inner .plan-grid { max-width: 100% !important; margin-left: 0 !important; margin-right: 0 !important; }
  .pricing-hero-inner > p { margin-bottom: 0 !important; }
  .pricing-hero-inner .plan-carousel { margin-top: 4px !important; }
}
@media (max-width: 768px) {
  .page-hero-grid { grid-template-columns: 1fr !important; gap: 28px !important;}
  .h1 { font-size: 28px !important; letter-spacing: -0.6px !important; line-height: 1.2 !important; }
  .lead { font-size: 14px !important; margin-top: 14px !important; line-height: 1.5 !important; max-width: 100% !important; }

  /* ── 배너 (case-study 모바일 동일) ── */
  [style*="padding:100px 80px 80px"] { padding: 52px 20px 40px !important; }
  [style*="padding:100px 80px 80px"] .sh { font-size: 26px !important; letter-spacing: -0.5px !important; line-height: 1.2 !important; word-break: keep-all !important; }
  [style*="padding:100px 80px 80px"] .sm { font-size: 22px !important; letter-spacing: -0.4px !important; line-height: 1.3 !important; word-break: keep-all !important; }
  [style*="padding:100px 80px 80px"] p { font-size: 14px !important; margin-top: 16px !important; line-height: 1.6 !important; max-width: 100% !important; }

  /* Section headings */
  .sh, .sm { font-size: 26px !important; letter-spacing: -0.5px !important; line-height: 1.2 !important; word-break: keep-all !important; }

  /* Plan carousel — scroll-snap + 화살표 + 자동재생 (JS 가 4초마다 다음 카드로) */
  .plan-carousel { padding: 0 !important; margin-top: 8px !important; }
  /* hero 와 carousel 간격 축소 → 견적문의 + 바우처까지 한 화면에 보이도록 */
  .page-hero { padding-bottom: 0 !important; }
  /* 도입은 하고 싶은데~ 섹션 좌우 여백을 나머지 섹션과 동일하게(20px) */
  [style*="padding:56px 80px 60px"] { padding-left: 20px !important; padding-right: 20px !important; padding-top: 40px !important; padding-bottom: 40px !important; }
  [style*="padding:56px 80px 60px"] [style*="font-size:40px"] { font-size: 24px !important; letter-spacing: -0.5px !important; line-height: 1.25 !important; margin-top: 32px !important; margin-bottom: 20px !important; word-break: keep-all !important; }
  [style*="padding:56px 80px 60px"] [style*="font-size:25px"] { font-size: 15px !important; line-height: 1.65 !important; margin-bottom: 24px !important; }
  .plan-grid {
    display: flex !important;
    grid-template-columns: none !important;
    overflow-x: auto !important;
    scroll-snap-type: x mandatory !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: none !important;
    gap: 0 !important;
    margin-top: 0 !important;
    /* padding-top 26px → 카드 위로 떠 있는 plan-badge(-12px) 가 잘림 없이 표시되는 여유 */
    padding: 26px 20px 8px !important;
    scroll-padding: 0 20px !important;
  }
  .plan-grid::-webkit-scrollbar { display: none !important; }
  .plan-card {
    flex: 0 0 calc(100% - 40px) !important;
    width: calc(100% - 40px) !important;
    scroll-snap-align: center !important;
    /* 카드 내부 위/아래 패딩 키워서 badge 와 내용 사이 여유 + 콘텐츠 호흡 */
    padding: 32px 22px 28px !important;
    border-radius: 16px !important;
    margin-right: 12px !important;
  }
  .plan-card:last-child { margin-right: 0 !important; }
  .plan-price { font-size: 28px !important; }
  .plan-features { font-size: 13px !important; }

  /* 화살표 버튼 — carousel 좌우 끝, 카드와 안 겹치게 */
  .plan-nav {
    display: flex !important;
    position: absolute !important;
    top: calc(50% + 40px) !important;
    transform: translateY(-50%) !important;
    width: 36px !important;
    height: 36px !important;
    border-radius: 50% !important;
    background: rgba(255,255,255,.96) !important;
    border: .5px solid var(--border) !important;
    box-shadow: 0 4px 14px rgba(0,0,0,.10) !important;
    color: var(--fg1) !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 10 !important;
    cursor: pointer !important;
    padding: 0 !important;
    font-family: var(--font) !important;
  }
  .plan-prev { left: 2px !important; }
  .plan-next { right: 2px !important; }

  /* 도트 인디케이터 — carousel 아래 중앙 (카드 하단에서 충분히 떨어짐) */
  .plan-dots {
    display: flex !important;
    justify-content: center !important;
    gap: 7px !important;
    margin-top: 18px !important;
    padding-bottom: 4px !important;
  }
  .plan-dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--border);
    transition: background 200ms, transform 200ms;
    cursor: pointer;
    border: none;
    padding: 0;
  }
  .plan-dot.active {
    background: var(--green);
    transform: scale(1.3);
  }

  /* FAQ — 닫힘 기본 + 답변 max-height 늘려 잘리지 않도록 */
  .faq-q { font-size: 14px !important; padding: 14px 14px !important; gap: 12px !important; }
  .faq-q span { line-height: 1.4 !important; }
  .faq-a { font-size: 13px !important; padding: 0 14px !important; line-height: 1.7 !important; }
  .faq-a.open {
    max-height: 600px !important;
    padding: 12px 14px 18px !important;
    gap: 10px !important;
  }

  /* ── CTA ── */
  .cta-banner { padding: 60px 20px !important; }
  .cta-h, .cta-m { font-size: 24px !important; }
  .cta-btn-row { justify-content: center !important; flex-wrap: wrap !important; }
  .cta-btn-row .btn-p { font-size: 12px !important; padding: 14px 20px !important; justify-content: center!important; flex-wrap: wrap !important; }
  .cta-btn-row .btn-g { background: #fff; font-size: 12px!important; padding: 14px 20px!important; justify-content: center!important; border: 1px solid var(--green); color: var(--green); }

  /* 도입 고민 섹션 (위 inline-styled section) — 모바일 패딩 컴팩트 */
  .mb-br { display: inline; }

  /* 모든 desktop 80px 측면 padding 섹션을 데이터 페이지 기준 20px 로 통일 */
  .feature-section, .pain-section, .split-section, .stats-banner,
  [style*="padding:100px 80px"],
  [style*="padding:80px 80px"],
  [style*="padding:72px 80px"] {
    padding-left: 20px !important;
    padding-right: 20px !important;
    padding-top: 60px !important;
    padding-bottom: 60px !important;
  }
  /* 도입 고민 섹션 — 좀 더 컴팩트 */
  [style*="padding:72px 80px"] { padding-top: 48px !important; padding-bottom: 48px !important; }
  /* hero 도 안전하게 한 번 더 보정 */
  .page-hero { padding: 168px 20px !important; }
  /* 견적문의 + 바우처 안내 한 화면에 */
  #pricing-cta-row { margin-top: 25px !important; }
  #pricing-cta-row + p { margin-top: 20px !important; font-size: 13px !important; }
  #pricing-cta-row .btn-p { padding: 13px 32px !important; font-size: 14px !important; }
  [style*="padding:56px 80px 60px"] .btn-p { padding: 13px 32px !important; font-size: 14px !important; }
  /* FAQ 섹션 좌우 여백 — 다른 섹션과 동일하게 20px */
  [style*="padding:40px 80px"] { padding-left: 20px !important; padding-right: 20px !important; padding-top: 36px !important; padding-bottom: 60px !important; }
  .cta-banner::before { display: block !important; content: "" !important; position: absolute !important; left: 0; right: 0; top: 0; bottom: 0; pointer-events: none; z-index: 0; background: url('/theme/basic/assets/Shadow.png') center center / cover no-repeat !important; }
  .cta-banner { background: #fff !important; }
  .cta-banner > .cta-inner { position: relative; z-index: 2; }
  /* pricing-hero-section 모바일 */
  .pricing-hero-section {
    min-height:calc(100vh + 68px) !important;
    padding: 100px 20px !important;
  }
  .pricing-hero-inner .plan-grid {
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
  .pricing-hero-inner > p { margin-bottom: 0 !important; }
  .pricing-hero-inner .plan-carousel { margin-top: -30px !important; }
  .pricing-hero-inner .plan-card {
    padding: 32px 22px 28px !important;
  }
  .pricing-hero-inner .plan-header {
    margin: -32px -22px 16px !important;
    padding: 14px 22px 14px !important;
  }
  .pricing-hero-inner .plan-feat { font-size: 13px !important; }
  .pricing-hero-inner .plan-feat-head { font-size: 13px !important; }
  .pricing-hero-inner > p { font-size: 14px !important; }
  .pricing-hero-inner .sh { font-size: 28px !important; }
  .pricing-hero-inner .sm { font-size: 28px !important; }

}
.mb-br { display: none; }


.cta-btn-row{display:flex;gap:14px;align-items:center;justify-content:center;}

.cta-inner .sh, .cta-inner .sm { text-align: left; }
@media (max-width: 768px) {
  .cta-inner .sh, .cta-inner .sm { text-align: center; }
}

/* ── Pricing hero: fit in one viewport ── */
.pricing-hero-section {
  min-height: 100vh;
  box-sizing: border-box;
  padding: clamp(100px, 10vh + 68px, 200px) clamp(40px, 6vw, 120px) clamp(20px, 4vh, 60px);
}
.pricing-hero-inner .sh { font-size: clamp(40px, 3.5vw, 60px); }
.pricing-hero-inner .sm { font-size: clamp(40px, 3.5vw, 60px); margin-bottom: clamp(12px, 1.5vh, 24px); }
.pricing-hero-inner > p { margin-top: clamp(10px, 1.5vh, 20px) !important; font-size: clamp(14px, 1.1vw, 17px); }
.pricing-hero-inner .plan-grid { margin-top: clamp(20px, 2.5vh, 40px); max-width: clamp(700px, 72vw, 1060px); margin-left: auto; margin-right: auto; }
.pricing-hero-inner .plan-card { padding: clamp(16px, 2vw, 30px); margin-top: clamp(20px, 2.5vh, 36px); }
.pricing-hero-inner .plan-header { margin: calc(-1 * clamp(16px, 2vw, 30px)) calc(-1 * clamp(16px, 2vw, 30px)) 16px; padding: 14px clamp(16px, 2vw, 30px) 14px; }
.pricing-hero-inner .plan-features { gap: clamp(4px, 0.5vh, 8px); }
.pricing-hero-inner .plan-feat { font-size: clamp(12px, 0.9vw, 14px); }
.pricing-hero-inner .plan-feat-head { font-size: clamp(12px, 0.9vw, 14px); margin-top: 6px; margin-bottom: 0; }
.pricing-hero-inner .plan-price { font-size: clamp(20px, 2.2vw, 30px); }
.pricing-hero-inner .plan-desc { font-size: clamp(12px, 0.85vw, 14px); margin-top: 4px; }
.pricing-hero-inner .plan-badge { font-size: clamp(11px, 0.8vw, 13px); margin-bottom: 4px; }
#pricing-cta-row { margin-top: clamp(20px, 2.5vh, 36px) !important; }
#pricing-cta-row + p { margin-top: 20px !important; }