/* ═══════════════════════════════════
   TOKENS
═══════════════════════════════════ */
:root{
  --ink:#08090d;
  --ink2:#1a1d2e;
  --ink3:#2d3152;
  --surface:#f5f6fa;
  --surface2:#eef0f8;
  --white:#ffffff;
  --blue:#2352ff;
  --blue-light:#e8edff;
  --blue-mid:#4f72ff;
  --green:#00c48c;
  --green-light:#e0faf3;
  --purple:#7c4dff;
  --purple-light:#ede8ff;
  --orange:#ff6b2b;
  --orange-light:#fff0eb;
  --yellow:#ffd60a;
  --red:#ff3b3b;
  --t:#08090d;
  --t2:#5c5f7a;
  --t3:#9699b8;
  --bd:#e2e4f0;
  --bd2:#c8cbdf;
  --kakao:#FEE500;
  --r:16px;
  --r2:12px;
  --r3:8px;
  --sh:0 2px 8px rgba(8,9,13,.06),0 8px 32px rgba(8,9,13,.06);
  --sh2:0 4px 16px rgba(8,9,13,.08),0 16px 48px rgba(8,9,13,.1);
  --sh-blue:0 8px 32px rgba(35,82,255,.25);
}

/* ═══════════════════════════════════
   RESET & BASE
═══════════════════════════════════ */
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;}
body{font-family:'Noto Sans KR',sans-serif;background:var(--surface);color:var(--t);min-height:100vh;overflow-x:hidden;}
a{text-decoration:none;color:inherit;}
button{font-family:'Noto Sans KR',sans-serif;}

/* ═══════════════════════════════════
   PAGE SYSTEM
═══════════════════════════════════ */
.page{display:none;animation:pageIn .3s ease;}
.page.on{display:block;}
@keyframes pageIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ═══════════════════════════════════
   NAVIGATION
═══════════════════════════════════ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1200;
  height:60px;
  display:flex;align-items:center;
  padding:0 32px;
  transition:all .3s;
  background:rgba(255,255,255,.92);
  border-bottom:1px solid rgba(35,82,255,.08);
}
@media(max-width:768px){
  .nav{padding:0 16px;height:56px;}
}
.nav.scrolled{
  background:rgba(255,255,255,.95);
  border-bottom:1px solid rgba(35,82,255,.12);
  box-shadow:0 4px 24px rgba(35,82,255,.07);
}
.nav-logo{
  display:flex;align-items:center;gap:10px;cursor:pointer;margin-right:32px;
}
.nav-logo-mark{
  width:34px;height:34px;border-radius:10px;
  background:linear-gradient(135deg,var(--blue),var(--purple));
  display:flex;align-items:center;justify-content:center;
  font-size:17px;box-shadow:0 4px 12px rgba(35,82,255,.3);
  flex-shrink:0;
}
.nav-logo-text{font-size:17px;font-weight:800;color:var(--ink);letter-spacing:-.4px;}
.nav-logo-sub{font-size:9.5px;color:var(--t3);letter-spacing:.5px;margin-top:1px;}
@media(max-width:768px){
  .nav-logo{margin-right:auto;}
  .nav-logo-mark{width:30px;height:30px;font-size:15px;}
  .nav-logo-text{font-size:15px;}
  .nav-logo-sub{font-size:8.5px;}
}

.nav-links{display:flex;align-items:center;gap:2px;}
@media(max-width:768px){
  .nav-links{
    position:fixed;top:56px;right:0;bottom:0;
    width:60vw;max-width:220px;
    flex-direction:column;align-items:stretch;gap:0;
    background:#fff;
    border-left:1px solid rgba(0,0,0,.07);
    box-shadow:-8px 0 32px rgba(0,0,0,.15);
    padding:16px 14px 24px;overflow-y:auto;
    transform:translateX(100%);transition:transform .3s ease;
    z-index:9999;
  }
  .nav-links.open{transform:translateX(0);}
  .nav-link{
    padding:11px 12px !important;
    font-size:14px !important;
    border-radius:10px !important;
    margin-bottom:2px !important;
  }
}
/* 드로어 열릴 때 배경 오버레이 */
.nav-overlay{
  display:none;
  position:fixed;top:56px;left:0;right:0;bottom:0;
  background:rgba(0,0,0,.25);
  z-index:9998;
}
.nav-overlay.open{display:block;}

.nav-actions{
  display:flex;align-items:center;gap:6px;margin-left:auto;
}
@media(max-width:768px){
  .nav-actions{ display:none !important; }
}
.nav-link{
  padding:6px 14px;border-radius:8px;
  font-size:13px;font-weight:600;color:var(--t2);
  cursor:pointer;transition:all .18s;white-space:nowrap;
  display:flex;align-items:center;gap:6px;
  position:relative;
}
.nav-link:hover{color:var(--blue);background:var(--blue-light);}
.nav-link.on{color:var(--blue);background:var(--blue-light);}
.nav-link .dot{width:6px;height:6px;border-radius:50%;background:var(--blue-mid);}
@media(max-width:768px){
  .nav-link{
    padding:9px 12px;font-size:14px;
    border-radius:8px;margin-bottom:2px;
    justify-content:flex-start;
  }
}

/* 드롭다운 메뉴 */
.nav-dropdown{position:relative;}
.nav-dropdown-trigger{
  padding:6px 14px;border-radius:8px;
  font-size:13px;font-weight:600;color:var(--t2);
  cursor:pointer;transition:all .18s;white-space:nowrap;
  display:flex;align-items:center;gap:6px;
}
.nav-dropdown-trigger:hover{color:var(--blue);background:var(--blue-light);}
@media(max-width:768px){
  .nav-dropdown-trigger{
    padding:9px 12px;font-size:14px;
    border-radius:8px;margin-bottom:2px;
  }
}
.nav-dropdown-trigger::after{
  content:'▼';font-size:8px;margin-left:2px;
  transition:transform .2s;
}
.nav-dropdown.open .nav-dropdown-trigger::after{transform:rotate(180deg);}
.nav-dropdown.open .nav-dropdown-trigger{color:var(--blue);background:var(--blue-light);}

.nav-dropdown-menu{
  position:absolute;top:calc(100% + 4px);left:0;
  min-width:180px;
  background:rgba(255,255,255,.98);
  backdrop-filter:blur(20px);
  border:1px solid rgba(35,82,255,.12);
  border-radius:12px;
  box-shadow:0 8px 32px rgba(35,82,255,.15);
  padding:6px;
  display:none;
  z-index:1000;
  animation:dropdownIn .2s ease;
}
.nav-dropdown.open .nav-dropdown-menu{display:block;}
@media(max-width:768px){
  .nav-dropdown-menu{
    position:static;
    min-width:100%;
    box-shadow:none;
    border:none;
    background:transparent;
    padding:0 0 0 16px;
    margin-top:8px;
    animation:none;
  }
}

@keyframes dropdownIn{
  from{opacity:0;transform:translateY(-8px);}
  to{opacity:1;transform:translateY(0);}
}

.nav-dropdown-item{
  padding:8px 12px;
  border-radius:8px;
  font-size:13px;font-weight:600;
  color:var(--t2);
  cursor:pointer;
  transition:all .15s;
  display:flex;align-items:center;gap:8px;
  white-space:nowrap;
}
.nav-dropdown-item:hover{
  color:var(--blue);
  background:var(--blue-light);
}
@media(max-width:768px){
  .nav-dropdown-item{
    padding:12px 16px;
    font-size:14px;
    margin-bottom:4px;
  }
}
.nav-dropdown-item .dot{
  width:6px;height:6px;
  border-radius:50%;
  flex-shrink:0;
}

.nav-cta{
  background:var(--blue);color:#fff;
  border:none;border-radius:20px;
  padding:8px 20px;font-size:12.5px;font-weight:800;
  cursor:pointer;display:flex;align-items:center;gap:6px;
  transition:all .18s;white-space:nowrap;
  box-shadow:0 4px 12px rgba(35,82,255,.25);
}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(35,82,255,.35);}
@media(max-width:768px){
  .nav-cta{
    margin:16px 0 0 0;
    width:100%;justify-content:center;
    padding:14px 24px;font-size:15px;
  }
}
@media(max-width:430px){
  .nav-cta{
    margin:0 !important;width:auto !important;
    padding:8px 13px !important;font-size:12px !important;
  }
}

.nav-report{
  background:transparent;color:var(--t2);
  border:1.5px solid var(--bd);border-radius:20px;
  padding:7px 14px;font-size:12px;font-weight:600;
  cursor:pointer;display:flex;align-items:center;gap:5px;
  transition:all .18s;white-space:nowrap;
}
.nav-report:hover{background:var(--surface2);border-color:var(--bd2);color:var(--t);}

/* 모바일 드로어 하단 버튼 영역 */
.mob-nav-bottom{display:none;}
@media(max-width:768px){
  .mob-nav-bottom{display:block;padding-top:4px;}
  .mob-nav-bottom .nav-report{
    padding:8px 16px;font-size:12px;
    border-radius:8px;margin-bottom:6px;
  }
  .mob-nav-bottom .nav-cta{
    padding:8px 16px;font-size:12px;
    border-radius:8px;
  }
}
.nav-hamburger{
  display:none;
  flex-direction:column;gap:4px;
  width:20px;height:28px;
  background:none;border:none;
  cursor:pointer;padding:0;
  position:relative;
  z-index:1200;
}
@media(max-width:768px){
  .nav-hamburger{
    position:absolute !important;
    right:16px !important;
    top:50% !important;
    transform:translateY(-50%) !important;
  }
}
.nav-hamburger span{
  display:block;width:100%;height:2.5px;
  background:#08090d;
  border-radius:2px;
  transition:all .3s ease;
}
@media(max-width:768px){
  .nav-hamburger span{ background:#08090d !important; }
}
.nav-hamburger.open span:nth-child(1){
  transform:rotate(45deg) translate(6px, 6px);
}
.nav-hamburger.open span:nth-child(2){
  opacity:0;
}
.nav-hamburger.open span:nth-child(3){
  transform:rotate(-45deg) translate(6px, -6px);
}
@media(max-width:768px){
  .nav-hamburger{display:flex;}
}
.nav-report:hover{background:rgba(239,68,68,.15);transform:translateY(-1px);}

/* ═══════════════════════════════════
   HOME — HERO (밝은 버전)
═══════════════════════════════════ */
.hero{
  min-height:calc(100vh - 220px);
  max-height:680px;
  background:linear-gradient(160deg,#f0f4ff 0%,#e8f0ff 40%,#f5f0ff 70%,#fff0f8 100%);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:80px 24px 60px;
  position:relative;overflow:hidden;
}
@media(max-width:768px){
  .hero{
    min-height:calc(100vh - 180px);
    max-height:none;
    padding:60px 16px 40px;
  }
}

/* 배경 도트 패턴 */
.hero-grid{
  position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(35,82,255,.12) 1px,transparent 1px);
  background-size:40px 40px;
  mask-image:radial-gradient(ellipse 90% 90% at 50% 50%,black 20%,transparent 100%);
}

/* 배경 장식 원 */
.hero-glow{
  position:absolute;border-radius:50%;
  filter:blur(60px);pointer-events:none;
}
.hero-glow.g1{
  width:640px;height:480px;top:-80px;left:50%;transform:translateX(-50%);
  background:radial-gradient(ellipse,rgba(35,82,255,.14) 0%,transparent 70%);
  animation:gFloat 10s ease-in-out infinite;
}
.hero-glow.g2{
  width:380px;height:320px;bottom:10%;left:5%;
  background:radial-gradient(ellipse,rgba(124,77,255,.1) 0%,transparent 70%);
  animation:gFloat2 12s ease-in-out infinite reverse;
}
.hero-glow.g3{
  width:320px;height:240px;top:20%;right:5%;
  background:radial-gradient(ellipse,rgba(0,196,140,.1) 0%,transparent 70%);
  animation:gFloat3 14s ease-in-out infinite 2s;
}
/* 장식 도형 */
.hero-deco{position:absolute;border-radius:50%;opacity:.5;}
.hero-deco.d1{width:120px;height:120px;top:12%;left:8%;background:linear-gradient(135deg,rgba(35,82,255,.12),rgba(124,77,255,.08));border:1px solid rgba(35,82,255,.15);animation:dSpin 20s linear infinite;}
.hero-deco.d2{width:80px;height:80px;bottom:20%;right:10%;background:linear-gradient(135deg,rgba(0,196,140,.12),rgba(35,82,255,.08));border:1px solid rgba(0,196,140,.2);animation:dSpin 15s linear infinite reverse;}
.hero-deco.d3{width:48px;height:48px;top:40%;left:15%;background:rgba(254,229,0,.25);border:1px solid rgba(254,229,0,.4);animation:dSpin 10s linear infinite;}
@media(max-width:768px){
  .hero-deco.d1{width:80px;height:80px;left:5%;}
  .hero-deco.d2{width:60px;height:60px;right:5%;}
  .hero-deco.d3{width:36px;height:36px;left:10%;}
}
@keyframes dSpin{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}
@keyframes gFloat{0%,100%{transform:translateY(0) translateX(-50%)}50%{transform:translateY(-24px) translateX(-50%)}}
@keyframes gFloat2{0%,100%{transform:translateY(0)}50%{transform:translateY(-18px)}}
@keyframes gFloat3{0%,100%{transform:translateY(0)}50%{transform:translateY(14px)}}

.hero-inner{position:relative;text-align:center;max-width:860px;z-index:1;}

.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(35,82,255,.08);border:1px solid rgba(35,82,255,.2);
  border-radius:100px;padding:7px 18px;
  font-size:12px;font-weight:700;color:var(--blue);
  margin-bottom:28px;letter-spacing:.3px;
  animation:fadeUp .8s ease both;
  backdrop-filter:blur(8px);
}
@media(max-width:768px){
  .hero-badge{
    padding:6px 14px;
    font-size:11px;
    margin-bottom:20px;
  }
}
.badge-dot{width:6px;height:6px;border-radius:50%;background:var(--blue);animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}

.hero-title{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(44px,7.5vw,92px);
  line-height:.95;
  color:var(--ink);
  letter-spacing:-1px;
  margin-bottom:8px;
  animation:fadeUp .8s ease .1s both;
}
.hero-title .accent{
  background:linear-gradient(135deg,var(--blue),var(--purple));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.hero-title .filled{color:var(--ink);}

.hero-sub-title{
  font-size:clamp(13px,1.8vw,16px);
  color:var(--t2);
  font-weight:400;line-height:1.7;
  max-width:500px;margin:12px auto 36px;
  animation:fadeUp .8s ease .2s both;
}
.hero-sub-title strong{color:var(--blue);font-weight:700;}
@media(max-width:768px){
  .hero-sub-title{
    font-size:14px;
    margin:12px auto 28px;
    padding:0 8px;
  }
}

@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* 히어로 버튼 */
.hero-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;animation:fadeUp .8s ease .3s both;}
.hbtn{
  padding:14px 28px;border-radius:12px;border:none;
  font-size:14px;font-weight:700;cursor:pointer;
  display:flex;align-items:center;gap:8px;
  transition:all .2s;font-family:'Noto Sans KR',sans-serif;
}
@media(max-width:768px){
  .hero-btns{gap:10px;padding:0 8px;}
  .hbtn{
    padding:13px 22px;
    font-size:13px;
    flex:1;
    min-width:140px;
    justify-content:center;
  }
}
.hbtn-primary{
  background:var(--blue);color:#fff;
  box-shadow:0 6px 24px rgba(35,82,255,.3);
}
.hbtn-primary:hover{background:var(--blue-mid);transform:translateY(-2px);box-shadow:0 12px 36px rgba(35,82,255,.4);}
.hbtn-kakao{background:var(--kakao);color:#1a1200;box-shadow:0 4px 16px rgba(254,229,0,.35);}
.hbtn-kakao:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(254,229,0,.45);}
.hbtn-ghost{
  background:rgba(255,255,255,.7);color:var(--ink);
  border:1.5px solid rgba(35,82,255,.2);
  backdrop-filter:blur(8px);
}
.hbtn-ghost:hover{background:#fff;border-color:var(--blue);color:var(--blue);}

/* 히어로 스탯 */
.hero-stats{
  display:flex;justify-content:center;gap:36px;
  margin-top:36px;padding-top:28px;
  border-top:1px solid rgba(35,82,255,.1);
  animation:fadeUp .8s ease .5s both;
  flex-wrap:wrap;
}
.hstat{text-align:center;}
.hstat-val{
  font-family:'Bebas Neue',sans-serif;
  font-size:32px;line-height:1;
  color:var(--ink);letter-spacing:1px;
  margin-bottom:3px;
}
.hstat-val em{color:var(--blue);font-style:normal;}
.hstat-lbl{font-size:11px;color:var(--t2);font-weight:500;letter-spacing:.3px;}

/* ═══════════════════════════════════
   HERO SLIDER
═══════════════════════════════════ */
.hero-slider-wrap{
  position:relative;overflow:hidden;
}
.hero-slide{
  min-width:100%;transition:none;
}
/* 슬라이드 컨테이너: flex로 가로 배치 */
.hero-slides-track{
  display:flex;
  transition:transform .55s cubic-bezier(.77,0,.18,1);
}
/* 화살표 버튼 */
.hero-slider-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.85);backdrop-filter:blur(10px);
  border:1.5px solid rgba(35,82,255,.15);
  font-size:22px;font-weight:700;color:var(--blue);
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:all .2s;z-index:10;
  box-shadow:0 4px 16px rgba(35,82,255,.12);
}
.hero-slider-arrow:hover{background:#fff;box-shadow:0 6px 24px rgba(35,82,255,.22);transform:translateY(-50%) scale(1.08);}
.arr-left{left:20px;}
.arr-right{right:20px;}
/* 점 인디케이터 */
.hero-slider-ctrl{
  position:absolute;bottom:16px;left:50%;transform:translateX(-50%);
  display:flex;gap:8px;z-index:10;
}
.hsc-dot{
  width:8px;height:8px;border-radius:50%;
  background:rgba(35,82,255,.25);border:none;cursor:pointer;
  transition:all .2s;padding:0;
}
.hsc-dot.active{background:var(--blue);width:24px;border-radius:4px;}

/* ═══════════════════════════════════
   SLIDE 2 — 구독료 탈출 (밝은 버전)
═══════════════════════════════════ */
.slide2-pricing{
  min-height:calc(100vh - 220px);
  max-height:none !important;
  background:linear-gradient(150deg,#fffbf0 0%,#fff7e6 30%,#fef0f0 60%,#f0f6ff 100%);
  display:flex !important;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  padding:80px 24px 70px;
  position:relative;overflow:hidden;
}

/* 배경 도트 패턴 */
.s2-grid{
  position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(255,107,43,.1) 1.5px,transparent 1.5px);
  background-size:36px 36px;
  mask-image:radial-gradient(ellipse 90% 90% at 50% 50%,black 20%,transparent 100%);
}

/* 장식 블롭 */
.s2-glow{position:absolute;border-radius:50%;filter:blur(70px);pointer-events:none;}
.s2-glow.g1{
  width:600px;height:400px;top:-60px;right:-80px;
  background:radial-gradient(ellipse,rgba(255,107,43,.12) 0%,transparent 70%);
  animation:gFloat 10s ease-in-out infinite;
}
.s2-glow.g2{
  width:500px;height:400px;bottom:-80px;left:-60px;
  background:radial-gradient(ellipse,rgba(35,82,255,.1) 0%,transparent 70%);
  animation:gFloat2 13s ease-in-out infinite reverse;
}

/* 날아다니는 코인 장식 */
.s2-coins{position:absolute;inset:0;pointer-events:none;overflow:hidden;}
.coin{position:absolute;font-size:24px;animation:coinFloat 8s ease-in-out infinite;}
.coin.c1{top:12%;left:5%;animation-delay:0s;opacity:.25;}
.coin.c2{top:65%;left:3%;animation-delay:2s;opacity:.18;}
.coin.c3{top:25%;right:4%;animation-delay:1s;opacity:.2;}
.coin.c4{top:72%;right:8%;animation-delay:3.5s;opacity:.22;}
.coin.c5{top:8%;right:18%;animation-delay:1.8s;opacity:.15;}
@keyframes coinFloat{
  0%,100%{transform:translateY(0) rotate(-5deg);}
  50%{transform:translateY(-28px) rotate(8deg);}
}

/* 메인 레이아웃 */
.s2-inner{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1fr 1fr;
  gap:44px;max-width:1080px;width:100%;
  align-items:start;
}
@media(max-width:860px){
  .s2-inner{grid-template-columns:1fr;gap:28px;max-width:560px;}
}

/* 좌측 텍스트 */
.s2-left{}
.s2-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,107,43,.1);border:1.5px solid rgba(255,107,43,.3);
  border-radius:100px;padding:7px 18px;
  font-size:12px;font-weight:700;color:#d94f00;
  margin-bottom:22px;letter-spacing:.2px;
  animation:fadeUp .8s ease both;
}
.s2-badge-dot{width:7px;height:7px;border-radius:50%;background:#ff6b2b;animation:pulse 2s infinite;flex-shrink:0;}

.s2-h-sub{
  font-size:15px;font-weight:600;color:#9ca3af;
  margin-bottom:4px;letter-spacing:.2px;
  animation:fadeUp .8s ease .08s both;
}
.s2-h-main{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(50px,7vw,84px);
  line-height:.95;letter-spacing:-1px;
  color:var(--ink);
  margin-bottom:28px;
  animation:fadeUp .8s ease .14s both;
}
.s2-h-accent{
  background:linear-gradient(135deg,#ff4500,#ff6b2b,#ff4500);
  background-size:200% auto;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  animation:fadeUp .8s ease .14s both, gradShift 3s ease-in-out infinite;
}
@keyframes gradShift{0%,100%{background-position:0%}50%{background-position:100%}}

/* 구독료 폭탄 리스트 */
.s2-bomb-title{
  font-size:11px;font-weight:800;color:#9ca3af;
  letter-spacing:2px;text-transform:uppercase;
  margin-bottom:12px;display:flex;align-items:center;gap:8px;
  animation:fadeUp .8s ease .18s both;
}
.s2-bomb-title::before{content:'';width:20px;height:2px;background:#ff6b2b;border-radius:2px;}

.s2-pain-list{
  display:flex;flex-direction:column;gap:8px;
  margin-bottom:16px;
  animation:fadeUp .8s ease .22s both;
}
.s2-pain-item{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 14px;border-radius:10px;
  background:#fff;border:1px solid #f3e8dc;
  box-shadow:0 1px 4px rgba(0,0,0,.04);
  font-size:13.5px;color:#374151;
  gap:12px;
}
.s2-pain-left{display:flex;align-items:center;gap:8px;}
.s2-pain-x{
  width:18px;height:18px;border-radius:50%;
  background:#fee2e2;border:none;
  display:flex;align-items:center;justify-content:center;
  font-size:9px;color:#ef4444;font-weight:900;flex-shrink:0;
}
.s2-pain-name{color:#6b7280;font-size:13px;}
.s2-pain-price{
  font-size:13.5px;font-weight:800;color:#dc2626;
  white-space:nowrap;flex-shrink:0;
}
.s2-pain-total{
  margin-top:4px;padding:13px 16px;
  background:linear-gradient(135deg,#fef2f2,#fff5f5);
  border:1.5px solid #fca5a5;
  border-radius:12px;font-size:14px;color:#374151;
  font-weight:600;display:flex;align-items:center;justify-content:space-between;
  animation:fadeUp .8s ease .28s both;
}
.s2-pain-total-label{color:#6b7280;font-size:13px;}
.s2-pain-total-num{font-size:20px;font-weight:900;color:#dc2626;}
.s2-pain-total-sub{font-size:11px;color:#9ca3af;margin-top:1px;text-align:right;}

/* 버튼 */
.s2-btns{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px;animation:fadeUp .8s ease .34s both;}
.s2-btn-main{
  padding:14px 28px;border-radius:12px;border:none;
  background:linear-gradient(135deg,var(--blue),var(--purple));
  color:#fff;font-size:14px;font-weight:800;
  cursor:pointer;font-family:'Noto Sans KR',sans-serif;
  box-shadow:0 6px 24px rgba(35,82,255,.3);
  transition:all .2s;display:flex;align-items:center;gap:8px;
}
.s2-btn-main:hover{transform:translateY(-2px);box-shadow:0 10px 36px rgba(35,82,255,.45);}
.s2-btn-ghost{
  padding:13px 22px;border-radius:12px;
  background:#fff;
  border:1.5px solid #dbeafe;
  color:var(--blue);font-size:14px;font-weight:700;
  cursor:pointer;font-family:'Noto Sans KR',sans-serif;transition:all .2s;
  box-shadow:0 2px 8px rgba(35,82,255,.08);
}
.s2-btn-ghost:hover{background:var(--blue-light);border-color:var(--blue);}

/* 우측 카드 영역 */
.s2-right{display:flex;flex-direction:column;gap:14px;animation:fadeUp .8s ease .18s both;}

/* 비교 헤더 */
.s2-compare-head{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;
  margin-bottom:0;
}
.s2-ch{
  text-align:center;padding:8px 10px;border-radius:10px 10px 0 0;
  font-size:12px;font-weight:800;letter-spacing:.3px;
}
.s2-ch.bad{background:#fee2e2;color:#b91c1c;}
.s2-ch.good{background:#dbeafe;color:#1d4ed8;}

/* 비교 테이블 카드 */
.s2-compare-card{
  background:#fff;border-radius:16px;overflow:hidden;
  box-shadow:0 4px 24px rgba(0,0,0,.06);
  border:1px solid #f3f4f6;
}
.s2-compare-row{
  display:grid;grid-template-columns:1fr 1fr;
  border-bottom:1px solid #f3f4f6;
}
.s2-compare-row:last-child{border-bottom:none;}
.s2-cr-cell{
  padding:11px 14px;font-size:13px;
  display:flex;align-items:center;gap:7px;
  border-right:1px solid #f3f4f6;
}
.s2-cr-cell:last-child{border-right:none;}
.s2-cr-cell.bad-cell{background:#fffbfb;color:#6b7280;}
.s2-cr-cell.good-cell{background:#f8faff;color:#374151;font-weight:600;}
.s2-cr-cell.bad-cell .ci{color:#ef4444;font-size:12px;flex-shrink:0;}
.s2-cr-cell.good-cell .ci{color:#22c55e;font-size:12px;flex-shrink:0;}

/* 비용 비교 큰 카드 */
.s2-cost-compare{
  display:grid;grid-template-columns:1fr auto 1fr;
  gap:0;align-items:center;
  background:#fff;border-radius:16px;
  border:1px solid #f3f4f6;
  box-shadow:0 4px 24px rgba(0,0,0,.06);
  overflow:hidden;
}
.s2-cost-cell{padding:20px 18px;text-align:center;}
.s2-cost-cell.bad{background:linear-gradient(180deg,#fff5f5,#fff);}
.s2-cost-cell.good{background:linear-gradient(180deg,#f0f9ff,#fff);}
.s2-cost-vs{
  padding:16px 12px;text-align:center;
  background:#f9fafb;border-left:1px solid #f3f4f6;border-right:1px solid #f3f4f6;
  font-size:13px;font-weight:900;color:#9ca3af;
}
.s2-cost-label{font-size:11px;font-weight:700;color:#9ca3af;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase;}
.s2-cost-price{
  font-family:'Bebas Neue',sans-serif;
  font-size:36px;letter-spacing:-1px;line-height:1;margin-bottom:4px;
}
.s2-cost-price.bad{color:#dc2626;}
.s2-cost-price.good{color:var(--blue);}
.s2-cost-price span{font-size:16px;font-family:'Noto Sans KR',sans-serif;font-weight:700;}
.s2-cost-sub{font-size:11px;color:#9ca3af;}

/* 여정 카드 */
.s2-journey-card{
  background:#fff;border-radius:16px;overflow:hidden;
  border:1.5px solid #dbeafe;
  box-shadow:0 4px 24px rgba(35,82,255,.08);
}
.s2-journey-head{
  background:linear-gradient(135deg,var(--blue-light),#ede9ff);
  padding:14px 20px;
  display:flex;align-items:center;gap:10px;
  border-bottom:1px solid #dbeafe;
}
.s2-journey-head-ico{font-size:20px;}
.s2-journey-head-title{font-size:14px;font-weight:800;color:var(--ink);}
.s2-journey-head-sub{font-size:11.5px;color:var(--t2);margin-top:1px;}

.s2-journey{display:flex;flex-direction:column;padding:14px 20px;gap:0;}
.s2-journey-step{
  display:flex;align-items:flex-start;gap:12px;
  padding:9px 10px;border-radius:10px;
}
.s2-journey-step.highlight{
  background:var(--green-light);border:1px solid rgba(0,196,140,.25);
  margin:2px 0;
}
.s2-journey-step.highlight2{
  background:var(--blue-light);border:1px solid rgba(35,82,255,.18);
  margin:2px 0;
}
.s2-journey-arrow{
  font-size:12px;color:#d1d5db;
  padding-left:21px;line-height:1;margin:-2px 0;
}
.s2-step-num{
  width:24px;height:24px;border-radius:50%;
  background:var(--surface2);border:1.5px solid var(--bd);
  display:flex;align-items:center;justify-content:center;
  font-size:10px;font-weight:800;color:var(--t2);
  flex-shrink:0;margin-top:1px;
}
.s2-step-num.green{background:var(--green-light);border-color:rgba(0,196,140,.4);color:#00a878;}
.s2-step-num.blue{background:var(--blue-light);border-color:rgba(35,82,255,.3);color:var(--blue);}
.s2-step-text{font-size:12.5px;color:var(--t2);line-height:1.5;}
.s2-step-text strong{color:var(--ink);font-weight:800;}
.s2-step-gift{
  margin-left:auto;flex-shrink:0;
  background:var(--green);color:#fff;
  font-size:10px;font-weight:800;
  padding:2px 8px;border-radius:20px;
  white-space:nowrap;margin-top:2px;
}

.s2-journey-footer{
  display:flex;gap:6px;flex-wrap:wrap;
  padding:12px 20px;border-top:1px solid var(--bd);
  background:var(--surface);
}
.s2-good-tag{
  font-size:11px;font-weight:700;
  padding:4px 11px;border-radius:20px;
  background:var(--blue-light);border:1px solid rgba(35,82,255,.2);
  color:var(--blue);
}
.s2-good-tag.green{background:var(--green-light);border-color:rgba(0,196,140,.3);color:#00a878;}

/* ═══════════════════════════════════
   HOME — TOOLS SECTION
═══════════════════════════════════ */
.tools-section{
  background:var(--surface);
  padding:48px 24px 64px;
}
.section-inner{max-width:1140px;margin:0 auto;}
.section-eyebrow{
  font-size:11px;font-weight:800;color:var(--blue);
  letter-spacing:2px;text-transform:uppercase;
  margin-bottom:12px;display:flex;align-items:center;gap:8px;
}
.section-eyebrow::before{content:'';width:24px;height:2px;background:var(--blue);border-radius:2px;}
.section-title{font-size:clamp(26px,4vw,42px);font-weight:900;letter-spacing:-1px;line-height:1.2;margin-bottom:12px;}
.section-desc{font-size:15px;color:var(--t2);line-height:1.7;max-width:520px;}

.tools-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:20px;
  margin-top:48px;
}
@media(max-width:640px){.tools-grid{grid-template-columns:1fr;}}

.tool-card{
  background:var(--white);
  border:1px solid var(--bd);
  border-radius:var(--r);
  padding:0;overflow:hidden;
  cursor:pointer;transition:all .25s;
  box-shadow:var(--sh);
  display:flex;flex-direction:column;
}
.tool-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--sh2);
  border-color:var(--bd2);
}
.tool-card-top{
  padding:28px 28px 0;
  display:flex;align-items:flex-start;justify-content:space-between;
  margin-bottom:20px;
}
.tool-icon-wrap{
  width:56px;height:56px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  font-size:26px;
}
.tool-icon-wrap.blue{background:var(--blue-light);}
.tool-icon-wrap.green{background:var(--green-light);}
.tool-icon-wrap.purple{background:var(--purple-light);}
.tool-icon-wrap.orange{background:var(--orange-light);}
.tool-free{
  background:#dcfce7;color:#14532d;
  font-size:10.5px;font-weight:800;
  padding:3px 10px;border-radius:20px;
}
.tool-card-body{padding:0 28px 28px;flex:1;display:flex;flex-direction:column;}
.tool-name{font-size:20px;font-weight:800;letter-spacing:-.4px;margin-bottom:8px;}
.tool-desc{font-size:13.5px;color:var(--t2);line-height:1.65;margin-bottom:20px;flex:1;}
.tool-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px;}
.tool-tag{
  font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px;
  background:var(--surface);color:var(--t2);border:1px solid var(--bd);
}
.tool-go{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 20px;
  border-top:1px solid var(--bd);
  font-size:13px;font-weight:700;
}
.tool-go.blue{color:var(--blue);}
.tool-go.green{color:var(--green);}
.tool-go.purple{color:var(--purple);}
.tool-go.orange{color:var(--orange);}
.tool-go-arrow{
  width:28px;height:28px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  font-size:14px;transition:transform .2s;
}
.tool-card:hover .tool-go-arrow{transform:translateX(4px);}
.tool-go.blue .tool-go-arrow{background:var(--blue-light);}
.tool-go.green .tool-go-arrow{background:var(--green-light);}
.tool-go.purple .tool-go-arrow{background:var(--purple-light);}
.tool-go.orange .tool-go-arrow{background:var(--orange-light);}

/* ═══════════════════════════════════
   HOME — CTA SECTION
═══════════════════════════════════ */
.cta-section{
  background:var(--ink2);
  padding:80px 24px;
  position:relative;overflow:hidden;
}
.cta-section::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 80% at 50% 50%,rgba(35,82,255,.12) 0%,transparent 70%);
}
.cta-inner{
  max-width:760px;margin:0 auto;text-align:center;position:relative;
}
.cta-title{font-size:clamp(24px,4vw,40px);font-weight:900;color:#fff;letter-spacing:-.8px;margin-bottom:14px;line-height:1.2;}
.cta-desc{font-size:15px;color:rgba(255,255,255,.55);line-height:1.7;margin-bottom:36px;}
.cta-features{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:12px;margin-bottom:36px;text-align:left;
}
@media(max-width:500px){.cta-features{grid-template-columns:1fr;}}
.cta-feat{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--r2);padding:14px 16px;
  display:flex;align-items:flex-start;gap:10px;
}
.cta-feat-ico{font-size:18px;flex-shrink:0;margin-top:1px;}
.cta-feat-text{font-size:13px;color:rgba(255,255,255,.7);line-height:1.5;}
.cta-feat-text strong{color:#fff;display:block;font-size:13.5px;margin-bottom:2px;}
.big-kakao{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--kakao);color:#1a1200;
  border:none;border-radius:14px;padding:16px 36px;
  font-size:16px;font-weight:800;cursor:pointer;
  box-shadow:0 8px 32px rgba(254,229,0,.3);transition:all .2s;
}
.big-kakao:hover{transform:translateY(-2px);box-shadow:0 12px 40px rgba(254,229,0,.4);}

/* ═══════════════════════════════════
   HOME — FOOTER
═══════════════════════════════════ */
.site-footer{
  background:var(--ink);
  padding:32px 24px;text-align:center;
  border-top:1px solid rgba(255,255,255,.06);
}
.footer-text{font-size:12px;color:rgba(255,255,255,.3);line-height:1.8;}
.footer-kakao{color:var(--kakao);cursor:pointer;font-weight:700;}

/* ═══════════════════════════════════
   TOOL PAGE WRAPPER
═══════════════════════════════════ */
.tool-page{padding-top:60px;min-height:100vh;}
.tool-page-hero{
  padding:48px 24px 40px;
  border-bottom:1px solid var(--bd);
  background:var(--white);
}
.tool-page-hero-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;}
.tph-left{}
.tph-badge{
  display:inline-flex;align-items:center;gap:6px;
  font-size:11px;font-weight:800;padding:4px 12px;
  border-radius:20px;margin-bottom:10px;letter-spacing:.3px;
}
.tph-badge.blue{background:var(--blue-light);color:var(--blue);}
.tph-badge.green{background:var(--green-light);color:var(--green);}
.tph-badge.purple{background:var(--purple-light);color:var(--purple);}
.tph-badge.orange{background:var(--orange-light);color:var(--orange);}
.tph-title{font-size:clamp(22px,3.5vw,34px);font-weight:900;letter-spacing:-.7px;margin-bottom:6px;}
.tph-sub{font-size:13.5px;color:var(--t2);}
.tph-right{display:flex;gap:8px;align-items:center;flex-wrap:wrap;}

/* TOOL CONTENT */
.tool-content{max-width:1100px;margin:0 auto;padding:28px 24px 60px;}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.three-col{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;}
@media(max-width:800px){.two-col,.three-col{grid-template-columns:1fr;}}

/* ═══════════════════════════════════
   PANEL SYSTEM
═══════════════════════════════════ */
.panel{
  background:var(--white);border:1px solid var(--bd);
  border-radius:var(--r);box-shadow:var(--sh);overflow:hidden;
}
.ph{
  padding:14px 20px;border-bottom:1px solid var(--bd);
  display:flex;align-items:center;gap:8px;background:var(--white);
}
.ph-ico{font-size:16px;}
.ph-title{font-size:13.5px;font-weight:700;flex:1;}
.ph-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;background:var(--surface2);color:var(--t2);}
.pb{padding:20px;display:flex;flex-direction:column;gap:14px;}

/* ═══════════════════════════════════
   FORM ELEMENTS
═══════════════════════════════════ */
.fg{display:flex;flex-direction:column;gap:5px;}
.fg label{font-size:11px;font-weight:700;color:var(--t2);letter-spacing:.3px;}
.inp,.sel,.ta{
  background:var(--surface);border:1.5px solid var(--bd);
  border-radius:var(--r3);color:var(--t);
  font-size:13px;padding:9px 12px;width:100%;
  font-family:'Noto Sans KR',sans-serif;
  transition:all .15s;
  user-select:text;
  -webkit-user-select:text;
  -moz-user-select:text;
  -ms-user-select:text;
  pointer-events:auto;
  position:relative;
  z-index:1;
}
.inp:focus,.sel:focus,.ta:focus{outline:none;border-color:var(--blue);background:var(--white);box-shadow:0 0 0 3px rgba(35,82,255,.08);}
.inp::placeholder,.ta::placeholder{color:var(--t3);}
.ta{resize:vertical;}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.frow3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;}
@media(max-width:500px){.frow{grid-template-columns:1fr;}}

/* ═══════════════════════════════════
   BUTTONS
═══════════════════════════════════ */
.btn{
  padding:10px 18px;border-radius:var(--r3);border:none;
  font-size:13px;font-weight:700;cursor:pointer;
  font-family:'Noto Sans KR',sans-serif;transition:all .17s;
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  white-space:nowrap;
}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important;}
.btn-primary{background:var(--blue);color:#fff;box-shadow:0 4px 12px rgba(35,82,255,.25);}
.btn-primary:hover{background:#1a3de0;transform:translateY(-1px);box-shadow:0 6px 20px rgba(35,82,255,.35);}
.btn-green{background:var(--green);color:#fff;box-shadow:0 4px 12px rgba(0,196,140,.25);}
.btn-green:hover{background:#00a878;transform:translateY(-1px);}
.btn-purple{background:var(--purple);color:#fff;}
.btn-purple:hover{background:#6a38f0;transform:translateY(-1px);}
.btn-orange{background:var(--orange);color:#fff;}
.btn-orange:hover{background:#e85a1f;transform:translateY(-1px);}
.btn-ghost{background:var(--white);color:var(--t);border:1.5px solid var(--bd2);}
.btn-ghost:hover{border-color:var(--blue);color:var(--blue);}
.btn-full{width:100%;}
.btn-row{display:flex;gap:8px;flex-wrap:wrap;}
.btn-lg{padding:13px 24px;font-size:14px;border-radius:var(--r2);}

/* ═══════════════════════════════════
   TOGGLE
═══════════════════════════════════ */
.tog-row{display:flex;align-items:center;gap:10px;}
.tog{
  width:40px;height:22px;background:var(--bd2);border-radius:11px;
  cursor:pointer;transition:all .2s;position:relative;flex-shrink:0;
}
.tog.on{background:var(--blue);}
.tog::after{
  content:'';position:absolute;top:2px;left:2px;
  width:18px;height:18px;border-radius:50%;background:#fff;
  transition:all .2s;box-shadow:0 1px 4px rgba(0,0,0,.15);
}
.tog.on::after{left:20px;}
.tog-lbl{font-size:12.5px;font-weight:600;color:var(--t2);}

/* ═══════════════════════════════════
   SECTION LABEL
═══════════════════════════════════ */
.slbl{
  font-size:10px;font-weight:800;color:var(--blue);
  letter-spacing:1.5px;text-transform:uppercase;
  padding-bottom:10px;border-bottom:1px solid var(--bd);
}
.sep{height:1px;background:var(--bd);}

/* ═══════════════════════════════════
   RESULT BOXES
═══════════════════════════════════ */
.result-box{
  background:var(--green-light);border:1px solid #6ee7b7;
  border-radius:var(--r2);padding:16px;display:none;
}
.result-box.show{display:block;}
.result-row{display:flex;justify-content:space-between;padding:4px 0;border-bottom:1px solid rgba(0,0,0,.05);font-size:12.5px;}
.result-row:last-child{border:none;}
.rk{color:var(--t2);}
.rv{font-weight:700;color:var(--green);font-family:'Bebas Neue',sans-serif;font-size:15px;letter-spacing:.5px;}

.err-box{
  background:#fff1f0;border:1px solid #fca5a5;
  border-radius:var(--r2);padding:12px 14px;
  font-size:12.5px;color:var(--red);display:none;line-height:1.6;
}
.err-box.show{display:block;}

/* ═══════════════════════════════════
   TOTAL BOX (DOC)
═══════════════════════════════════ */
.total-box{
  background:var(--surface);border-radius:var(--r2);
  padding:14px 16px;display:flex;flex-direction:column;gap:5px;
  border:1px solid var(--bd);
}
.tr{display:flex;justify-content:space-between;font-size:13px;}
.tr.big{
  font-size:17px;font-weight:800;color:var(--blue);
  padding-top:10px;border-top:2px solid var(--bd2);margin-top:4px;
}
.trl{color:var(--t2);}

/* ═══════════════════════════════════
   DOC TYPE TABS
═══════════════════════════════════ */
.doc-tabs{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;}
.doc-tab{
  padding:10px 6px;border-radius:var(--r3);
  border:2px solid var(--bd);background:var(--surface);
  font-size:11.5px;font-weight:700;color:var(--t2);
  cursor:pointer;transition:all .17s;text-align:center;line-height:1.5;
}
.doc-tab:hover{border-color:var(--blue);color:var(--blue);}
.doc-tab.on{border-color:var(--blue);background:var(--blue-light);color:var(--blue);}

/* 견적서 스타일 선택 */
.quote-style-tabs{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-top:10px;}
.qs-tab{
  padding:8px 4px;border-radius:var(--r3);
  border:2px solid var(--bd);background:var(--surface);
  font-size:10.5px;font-weight:700;color:var(--t2);
  cursor:pointer;transition:all .17s;text-align:center;line-height:1.5;
}
.qs-tab:hover{border-color:var(--purple);color:var(--purple);}
.qs-tab.on{border-color:var(--purple);background:var(--purple-light);color:var(--purple);}
.qs-tab .qs-icon{font-size:16px;display:block;margin-bottom:2px;}
.qs-tab .qs-name{font-size:9.5px;display:block;}

/* ═══════════════════════════════════
   이미지 드래그 개선
═══════════════════════════════════ */
.img-drop-zone{
  border:2px dashed var(--bd2);border-radius:var(--r2);
  padding:36px 20px;text-align:center;cursor:pointer;
  transition:all .2s;position:relative;
}
.img-drop-zone:hover,.img-drop-zone.drag-over{
  border-color:var(--purple);background:var(--purple-light);
}
.img-drop-zone.drag-over::after{
  content:'이미지를 여기에 놓으세요';
  position:absolute;inset:0;
  background:rgba(124,77,255,.12);
  display:flex;align-items:center;justify-content:center;
  font-size:16px;font-weight:800;color:var(--purple);
  border-radius:var(--r2);
}

/* 비율 프리셋 버튼 */
.ratio-presets{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px;}
.rp-btn{
  padding:5px 10px;border-radius:6px;
  border:1.5px solid var(--bd2);background:var(--surface);
  font-size:11px;font-weight:700;color:var(--t2);
  cursor:pointer;transition:all .15s;
}
.rp-btn:hover{border-color:var(--purple);color:var(--purple);background:var(--purple-light);}
.rp-btn.on{border-color:var(--purple);background:var(--purple-light);color:var(--purple);}

/* 이미지 미리보기 비교 */
.img-compare-wrap{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px;}
.img-compare-box{border-radius:var(--r2);overflow:hidden;border:1px solid var(--bd);background:var(--surface);}
.img-compare-label{font-size:10.5px;font-weight:700;color:var(--t2);padding:7px 10px;background:var(--surface2);border-bottom:1px solid var(--bd);}
.img-compare-canvas{width:100%;display:block;}
@media(max-width:500px){.img-compare-wrap{grid-template-columns:1fr;}}

/* PDF 미리보기 */
.pdf-preview-panel{margin-top:16px;}
.pdf-page-thumb{
  background:#fff;border:1px solid var(--bd);
  border-radius:var(--r2);padding:10px;
  display:flex;align-items:center;gap:10px;
  font-size:12.5px;transition:all .15s;
}
.pdf-page-thumb:hover{border-color:var(--orange);background:var(--orange-light);}
.pdf-thumb-num{
  width:28px;height:28px;border-radius:6px;
  background:var(--orange-light);color:var(--orange);
  font-size:11px;font-weight:800;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.pdf-thumb-name{flex:1;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.pdf-thumb-size{font-size:10.5px;color:var(--t3);}
.pdf-merge-arrow{
  text-align:center;padding:6px 0;
  font-size:20px;color:var(--bd2);
}
.pdf-merge-result{
  background:var(--green-light);border:1px solid #6ee7b7;
  border-radius:var(--r2);padding:12px;
  text-align:center;font-size:13px;font-weight:700;color:var(--green);
  display:none;
}
.pdf-merge-result.show{display:block;}

/* ═══════════════════════════════════
   ITEMS TABLE (DOC)
═══════════════════════════════════ */
.items-wrap{overflow-x:auto;}
.items-tbl{width:100%;border-collapse:collapse;font-size:12.5px;}
.items-tbl th{
  background:var(--surface);padding:8px 7px;
  text-align:left;font-size:10.5px;font-weight:700;color:var(--t2);
  border-bottom:1.5px solid var(--bd);white-space:nowrap;
}
.items-tbl td{padding:5px 4px;border-bottom:1px solid var(--surface2);}
.items-tbl td input{
  width:100%;background:transparent;
  border:1.5px solid transparent;border-radius:6px;
  color:var(--t);font-size:12.5px;padding:5px 7px;
  font-family:'Noto Sans KR',sans-serif;transition:all .13s;
}
.items-tbl td input:focus{outline:none;background:var(--white);border-color:var(--blue);}
.items-tbl td.amt{
  font-weight:700;font-size:12px;color:var(--blue);
  text-align:right;padding-right:8px;white-space:nowrap;
}
.del-btn{
  background:none;border:none;cursor:pointer;
  color:var(--t3);font-size:14px;padding:3px 5px;
  border-radius:5px;transition:all .13s;
}
.del-btn:hover{color:var(--red);background:rgba(255,59,59,.08);}
.add-row{
  width:100%;background:none;
  border:1.5px dashed var(--bd2);border-radius:var(--r3);
  color:var(--t2);font-size:12.5px;font-weight:600;padding:9px;
  cursor:pointer;transition:all .17s;
  font-family:'Noto Sans KR',sans-serif;margin-top:8px;
}
.add-row:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-light);}

/* ═══════════════════════════════════
   DOC PREVIEW
═══════════════════════════════════ */
.doc-preview{
  background:#fff;border:1px solid var(--bd);
  border-radius:var(--r);padding:28px;
  font-size:12.5px;line-height:1.6;
  box-shadow:var(--sh);
}
.dp-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;}
.dp-type{font-size:22px;font-weight:900;letter-spacing:-.5px;border-bottom:3px solid var(--blue);padding-bottom:4px;}
.dp-meta{font-size:10.5px;color:var(--t2);text-align:right;}
.dp-meta strong{display:block;font-size:12.5px;color:var(--t);}
.dp-parties{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px;}
.dp-party{border:1px solid var(--bd);border-radius:8px;padding:11px 13px;}
.dp-party-lbl{font-size:9px;font-weight:800;color:var(--t3);letter-spacing:1px;text-transform:uppercase;margin-bottom:5px;}
.dp-party-name{font-size:14px;font-weight:800;margin-bottom:3px;}
.dp-party-info{font-size:11px;color:var(--t2);line-height:1.65;}
.dp-table{width:100%;border-collapse:collapse;margin-bottom:14px;font-size:11.5px;}
.dp-table th{background:var(--surface);padding:7px 8px;text-align:center;font-size:10px;font-weight:700;color:var(--t2);border:1px solid var(--bd);}
.dp-table td{padding:6px 8px;border:1px solid var(--bd);text-align:center;}
.dp-table td.l{text-align:left;}
.dp-table td.r{text-align:right;font-weight:600;}
.dp-table tr:nth-child(even) td{background:var(--surface);}
.dp-table tfoot td{background:var(--blue-light);font-weight:700;border-top:2px solid var(--blue);}
.dp-grand{font-size:13.5px;color:var(--blue);font-weight:900;}
.dp-note{margin-top:12px;background:#fffbeb;border:1px solid #fde68a;border-radius:8px;padding:10px 12px;font-size:11px;color:#92400e;}
.dp-note-lbl{font-weight:700;margin-bottom:2px;}
.dp-sign{display:flex;justify-content:flex-end;margin-top:14px;}
.dp-sign-box{border:1px solid var(--bd);border-radius:8px;padding:11px 18px;text-align:center;font-size:11.5px;position:relative;}
.dp-sign-lbl{color:var(--t2);margin-bottom:20px;}
.dp-sign-name{font-weight:700;border-top:1px solid var(--t);padding-top:4px;}

/* 도장 스타일 */
.stamp-wrap{position:absolute;top:50%;right:10px;transform:translateY(-60%) rotate(-12deg);pointer-events:none;}
.stamp-circle{
  width:72px;height:72px;border-radius:50%;
  border:3px solid rgb(210,0,0);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:transparent;opacity:.85;
}
.stamp-inner-ring{
  width:62px;height:62px;border-radius:50%;
  border:1.5px solid rgb(210,0,0);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  position:absolute;
}
.stamp-text-top{font-size:8px;font-weight:900;color:rgb(210,0,0);letter-spacing:1.5px;margin-bottom:1px;}
.stamp-text-main{font-size:9.5px;font-weight:900;color:rgb(210,0,0);letter-spacing:.5px;text-align:center;line-height:1.2;max-width:48px;word-break:keep-all;}
.stamp-text-bot{font-size:7px;font-weight:700;color:rgb(210,0,0);letter-spacing:1px;margin-top:1px;}
.stamp-img{width:72px;height:72px;object-fit:contain;opacity:.85;}

/* 도장 업로드 UI */
.stamp-upload-area{
  border:1.5px dashed rgba(210,0,0,.25);border-radius:var(--r3);
  padding:12px;text-align:center;cursor:pointer;transition:all .18s;
  background:rgba(210,0,0,.03);
}
.stamp-upload-area:hover{border-color:rgb(210,0,0);background:rgba(210,0,0,.06);}
.stamp-preview-wrap{display:flex;align-items:center;gap:12px;padding:8px 0;}
.stamp-canvas-preview{border-radius:50%;border:1px solid var(--bd);}
.dp-footer{margin-top:14px;text-align:center;font-size:10px;color:var(--t3);border-top:1px solid var(--bd);padding-top:10px;}

/* ═══════════════════════════════════
   QR
═══════════════════════════════════ */
.qr-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;}
.qr-item{
  background:var(--surface);border:1px solid var(--bd);
  border-radius:var(--r2);padding:14px;text-align:center;
  transition:all .18s;overflow:hidden;
  display:flex;flex-direction:column;align-items:center;
}
.qr-item:hover{border-color:var(--green);box-shadow:0 4px 16px rgba(0,196,140,.1);}
.qr-item-canvas-wrap{
  width:100%;display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
/* QRCode 라이브러리가 canvas+img 둘 다 생성 — canvas는 숨기고 img만 표시 */
.qr-item-canvas-wrap canvas{display:none !important;}
.qr-item-canvas-wrap img{
  max-width:100%;height:auto;display:block;
  border-radius:4px;
}
.qr-lbl{font-size:10.5px;color:var(--t2);margin:8px 0 6px;word-break:break-all;line-height:1.4;width:100%;}
.qr-dl{
  width:100%;background:var(--green);color:#fff;
  border:none;border-radius:6px;padding:6px;
  font-size:11px;font-weight:700;cursor:pointer;
  font-family:'Noto Sans KR',sans-serif;transition:opacity .15s;
}
.qr-dl:hover{opacity:.88;}
.color-sw-row{display:flex;gap:7px;flex-wrap:wrap;align-items:center;}
.csw{
  width:28px;height:28px;border-radius:50%;cursor:pointer;
  border:2.5px solid transparent;transition:all .15s;
  flex-shrink:0;
}
.csw.on{border-color:var(--t);transform:scale(1.1);}

/* ═══════════════════════════════════
   IMAGE
═══════════════════════════════════ */
.img-preview-wrap{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:10px;
}
.img-thumb{
  position:relative;aspect-ratio:1;border-radius:var(--r3);
  overflow:hidden;background:var(--surface);border:1px solid var(--bd);
}
.img-thumb img{width:100%;height:100%;object-fit:cover;}
.img-overlay{
  position:absolute;inset:0;background:rgba(0,0,0,.55);
  display:flex;align-items:center;justify-content:center;
  opacity:0;transition:.15s;
}
.img-thumb:hover .img-overlay{opacity:1;}
.img-rm{color:#fff;font-size:20px;cursor:pointer;}
.img-sz{
  position:absolute;bottom:0;left:0;right:0;
  background:rgba(0,0,0,.6);color:#fff;
  font-size:9px;padding:2px 5px;text-align:center;
}
#wm-preview-wrap{
  background:var(--surface);border-radius:var(--r2);
  overflow:hidden;display:flex;align-items:center;
  justify-content:center;min-height:220px;
}

/* ═══════════════════════════════════
   PDF
═══════════════════════════════════ */
.pdf-drop{
  border:2px dashed var(--bd2);border-radius:var(--r2);
  padding:36px 20px;text-align:center;cursor:pointer;
  transition:all .2s;
}
.pdf-drop:hover,.pdf-drop.over{border-color:var(--orange);background:var(--orange-light);}
.pdf-file-list{display:flex;flex-direction:column;gap:6px;}
.pdf-fi{
  display:flex;align-items:center;gap:9px;
  background:var(--surface);border:1px solid var(--bd);
  border-radius:var(--r3);padding:9px 13px;font-size:12.5px;
}
.pdf-ext{
  background:rgba(255,107,43,.12);color:var(--orange);
  font-size:9px;font-weight:800;padding:2px 6px;border-radius:4px;
  font-family:'Bebas Neue',sans-serif;letter-spacing:.5px;flex-shrink:0;
}
.pdf-fn{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500;}
.pdf-fs{font-size:10.5px;color:var(--t3);flex-shrink:0;}
.pdf-rm{color:var(--t3);cursor:pointer;font-size:14px;flex-shrink:0;transition:.13s;}
.pdf-rm:hover{color:var(--red);}

/* ═══════════════════════════════════
   KAKAO PROMO
═══════════════════════════════════ */
.kakao-promo{
  background:linear-gradient(135deg,var(--ink2),var(--ink3));
  border-radius:var(--r);padding:24px;color:#fff;
  border:1px solid rgba(255,255,255,.07);
}
.kp-title{font-size:15px;font-weight:800;margin-bottom:6px;}
.kp-desc{font-size:12.5px;color:rgba(255,255,255,.6);line-height:1.65;margin-bottom:16px;}
.kp-btn{
  width:100%;background:var(--kakao);color:#1a1200;
  border:none;border-radius:var(--r3);padding:12px;
  font-size:13px;font-weight:800;cursor:pointer;
  font-family:'Noto Sans KR',sans-serif;
  display:flex;align-items:center;justify-content:center;gap:7px;
  transition:all .17s;
}
.kp-btn:hover{opacity:.9;transform:translateY(-1px);}

/* ═══════════════════════════════════
   STICKY PREVIEW
═══════════════════════════════════ */
.sticky-preview{position:sticky;top:72px;max-height:calc(100vh - 90px);overflow-y:auto;min-height:200px;}
.sticky-preview::-webkit-scrollbar{width:4px;}
.sticky-preview::-webkit-scrollbar-thumb{background:var(--bd2);border-radius:2px;}

/* ═══════════════════════════════════
   SPINNER
═══════════════════════════════════ */
@keyframes spin{to{transform:rotate(360deg)}}
.spin{display:inline-block;width:13px;height:13px;border:2px solid rgba(255,255,255,.25);border-top-color:#fff;border-radius:50%;animation:spin .65s linear infinite;}

/* ═══════════════════════════════════
   UPSCALE 전용 스타일
═══════════════════════════════════ */
.upscale-drop{
  border:2px dashed var(--bd2);border-radius:var(--r2);
  padding:56px 20px;text-align:center;cursor:pointer;
  transition:all .2s;position:relative;
  background:linear-gradient(135deg,rgba(124,77,255,.02),rgba(35,82,255,.02));
}
.upscale-drop:hover,.upscale-drop.drag-over{border-color:var(--purple);background:var(--purple-light);}
.upscale-compare{
  display:grid;grid-template-columns:1fr 1fr;gap:16px;
}
@media(max-width:600px){.upscale-compare{grid-template-columns:1fr;}}
.upscale-panel{
  border-radius:var(--r2);overflow:hidden;
  border:1px solid var(--bd);background:var(--white);
}
.upscale-panel-head{
  padding:9px 14px;font-size:11.5px;font-weight:700;
  display:flex;align-items:center;gap:6px;
  border-bottom:1px solid var(--bd);
}
.upscale-panel-head.before{background:var(--surface2);color:var(--t2);}
.upscale-panel-head.after{background:var(--purple-light);color:var(--purple);}
.upscale-img-wrap{
  padding:12px;min-height:200px;
  display:flex;align-items:center;justify-content:center;
  background:#f8f7fc;position:relative;
}
.upscale-img-wrap img{max-width:100%;max-height:340px;border-radius:6px;display:block;}
.upscale-info{padding:8px 12px;font-size:11px;color:var(--t2);border-top:1px solid var(--bd);text-align:center;line-height:1.7;}
.upscale-progress{
  width:100%;height:6px;background:var(--surface2);
  border-radius:3px;overflow:hidden;margin-top:10px;
}
.upscale-progress-bar{
  height:100%;background:linear-gradient(90deg,var(--purple),var(--blue));
  border-radius:3px;transition:width .3s ease;
  width:0%;
}
.upscale-badge{
  display:inline-flex;align-items:center;gap:5px;
  background:var(--purple-light);color:var(--purple);
  font-size:10px;font-weight:800;padding:3px 10px;
  border-radius:20px;letter-spacing:.3px;
}
.upscale-scale-btn{
  padding:8px 16px;border-radius:var(--r3);
  border:2px solid var(--bd);background:var(--surface);
  font-size:13px;font-weight:800;color:var(--t2);
  cursor:pointer;transition:all .15s;
  font-family:'Noto Sans KR',sans-serif;
}
.upscale-scale-btn:hover{border-color:var(--purple);color:var(--purple);background:var(--purple-light);}
.upscale-scale-btn.on{border-color:var(--purple);background:var(--purple);color:#fff;box-shadow:0 4px 12px rgba(124,77,255,.3);}
.enhance-opt{
  display:flex;align-items:center;gap:10px;
  background:var(--surface);border-radius:var(--r3);
  padding:12px 14px;border:1.5px solid var(--bd);
  cursor:pointer;transition:all .15s;
}
.enhance-opt:hover{border-color:var(--purple);background:var(--purple-light);}
.enhance-opt.on{border-color:var(--purple);background:var(--purple-light);}
.enhance-opt input[type=checkbox]{accent-color:var(--purple);width:15px;height:15px;flex-shrink:0;}
.enhance-opt-text{flex:1;}
.enhance-opt-title{font-size:12.5px;font-weight:700;color:var(--t);}
.enhance-opt-desc{font-size:11px;color:var(--t3);margin-top:1px;}
.upscale-result-hint{
  background:linear-gradient(135deg,var(--purple-light),var(--blue-light));
  border:1px solid rgba(124,77,255,.2);border-radius:var(--r2);
  padding:14px 16px;font-size:12.5px;color:var(--ink2);
  display:flex;align-items:flex-start;gap:10px;
}
.img-tool-tabs{
  display:grid;grid-template-columns:1fr 1fr;gap:8px;
  margin-bottom:20px;
}
.img-tool-tab{
  padding:13px 10px;border-radius:var(--r2);
  border:2px solid var(--bd);background:var(--white);
  font-size:13px;font-weight:700;color:var(--t2);
  cursor:pointer;transition:all .17s;text-align:center;
  display:flex;align-items:center;justify-content:center;gap:7px;
}
.img-tool-tab:hover{border-color:var(--purple);color:var(--purple);}
.img-tool-tab.on{border-color:var(--purple);background:var(--purple-light);color:var(--purple);}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.shimmer{
  background:linear-gradient(90deg,#f0eeff 25%,#e4dcff 50%,#f0eeff 75%);
  background-size:200% 100%;
  animation:shimmer 1.4s infinite;
}

/* ═══════════════════════════════════
   TOOL STORE
═══════════════════════════════════ */
.store-hero{
  min-height:460px;padding:100px 24px 64px;
  background:linear-gradient(145deg,#080b18 0%,#0f1326 45%,#180d2a 75%,#0a1520 100%);
  position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}
.store-grid-bg{
  position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(79,124,255,.18) 1px,transparent 1px);
  background-size:36px 36px;
  mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 20%,transparent 100%);
}
.sg-glow{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none;}
.sg-glow.a{width:560px;height:380px;top:-60px;left:50%;transform:translateX(-50%);background:radial-gradient(ellipse,rgba(79,124,255,.24) 0%,transparent 70%);animation:sgf 9s ease-in-out infinite;}
.sg-glow.b{width:300px;height:240px;bottom:0;left:0;background:radial-gradient(ellipse,rgba(176,108,255,.18) 0%,transparent 70%);animation:sgf 13s ease-in-out infinite reverse;}
.sg-glow.c{width:260px;height:200px;top:20%;right:4%;background:radial-gradient(ellipse,rgba(255,107,43,.13) 0%,transparent 70%);animation:sgf 16s ease-in-out infinite 2s;}
@keyframes sgf{0%,100%{transform:translateY(0) translateX(-50%)}50%{transform:translateY(-18px) translateX(-50%)}}
.store-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(79,124,255,.14);border:1px solid rgba(79,124,255,.28);
  border-radius:100px;padding:6px 18px;
  font-size:11px;font-weight:800;color:#8ba4ff;letter-spacing:1.5px;text-transform:uppercase;
  margin-bottom:22px;backdrop-filter:blur(8px);animation:fadeUp .7s ease both;
}
.se-dot{width:6px;height:6px;border-radius:50%;background:linear-gradient(135deg,#4f7cff,#b06cff);animation:pulse 2s infinite;}
.store-htitle-wrap{
  display:flex;flex-direction:column;gap:0;
  animation:fadeUp .7s ease .1s both;
  margin-bottom:6px;
}
.store-ht-line1{
  display:flex;align-items:center;gap:12px;
  line-height:1;
}
.sht-ai{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(64px,10vw,110px);
  background:linear-gradient(135deg,#4f7cff 0%,#b06cff 50%,#ff6b6b 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  letter-spacing:2px;
  filter:drop-shadow(0 0 24px rgba(79,124,255,.45));
  line-height:.9;
}
.sht-slash{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(40px,6vw,72px);
  color:rgba(255,255,255,.15);
  letter-spacing:0;
  line-height:1;
  margin-top:4px;
}
.sht-auto{
  font-size:clamp(28px,4.5vw,52px);
  font-weight:900;
  color:rgba(255,255,255,.92);
  letter-spacing:-1px;
  line-height:1;
  margin-top:8px;
}
.store-ht-line2{
  display:flex;align-items:baseline;gap:16px;
  line-height:1;
  margin-top:-4px;
}
.sht-studio{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(52px,9vw,104px);
  color:rgba(255,255,255,.08);
  letter-spacing:6px;
  line-height:.9;
  -webkit-text-stroke:1px rgba(255,255,255,.2);
}
.sht-count{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(18px,2.5vw,28px);
  background:linear-gradient(135deg,#4f7cff,#b06cff);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  border:1px solid rgba(79,124,255,.4);
  border-radius:8px;
  padding:4px 12px;
  letter-spacing:1px;
  margin-bottom:6px;
}
.store-htitle{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(52px,9vw,100px);line-height:.9;letter-spacing:1px;
  color:#fff;margin-bottom:6px;animation:fadeUp .7s ease .1s both;
}
.store-htitle .sg{background:linear-gradient(90deg,#4f7cff,#b06cff,#ff6b2b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;}
.store-hsub{font-size:clamp(13px,1.6vw,15px);color:rgba(255,255,255,.5);line-height:1.75;margin-top:12px;animation:fadeUp .7s ease .2s both;}
.store-hsub strong{color:rgba(255,255,255,.88);font-weight:700;}

.store-section{background:var(--surface);padding:52px 24px 80px;}
.store-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:24px;margin-top:28px;}

.sc{
  background:var(--white);border:1px solid var(--bd);
  border-radius:20px;overflow:hidden;
  box-shadow:var(--sh);transition:all .28s;
  display:flex;flex-direction:column;
}
.sc:not(.sc-coming):hover{transform:translateY(-8px);box-shadow:0 20px 60px rgba(35,82,255,.11);border-color:rgba(79,124,255,.28);}
.sc-coming{opacity:.62;cursor:default;}

/* 카드 히어로 */
.sc-img{
  position:relative;height:220px;overflow:hidden;
  background:linear-gradient(145deg,#090c1a,#160d28);
  display:flex;align-items:center;justify-content:center;cursor:pointer;
}
.sc-img-grid{position:absolute;inset:0;background-image:radial-gradient(circle,rgba(79,124,255,.2) 1px,transparent 1px);background-size:28px 28px;}
.sc-img-glow{position:absolute;inset:0;background:radial-gradient(ellipse 80% 80% at 50% 40%,rgba(79,124,255,.28) 0%,rgba(176,108,255,.14) 55%,transparent 75%);}
.sc-img-content{position:relative;z-index:2;text-align:center;}
.sc-icon{
  width:78px;height:78px;border-radius:20px;
  background:linear-gradient(135deg,#4f7cff,#b06cff);
  display:flex;align-items:center;justify-content:center;
  font-size:36px;margin:0 auto 14px;
  box-shadow:0 0 36px rgba(79,124,255,.55),0 8px 24px rgba(0,0,0,.4);
  animation:iconFloat 4s ease-in-out infinite;
}
@keyframes iconFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.sc-iname{font-family:'Bebas Neue',sans-serif;font-size:21px;color:#fff;letter-spacing:1px;}
.sc-iver{font-size:9.5px;color:rgba(255,255,255,.38);letter-spacing:1.2px;font-weight:700;margin-top:2px;}

/* 호버 오버레이 */
.sc-overlay{
  position:absolute;inset:0;z-index:3;
  background:rgba(10,15,40,0);
  display:flex;align-items:center;justify-content:center;
  transition:all .25s;opacity:0;
}
.sc:not(.sc-coming):hover .sc-overlay{opacity:1;background:rgba(10,15,40,.48);}
.sc-launch{
  background:rgba(0,168,120,.92);color:#fff;
  border:none;border-radius:11px;padding:11px 26px;
  font-size:13.5px;font-weight:800;cursor:pointer;
  display:flex;align-items:center;gap:7px;
  backdrop-filter:blur(8px);
  box-shadow:0 4px 20px rgba(0,168,120,.45);
  transform:translateY(10px);transition:transform .25s;
  font-family:'Noto Sans KR',sans-serif;
}
.sc:not(.sc-coming):hover .sc-launch{transform:translateY(0);}
.coming-pill{
  position:absolute;top:13px;right:13px;z-index:4;
  background:rgba(0,0,0,.5);color:rgba(255,255,255,.65);
  font-size:9px;font-weight:800;padding:4px 10px;
  border-radius:20px;letter-spacing:.5px;backdrop-filter:blur(4px);
}

/* 카드 바디 */
.sc-body{padding:20px 22px 18px;flex:1;display:flex;flex-direction:column;}
.sc-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:11px;}
.sc-tag{font-size:10px;font-weight:800;padding:3px 10px;border-radius:20px;}
.sc-tag.new{background:linear-gradient(135deg,#4f7cff,#b06cff);color:#fff;}
.sc-tag.free{background:#dcfce7;color:#14532d;}
.sc-tag.cat{background:rgba(0,196,140,.1);color:#00a878;}
.sc-name{font-size:18px;font-weight:900;letter-spacing:-.5px;margin-bottom:7px;color:var(--ink);}
.sc-desc{font-size:13px;color:var(--t2);line-height:1.7;flex:1;margin-bottom:14px;}
.sc-feats{display:flex;flex-direction:column;gap:5px;margin-bottom:16px;}
.sc-feat{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--t2);}
.sc-fdot{width:5px;height:5px;border-radius:50%;background:#4f7cff;flex-shrink:0;}
.sc-foot{display:flex;align-items:center;justify-content:space-between;padding-top:13px;border-top:1px solid var(--bd);}
.sc-price{font-size:12.5px;font-weight:800;color:#4f7cff;}
.sc-btn{
  background:linear-gradient(135deg,#00a878,#00c48c);color:#fff;
  border:none;border-radius:9px;padding:8px 16px;
  font-size:12px;font-weight:800;cursor:pointer;
  display:flex;align-items:center;gap:5px;
  font-family:'Noto Sans KR',sans-serif;
  box-shadow:0 3px 12px rgba(0,168,120,.3);transition:all .18s;
}
.sc-btn:hover{transform:translateY(-1px);box-shadow:0 5px 18px rgba(0,168,120,.42);}
.sc-btn.disabled{background:#e5e7eb;color:var(--t3);box-shadow:none;cursor:default;}

/* ═══════════════════════════════════
   RESPONSIVE NAV
═══════════════════════════════════ */
@media(max-width:700px){
  .nav{padding:0 16px;}
  .nav-logo-sub{display:none;}
  .hero-stats{gap:28px;}
  .cta-features{grid-template-columns:1fr;}
}


/* ── TOOLSTORE CARD STYLES ── */
/* ── GRID ── */
.store-wrap{max-width:1200px;margin:0 auto;padding:52px 24px 80px;}
.section-label{font-size:10px;font-weight:700;color:rgba(255,255,255,.3);letter-spacing:2px;margin-bottom:8px;font-family:'Space Mono',monospace;}
.section-title{font-size:26px;font-weight:900;margin-bottom:4px;}
.section-desc{font-size:13px;color:rgba(255,255,255,.55);margin-bottom:32px;}

/* ── 카드 그리드 ── */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:20px;}
@media(max-width:760px){.cards{grid-template-columns:1fr;}}

/* ── 카드 ── */
.card{background:#0f1117;border:1px solid rgba(255,255,255,.07);border-radius:16px;overflow:hidden;transition:all .25s;cursor:pointer;display:flex;flex-direction:column;}
.card:hover{border-color:rgba(255,255,255,.12);transform:translateY(-4px);box-shadow:0 16px 48px rgba(0,0,0,.4);}

/* 카드 상단 이미지 영역 */
.card-img{position:relative;height:180px;overflow:hidden;}
.card-img-glow{position:absolute;inset:0;pointer-events:none;}
.card-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:28px 28px;}
.card-badges{position:absolute;inset:12px;display:flex;flex-direction:column;justify-content:space-between;}
.card-badges-row{display:flex;justify-content:space-between;}
.badge{font-size:9.5px;font-weight:700;padding:4px 9px;border-radius:7px;backdrop-filter:blur(6px);}
.card-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;}
.card-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:4px;}
.card-iname{font-family:'Bebas Neue',sans-serif;font-size:18px;color:#fff;letter-spacing:.5px;}
.card-iver{font-size:9px;color:rgba(255,255,255,.4);font-family:'Space Mono',monospace;letter-spacing:1px;}
.card-hover-overlay{position:absolute;inset:0;background:rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;}
.card:hover .card-hover-overlay{opacity:1;}
.card-launch-btn{padding:10px 22px;border-radius:10px;border:none;font-size:13px;font-weight:800;cursor:pointer;font-family:'Noto Sans KR',sans-serif;color:#fff;transition:transform .15s;}
.card-launch-btn:hover{transform:scale(1.04);}

/* 카드 하단 본문 */
.card-body{padding:18px 20px 20px;display:flex;flex-direction:column;flex:1;}
.card-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px;}
.tag{font-size:11.5px;font-weight:700;padding:4px 10px;border-radius:20px;}
.tag-new{background:rgba(35,82,255,.2);color:#7aa0ff;}
.tag-free{background:rgba(0,196,140,.15);color:#00d4aa;}
.card-name{font-size:17px;font-weight:900;margin-bottom:7px;}
.card-desc{font-size:13.5px;color:rgba(255,255,255,.55);line-height:1.7;margin-bottom:12px;}
.card-feats{display:flex;flex-direction:column;gap:5px;margin-bottom:16px;flex:1;}
.feat{display:flex;align-items:flex-start;gap:7px;font-size:13px;color:rgba(255,255,255,.55);line-height:1.5;}
.feat-dot{width:5px;height:5px;border-radius:50%;margin-top:5px;flex-shrink:0;}
.card-foot{display:flex;align-items:center;justify-content:flex-end;}
.card-price{font-size:13px;font-weight:700;color:rgba(255,255,255,.3);}
.run-btn{padding:8px 18px;border-radius:8px;border:none;font-size:13.5px;font-weight:800;cursor:pointer;font-family:'Noto Sans KR',sans-serif;color:#fff;transition:all .2s;}
.run-btn:hover{transform:translateY(-1px);}


/* ── PHASE SECTION ── */
.phase-header{display:flex;align-items:center;gap:14px;margin:52px 0 20px;padding-bottom:14px;border-bottom:1px solid rgba(255,255,255,.07);}
.phase-badge{font-family:'Space Mono',monospace;font-size:11px;font-weight:700;letter-spacing:1px;padding:4px 12px;border-radius:6px;white-space:nowrap;}
.phase-title-wrap{flex:1;}
.phase-title-main{font-size:20px;font-weight:900;}
.phase-title-sub{font-size:11px;color:rgba(255,255,255,.3);margin-top:2px;font-family:'Space Mono',monospace;letter-spacing:.5px;}
.phase-line{flex:1;height:1px;background:rgba(255,255,255,.07);}
.phase-count{font-size:10px;color:rgba(255,255,255,.3);font-family:'Space Mono',monospace;white-space:nowrap;}
.start-badge{display:inline-flex;align-items:center;gap:5px;font-size:10px;font-weight:700;padding:3px 10px;border-radius:20px;background:rgba(35,82,255,.18);border:1px solid rgba(35,82,255,.38);color:#7aa0ff;margin-bottom:8px;}
/* ── 카드 아이콘 애니메이션 ── */
.card-icon{animation:iconFloat 4s ease-in-out infinite;}

/* ── 섹션 배경: Enterprise처럼 밝은 회색 ── */
#page-store .store-section{background:var(--surface);}

/* ── phase 헤더: 밝은 배경 위 어두운 글씨 ── */
.phase-title-main{font-size:20px;font-weight:900;color:var(--ink);}
.phase-title-sub{font-size:11px;color:var(--t3);margin-top:2px;font-family:'Space Mono',monospace;letter-spacing:.5px;}
.phase-count{font-size:10px;color:var(--t3);font-family:'Space Mono',monospace;white-space:nowrap;}
.phase-header{display:flex;align-items:center;gap:14px;margin:52px 0 20px;padding-bottom:14px;border-bottom:1px solid var(--bd);}
.phase-line{flex:1;height:1px;background:var(--bd);}

/* ── section 타이틀: 밝은 배경 위 어두운 글씨 ── */
.section-title{font-size:26px;font-weight:900;margin-bottom:4px;color:var(--ink);}
.section-desc{font-size:13px;color:var(--t2);margin-bottom:32px;}

/* ── 카드 본문: 다크 카드 위 밝은 글씨 ── */
.card-name{font-size:17px;font-weight:900;letter-spacing:-.3px;color:#ffffff;}
.card-desc{font-size:13.5px;color:rgba(220,225,255,.85);line-height:1.75;margin-bottom:12px;}
.feat{display:flex;align-items:flex-start;gap:7px;font-size:13px;color:rgba(210,218,255,.78);line-height:1.5;}

/* ── 래퍼 ── */
.ts-store-wrap{max-width:1200px;margin:0 auto;padding:32px 0 60px;}
.ts-store-wrap .phase-header:first-child{margin-top:0;}


/* ════════════════════════════════════════════════
   📱 AUTO MAKER 모바일 최적화 (430px 이하)
════════════════════════════════════════════════ */
@media (min-width: 431px) {
  .mob-sub-links { display: none !important; }
  .mob-hide-btn { display: flex !important; }
}

@media (max-width: 430px) {

  html, body { overflow-x: hidden; }

  /* ── NAV ── */
  .nav { padding: 0 16px !important; height: 56px !important; z-index: 1200 !important; }
  .nav-logo { margin-right: 0 !important; }
  .nav-logo-mark { width: 30px !important; height: 30px !important; font-size: 15px !important; }
  .nav-logo-text { font-size: 14px !important; }
  .nav-logo-sub { display: none !important; }
  .nav-actions { z-index: 499 !important; }
  .nav-links { top: 56px !important; z-index: 9999 !important; }
  .nav-cta { margin: 0 !important; width: auto !important; padding: 8px 13px !important; font-size: 12px !important; }
  .nav-hamburger { width: 20px !important; height: 44px !important; display: flex !important; align-items: center !important; justify-content: center !important; }

  /* ══════════════════════════════════════
     📱 모바일 슬라이더 — 완전 새 디자인
  ══════════════════════════════════════ */

  /* 슬라이더 래퍼 */
  .hero-slider-wrap { padding-top: 56px !important; position: relative !important; overflow: hidden !important; }

  /* 각 슬라이드 — 화면 꽉 채우기 */
  .hero-slide {
    padding: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    min-height: calc(100svh - 56px) !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
  }
  .hero {
    min-height: unset !important;
    max-height: unset !important;
    padding: 0 !important;
    justify-content: flex-start !important;
    overflow: hidden !important;
  }
  .hero-inner {
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
    text-align: center !important;
    display: none !important;
  }

  /* 기존 hero 요소들 모두 숨기기 — 모바일은 완전 새 HTML 사용 */
  .hero-badge, .hero-title, .hero-sub-title, .hero-btns,
  .hero-stats, .s3-flow, .s2-simple-row, .s2-sub-line,
  .hero-deco, .hero-glow, .hero-grid { display: none !important; }

  /* 화살표 */
  .hero-slider-arrow { width: 28px !important; height: 28px !important; font-size: 16px !important; z-index: 10 !important; }
  .arr-left { left: 8px !important; }
  .arr-right { right: 8px !important; }
  .hero-slider-ctrl { bottom: 18px !important; z-index: 10 !important; }

  /* ── 모바일 전용 슬라이드 콘텐츠 ── */
  .mob-slide { flex-direction: column !important; height: calc(100svh - 56px) !important; padding: 0 20px 64px !important; box-sizing: border-box !important; }
  .mob-slide-top { flex: 1 !important; display: flex !important; flex-direction: column !important; justify-content: center !important; }
  .mob-badge {
    display: inline-flex !important; align-items: center !important; gap: 6px !important;
    font-size: 11px !important; font-weight: 700 !important; padding: 5px 12px !important;
    border-radius: 20px !important; margin: 0 auto 12px !important;
    border: 1px solid !important;
  }
  .mob-badge-dot { width: 6px !important; height: 6px !important; border-radius: 50% !important; }
  .mob-title { font-size: 32px !important; font-weight: 900 !important; line-height: 1.1 !important; letter-spacing: -1px !important; margin-bottom: 6px !important; }
  .mob-sub { font-size: 12.5px !important; color: var(--t2) !important; line-height: 1.6 !important; margin-bottom: 20px !important; }

  /* 슬라이드1 — 4단계 가로형 리스트 */
  .mob-steps { display: flex !important; flex-direction: column !important; gap: 8px !important; margin-bottom: 20px !important; }
  .mob-step-row {
    display: flex !important; align-items: center !important; gap: 12px !important;
    background: rgba(255,255,255,.7) !important; border-radius: 14px !important;
    padding: 12px 14px !important; border: 1px solid rgba(0,0,0,.07) !important;
    backdrop-filter: blur(8px) !important;
  }
  .mob-step-num {
    width: 28px !important; height: 28px !important; border-radius: 8px !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    font-size: 11px !important; font-weight: 900 !important; color: #fff !important; flex-shrink: 0 !important;
  }
  .mob-step-body { flex: 1 !important; text-align: left !important; }
  .mob-step-name { font-size: 13px !important; font-weight: 800 !important; color: var(--ink) !important; margin-bottom: 1px !important; }
  .mob-step-desc { font-size: 11px !important; color: var(--t2) !important; }
  .mob-step-tag {
    font-size: 9px !important; font-weight: 700 !important; padding: 3px 7px !important;
    border-radius: 6px !important; flex-shrink: 0 !important;
  }

  /* 슬라이드2 — 반복업무 */
  .mob-stats-row { display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 8px !important; margin-bottom: 20px !important; }
  .mob-stat-card {
    background: rgba(255,255,255,.7) !important; border-radius: 14px !important;
    padding: 14px 12px !important; border: 1px solid rgba(0,0,0,.07) !important;
    backdrop-filter: blur(8px) !important; text-align: center !important;
  }
  .mob-stat-val { font-size: 28px !important; font-weight: 900 !important; line-height: 1 !important; margin-bottom: 4px !important; }
  .mob-stat-lbl { font-size: 10px !important; color: var(--t2) !important; font-weight: 600 !important; }
  .mob-feature-list { display: flex !important; flex-direction: column !important; gap: 6px !important; margin-bottom: 20px !important; }
  .mob-feat-row {
    display: flex !important; align-items: center !important; gap: 10px !important;
    background: rgba(255,255,255,.65) !important; border-radius: 12px !important;
    padding: 10px 14px !important; border: 1px solid rgba(0,0,0,.06) !important;
  }
  .mob-feat-icon { font-size: 18px !important; flex-shrink: 0 !important; }
  .mob-feat-text { font-size: 12.5px !important; font-weight: 700 !important; color: var(--ink) !important; }
  .mob-feat-sub { font-size: 10.5px !important; color: var(--t2) !important; margin-top: 1px !important; }

  /* 슬라이드3 — 구독료 */
  .mob-pain-card {
    background: rgba(255,255,255,.7) !important; border-radius: 16px !important;
    padding: 16px !important; border: 1px solid rgba(0,0,0,.07) !important;
    margin-bottom: 10px !important; backdrop-filter: blur(8px) !important;
  }
  .mob-pain-row { display: flex !important; align-items: center !important; justify-content: space-between !important; }
  .mob-pain-label { font-size: 12px !important; color: var(--t2) !important; font-weight: 600 !important; }
  .mob-pain-price { font-size: 22px !important; font-weight: 900 !important; }
  .mob-vs-row {
    display: flex !important; align-items: center !important; gap: 8px !important;
    margin-bottom: 10px !important;
  }
  .mob-vs-card {
    flex: 1 !important; border-radius: 14px !important; padding: 14px 12px !important;
    text-align: center !important; border: 1px solid !important;
  }
  .mob-vs-icon { font-size: 22px !important; margin-bottom: 6px !important; }
  .mob-vs-title { font-size: 12px !important; font-weight: 800 !important; margin-bottom: 2px !important; }
  .mob-vs-sub { font-size: 10px !important; }
  .mob-vs-arrow { font-size: 20px !important; color: var(--t3) !important; flex-shrink: 0 !important; }
  .mob-save-banner {
    background: linear-gradient(135deg, #2352ff, #7c4dff) !important;
    border-radius: 14px !important; padding: 14px 18px !important;
    display: flex !important; align-items: center !important; justify-content: space-between !important;
    margin-bottom: 16px !important;
  }
  .mob-save-left { text-align: left !important; }
  .mob-save-label { font-size: 10px !important; color: rgba(255,255,255,.7) !important; font-weight: 600 !important; margin-bottom: 2px !important; }
  .mob-save-amount { font-size: 24px !important; font-weight: 900 !important; color: #fff !important; }
  .mob-save-right { font-size: 32px !important; }

  /* 공통 버튼 */
  .mob-btn-primary {
    width: 100% !important; padding: 15px !important; border-radius: 14px !important;
    border: none !important; font-size: 15px !important; font-weight: 800 !important;
    font-family: 'Noto Sans KR', sans-serif !important; cursor: pointer !important;
    margin-bottom: 10px !important; display: flex !important; align-items: center !important;
    justify-content: center !important; gap: 6px !important;
  }
  .mob-links { display: flex !important; align-items: center !important; justify-content: center !important; gap: 12px !important; }
  .mob-link { font-size: 12px !important; font-weight: 600 !important; color: var(--t2) !important; cursor: pointer !important; text-decoration: underline !important; text-underline-offset: 3px !important; text-decoration-color: rgba(0,0,0,.2) !important; }
  .mob-sep { font-size: 10px !important; color: var(--t3) !important; }

  /* ── 툴 카드 2×2 ── */
  .tools-section { padding: 28px 14px 40px !important; }
  .section-title { font-size: clamp(19px, 5.5vw, 24px) !important; margin-bottom: 4px !important; }
  .section-desc { font-size: 11.5px !important; margin-bottom: 12px !important; }
  .tools-grid { grid-template-columns: 1fr 1fr !important; gap: 8px !important; margin-top: 12px !important; }
  .tool-card { border-radius: 12px !important; display: flex !important; flex-direction: column !important; }
  .tool-card-top { padding: 12px 11px 0 !important; margin-bottom: 7px !important; flex-direction: row !important; align-items: center !important; justify-content: space-between !important; }
  .tool-icon-wrap { width: 34px !important; height: 34px !important; font-size: 16px !important; border-radius: 8px !important; }
  .tool-free { font-size: 7.5px !important; padding: 2px 5px !important; }
  .tool-card-body { padding: 0 11px 0 !important; flex: 1 !important; }
  .tool-name { font-size: 12px !important; font-weight: 900 !important; margin-bottom: 4px !important; line-height: 1.2 !important; }
  .tool-desc { display: none !important; }
  .tool-tags { flex-wrap: nowrap !important; gap: 3px !important; margin-bottom: 0 !important; overflow: hidden !important; }
  .tool-tag { font-size: 7.5px !important; padding: 2px 5px !important; white-space: nowrap !important; }
  .tool-tag:nth-child(n+3) { display: none !important; }
  .tool-go { padding: 8px 11px !important; font-size: 10px !important; margin-top: 7px !important; }
  .tool-go-arrow { width: 16px !important; height: 16px !important; font-size: 9px !important; border-radius: 4px !important; }

  /* ── 공통 ── */
  .section-inner { padding: 0 !important; }
  [style*="grid-template-columns:1fr 1fr"], [style*="grid-template-columns: 1fr 1fr"] { grid-template-columns: 1fr !important; }
  [style*="grid-template-columns:1fr 1fr 1fr"], [style*="grid-template-columns:repeat(3,1fr)"] { grid-template-columns: 1fr 1fr !important; }
  [style*="grid-template-columns:repeat(5,1fr)"] { grid-template-columns: repeat(3,1fr) !important; }
  [style*="minmax(300px"], [style*="minmax(280px"] { grid-template-columns: 1fr !important; }
  [style*="minmax(160px"] { grid-template-columns: repeat(2,1fr) !important; }
  [style*="minmax(200px"] { grid-template-columns: 1fr !important; }
  .two-col, .three-col { grid-template-columns: 1fr !important; gap: 12px !important; }
  .frow { grid-template-columns: 1fr !important; gap: 10px !important; }
  .cta-features { grid-template-columns: 1fr !important; }
  .cta-btn-row { flex-direction: column !important; gap: 8px !important; }
  .cta-btn-row .hbtn { width: 100% !important; }
  .cards { grid-template-columns: 1fr !important; gap: 12px !important; }
  .img-compare-wrap, .upscale-compare { grid-template-columns: 1fr !important; }
  .plans-grid { grid-template-columns: 1fr !important; padding: 0 !important; }

  /* ── revenue/sns 페이지 모바일 수정 ── */
  /* 얼리버드 혜택 텍스트 크기 축소 */
  #page-revenue [style*="font-size:14px;color:var(--ink)"] { font-size: 13px !important; }
  /* sns 비교 그리드 1열로 */
  #page-sns [style*="grid-template-columns:1fr 1fr"] { grid-template-columns: 1fr !important; }
  /* 디자인 업종 카드 텍스트 줄바꿈 방지 */
  #page-design .tool-card [style*="font-size:10.5px"] { white-space: nowrap !important; overflow: hidden !important; text-overflow: ellipsis !important; }
  input, select, textarea, .inp, .sel, .ta { font-size: 16px !important; }
  .compare-wrap, .table-wrap { overflow-x: auto !important; }
  .footer-top { flex-direction: column !important; gap: 10px !important; padding: 20px 14px !important; }
  .footer-info { padding: 14px !important; }
  .footer-info-row { font-size: 10px !important; }
  .footer-copy { padding: 10px 14px !important; font-size: 10px !important; }
  .site-footer { padding: 24px 16px !important; }
  .ts-store-wrap { padding: 18px 14px 44px !important; }
  .phase-header { flex-wrap: wrap !important; gap: 6px !important; }
  .phase-line { display: none !important; }
  .phase-title-main { font-size: 16px !important; }
  .modal, .modal-box { width: 92vw !important; max-width: 92vw !important; padding: 20px 16px !important; }
  .toast { max-width: 86vw !important; white-space: normal !important; text-align: center !important; bottom: 14px !important; }
  ::-webkit-scrollbar { width: 0 !important; height: 0 !important; }
}

/* ══════════════════════════════════
   홈 - 두 카드 섹션
══════════════════════════════════ */
.tool-big-card{
  border-radius:20px;
  padding:28px;
  border:1.5px solid var(--bd);
  background:var(--white);
  display:flex;
  flex-direction:column;
  gap:16px;
  cursor:pointer;
  transition:transform .22s ease, box-shadow .22s ease;
}
.tool-big-card:hover{transform:translateY(-4px);box-shadow:0 16px 48px rgba(8,9,13,.1);}
.tool-big-card--ai{border-top:3px solid #2352ff;}
.tool-big-card--free{border-top:3px solid #00c48c;}
.tbc-header{display:flex;align-items:center;gap:10px;}
.tbc-icon{font-size:26px;}
.tbc-badge{font-size:10px;font-weight:800;padding:3px 10px;border-radius:20px;letter-spacing:.3px;}
.tbc-badge--ai{background:#e8edff;color:#2352ff;}
.tbc-badge--free{background:#e0faf3;color:#009e70;}
.tbc-name{font-size:22px;font-weight:800;color:var(--ink);}
.tbc-desc{font-size:13.5px;color:var(--t2);line-height:1.7;}
.tbc-tags{display:flex;flex-wrap:wrap;gap:7px;}
.tbc-tag{font-size:12px;padding:5px 12px;border-radius:20px;border:1px solid var(--bd);color:var(--t2);background:var(--surface);}

/* AI 도구 11개 그리드 */
.ai-tool-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:8px;
}
@media(max-width:768px){.ai-tool-grid{grid-template-columns:repeat(2,1fr);}}
.ai-tool-item{
  cursor:pointer;
  background:rgba(35,82,255,.04);
  border:1px solid rgba(35,82,255,.1);
  border-radius:12px;
  padding:12px;
  transition:background .15s, border-color .15s;
}
.ai-tool-item:hover{background:rgba(35,82,255,.09);border-color:rgba(35,82,255,.25);}
.ai-tool-icon{font-size:18px;display:block;margin-bottom:6px;}
.ai-tool-name{font-size:12px;font-weight:800;color:var(--ink);margin-bottom:2px;}
.ai-tool-sub{font-size:10px;color:var(--t2);}

/* ══════════════════════════════════
   홈 - 시나리오 카드 섹션
══════════════════════════════════ */
.scen-header{text-align:center;margin-bottom:40px;}
.scen-cards{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}
@media(max-width:900px){.scen-cards{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.scen-cards{grid-template-columns:1fr;}}

.scen-card{
  background:var(--white);
  border:1.5px solid var(--bd);
  border-radius:20px;
  padding:24px 20px;
  display:flex;
  flex-direction:column;
  gap:16px;
  cursor:pointer;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  position:relative;
  overflow:hidden;
}
.scen-card::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(35,82,255,.04),transparent);
  opacity:0;
  transition:opacity .2s;
}
.scen-card:hover{
  transform:translateY(-5px);
  box-shadow:0 16px 40px rgba(35,82,255,.12);
  border-color:rgba(35,82,255,.3);
}
.scen-card:hover::before{opacity:1;}

.scen-situation{display:flex;flex-direction:column;gap:8px;}
.scen-num{
  font-size:11px;font-weight:900;color:#2352ff;
  letter-spacing:1px;
  width:28px;height:28px;
  background:#e8edff;
  border-radius:8px;
  display:flex;align-items:center;justify-content:center;
}
.scen-q{font-size:15px;font-weight:800;color:var(--ink);line-height:1.45;}
.scen-pain{font-size:12px;color:var(--t2);line-height:1.5;}

.scen-arrow{
  font-size:20px;color:var(--bd);
  text-align:center;
  transition:color .2s, transform .2s;
}
.scen-card:hover .scen-arrow{color:#2352ff;transform:translateX(4px);}

.scen-solution{
  background:var(--surface);
  border-radius:12px;
  padding:14px;
  border:1px solid var(--bd);
  display:flex;
  flex-direction:column;
  gap:5px;
  transition:background .2s, border-color .2s;
}
.scen-card:hover .scen-solution{background:#f0f4ff;border-color:rgba(35,82,255,.2);}
.scen-badge{font-size:10px;font-weight:800;padding:2px 9px;border-radius:20px;display:inline-block;margin-bottom:4px;}
.scen-badge--ai{background:#e8edff;color:#2352ff;}
.scen-badge--free{background:#e0faf3;color:#009e70;}
.scen-sol-title{font-size:14px;font-weight:800;color:var(--ink);}
.scen-sol-desc{font-size:11px;color:var(--t2);line-height:1.5;}

/* ══════════════════════════════════
   nav 아래 사장AI 띠 배너
══════════════════════════════════ */
.sub-banner{
  position:fixed;top:60px;left:0;right:0;z-index:1100;
  background:linear-gradient(135deg,#0f1f3d 0%,#1a0f2e 50%,#0f1f3d 100%);
  border-bottom:1px solid rgba(108,79,246,.3);
  height:36px;
  display:flex;align-items:center;justify-content:center;
  gap:12px;padding:0 20px;
  cursor:pointer;
  transition:transform .4s cubic-bezier(.4,0,.2,1), opacity .4s ease, visibility .4s;
  transform:translateY(0);opacity:1;visibility:visible;
}
.sub-banner--hide{
  transform:translateY(-100%);
  opacity:0;
  visibility:hidden;
}
.sub-banner--gone{
  display:none !important;
}
.sub-banner-dot{
  width:6px;height:6px;border-radius:50%;flex-shrink:0;
  background:#6c4ff6;animation:pulse 2s infinite;
}
.sub-banner-text{
  font-size:13px;color:rgba(255,255,255,.8);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.sub-banner-text strong{color:#fff;font-weight:800;}
.sub-banner-btn{
  flex-shrink:0;
  background:linear-gradient(135deg,#6c4ff6,#e040fb);
  color:#fff;border-radius:20px;
  padding:4px 14px;font-size:12px;font-weight:700;
  white-space:nowrap;
}
@media(max-width:600px){
  .sub-banner-text{font-size:11px;}
  .sub-banner-btn{display:none;}
}

/* ══════════════════════════════════
   사장AI 홍보 섹션 (store 페이지)
══════════════════════════════════ */
.sajang-section{
  background:linear-gradient(160deg,#0a0f1e 0%,#120826 50%,#0a0f1e 100%);
  padding:80px 24px;
  position:relative;
  overflow:hidden;
}
.sajang-section::before{
  content:'';position:absolute;
  top:-200px;left:50%;transform:translateX(-50%);
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(ellipse,rgba(108,79,246,.12),transparent 70%);
  pointer-events:none;
}
.sajang-inner{
  max-width:860px;margin:0 auto;
  text-align:center;position:relative;z-index:1;
}
.sajang-label{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(108,79,246,.15);
  border:1px solid rgba(108,79,246,.3);
  border-radius:20px;padding:5px 14px;
  font-size:11px;font-weight:800;color:#9b8ff5;
  letter-spacing:.8px;margin-bottom:20px;
}
.sajang-dot{
  width:6px;height:6px;border-radius:50%;
  background:#6c4ff6;animation:pulse 2s infinite;
}
.sajang-title{
  font-size:clamp(26px,4vw,44px);font-weight:900;
  color:#fff;line-height:1.2;letter-spacing:-.5px;
  margin-bottom:14px;
}
.sajang-hl{
  background:linear-gradient(135deg,#e040fb,#6c4ff6,#00b884);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.sajang-desc{
  font-size:15px;color:rgba(255,255,255,.5);
  line-height:1.75;margin-bottom:48px;
}
.sajang-cards{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:16px;margin-bottom:40px;
}
@media(max-width:640px){.sajang-cards{grid-template-columns:1fr;}}
.sajang-card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:20px;padding:24px 20px;
  cursor:pointer;
  transition:transform .2s ease, background .2s, border-color .2s;
  display:flex;flex-direction:column;align-items:center;gap:12px;
  text-align:center;
}
.sajang-card:hover{
  transform:translateY(-4px);
  background:rgba(255,255,255,.07);
  border-color:rgba(255,255,255,.15);
}
.sajang-card-icon{
  width:52px;height:52px;border-radius:14px;
  border:1px solid;
  display:flex;align-items:center;justify-content:center;
  font-size:24px;
}
.sajang-card-name{
  font-size:16px;font-weight:800;color:#fff;
}
.sajang-card-desc{
  font-size:12px;color:rgba(255,255,255,.5);line-height:1.6;
}
.sajang-card-tag{
  font-size:10px;font-weight:800;
  padding:3px 10px;border-radius:20px;border:1px solid;
  letter-spacing:.3px;
}
.sajang-cta{
  background:linear-gradient(135deg,#6c4ff6,#e040fb);
  color:#fff;border:none;border-radius:14px;
  padding:16px 40px;font-size:15px;font-weight:800;
  cursor:pointer;font-family:inherit;
  box-shadow:0 8px 32px rgba(108,79,246,.35);
  transition:transform .2s, box-shadow .2s;
}
.sajang-cta:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 40px rgba(108,79,246,.45);
}

/* ══════════════════════════════════
   홈 - 사장AI 홍보 배너
══════════════════════════════════ */
.home-sajang-banner{
  background:linear-gradient(135deg,#0a0f1e 0%,#1a0826 50%,#0a0f1e 100%);
  padding:48px 24px;
  cursor:pointer;
  transition:filter .2s;
  position:relative;
  overflow:hidden;
}
.home-sajang-banner::before{
  content:'';position:absolute;
  top:-100px;right:-100px;
  width:400px;height:400px;border-radius:50%;
  background:radial-gradient(ellipse,rgba(108,79,246,.15),transparent 70%);
  pointer-events:none;
}
.home-sajang-banner:hover{filter:brightness(1.08);}
.home-sajang-inner{
  max-width:1100px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;flex-wrap:wrap;
  position:relative;z-index:1;
}
.home-sajang-new{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(108,79,246,.2);border:1px solid rgba(108,79,246,.3);
  border-radius:20px;padding:4px 12px;
  font-size:11px;font-weight:800;color:#9b8ff5;
  letter-spacing:.5px;margin-bottom:12px;
}
.home-sajang-title{
  font-size:clamp(20px,3vw,30px);font-weight:900;
  color:#fff;line-height:1.3;margin-bottom:8px;
}
.home-sajang-hl{
  background:linear-gradient(135deg,#e040fb,#6c4ff6);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.home-sajang-desc{
  font-size:13px;color:rgba(255,255,255,.5);margin-bottom:14px;
}
.home-sajang-tags{
  display:flex;gap:16px;flex-wrap:wrap;
  font-size:13px;font-weight:700;
}
.home-sajang-cta{
  flex-shrink:0;
  background:linear-gradient(135deg,#6c4ff6,#e040fb);
  color:#fff;border-radius:14px;
  padding:14px 28px;font-size:14px;font-weight:800;
  white-space:nowrap;
  box-shadow:0 8px 28px rgba(108,79,246,.35);
}
@media(max-width:640px){
  .home-sajang-cta{width:100%;text-align:center;}
}

/* ══════════════════════════════════
   nav - 사장AI 세금절약 버튼
══════════════════════════════════ */
.nav-sajang-btn{
  background:linear-gradient(135deg,#6c4ff6,#e040fb);
  color:#fff;
  border:none;
  border-radius:20px;
  padding:7px 14px;
  font-size:12px;
  font-weight:700;
  cursor:pointer;
  font-family:inherit;
  letter-spacing:-.2px;
  box-shadow:0 3px 12px rgba(108,79,246,.35);
  transition:opacity .15s, transform .15s;
  white-space:nowrap;
}
.nav-sajang-btn:hover{
  opacity:.88;
  transform:translateY(-1px);
}
@media(max-width:768px){
  .nav-sajang-btn{display:none;}
}

/* ══════════════════════════════════
   슬라이드1 워크플로우 카드 (s3-step)
══════════════════════════════════ */
.s3-flow{
  display:flex;align-items:stretch;gap:0;
  margin-top:28px;
  max-width:780px;
}
.s3-step{
  flex:1;
  background:#fff;
  border-radius:16px;
  padding:16px 14px;
  border:1.5px solid rgba(0,0,0,.07);
  box-shadow:0 4px 20px rgba(0,0,0,.06);
  opacity:0;
  transform:translateY(16px);
  transition:opacity .4s ease, transform .4s ease;
  position:relative;
}
.s3-step.active{
  opacity:1;
  transform:translateY(0);
}
.s3-step-top{
  display:flex;align-items:center;gap:8px;margin-bottom:10px;
}
.s3-step-num{
  width:26px;height:26px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:900;color:#fff;flex-shrink:0;
}
.s3-step-lbl{
  font-size:10px;font-weight:800;
  padding:2px 8px;border-radius:20px;border:1px solid;
  letter-spacing:.3px;
}
.s3-step-title{
  font-size:13px;font-weight:800;color:#08090d;margin-bottom:8px;
}
.s3-arrow{
  display:flex;align-items:center;padding:0 6px;
  color:rgba(0,0,0,.2);font-size:16px;flex-shrink:0;align-self:center;
}
@media(max-width:768px){
  .s3-flow{gap:6px;}
  .s3-arrow{display:none;}
  .s3-step{padding:12px 10px;}
  .s3-step-title{font-size:12px;}
}
@media(max-width:480px){
  .s3-flow{flex-wrap:wrap;}
  .s3-step{flex:1 1 calc(50% - 6px);}
}
