/* ===== RESET & BASE ===== */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --navy:#1e2270;
  --navy-d:#141C6B;
  --navy-l:#2e339a;
  --blue:#3a40c4;
  --accent:#6e74e8;
  --ink:#1a1c2e;
  --gray:#6b6f82;
  --gray-soft:#9aa0b3;
  --line:#e6e8f0;
  --line-soft:#eef0f5;
  --bg-soft:#f4f5fa;
  --card-blue:#eef0fb;
  --sec-pad-y:100px;
  --radius-card:16px;
  --shadow-card:0 6px 22px rgba(15,17,46,.06);
  --shadow-card-hover:0 18px 44px rgba(15,17,46,.14);
  --ease-out:cubic-bezier(.2,.7,.2,1);
}
.solution,.stats,.cases,.lawyer,.faq,.location,.contact{
  padding-top:var(--sec-pad-y);
  padding-bottom:var(--sec-pad-y);
}
html{scroll-behavior:smooth;overflow-x:clip}
body{
  font-family:'Pretendard',-apple-system,sans-serif;
  color:var(--ink);
  background:#fff;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:clip;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,select{font-family:inherit}
.container{max-width:1200px;margin:0 auto;padding:0 24px}

/* ===== SECTION HEAD (unified scale) ===== */
.sec-head{text-align:center;margin-bottom:60px}
.sec-head .eyebrow{
  color:var(--navy);font-weight:700;font-size:14px;
  letter-spacing:.06em;margin-bottom:14px;line-height:1;
}
.sec-head h2{
  font-size:clamp(28px,3.2vw,40px);font-weight:800;
  letter-spacing:-1.4px;line-height:1.3;color:#000;
}
.sec-head h2 b{color:var(--navy)}
.sec-head p{
  margin-top:18px;color:var(--gray);font-size:16px;
  line-height:1.7;letter-spacing:-.2px;
}
.sec-head.light h2,.sec-head.light .eyebrow{color:#fff}
.sec-head.light h2 b{color:#aab0ff}
.eyebrow{
  display:block;color:var(--navy);font-weight:700;font-size:14px;
  letter-spacing:.06em;
}

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-weight:700;font-size:16px;border-radius:999px;
  padding:16px 32px;transition:.2s;
}
.btn-primary{background:var(--navy);color:#fff}
.btn-primary:hover{background:var(--navy-l)}
.btn-primary img{width:20px;filter:brightness(0) invert(1)}
.btn-block{
  display:block;width:100%;background:var(--navy);color:#fff;
  border-radius:10px;padding:20px;font-size:17px;font-weight:700;
}
.btn-block:hover{background:var(--navy-l)}

/* ===== HEADER ===== */
.header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  transition:background .3s, backdrop-filter .3s, border-color .3s;
  border-bottom:1px solid transparent;
}
.header-inner{
  width:100%;padding:18px 48px;
  display:flex;align-items:center;gap:48px;
  transition:padding .3s;
}
.logo{display:inline-flex;align-items:center;flex:1 1 0;min-width:0}
.logo img{height:36px;width:auto;transition:height .3s}

.nav{display:flex;gap:42px;flex:0 0 auto;justify-content:center}
.nav a{
  position:relative;color:#fff;font-size:15px;font-weight:500;
  letter-spacing:-.2px;opacity:.86;
  transition:opacity .2s ease;
  padding:6px 0;
}
.nav a:hover{opacity:1}
.nav a::after{
  content:"";position:absolute;left:50%;bottom:-3px;
  width:0;height:2px;border-radius:2px;
  background:linear-gradient(90deg,#8fb0ff,#b9a3ff);
  transform:translateX(-50%);box-shadow:0 0 8px rgba(143,176,255,.6);
  transition:width .28s var(--ease-out);
}
.nav a:hover::after{width:100%}

.header-right{display:flex;align-items:center;justify-content:flex-end;gap:12px;flex:1 1 0}
.header-tel{
  display:inline-flex;align-items:center;gap:8px;
  color:#fff;font-size:14px;font-weight:700;letter-spacing:-.2px;
  padding:9px 16px;border-radius:999px;
  border:1px solid rgba(255,255,255,.26);background:rgba(255,255,255,.06);
  backdrop-filter:blur(6px);transition:background .2s,border-color .2s,transform .2s;
}
.header-tel:hover{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.4);transform:translateY(-1px)}
.header-tel svg{opacity:.95}
.header-cta{
  display:inline-flex;align-items:center;gap:7px;
  font-size:14px;font-weight:700;letter-spacing:-.3px;color:#fff;
  padding:10px 20px;border-radius:999px;
  background:linear-gradient(135deg,#5b6bff,#8b5bff);
  box-shadow:0 10px 26px rgba(91,107,255,.42);
  transition:transform .22s var(--ease-out),box-shadow .22s;
}
.header-cta:hover{transform:translateY(-2px);box-shadow:0 16px 34px rgba(91,107,255,.55)}
.header-cta svg{transition:transform .25s var(--ease-out)}
.header-cta:hover svg{transform:translateX(3px)}

.header.scrolled{
  background:rgba(10,12,30,.72);
  backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);
  border-bottom-color:rgba(255,255,255,.08);
  box-shadow:0 8px 30px rgba(0,0,0,.28);
}
.header.scrolled::after{
  content:"";position:absolute;left:0;right:0;bottom:-1px;height:1px;
  background:linear-gradient(90deg,transparent,rgba(123,91,255,.6),rgba(91,107,255,.6),transparent);
}
.header.scrolled .header-inner{padding:12px 48px}
.header.scrolled .logo img{height:30px}

.nav-toggle{display:none;flex-direction:column;gap:5px;padding:6px}
.nav-toggle span{width:24px;height:2px;background:#fff;border-radius:2px;transition:.2s}
/* mobile-menu-only chrome — hidden on desktop */
.nav-head,.nav-foot,.nav-dim{display:none}

@media (max-width:1024px){
  .header-inner{padding:16px 28px;gap:24px}
  .header.scrolled .header-inner{padding:12px 28px}
  .nav{gap:30px}
  .header-tel span{display:none}
  .header-tel{padding:8px;border:1px solid rgba(255,255,255,.25);border-radius:50%}
}
@media (max-width:780px){
  .header-inner{padding:14px 20px;gap:0;justify-content:space-between}
  .header.scrolled .header-inner{padding:10px 20px}
  .nav, .header-right{display:none}
  .nav-toggle{display:flex}
}

/* ===== HERO ===== */
.hero{position:relative;height:100vh;background:#06081a}
.hero-stage{
  position:relative;width:100%;height:100vh;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}

/* full-bleed background (image now / video later) */
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img,
.hero-bg video{
  width:100%;height:100%;object-fit:cover;display:block;
}
.hero-bg-shade{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(180deg,rgba(6,8,26,.10) 0%,rgba(6,8,26,.20) 55%,rgba(6,8,26,.45) 100%),
    radial-gradient(90% 70% at 50% 55%,rgba(6,8,26,.45) 0%,transparent 60%);
}

.hero-text{
  position:relative;z-index:2;text-align:center;color:#fff;
  padding:0 24px;max-width:920px;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;
  margin:0 0 26px;padding:8px 20px;border-radius:999px;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.22);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  font-size:13px;font-weight:500;letter-spacing:.04em;
  color:rgba(255,255,255,.92);
}
.hero-headline{
  margin:0;
  font-size:clamp(32px,4.4vw,60px);font-weight:800;line-height:1.32;
  letter-spacing:-1.6px;color:#fff;text-shadow:0 6px 30px rgba(0,0,0,.55);
}
.hero-headline em{
  font-style:normal;font-weight:800;color:#aab0ff;
  text-shadow:0 6px 30px rgba(120,130,255,.55);
}
.hero-sub{
  margin:22px 0 0;
  font-size:clamp(14px,1.2vw,17px);font-weight:400;line-height:1.85;
  color:rgba(255,255,255,.82);letter-spacing:-.2px;
}
.hero-sub b{color:#fff;font-weight:700}

.hero-cta{
  margin-top:36px;display:inline-flex;gap:12px;flex-wrap:wrap;justify-content:center;
}
.hero-btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 26px;border-radius:999px;
  font-size:15px;font-weight:700;letter-spacing:-.2px;
  transition:transform .2s ease, background .2s ease, box-shadow .2s ease;
}
.hero-btn-primary{
  background:#fff;color:#0b0d20;
  box-shadow:0 18px 40px rgba(255,255,255,.18);
}
.hero-btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 22px 48px rgba(255,255,255,.28);
}
.hero-btn-primary svg{transition:transform .2s ease}
.hero-btn-primary:hover svg{transform:translateX(3px)}
.hero-btn-tel{
  background:rgba(20,22,40,.55);color:#fff;
  border:1px solid rgba(255,255,255,.22);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
}
.hero-btn-tel:hover{
  background:rgba(20,22,40,.78);
  transform:translateY(-2px);
}

.hero-scroll{
  position:absolute;left:50%;bottom:38px;z-index:3;
  transform:translateX(-50%);
}
.hero-scroll span{
  display:block;width:24px;height:38px;border:2px solid rgba(255,255,255,.7);
  border-radius:14px;position:relative;
}
.hero-scroll span::after{
  content:"";position:absolute;left:50%;top:8px;width:4px;height:8px;
  background:#fff;border-radius:2px;transform:translateX(-50%);
  animation:scroll 1.6s infinite;
}
@keyframes scroll{0%{opacity:0;top:8px}40%{opacity:1}80%{opacity:0;top:20px}100%{opacity:0}}

@media (max-width:780px){
  .hero-text{padding:0 20px}
  .hero-headline{letter-spacing:-1.2px;line-height:1.36}
  .hero-sub br{display:none}
  .hero-cta{margin-top:30px;width:100%;gap:10px}
  .hero-btn{padding:14px 22px;font-size:14px}
}

/* ===== CHAT — full-view auto-playing conversation ===== */
.chat{
  position:relative;overflow:hidden;color:#fff;
  min-height:100vh;display:flex;align-items:center;
  padding:88px 0;
  background:
    radial-gradient(1100px 680px at 80% 8%, #1d2974 0%, transparent 58%),
    radial-gradient(820px 560px at 8% 92%, #181f52 0%, transparent 55%),
    linear-gradient(162deg,#0b0f2e 0%,#10153a 52%,#0c1130 100%);
}
.chat-orbs{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:1}
.chat-orbs span{position:absolute;border-radius:50%;filter:blur(64px)}
.chat-orbs span:nth-child(1){width:440px;height:440px;left:-90px;top:6%;background:radial-gradient(circle,#3a49c9,transparent 70%);opacity:.5}
.chat-orbs span:nth-child(2){width:380px;height:380px;right:2%;top:38%;background:radial-gradient(circle,#7b5bff,transparent 70%);opacity:.34}
.chat-orbs span:nth-child(3){width:320px;height:320px;left:28%;bottom:-70px;background:radial-gradient(circle,#23a6ff,transparent 70%);opacity:.22}

.chat-inner{
  position:relative;z-index:2;
  width:min(1180px,92vw);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  gap:clamp(40px,5vw,90px);
}

/* ---- left: copy + phases + cta ---- */
.chat-copy{flex:1;min-width:0;max-width:520px}
.chat-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:12.5px;font-weight:700;letter-spacing:.1em;color:#aeb8ff;
  padding:7px 14px;border-radius:999px;
  background:rgba(122,138,255,.12);border:1px solid rgba(135,150,255,.22);
}
.chat-eyebrow i{width:7px;height:7px;border-radius:50%;background:#ff5a5a;animation:cdPulse 1.6s infinite}
.chat-title{margin:22px 0 15px;font-size:clamp(30px,3.4vw,46px);font-weight:800;line-height:1.24;letter-spacing:-1px;color:#fff}
.chat-title em{
  font-style:normal;
  background:linear-gradient(90deg,#9ab0ff,#c9b3ff,#8fd9ff,#c9b3ff,#9ab0ff);
  background-size:220% auto;
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;
  animation:titleFlow 5.5s linear infinite;
}
@keyframes titleFlow{0%{background-position:0% center}100%{background-position:-220% center}}
@media(prefers-reduced-motion:reduce){.chat-title em{animation:none}}
.chat-sub{font-size:clamp(15px,1.2vw,17px);line-height:1.7;color:#b7bedd;margin:0 0 30px}

.chat-phases{display:flex;flex-direction:column;margin:0 0 34px;padding:0;list-style:none}
.chat-phases li{position:relative;display:flex;flex-direction:column;padding:0 0 22px 30px;opacity:.4;transition:opacity .5s ease}
.chat-phases li:last-child{padding-bottom:0}
.chat-phases li::before{content:"";position:absolute;left:8px;top:7px;bottom:-7px;width:2px;background:rgba(255,255,255,.14)}
.chat-phases li:last-child::before{display:none}
.chat-phases li i{position:absolute;left:0;top:4px;width:18px;height:18px;border-radius:50%;border:2px solid rgba(255,255,255,.3);background:#0e1336;transition:all .45s ease}
.chat-phases li b{font-size:16px;font-weight:700;color:#fff;letter-spacing:-.3px}
.chat-phases li span{font-size:13px;color:#9aa2c9;margin-top:2px}
.chat-phases li.is-active{opacity:1}
.chat-phases li.is-active i{border-color:#8fb0ff;background:#8fb0ff;box-shadow:0 0 0 5px rgba(143,176,255,.2)}

.chat-cta{
  display:inline-flex;align-items:center;gap:9px;
  background:linear-gradient(135deg,#5b6bff,#7b5bff);color:#fff;
  font-size:16px;font-weight:700;letter-spacing:-.3px;
  padding:16px 28px;border-radius:999px;
  box-shadow:0 18px 40px rgba(74,86,255,.4);transition:transform .25s ease,box-shadow .25s ease;
}
.chat-cta:hover{transform:translateY(-2px);box-shadow:0 24px 50px rgba(74,86,255,.5)}

/* ---- right: open conversation stage (no device frame) ---- */
.chat-stage-wrap{
  position:relative;flex:none;width:clamp(380px,40vw,470px);
  padding:8px 16px;border-radius:30px;
  background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.018));
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 44px 90px rgba(0,0,0,.42),inset 0 1px 0 rgba(255,255,255,.07);
}
.chat-convo{
  position:relative;width:100%;height:min(74vh,680px);
  overflow-y:auto;overflow-x:hidden;scrollbar-width:none;
  -webkit-mask-image:linear-gradient(180deg,transparent 0,#000 9%,#000 88%,transparent 100%);
          mask-image:linear-gradient(180deg,transparent 0,#000 9%,#000 88%,transparent 100%);
}
.chat-convo::-webkit-scrollbar{display:none}
.convo-track{display:flex;flex-direction:column;gap:17px;padding:24px 6px}

/* messages — hidden until revealed by JS */
.cmsg{display:none;max-width:90%}
.cmsg--in{align-self:flex-start;flex-direction:row;align-items:flex-end;gap:11px}
.cmsg--chip{align-self:center;max-width:96%}
.cmsg--turn{align-self:stretch;max-width:100%}
.cmsg.is-typing,.cmsg.is-shown{display:flex}

/* avatars */
.cmsg-ava{flex:none;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;margin-bottom:22px}
.cmsg-ava--debt{background:rgba(255,90,90,.16);color:#ff9a9a;border:1px solid rgba(255,90,90,.34)}
.cmsg-ava--dream{background:linear-gradient(135deg,#5b6bff,#7b5bff);color:#fff;box-shadow:0 6px 18px rgba(91,107,255,.45)}

.cmsg-body{display:flex;flex-direction:column;min-width:0}
.cmsg-from{font-size:12px;color:#9aa2c9;font-weight:600;margin:0 0 6px 4px}
.cmsg .cmsg-from,.cmsg .cmsg-bubble,.cmsg .cmsg-time{display:none}
.cmsg.is-shown .cmsg-from{display:block}
.cmsg.is-shown .cmsg-bubble{display:block;animation:cdPop .42s cubic-bezier(.2,.8,.3,1.25) both}
.cmsg.is-shown .cmsg-time{display:block}

/* debt = heavy translucent glass on dark */
.cmsg-bubble{
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);
  color:#d7dcf2;font-size:15px;line-height:1.55;font-weight:500;
  padding:14px 17px;border-radius:4px 17px 17px 17px;
}
.cmsg-bubble b{font-weight:700;color:#fff}
.cmsg-time{font-size:11px;color:#7e86ad;margin:7px 0 0 4px}

/* typing indicator */
.cmsg-typing{display:none;width:fit-content;align-items:center;gap:5px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);padding:15px 17px;border-radius:4px 17px 17px 17px}
.cmsg.is-typing .cmsg-typing{display:inline-flex;animation:cdPop .3s ease both}
.cmsg-typing span{width:7px;height:7px;border-radius:50%;background:#aab0d0;animation:cdDot 1.3s infinite ease-in-out}
.cmsg-typing span:nth-child(2){animation-delay:.18s}
.cmsg-typing span:nth-child(3){animation-delay:.36s}
.cmsg--dream .cmsg-typing{background:#eaf0ff;border-color:transparent}
.cmsg--dream .cmsg-typing span{background:#8d96bd}

/* system chips */
.cmsg--chip{font-size:12.5px;font-weight:600;padding:9px 18px;border-radius:999px;letter-spacing:-.3px;text-align:center;white-space:nowrap}
.cmsg--chip.is-shown{display:block;animation:cdPop .42s cubic-bezier(.2,.8,.3,1.25) both}
.cmsg--chip b{font-weight:800}
.cmsg--alert{background:rgba(255,90,90,.14);color:#ff9a9a;border:1px solid rgba(255,90,90,.3)}
.cmsg--call{background:rgba(255,255,255,.08);color:#cfd5ee;border:1px solid rgba(255,255,255,.13)}
.cmsg--call b{color:#ff9a9a;font-weight:800}
.cmsg--good{background:rgba(70,220,150,.14);color:#7ef0b0;border:1px solid rgba(70,220,150,.32)}
.cmsg--good b{color:#b6f7d6}
.cmsg--good.is-shown{display:inline-flex;flex-direction:row;align-items:center;justify-content:center;gap:7px}
.cmsg-okmini{width:16px;height:16px;border-radius:50%;background:#34d399;color:#06321f;font-size:10px;font-style:normal;display:inline-flex;align-items:center;justify-content:center}

/* turning-point divider */
.cmsg--turn{position:relative;text-align:center;padding:7px 0}
.cmsg--turn::before{content:"";position:absolute;left:0;right:0;top:50%;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2) 30%,rgba(255,255,255,.2) 70%,transparent)}
.cmsg-turn-pill{position:relative;display:inline-block;background:linear-gradient(135deg,#5b6bff,#7b5bff);color:#fff;font-size:12.5px;font-weight:700;padding:9px 18px;border-radius:999px;box-shadow:0 8px 28px rgba(91,107,255,.5);letter-spacing:-.2px}
.cmsg--turn.is-shown .cmsg-turn-pill{animation:cdPop .45s cubic-bezier(.2,.8,.3,1.25) both}

/* dream = bright bubbles, light arriving */
.cmsg-bubble--dream{background:linear-gradient(135deg,#eaf0ff,#f4f0ff);border:none;color:#1a1f3a;box-shadow:0 10px 30px rgba(91,107,255,.28)}
.cmsg-bubble--dream b{color:var(--navy);font-weight:800}
.cmsg-bubble--win{background:linear-gradient(135deg,#5b6bff 0%,#7b5bff 100%);border:none;color:#fff;border-radius:18px;padding:17px 19px;flex-direction:column;gap:6px;box-shadow:0 20px 50px rgba(91,107,255,.55)}
.cmsg.is-shown .cmsg-bubble--win{display:flex;animation:cdWin .55s cubic-bezier(.2,.8,.3,1.3) both}
.cmsg-win-top{display:flex;align-items:center;gap:8px;font-size:17px;font-weight:800}
.cmsg-ok{width:20px;height:20px;border-radius:50%;background:#fff;color:#5b6bff;font-size:12px;font-style:normal;display:inline-flex;align-items:center;justify-content:center}
.cmsg-win-sub{font-size:13.5px;color:#e6e9ff;font-weight:500}

@keyframes cdPop{from{opacity:0;transform:translateY(8px) scale(.96)}to{opacity:1;transform:none}}
@keyframes cdWin{0%{opacity:0;transform:translateY(12px) scale(.92)}60%{transform:translateY(0) scale(1.03)}100%{opacity:1;transform:none}}
@keyframes cdDot{0%,65%,100%{opacity:.35;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}
@keyframes cdPulse{0%,100%{box-shadow:0 0 0 4px rgba(255,90,90,.22)}50%{box-shadow:0 0 0 8px rgba(255,90,90,0)}}

/* reduced motion: show whole conversation statically */
.chat.no-motion .chat-convo{height:auto;-webkit-mask-image:none;mask-image:none}
.chat.no-motion .cmsg{display:flex}
.chat.no-motion .cmsg--chip{display:inline-flex}
.chat.no-motion .cmsg-typing{display:none!important}
.chat.no-motion .cmsg-bubble,.chat.no-motion .cmsg-from,.chat.no-motion .cmsg-time{display:block}
.chat.no-motion .cmsg-bubble--win{display:flex}
.chat.no-motion .chat-accent{opacity:1;transform:none}

/* ===== SOLUTION ===== */
.solution{
  position:relative;overflow:hidden;
  background:
    radial-gradient(620px 440px at 10% 16%, rgba(123,91,255,.13), transparent 62%),
    radial-gradient(580px 460px at 90% 84%, rgba(91,107,255,.13), transparent 62%),
    linear-gradient(180deg,#e9edfb 0%,#eef1fc 48%,#f2f4fd 100%);
}
.solution::before{content:"";position:absolute;left:0;right:0;top:0;height:170px;background:linear-gradient(180deg,#0c1130,transparent);opacity:.05;pointer-events:none}
.solution .container{position:relative;z-index:1}
.solution .sec-head p{margin-top:14px;font-size:15px}

/* interactive Q→A grid */
.sol-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(214px,1fr));gap:20px;
  list-style:none;margin:0;padding:0;
}
.sol-grid > li{display:flex}
.sol-card{
  position:relative;width:100%;height:216px;overflow:hidden;text-align:left;
  background:linear-gradient(180deg,#ffffff 0%,#f6f7ff 100%);
  border:1px solid rgba(91,107,255,.12);border-radius:var(--radius-card);
  box-shadow:0 12px 32px rgba(40,50,120,.09);padding:26px 22px;cursor:pointer;
  display:flex;flex-direction:column;
  transition:transform .32s var(--ease-out),box-shadow .32s var(--ease-out),border-color .32s var(--ease-out);
}
.sol-card:hover,.sol-card:focus-visible{transform:translateY(-7px);box-shadow:0 26px 54px rgba(91,107,255,.26);border-color:rgba(91,107,255,.32);outline:none}
/* after reveal, keep hover snappy (override .reveal's .8s transition) */
.sol-card.reveal.in{transition:transform .32s var(--ease-out),box-shadow .32s var(--ease-out),border-color .32s var(--ease-out)}
.sol-badge{
  width:52px;height:52px;border-radius:15px;flex:none;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#5b6bff,#8b5bff);margin-bottom:15px;
  box-shadow:0 10px 22px rgba(91,107,255,.4);
  transition:transform .32s var(--ease-out);
}
.sol-card:hover .sol-badge{transform:scale(1.06) rotate(-3deg)}
.sol-badge img{width:28px;filter:brightness(0) invert(1)}
.sol-q{font-size:17px;font-weight:800;line-height:1.4;color:var(--navy);letter-spacing:-.4px;margin:0}
.sol-more{
  margin-top:auto;display:inline-flex;align-items:center;gap:5px;
  font-size:12.5px;font-weight:700;color:var(--accent);
}
.sol-more svg{transition:transform .32s var(--ease-out)}
/* answer overlay slides up */
.sol-answer{
  position:absolute;inset:0;padding:24px 22px;
  background:linear-gradient(150deg,var(--navy) 0%,var(--accent) 100%);color:#fff;
  display:flex;flex-direction:column;justify-content:center;gap:11px;
  transform:translateY(101%);transition:transform .44s cubic-bezier(.2,.8,.2,1);
}
.sol-card:hover .sol-answer,.sol-card:focus-visible .sol-answer,.sol-card.is-open .sol-answer{transform:translateY(0)}
.sol-card:hover .sol-more svg,.sol-card.is-open .sol-more svg{transform:rotate(90deg)}
.sol-yes{display:inline-flex;align-items:center;gap:8px;font-size:16px;font-weight:800;letter-spacing:-.3px}
.sol-yes i{
  width:21px;height:21px;border-radius:50%;background:#fff;color:var(--navy);
  font-size:12px;font-style:normal;display:inline-flex;align-items:center;justify-content:center;flex:none;
}
.sol-atext{font-size:13.5px;line-height:1.62;color:#e6e9ff}

/* closing CTA strip */
.sol-foot{
  display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:14px 26px;
  margin-top:40px;padding:22px 30px;border-radius:20px;
  background:linear-gradient(120deg,rgba(255,255,255,.7),rgba(255,255,255,.4));
  border:1px solid rgba(91,107,255,.16);
  box-shadow:0 14px 38px rgba(40,50,120,.08);backdrop-filter:blur(6px);
}
.sol-foot p{margin:0;font-size:16px;font-weight:600;color:var(--navy);letter-spacing:-.3px}
.sol-foot p b{font-weight:800;color:var(--accent)}
.sol-foot-btn{
  display:inline-flex;align-items:center;gap:8px;flex:none;
  background:linear-gradient(135deg,#5b6bff,#8b5bff);color:#fff;
  font-size:15px;font-weight:700;letter-spacing:-.3px;padding:13px 24px;border-radius:999px;
  box-shadow:0 14px 32px rgba(91,107,255,.4);transition:transform .25s var(--ease-out),box-shadow .25s;
}
.sol-foot-btn:hover{transform:translateY(-2px);box-shadow:0 20px 42px rgba(91,107,255,.52)}

/* ===== STATS ===== */
.stats{
  position:relative;overflow:hidden;
  background:
    radial-gradient(640px 460px at 88% 14%, rgba(91,107,255,.12), transparent 62%),
    radial-gradient(560px 440px at 8% 90%, rgba(123,91,255,.1), transparent 62%),
    linear-gradient(180deg,#f1f3fd,#e7eaf8);
}
.stats-inner{position:relative;z-index:1}
.stats-inner{
  max-width:1560px;
  display:flex;justify-content:space-between;align-items:flex-start;gap:460px;
}
.stats-text{margin-top:24px;flex:0 1 auto;min-width:307px}
.stats-grid{flex:0 0 auto}
.stats-text .eyebrow{
  color:var(--navy);font-weight:700;font-size:16px;line-height:1;margin-bottom:14px;
}
.stats-text h2{
  font-size:34px;font-weight:700;line-height:1.26;letter-spacing:0;
  color:#000;margin:0 0 20px;text-align:left;
}
.stats-text p{
  color:#000;font-weight:500;font-size:20px;line-height:1.45;
  margin-bottom:32px;text-align:left;
}
.stats-text .btn-primary{
  width:265px;height:54px;padding:0;border-radius:999px;
  background:var(--navy-d);font-size:16px;font-weight:700;letter-spacing:-.3px;
  box-shadow:0 12px 28px rgba(20,28,107,.22);
  transition:transform .2s var(--ease-out), box-shadow .2s, background .2s;
}
.stats-text .btn-primary:hover{background:var(--navy-l);transform:translateY(-2px);box-shadow:0 18px 36px rgba(20,28,107,.32)}
.stats-grid{
  display:grid;
  grid-template-columns:repeat(2,357px);
  grid-template-rows:repeat(2,290px);
  column-gap:30px;row-gap:30px;
  justify-content:end;
  padding-bottom:85px;
}
.stat-card{
  width:357px;height:290px;box-sizing:border-box;position:relative;
  background:linear-gradient(180deg,#ffffff 0%,#fafbff 100%);border-radius:0 var(--radius-card) 0 var(--radius-card);
  padding:32px 28px 32px;text-align:center;
  border:1px solid rgba(91,107,255,.1);
  box-shadow:0 12px 32px rgba(40,50,120,.08);
  transition:transform .3s var(--ease-out), box-shadow .3s var(--ease-out), border-color .3s var(--ease-out);
  display:flex;flex-direction:column;justify-content:space-between;align-items:center;
}
.stat-card:hover{transform:translateY(-6px);box-shadow:0 28px 56px rgba(91,107,255,.22);border-color:rgba(91,107,255,.28)}
.stat-card:nth-child(2),.stat-card:nth-child(4){
  align-self:start;position:relative;top:85px;
}
.stat-ico{
  display:inline-flex;width:56px;height:56px;border-radius:50%;
  background:linear-gradient(135deg,var(--card-blue),#dfe5ff);
  align-items:center;justify-content:center;margin-bottom:8px;
  box-shadow:inset 0 0 0 1px rgba(30,34,112,.08);
}
.stat-ico img{width:26px}
.stat-label{font-size:13px;color:var(--gray);font-weight:600;letter-spacing:.06em;margin:0}
.stat-value{
  font-size:clamp(36px,4.5vw,56px);font-weight:800;
  line-height:1;margin:6px 0 4px;letter-spacing:-1.8px;
  background:linear-gradient(135deg,var(--navy) 0%,var(--accent) 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.stat-desc{font-size:13px;color:var(--gray);line-height:1.65;margin:0}
/* hero stat (탕감률) emphasis */
.stat-card--hero{background:linear-gradient(160deg,#ffffff 0%,#e9edff 100%);border-color:rgba(91,107,255,.28);box-shadow:0 20px 46px rgba(91,107,255,.2)}
.stat-card--hero .stat-ico{background:linear-gradient(135deg,#5b6bff,#7b5bff);box-shadow:0 8px 20px rgba(91,107,255,.4)}
.stat-card--hero .stat-ico img{filter:brightness(0) invert(1)}
/* long text value shouldn't use the huge number size */
.stat-value--text{font-size:clamp(24px,2.8vw,32px);letter-spacing:-1px;line-height:1.2}

/* ===== CASES ===== */
.cases{background:#f5f7fb;color:var(--ink)}
.cases .sec-head h2 b{color:var(--blue)}
.cases > .container{max-width:1560px}
.case-feature{
  position:relative;border-radius:10px;overflow:hidden;
  aspect-ratio:1520/666;
  display:flex;align-items:center;
  color:#fff;
}
.case-feature-bg{position:absolute;inset:0;transition:opacity .35s ease}
.case-feature-bg img{width:100%;height:100%;object-fit:cover}
.case-feature::before{
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(to right,rgba(0,0,0,.78) 0%,rgba(0,0,0,.55) 35%,rgba(0,0,0,.15) 65%,rgba(0,0,0,0) 85%);
}
.case-feature-body{position:relative;z-index:2;padding:60px 64px;max-width:600px}
.case-tag{
  display:inline-block;background:rgba(255,255,255,.14);color:#fff;
  font-size:14px;font-weight:500;padding:8px 18px;border-radius:999px;margin-bottom:24px;
}
.case-feature-body h3{font-size:28px;font-weight:700;line-height:1.4;margin-bottom:36px;color:#fff}
.case-list{margin-bottom:48px}
.case-list li{
  position:relative;padding-left:30px;font-size:15px;margin:10px 0;color:#fff;font-weight:500;
}
.case-list li::before{
  content:"";position:absolute;left:0;top:3px;width:18px;height:18px;border-radius:50%;
  border:1.5px solid rgba(255,255,255,.85);
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/11px no-repeat;
}
.case-result{font-size:15px;color:#fff;line-height:1.3}
.case-result-label{display:block;font-size:14px;color:rgba(255,255,255,.85);margin-bottom:4px;font-weight:500}
.case-result-num{font-size:48px;font-weight:800;color:#9ECDFB;margin-right:8px;letter-spacing:-1px}
.case-result-num strong{font-weight:800}
.case-result-suffix{font-size:15px;color:#fff;font-weight:500}

.case-reviews{
  display:grid;grid-template-columns:repeat(3,498px);
  justify-content:space-between;gap:0;margin-top:30px;
}
.review-card{
  position:relative;border-radius:10px;overflow:hidden;
  width:498px;height:329px;color:#fff;
  background:#0a1733;cursor:pointer;
  transition:transform .25s ease,box-shadow .25s ease;
  outline:0;
}
.review-card.is-active{box-shadow:none}
.review-card:hover{transform:translateY(-3px)}
.review-card:focus-visible{outline:2px solid #9ECDFB;outline-offset:2px}
.review-card .review-img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
}
.review-card::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(0,0,0,.4) 0%,rgba(0,0,0,.85) 100%);
  transition:opacity .3s ease;
}
.review-card:hover::after,
.review-card.is-active::after{opacity:0}
.review-card .review-foot,
.review-card .review-tag,
.review-card .review-active-icon{transition:opacity .3s ease}
.review-card:hover .review-foot,
.review-card.is-active .review-foot{
  /* keep text but slight backdrop for legibility on bright image */
  text-shadow:0 1px 3px rgba(0,0,0,.7);
}
.review-card:hover .review-tag,
.review-card.is-active .review-tag{
  background:rgba(0,0,0,.35);backdrop-filter:blur(4px);
  border-color:rgba(255,255,255,.6);
}
.review-tag{
  position:absolute;top:22px;left:22px;z-index:2;
  display:inline-block;
  border:1px solid rgba(255,255,255,.55);
  color:#fff;font-size:13px;font-weight:500;
  padding:6px 14px;border-radius:6px;
}
.review-play{display:none}
.review-active-icon{display:none}
.review-foot{position:absolute;left:24px;right:24px;bottom:24px;z-index:2}
.review-quote{font-size:16px;font-weight:700;line-height:1.55;margin-bottom:14px;color:#fff}
.review-result{font-size:14px;color:rgba(255,255,255,.85);font-weight:500}
.review-result b{color:#9ECDFB;font-weight:700;margin:0 4px}

/* ===== TICKER ===== */
.ticker{
  background:linear-gradient(135deg,#141C6B 0%,#1e2270 50%,#141C6B 100%);
  height:109px;display:flex;align-items:center;
  overflow:hidden;margin-bottom:100px;position:relative;
  mask-image:linear-gradient(90deg,transparent 0,#000 6%,#000 94%,transparent 100%);
  -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 6%,#000 94%,transparent 100%);
}
.ticker-track{
  display:flex;flex-shrink:0;gap:14px;padding-right:14px;
  animation:ticker 40s linear infinite;will-change:transform;
}
.ticker:hover .ticker-track{animation-play-state:paused}
.ticker-track span{
  flex:0 0 auto;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  height:55px;min-width:213px;padding:0 28px;
  white-space:nowrap;color:#fff;font-size:15px;font-weight:600;letter-spacing:-.2px;
  border:1px solid rgba(255,255,255,.4);border-radius:999px;
  background:rgba(255,255,255,.04);backdrop-filter:blur(4px);
}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-100%)}}
@media(prefers-reduced-motion:reduce){
  .ticker-track{animation:none!important}
  .float-cta::after,.float-dot,.float-tel .float-ico svg{animation:none!important}
}

/* ===== LAWYER ===== */
.lawyer{
  background:
    radial-gradient(60% 40% at 80% 10%,rgba(170,176,255,.08) 0%,transparent 70%),
    radial-gradient(50% 40% at 10% 90%,rgba(170,176,255,.06) 0%,transparent 70%),
    #fff;
}
.lawyer > .container{max-width:1560px}
.lawyer-inner{display:flex;justify-content:space-between;align-items:flex-start;gap:60px}
.lawyer-photo{
  position:relative;border-radius:10px;overflow:hidden;
  background:var(--navy-d);border:1px solid #707070;
  width:592px;height:601px;flex:0 0 592px;
}
.lawyer-photo>img{width:100%;height:100%;object-fit:cover;object-position:top}
.lawyer-info{flex:1 1 auto;max-width:780px}
.lawyer-name{
  position:absolute;left:0;right:0;bottom:0;padding:30px 28px;
  background:linear-gradient(transparent,rgba(15,17,46,.95));color:#fff;
}
.lawyer-name .name{font-size:24px;font-weight:800}
.lawyer-name .name span{font-size:15px;font-weight:500;margin-left:6px;color:#c5c9ee}
.lawyer-name .quote{margin-top:8px;font-size:14px;color:#cfd2ee;line-height:1.55}
.lawyer-info{padding-top:0}
.lawyer-info .eyebrow{color:#141C6B;font-weight:700;font-size:16px;line-height:1}
.lawyer-info h3{
  color:#000;font-size:clamp(20px,1.8vw,24px);font-weight:700;
  line-height:1.45;letter-spacing:-.4px;margin:10px 0 40px;
}
.lawyer-list li{
  display:flex;gap:20px;padding:28.5px 0;
  border-top:1px solid var(--line);
}
.lawyer-list li:first-of-type{border-top:none;padding-top:0}
.lawyer-list li:last-of-type{padding-bottom:0}
.li-ico{
  flex:none;width:52px;height:52px;border-radius:50%;background:var(--navy);
  display:flex;align-items:center;justify-content:center;
}
.li-ico img{width:26px}
.lawyer-list b{display:block;font-size:18px;color:var(--navy);margin-bottom:6px}
.lawyer-list p{font-size:15px;color:var(--gray);line-height:1.6}

/* ===== CASE CARDS ===== */
.case-cards{margin-top:64px;border-top:1px solid var(--line);padding-top:48px}
.case-cards-title{
  font-size:22px;font-weight:800;color:var(--navy);
  line-height:1.4;margin-bottom:28px;letter-spacing:-.5px;
}
.case-cards-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:40px;
}
.cc{padding:0}
.cc-title{font-size:18px;font-weight:700;line-height:1.5;color:#000;margin-bottom:18px;letter-spacing:-.3px}
.cc-tags{display:flex;flex-wrap:wrap;gap:8px}
.cc-tags span{
  font-size:12px;color:var(--blue);background:var(--card-blue);
  padding:6px 12px;border-radius:6px;font-weight:600;letter-spacing:-.2px;
}
@media (max-width:1024px){
  .case-cards-grid{grid-template-columns:repeat(2,1fr);gap:32px}
}

/* ===== CTA ===== */
.cta{position:relative;height:730px;overflow:hidden;margin-top:107px}
.cta-bg{position:absolute;inset:0}
.cta-bg img{width:100%;height:100%;object-fit:cover;object-position:center 15%}
.cta-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.92) 25%,rgba(255,255,255,.1) 60%)}
.cta-inner{
  position:absolute;
  left:19.17%;top:50%;transform:translateY(-50%);
  display:flex;flex-direction:column;align-items:flex-start;
  z-index:2;
}
.cta-inner .eyebrow{color:var(--navy);font-weight:700;font-size:16px;line-height:1;margin-bottom:14px}
.cta-inner h2{
  color:#000;font-size:32px;font-weight:700;line-height:1.4;
  margin:0 0 24px;letter-spacing:0;
}
.cta-inner h2 b{color:#000;font-weight:700}
.cta-divider{
  display:block;width:40px;height:1px;background:#000;margin:0 0 32px;
}
.cta-inner p{
  color:#000;font-weight:500;font-size:18px;line-height:1.55;
  margin-bottom:48px;max-width:340px;
}
.cta-inner .btn-primary{
  width:265px;height:54px;padding:0;border-radius:999px;
  background:linear-gradient(135deg,#5b6bff,#8b5bff);font-size:16px;font-weight:700;letter-spacing:-.3px;
  box-shadow:0 14px 32px rgba(91,107,255,.4);
  transition:transform .2s var(--ease-out), box-shadow .2s, background .2s;
}
.cta-inner .btn-primary:hover{background:linear-gradient(135deg,#5a5aff,#7a45f5);transform:translateY(-2px);box-shadow:0 20px 42px rgba(91,107,255,.55)}
.cta-inner.reveal{transform:translateY(calc(-50% + 34px))}
.cta-inner.reveal.in{transform:translateY(-50%)}
.cta-band{
  background:
    radial-gradient(80% 120% at 20% 30%,rgba(110,116,232,.35) 0%,transparent 50%),
    radial-gradient(70% 100% at 85% 70%,rgba(58,64,196,.25) 0%,transparent 55%),
    linear-gradient(135deg,#141C6B 0%,#1e2270 100%);
  text-align:center;padding:64px 24px;position:relative;overflow:hidden;
}
.cta-band::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(60% 80% at 50% 50%,#000,transparent 70%);
  -webkit-mask-image:radial-gradient(60% 80% at 50% 50%,#000,transparent 70%);
}
.cta-band p{position:relative}
.cta-band p b{color:#fff;font-size:clamp(22px,2.5vw,32px);font-weight:800;line-height:1.34;letter-spacing:-1px}
.cta-band .sm{color:rgba(255,255,255,.78);font-size:clamp(15px,1.3vw,18px);font-weight:500;margin-top:18px;line-height:1.75;letter-spacing:-.2px}

/* ===== FAQ ===== */
.faq{background:linear-gradient(180deg,#f8f9fd 0%,#f1f4fb 100%)}
.faq-tabs{display:flex;gap:10px;justify-content:center;margin-bottom:60px;flex-wrap:wrap}
.faq-tab{
  padding:0 26px;height:46px;border-radius:999px;font-size:14px;font-weight:600;letter-spacing:-.2px;
  background:#fff;color:var(--gray);transition:all .25s var(--ease-out);
  cursor:pointer;border:1px solid var(--line);
  display:inline-flex;align-items:center;
}
.faq-tab:hover{background:#f4f5fa;color:var(--navy);border-color:var(--card-blue)}
.faq-tab.active{
  background:var(--navy);color:#fff;border-color:var(--navy);
  box-shadow:0 8px 20px rgba(20,28,107,.22);
}
.faq-list{max-width:1236px;margin:0 auto}
.faq-list details{
  background:transparent;border-radius:0;margin:0;box-shadow:none;
  border-bottom:1px solid var(--line);
  transition:border-color .2s;
}
.faq-list details[open]{border-bottom-color:var(--navy)}
.faq-list summary{
  list-style:none;cursor:pointer;padding:28px 8px;
  font-size:17px;font-weight:700;color:#000;letter-spacing:-.3px;
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  transition:color .2s;
}
.faq-list summary:hover{color:var(--navy)}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::after{
  content:"";flex:none;width:24px;height:24px;border-radius:50%;
  background:var(--card-blue) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23141C6B' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") center/14px no-repeat;
  transition:transform .25s var(--ease-out), background-color .2s;
}
.faq-list details[open] summary::after{transform:rotate(180deg);background-color:var(--navy);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E")}
.faq-body{padding:0 8px 28px}
.faq-body p{color:var(--ink);font-size:15px;line-height:1.8;font-weight:400}

/* FAQ closing CTA */
.faq-cta{
  margin:64px auto 0;max-width:1236px;
  display:flex;align-items:center;justify-content:space-between;gap:32px;
  padding:36px 44px;border-radius:20px;
  background:
    radial-gradient(60% 100% at 100% 50%,rgba(110,116,232,.35) 0%,transparent 60%),
    linear-gradient(135deg,#141C6B 0%,#1e2270 100%);
  color:#fff;flex-wrap:wrap;
}
.faq-cta-eyebrow{font-size:13px;font-weight:600;color:#aab0ff;letter-spacing:.04em;margin:0 0 6px}
.faq-cta-title{font-size:clamp(20px,2vw,26px);font-weight:800;letter-spacing:-.6px;margin:0 0 6px;color:#fff;line-height:1.3}
.faq-cta-sub{font-size:14px;color:rgba(255,255,255,.78);margin:0;line-height:1.6}
.faq-cta-actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.faq-cta-tel{
  display:inline-flex;align-items:center;gap:12px;color:#fff;
  padding:14px 22px;border-radius:14px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.18);
  transition:background .2s, border-color .2s;
}
.faq-cta-tel:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.35)}
.faq-cta-tel svg{flex:none;opacity:.85}
.faq-cta-tel span{display:flex;flex-direction:column;line-height:1.2}
.faq-cta-tel b{font-size:18px;font-weight:800;letter-spacing:-.3px}
.faq-cta-tel em{font-style:normal;font-size:11px;color:rgba(255,255,255,.62);margin-top:3px;font-weight:500}
.faq-cta-btn{
  display:inline-flex;align-items:center;gap:8px;
  height:54px;padding:0 24px;border-radius:14px;
  background:#fff;color:var(--navy);font-size:15px;font-weight:700;letter-spacing:-.3px;
  box-shadow:0 12px 28px rgba(0,0,0,.22);
  transition:transform .2s var(--ease-out), box-shadow .2s;
}
.faq-cta-btn:hover{transform:translateY(-2px);box-shadow:0 18px 36px rgba(0,0,0,.32)}
@media (max-width:780px){
  .faq-cta{padding:28px 22px;flex-direction:column;align-items:stretch;text-align:center}
  .faq-cta-actions{justify-content:center}
}

/* ===== LOCATION ===== */
.location{
  position:relative;overflow:hidden;
  background:
    radial-gradient(620px 440px at 90% 8%, rgba(91,107,255,.08), transparent 62%),
    linear-gradient(180deg,#f5f7fd,#eef1fb);
}
.location > .container{max-width:1284px;position:relative;z-index:1}
.map{
  width:100%;height:560px;border-radius:24px;overflow:hidden;
  border:1px solid rgba(91,107,255,.14);
  box-shadow:0 26px 60px rgba(40,50,120,.16);background:#f4f5fa;
}
.map iframe,.map > div{width:100%;height:100%;border:0;display:block}
.company-info{margin-top:40px}
.company-info h3{font-size:20px;font-weight:800;color:var(--navy);margin-bottom:22px;letter-spacing:-.4px}
.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.info-item{
  display:flex;gap:16px;align-items:center;
  background:linear-gradient(180deg,#fff,#f7f8ff);
  border:1px solid rgba(91,107,255,.12);border-radius:18px;
  padding:22px 24px;box-shadow:0 12px 30px rgba(40,50,120,.08);
  transition:transform .28s var(--ease-out),box-shadow .28s,border-color .28s;
}
.info-item:hover{transform:translateY(-5px);box-shadow:0 22px 46px rgba(91,107,255,.2);border-color:rgba(91,107,255,.3)}
.info-ico{
  flex:none;width:54px;height:54px;border-radius:15px;
  background:linear-gradient(135deg,#5b6bff,#8b5bff);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 22px rgba(91,107,255,.4);
}
.info-ico img{width:25px;filter:brightness(0) invert(1)}
.info-item b{display:block;font-size:15px;font-weight:800;color:var(--navy);margin-bottom:4px;letter-spacing:-.2px}
.info-item p{font-size:14px;color:var(--ink);font-weight:500;line-height:1.6}
.info-item a{color:inherit;transition:color .2s}
.info-item a:hover{color:var(--accent)}

/* ===== CONTACT ===== */
.contact{
  position:relative;overflow:hidden;
  background:
    radial-gradient(640px 460px at 12% 12%, rgba(123,91,255,.1), transparent 60%),
    radial-gradient(560px 440px at 90% 90%, rgba(91,107,255,.1), transparent 60%),
    linear-gradient(180deg,#eef1fb,#e9ecf8);
}
.contact .container{position:relative;z-index:1}
.contact .sec-head{margin-bottom:36px}
.contact-lead{margin-top:14px;color:#5b6178;font-size:15px;font-weight:500}
.contact-form{
  max-width:680px;margin:0 auto;
  background:#fff;border:1px solid rgba(91,107,255,.12);border-radius:24px;
  padding:40px 40px 36px;box-shadow:0 30px 70px rgba(40,50,120,.14);
}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}
.field span{display:block;font-size:14px;font-weight:700;color:var(--navy);margin-bottom:9px;letter-spacing:-.2px}
.field input,.field textarea{
  width:100%;padding:16px 18px;border:1.5px solid #e2e5f0;
  background:#fafbff;border-radius:13px;font-size:15px;color:#000;
  transition:border-color .2s, box-shadow .2s, background .2s;font-family:inherit;
}
.field textarea{resize:vertical;min-height:84px;line-height:1.5}
.field input::placeholder,.field textarea::placeholder{color:#a8aec2}
.field input:hover,.field textarea:hover{border-color:#c0c6dc}
.field input:focus,.field textarea:focus{outline:0;border-color:#5b6bff;background:#fff;box-shadow:0 0 0 4px rgba(91,107,255,.14)}
.agree{
  display:flex;justify-content:center;align-items:center;gap:10px;
  margin:18px 0 22px;font-size:14px;color:#3a3d52;font-weight:500;
}
.agree input{width:18px;height:18px;accent-color:#5b6bff;cursor:pointer}
.privacy-link{
  background:none;border:0;padding:0;color:#141C6B;font-weight:700;font-size:15px;
  text-decoration:underline;text-underline-offset:3px;cursor:pointer;
}
.privacy-link:hover{color:#2e339a}
.btn-block{
  display:block;width:100%;background:linear-gradient(135deg,#5b6bff,#8b5bff);color:#fff;
  border-radius:14px;padding:20px;font-size:17px;font-weight:800;border:0;cursor:pointer;
  letter-spacing:-.3px;transition:transform .2s var(--ease-out), background .2s, box-shadow .2s;
  box-shadow:0 14px 32px rgba(91,107,255,.42);
}
.btn-block:hover{background:linear-gradient(135deg,#5a5aff,#7a45f5);transform:translateY(-2px);box-shadow:0 20px 42px rgba(91,107,255,.55)}
.or{display:flex;align-items:center;gap:16px;color:#8b90a6;margin:26px 0 18px;font-size:14px;justify-content:center}
.or::before,.or::after{content:"";flex:1;height:1px;background:#dde0ec}
.contact-tel{text-align:center;color:#3a3d52;font-size:15px;font-weight:500}
.contact-tel a{font-weight:800;color:var(--navy);font-size:18px;margin-left:4px}

/* ===== MODAL ===== */
.modal{
  position:fixed;inset:0;z-index:200;display:none;
  align-items:center;justify-content:center;
}
.modal.open{display:flex}
.modal-dim{position:absolute;inset:0;background:rgba(10,12,30,.55);cursor:pointer}
.modal-panel{
  position:relative;z-index:1;background:#fff;border-radius:14px;
  width:min(720px,92vw);max-height:85vh;display:flex;flex-direction:column;
  box-shadow:0 24px 60px rgba(0,0,0,.25);
}
.modal-head{
  display:flex;justify-content:space-between;align-items:center;
  padding:22px 28px;border-bottom:1px solid #eee;
}
.modal-head h3{font-size:20px;font-weight:700;color:#000}
.modal-close{
  background:none;border:0;font-size:30px;line-height:1;color:#6b6f82;
  cursor:pointer;padding:4px 8px;
}
.modal-close:hover{color:#000}
.modal-body{padding:24px 28px 32px;overflow-y:auto;color:#000;font-size:14px;line-height:1.7}
.modal-body h4{font-size:15px;font-weight:700;color:#141C6B;margin:22px 0 8px}
.modal-body h4:first-of-type{margin-top:18px}
.modal-body p{margin:8px 0}
.modal-body ul{margin:8px 0;padding-left:18px}
.modal-body li{margin:4px 0;list-style:disc}
.modal-body .mb-intro{color:#3a3d52;font-size:14px}
.modal-body .mb-foot{margin-top:24px;color:#6b6f82;font-size:13px}

/* ===== FOOTER ===== */
.footer{background:#0c0e22;color:#cfd2ee;padding:72px 0 32px;position:relative}
.footer::before{
  content:"";position:absolute;left:0;right:0;top:0;height:2px;
  background:linear-gradient(90deg,transparent,rgba(123,91,255,.7),rgba(91,107,255,.7),transparent);
}
.footer-nav a{position:relative}
.footer-nav a::after{content:"";position:absolute;left:0;right:100%;bottom:-4px;height:1.5px;background:linear-gradient(90deg,#8fb0ff,#b9a3ff);transition:right .25s var(--ease-out)}
.footer-nav a:hover::after{right:0}
.footer-inner{max-width:1560px}
.footer-top{
  display:flex;justify-content:space-between;align-items:center;
  gap:60px;flex-wrap:wrap;margin-bottom:40px;
}
.footer-brand{display:flex;flex-direction:column;gap:14px;min-width:240px}
.footer-lockup{display:flex;align-items:center;gap:12px}
.footer-logo{
  height:42px;width:auto;display:block;flex-shrink:0;
  filter:brightness(0) invert(1);opacity:.95;
}
.footer-wordmark{
  color:#cfd2ee;font-size:14px;font-weight:500;letter-spacing:.5px;
}
.footer-tagline{color:#9a9db8;font-size:13px;font-weight:500;line-height:1.6}
.footer-nav{display:flex;gap:28px;align-items:center;flex-wrap:wrap}
.footer-nav a{color:#cfd2ee;font-size:14px;font-weight:500;transition:color .15s ease}
.footer-nav a:hover{color:#fff}
.footer-divider{height:1px;background:rgba(255,255,255,.08);margin:0 0 28px}
.footer-meta{margin-bottom:24px}
.footer-info{
  display:flex;flex-wrap:wrap;gap:10px 40px;list-style:none;padding:0;margin:0;
}
.footer-info li{display:flex;gap:10px;font-size:13px;align-items:baseline}
.footer-info span{color:#6f7290;font-weight:400}
.footer-info b{color:#cfd2ee;font-weight:500}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;
  padding-top:20px;border-top:1px solid rgba(255,255,255,.06);
}
.copyright{font-size:12px;color:#5b5e78;margin:0;letter-spacing:.2px}
.footer-admin{
  color:#5b5e78;font-size:11px;font-weight:500;
  padding:4px 10px;border-radius:4px;opacity:.5;
  transition:opacity .2s ease, color .2s, background .2s;letter-spacing:.04em;
}
.footer-admin:hover{opacity:1;color:#cfd2ee;background:rgba(255,255,255,.04)}

/* ===== FLOATING STACK (call + booking) ===== */
.float-stack{
  position:fixed;right:24px;bottom:24px;z-index:90;
  display:flex;flex-direction:column;gap:12px;align-items:flex-end;
}
.float-action{
  position:relative;display:inline-flex;align-items:center;gap:12px;
  min-width:212px;box-sizing:border-box;
  height:58px;padding:0 24px 0 11px;border-radius:999px;
  color:#fff;border:1px solid rgba(255,255,255,.14);cursor:pointer;text-decoration:none;
  box-shadow:0 16px 36px rgba(20,28,107,.4);
  transition:transform .25s var(--ease-out), box-shadow .25s, background .2s, filter .2s;
}
.float-action:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 24px 48px rgba(20,28,107,.5);filter:brightness(1.06)}
.float-ico{
  flex:none;width:42px;height:42px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.18);box-shadow:inset 0 0 0 1px rgba(255,255,255,.12);
}
.float-label{display:flex;flex-direction:column;line-height:1.2;letter-spacing:-.2px}
.float-label em{font-style:normal;font-size:11px;font-weight:600;opacity:.82;margin-bottom:1px}
.float-label b{font-size:15px;font-weight:800}

.float-tel{
  background:linear-gradient(135deg,#222a8e 0%,#141C6B 100%);
}
.float-tel:hover{background:linear-gradient(135deg,#2e339a 0%,#1e2270 100%)}
/* phone icon gentle ring */
.float-tel .float-ico svg{animation:floRing 2.4s ease-in-out infinite;transform-origin:center}
@keyframes floRing{0%,82%,100%{transform:rotate(0)}86%{transform:rotate(-12deg)}90%{transform:rotate(12deg)}94%{transform:rotate(-8deg)}}

.float-cta{
  background:linear-gradient(135deg,#6b6bff 0%,#8b5bff 100%);
  font-family:inherit;
}
.float-cta:hover{background:linear-gradient(135deg,#5a5aff 0%,#7a45f5 100%)}
/* attention pulse ring */
.float-cta::after{
  content:"";position:absolute;inset:0;border-radius:999px;
  border:2px solid rgba(139,91,255,.6);
  animation:floPulse 2.2s ease-out infinite;pointer-events:none;
}
@keyframes floPulse{0%{opacity:.7;transform:scale(1)}70%{opacity:0;transform:scale(1.18)}100%{opacity:0;transform:scale(1.18)}}
/* "상담 가능" online dot */
.float-dot{
  position:absolute;top:8px;left:38px;z-index:2;
  width:12px;height:12px;border-radius:50%;background:#34d399;
  border:2px solid #fff;box-shadow:0 0 0 0 rgba(52,211,153,.6);
  animation:floDot 1.8s ease-out infinite;
}
@keyframes floDot{0%{box-shadow:0 0 0 0 rgba(52,211,153,.55)}70%{box-shadow:0 0 0 7px rgba(52,211,153,0)}100%{box-shadow:0 0 0 0 rgba(52,211,153,0)}}
.float-cta.top-mode .float-dot{display:none}
.float-cta.top-mode::after{display:none}
.float-cta .ico-top, .float-cta .label-top{display:none}
.float-cta.top-mode .ico-default, .float-cta.top-mode .label-default{display:none}
.float-cta.top-mode .ico-top, .float-cta.top-mode .label-top{display:inline-flex}
.float-cta.top-mode .label-top{display:flex}

@media (max-width:780px){
  /* simple icon-only circular FABs on mobile (equal size) */
  .float-stack{right:16px;bottom:16px;gap:12px}
  .float-action{width:56px;height:56px;min-width:0;padding:0;gap:0;border-radius:50%;justify-content:center}
  .float-label{display:none}
  .float-ico{width:auto;height:auto;background:transparent;box-shadow:none}
  .float-ico svg{width:23px;height:23px}
  .float-dot{top:1px;right:1px;left:auto;width:13px;height:13px}
}

/* ===== BOOKING PANEL ===== */
.panel-wrap{position:fixed;inset:0;z-index:200;visibility:hidden;overflow:hidden}
.panel-wrap.open{visibility:visible}
.panel-dim{position:absolute;inset:0;background:rgba(8,9,26,.55);opacity:0;transition:.3s}
.panel-wrap.open .panel-dim{opacity:1}
.panel{
  position:absolute;top:0;right:0;height:100%;width:480px;max-width:100%;
  transform:translateX(100%);transition:transform .35s ease;
  display:flex;flex-direction:column;
  background:
    radial-gradient(ellipse 720px 480px at 100% 0%,rgba(155,120,220,.28) 0%,transparent 65%),
    radial-gradient(ellipse 600px 600px at 0% 100%,rgba(80,90,200,.22) 0%,transparent 60%),
    linear-gradient(180deg,#0f1238 0%,#161b48 100%);
  box-shadow:-30px 0 60px rgba(0,0,0,.35);
}
.panel-wrap.open .panel{transform:translateX(0)}
.panel-visual{display:none}
.panel-form{
  flex:1;min-height:0;color:#fff;padding:40px 38px 32px;
  overflow-y:auto;position:relative;
  display:flex;flex-direction:column;gap:26px;
  scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.2) transparent;
}
/* 성함 + 연락처 한 행 */
.panel-grid2{display:grid;grid-template-columns:0.78fr 1.22fr;gap:12px}
.panel-grid2 .panel-section{gap:11px;min-width:0}
.panel-form::-webkit-scrollbar{width:6px}
.panel-form::-webkit-scrollbar-thumb{background:rgba(255,255,255,.2);border-radius:3px}
.panel-close{
  position:absolute;top:20px;right:22px;z-index:3;color:#fff;line-height:1;
  width:38px;height:38px;border-radius:50%;cursor:pointer;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);
  display:inline-flex;align-items:center;justify-content:center;
  transition:background .2s,transform .2s;
}
.panel-close:hover{background:rgba(255,255,255,.18);transform:rotate(90deg)}

/* intro header */
.panel-head{display:flex;flex-direction:column;align-items:flex-start;gap:0;flex-shrink:0}
.panel-logo{height:auto;width:128px;max-width:50%;margin:0 0 18px;display:block;object-fit:contain}
.panel-status{
  display:inline-flex;align-items:center;gap:7px;
  font-size:12.5px;font-weight:700;color:#9df5c0;letter-spacing:-.2px;
  padding:6px 13px;border-radius:999px;
  background:rgba(52,211,153,.12);border:1px solid rgba(52,211,153,.3);
}
.panel-status i{width:7px;height:7px;border-radius:50%;background:#34d399;box-shadow:0 0 0 0 rgba(52,211,153,.6);animation:floDot 1.8s ease-out infinite}
.panel-title{font-size:25px;font-weight:800;color:#fff;letter-spacing:-.6px;margin:14px 0 8px;line-height:1.25}
.panel-sub{font-size:14px;font-weight:500;color:rgba(255,255,255,.66);line-height:1.6;margin:0}
.panel-section{display:flex;flex-direction:column;gap:16px}
.panel-label{font-size:16px;font-weight:600;margin:0;color:#fff;letter-spacing:-.2px}
.panel-label b{color:#fff;font-weight:700}

.phone-row,.name-row{
  display:flex;align-items:center;gap:2px;min-width:0;
  border:1px solid rgba(255,255,255,.22);border-radius:14px;
  padding:4px 10px;background:rgba(255,255,255,.04);height:52px;box-sizing:border-box;
  transition:border-color .2s,background .2s,box-shadow .2s;
}
.name-row{padding:4px 16px}
.phone-row:focus-within,.name-row:focus-within{
  border-color:#8b9bff;background:rgba(139,155,255,.08);box-shadow:0 0 0 3px rgba(139,155,255,.16);
}
.phone-row input,.name-row input{
  flex:1;min-width:0;text-align:center;border:0;background:transparent;
  padding:10px 0;font-size:15px;color:#fff;font-weight:600;
}
.name-row input{text-align:left}
.phone-row input::placeholder,.name-row input::placeholder{color:rgba(255,255,255,.35);font-weight:500}
.phone-row input:focus,.name-row input:focus{outline:none}
.phone-row span{color:rgba(255,255,255,.3);font-weight:500;font-size:13px}
#panelEmail,#panelMessage{
  width:100%;border:1px solid rgba(255,255,255,.25);border-radius:14px;
  background:rgba(255,255,255,.03);padding:12px 16px;font-size:15px;color:#fff;
  font-family:inherit;transition:border-color .2s;
}
#panelEmail{margin-bottom:8px}
#panelMessage{resize:vertical;min-height:72px;line-height:1.5;display:block}
#panelEmail::placeholder,#panelMessage::placeholder{color:rgba(255,255,255,.35)}
#panelEmail:focus,#panelMessage:focus{outline:none;border-color:#8b9bff;box-shadow:0 0 0 3px rgba(139,155,255,.16)}

.calendar{background:transparent;border-radius:0;padding:0}
.cal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;font-weight:600;font-size:15px;color:#fff}
.cal-nav{display:flex;gap:4px}
.cal-nav button{
  width:30px;height:30px;border-radius:8px;
  background:rgba(255,255,255,.08);border:0;cursor:pointer;
  color:#fff;font-size:16px;line-height:1;
  display:inline-flex;align-items:center;justify-content:center;
  transition:background .15s ease;
}
.cal-nav button:hover{background:rgba(255,255,255,.18)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;text-align:center}
.cal-grid .dow{font-size:13px;font-weight:600;color:#fff;padding:8px 0}
.cal-grid .day{
  font-size:14px;padding:0;height:38px;
  display:flex;align-items:center;justify-content:center;
  border-radius:50%;cursor:pointer;color:#fff;transition:.15s;font-weight:500;
}
.cal-grid .day:hover{background:rgba(255,255,255,.1)}
.cal-grid .day.muted{color:rgba(255,255,255,.25);cursor:default}
.cal-grid .day.muted:hover{background:none}
.cal-grid .day.sel{
  background:linear-gradient(135deg,#5b6bff,#8b5bff);color:#fff;font-weight:700;
  border:none;box-shadow:0 6px 16px rgba(91,107,255,.5);
}
.cal-grid .day.sun{color:rgba(255,255,255,.45)}

.select-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:0}

.dropdown{position:relative}
.dropdown-toggle{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;
  border:1px solid rgba(255,255,255,.2);background:transparent;color:#fff;
  padding:14px 16px;border-radius:8px;font-size:14px;font-weight:500;
  cursor:pointer;transition:border-color .15s ease,background .15s ease;
}
.dropdown-toggle:hover{border-color:rgba(255,255,255,.4);background:rgba(255,255,255,.04)}
.dropdown.is-open .dropdown-toggle{border-color:#8b9bff;background:rgba(139,155,255,.1);box-shadow:0 0 0 3px rgba(139,155,255,.14)}
.dropdown-arrow{flex-shrink:0;transition:transform .2s ease}
.dropdown.is-open .dropdown-arrow{transform:rotate(180deg)}

.dropdown-menu{
  position:absolute;left:0;right:0;top:calc(100% + 6px);z-index:5;
  background:#1a1e4a;border:1px solid rgba(255,255,255,.15);
  border-radius:8px;padding:6px;margin:0;list-style:none;
  max-height:200px;overflow-y:auto;
  box-shadow:0 12px 30px rgba(0,0,0,.4);
  opacity:0;visibility:hidden;transform:translateY(-4px);
  transition:opacity .15s ease,transform .15s ease,visibility 0s linear .15s;
  scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.2) transparent;
}
.dropdown-menu::-webkit-scrollbar{width:6px}
.dropdown-menu::-webkit-scrollbar-thumb{background:rgba(255,255,255,.2);border-radius:3px}
.dropdown.is-open .dropdown-menu{
  opacity:1;visibility:visible;transform:translateY(0);
  transition:opacity .15s ease,transform .15s ease,visibility 0s;
}
.dropdown-menu li{
  padding:10px 12px;border-radius:6px;font-size:14px;color:#fff;cursor:pointer;
  font-weight:500;transition:background .12s ease;
}
.dropdown-menu li:hover{background:rgba(255,255,255,.1)}
.dropdown-menu li.is-selected{background:linear-gradient(135deg,rgba(91,107,255,.5),rgba(139,91,255,.5));color:#fff;font-weight:700}

.panel-foot{margin-top:auto;display:flex;flex-direction:column;gap:14px}
.panel-agree{
  display:flex;align-items:center;justify-content:center;gap:8px;
  margin:0;font-size:13px;color:#fff;font-weight:500;
}
.panel-privacy-link{color:#fff;text-decoration:underline;text-underline-offset:3px;font-size:13px}
.panel-privacy-link:hover{color:#d3d6ff}
.panel-agree input[type=checkbox]{
  appearance:none;-webkit-appearance:none;
  width:18px;height:18px;border:1.5px solid rgba(255,255,255,.6);border-radius:50%;
  background:transparent;cursor:pointer;position:relative;flex-shrink:0;
}
.panel-agree input[type=checkbox]:checked{background:#fff;border-color:#fff}
.panel-agree input[type=checkbox]:checked::after{
  content:"";position:absolute;left:4px;top:1px;width:6px;height:10px;
  border:solid #141C6B;border-width:0 2px 2px 0;transform:rotate(45deg);
}

.panel-submit{
  width:100%;border:none;color:#fff;font-size:16px;font-weight:800;letter-spacing:-.3px;
  background:linear-gradient(135deg,#5b6bff,#8b5bff);
  border-radius:14px;padding:18px;cursor:pointer;
  box-shadow:0 14px 32px rgba(91,107,255,.45);
  transition:transform .2s var(--ease-out),box-shadow .2s,background .2s;
}
.panel-submit:hover{transform:translateY(-2px);box-shadow:0 20px 42px rgba(91,107,255,.58);background:linear-gradient(135deg,#5a5aff,#7a45f5)}

.panel-tel{
  flex:0 0 auto;
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:20px 24px;
  text-align:center;background:#fff;color:#1a1c2e;font-size:15px;font-weight:600;
}
.panel-tel b{font-weight:800;margin-left:4px;color:var(--navy)}

/* ===== MOBILE QUICK BOTTOM SHEET ===== */
.qsheet-wrap{position:fixed;inset:0;z-index:210;visibility:hidden}
.qsheet-wrap.open{visibility:visible}
.qsheet-dim{position:absolute;inset:0;background:rgba(8,9,26,.58);opacity:0;transition:opacity .3s}
.qsheet-wrap.open .qsheet-dim{opacity:1}
.qsheet{
  position:absolute;left:0;right:0;bottom:0;
  width:100%;max-width:520px;margin:0 auto;
  padding:26px 22px calc(24px + env(safe-area-inset-bottom));
  border-radius:28px 28px 0 0;color:#fff;
  background:
    radial-gradient(ellipse 600px 360px at 100% 0%,rgba(139,91,255,.32) 0%,transparent 62%),
    radial-gradient(ellipse 520px 420px at 0% 100%,rgba(91,107,255,.26) 0%,transparent 60%),
    linear-gradient(180deg,#10143a 0%,#171c4c 100%);
  box-shadow:0 -24px 60px rgba(0,0,0,.45);
  transform:translateY(101%);transition:transform .4s cubic-bezier(.2,.8,.2,1);
}
.qsheet-wrap.open .qsheet{transform:translateY(0)}
.qsheet-close{
  position:absolute;top:18px;right:18px;width:38px;height:38px;border-radius:50%;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.16);color:#fff;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;transition:background .2s,transform .2s;
}
.qsheet-close:hover{background:rgba(255,255,255,.2);transform:rotate(90deg)}
.qsheet-title{font-size:24px;font-weight:800;line-height:1.34;letter-spacing:-.5px;margin:6px 0 26px;text-align:center}
.qsheet-title b{color:#5fe9c0}
/* borderless big phone (reference style) */
.qsheet-phone{
  display:flex;align-items:center;justify-content:center;gap:9px;padding:4px 0;
}
.qsheet-phone input{
  width:4ch;min-width:0;text-align:center;border:0;background:transparent;
  padding:6px 0;font-size:29px;font-weight:800;color:#fff;letter-spacing:.5px;
}
.qsheet-phone input:nth-child(1){width:3ch}
.qsheet-phone input:focus{outline:none}
.qsheet-phone input::placeholder{color:rgba(255,255,255,.3)}
.qsheet-phone span{color:rgba(255,255,255,.4);font-size:22px;font-weight:600}
.qsheet-agree{display:flex;align-items:center;justify-content:center;gap:9px;margin:18px 0 22px;font-size:13.5px;color:rgba(255,255,255,.82);font-weight:500;cursor:pointer}
.qsheet-agree input{position:absolute;opacity:0;width:0;height:0}
.qsheet-toggle{flex:none;width:42px;height:24px;border-radius:999px;background:rgba(255,255,255,.22);position:relative;transition:background .25s}
.qsheet-toggle::after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform .25s}
.qsheet-agree input:checked + .qsheet-toggle{background:#34d399}
.qsheet-agree input:checked + .qsheet-toggle::after{transform:translateX(18px)}
.qsheet-agree input:focus-visible + .qsheet-toggle{box-shadow:0 0 0 3px rgba(52,211,153,.4)}
.qsheet-agree .privacy-link{color:#cdd3ff;font-size:13.5px}
/* button hierarchy: primary filled + secondary ghost */
.qsheet-actions{display:grid;grid-template-columns:1.08fr 1fr;gap:11px}
.qsheet-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  height:60px;border-radius:17px;font-size:15.5px;font-weight:800;letter-spacing:-.3px;cursor:pointer;
  border:1.5px solid transparent;
  transition:transform .2s var(--ease-out),box-shadow .2s,background .2s,border-color .2s;
}
.qsheet-btn svg{opacity:.95}
.qsheet-btn--primary{
  background:linear-gradient(135deg,#5b6bff,#8b5bff);color:#fff;
  box-shadow:0 14px 30px rgba(91,107,255,.5);
}
.qsheet-btn--primary:hover{transform:translateY(-2px);box-shadow:0 20px 42px rgba(91,107,255,.62);background:linear-gradient(135deg,#5a5aff,#7a45f5)}
.qsheet-btn--ghost{
  background:rgba(255,255,255,.06);color:#fff;border-color:rgba(255,255,255,.28);
}
.qsheet-btn--ghost svg{color:#9df5c0}
.qsheet-btn--ghost:hover{background:rgba(255,255,255,.13);border-color:rgba(255,255,255,.5);transform:translateY(-2px)}
/* white pill trust badge (reference) */
.qsheet-trust{
  display:inline-flex;align-items:center;gap:6px;align-self:center;
  margin:18px auto 0;padding:9px 18px;border-radius:999px;
  background:#fff;color:#1a1c2e;font-size:13px;font-weight:600;
  box-shadow:0 10px 24px rgba(0,0,0,.3);width:fit-content;
}
.qsheet-trust{display:flex}
.qsheet-trust b{color:var(--navy);font-weight:800}
.qsheet-tel{text-align:center;margin:14px 0 0;font-size:14px;color:rgba(255,255,255,.72);font-weight:500}
.qsheet-tel b{color:#fff;font-weight:800;margin-left:4px;letter-spacing:.3px}

/* ===== REVEAL ANIM ===== */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .8s ease,transform .8s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}

/* word-by-word fill (chat step headings) */
.word-fill .w{color:#cdd0dd;transition:color .4s ease}
.word-fill .w.on{color:var(--navy)}

@media(prefers-reduced-motion:reduce){
  .reveal{
    transition:none!important;transform:none!important;opacity:1!important;
  }
  .word-fill .w{color:var(--navy)!important}
}

/* ===== RESPONSIVE ===== */
/* stats only fit side-by-side on wide screens (~1480px+); stack below the design width */
@media(max-width:1560px){
  /* .stats-inner is flex: stack it (grid-template-columns is a no-op here) */
  .stats-inner{flex-direction:column;gap:40px;align-items:stretch;max-width:none}
  .stats-grid{
    flex:1 1 auto;width:100%;
    grid-template-columns:1fr 1fr;grid-template-rows:auto;
    justify-content:stretch;padding-bottom:0;
  }
  .stat-card{width:auto}
  /* drop the desktop staggered offset when stacked */
  .stat-card:nth-child(2),.stat-card:nth-child(4){top:0;align-self:auto}
}
@media(max-width:1024px){
  /* .lawyer-inner is flex: stack it (grid-template-columns is a no-op here) */
  .lawyer-inner{flex-direction:column;gap:36px}
  .lawyer-photo{width:100%;height:auto;flex:0 0 auto}
  .lawyer-info{max-width:none}
  .lawyer-photo>img{height:440px}
  .case-cards-grid{grid-template-columns:repeat(2,1fr)}
  .sec-head h2,.stats-text h2,.cta-inner h2{font-size:32px}
}
@media(max-width:768px){
  /* ===== Mobile slide-in menu ===== */
  .nav{
    display:flex;flex-direction:column;justify-content:flex-start;align-items:stretch;
    position:fixed;top:0;right:0;height:100vh;width:300px;max-width:84vw;
    gap:0;padding:0;z-index:101;overflow-y:auto;-webkit-overflow-scrolling:touch;
    background:
      radial-gradient(120% 60% at 90% 0%,rgba(110,116,232,.22) 0%,transparent 55%),
      linear-gradient(180deg,#161a52 0%,#0c0e2e 100%);
    box-shadow:-24px 0 60px rgba(0,0,0,.45);
    transform:translateX(100%);transition:transform .38s cubic-bezier(.4,0,.2,1);
    will-change:transform;
  }
  .nav.open{transform:translateX(0)}

  .nav-head{
    display:flex;align-items:center;justify-content:space-between;
    padding:20px 22px;border-bottom:1px solid rgba(255,255,255,.09);
  }
  .nav-logo{height:30px;width:auto;filter:brightness(0) invert(1);opacity:.95}
  .nav-close{
    width:38px;height:38px;border-radius:50%;border:0;cursor:pointer;
    display:inline-flex;align-items:center;justify-content:center;
    background:rgba(255,255,255,.08);color:#fff;transition:background .2s;
  }
  .nav-close:hover{background:rgba(255,255,255,.16)}

  /* menu links (direct children only — excludes footer CTA links) */
  .nav a::after{display:none}            /* kill desktop underline pseudo */
  .nav > a{
    display:flex;align-items:center;justify-content:space-between;
    padding:19px 24px;margin:0;font-size:16px;font-weight:600;letter-spacing:-.3px;
    color:#eef0ff;border-bottom:1px solid rgba(255,255,255,.06);
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%237b82c8' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9 6l6 6-6 6'/%3E%3C/svg%3E");
    background-repeat:no-repeat;background-position:right 22px center;background-size:16px;
    /* staggered entrance */
    transform:translateX(24px);opacity:0;
    transition:background-color .2s, color .2s;
  }
  .nav > a:active{background-color:rgba(255,255,255,.06)}
  .nav.open > a{transform:none;opacity:.95;transition:transform .45s cubic-bezier(.2,.7,.2,1), opacity .45s ease}
  .nav.open > a:nth-child(2){transition-delay:.08s}
  .nav.open > a:nth-child(3){transition-delay:.13s}
  .nav.open > a:nth-child(4){transition-delay:.18s}
  .nav.open > a:nth-child(5){transition-delay:.23s}

  /* footer CTA inside menu */
  .nav-foot{display:flex;flex-direction:column;gap:12px;margin-top:auto;padding:22px}
  .nav-tel{
    display:flex;align-items:center;gap:12px;padding:0;background:none;border:0;
    background-image:none;
  }
  .nav-tel-ico{
    flex:none;width:42px;height:42px;border-radius:50%;
    display:inline-flex;align-items:center;justify-content:center;
    background:rgba(255,255,255,.1);color:#fff;
  }
  .nav-tel-txt{display:flex;flex-direction:column;line-height:1.25}
  .nav-tel-txt em{font-style:normal;font-size:11px;font-weight:500;color:#9da3d6}
  .nav-tel-txt b{font-size:18px;font-weight:800;color:#fff;letter-spacing:-.3px}
  .nav-cta{
    display:flex;align-items:center;justify-content:center;
    padding:15px;border-radius:12px;font-size:15px;font-weight:700;letter-spacing:-.3px;
    color:#fff;border-bottom:0;background:linear-gradient(135deg,var(--accent),var(--blue));
    background-position:center;box-shadow:0 12px 26px rgba(58,64,196,.4);
  }
  .nav-cta::after{display:none}

  /* dim backdrop */
  .nav-dim{
    display:block;position:fixed;inset:0;z-index:100;
    background:rgba(8,9,26,.55);backdrop-filter:blur(2px);
    opacity:0;visibility:hidden;transition:opacity .35s ease, visibility .35s;
  }
  .nav-dim.open{opacity:1;visibility:visible}

  .nav-toggle{display:flex;z-index:102}
  .header-inner{padding:16px 20px}
  .chat-inner{width:94vw;gap:clamp(28px,3.5vw,52px)}
  .chat-title{font-size:clamp(26px,3.6vw,36px)}
  .chat-stage-wrap{width:clamp(320px,42vw,400px)}
  .chat-convo{height:min(70vh,600px)}
  .chat-accent{display:none}
  :root{--sec-pad-y:70px}
  .sol-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
  .sol-card{height:196px;padding:22px 20px}
  .sol-q{font-size:16px}
  .stats-grid{grid-template-columns:1fr 1fr;gap:14px}
  .stat-card:nth-child(2),.stat-card:nth-child(3){margin-top:0}
  .case-feature-body{padding:40px 28px}
  .case-feature-body h3{font-size:22px}
  .case-reviews{grid-template-columns:1fr}
  .case-cards-grid{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .info-grid{grid-template-columns:1fr;gap:20px}
  .sec-head h2,.stats-text h2,.cta-inner h2,.lawyer-info h3{font-size:26px}
  .cta-inner{padding:90px 24px}
  .faq-tabs{flex-wrap:wrap}
  .section,.solution,.stats,.cases,.lawyer,.faq,.location,.contact{padding-left:0;padding-right:0}
  .panel{grid-template-columns:1fr}
  .panel-visual{display:none}
}

/* ===== Chat section — mobile (stacked) ===== */
@media(max-width:768px){
  .chat{min-height:auto;padding:60px 0 64px}
  .chat-inner{flex-direction:column;width:90vw;gap:30px;text-align:center}
  /* 모바일: 메시지 비주얼을 먼저, 카피를 아래로 */
  .chat-stage-wrap{order:1}
  .chat-copy{order:2}
  .chat-copy{max-width:none;display:flex;flex-direction:column;align-items:center}
  .chat-title{font-size:27px;line-height:1.3}
  .chat-sub{margin-bottom:24px}
  .chat-phases{align-self:center;width:auto;max-width:280px;margin:0 0 26px;text-align:left}
  .chat-stage-wrap{width:100%;max-width:430px}
  .chat-convo{height:min(66vh,540px)}
  .cmsg{max-width:100%}
  .chat-accent{display:none}
  .chat-orbs span{filter:blur(48px)}
}

/* ============================================================
   MOBILE REFINEMENT — typography + section layout (≤768px)
   Appended last so it wins on equal specificity.
   ============================================================ */
@media(max-width:768px){
  /* ---- global type rhythm ---- */
  .sec-head{margin-bottom:36px}
  .sec-head .eyebrow{font-size:13px}
  .sec-head h2{font-size:24px;line-height:1.35}
  .sec-head p{font-size:14px;line-height:1.6}

  /* ---- HERO (1) ---- */
  .hero-eyebrow{font-size:13px}
  .hero-headline{font-size:30px;line-height:1.3}
  .hero-sub{font-size:14px;line-height:1.7}

  /* ---- SOLUTION (3) ---- */
  .solution .sec-head h2{font-size:24px}
  .solution .sec-head p{font-size:14px}
  .sol-grid{grid-template-columns:1fr 1fr;gap:14px}
  .sol-card{height:180px;padding:20px 18px}
  .sol-q{font-size:15.5px;line-height:1.4}
  .sol-atext{font-size:13px;line-height:1.55}

  /* ---- STATS (4) ---- */
  .stats-text h2{font-size:24px;line-height:1.32}
  .stats-text p{font-size:15px;line-height:1.55}
  .stats-text .eyebrow{font-size:14px}
  .stats-text .btn-primary{width:100%;max-width:340px;height:52px;font-size:15px}
  .stats-grid{gap:12px}
  .stat-card{
    width:auto;height:auto;min-height:0;padding:24px 14px;
    justify-content:flex-start;gap:6px;
  }
  .stat-card:nth-child(2),.stat-card:nth-child(3),.stat-card:nth-child(4){top:0;margin-top:0;align-self:auto}
  .stat-ico{width:46px;height:46px;margin-bottom:2px}
  .stat-ico img{width:22px}
  .stat-label{font-size:12px;letter-spacing:.04em}
  .stat-value{
    font-size:23px;line-height:1.2;letter-spacing:-.3px;margin:4px 0;
    word-break:keep-all;overflow-wrap:anywhere;
  }
  .stat-desc{font-size:12px;line-height:1.55}

  /* ---- CASES (5) ---- */
  /* feature card: content-driven height, even dark overlay for legibility */
  .case-feature{aspect-ratio:auto;border-radius:12px}
  .case-feature::before{background:linear-gradient(180deg,rgba(0,0,0,.55),rgba(0,0,0,.78))}
  .case-feature-body{padding:30px 22px;max-width:none}
  .case-tag{font-size:12px;padding:6px 14px;margin-bottom:14px}
  .case-feature-body h3{font-size:19px;line-height:1.45;margin-bottom:20px}
  .case-list{margin-bottom:22px}
  .case-list li{font-size:14px;padding-left:26px;margin:8px 0}
  .case-result-num{font-size:36px}
  .case-result-label,.case-result-suffix{font-size:13px}
  /* review cards: no hover on touch → keep dark overlay + text always visible */
  .case-reviews{gap:14px}
  .review-card{width:auto;height:208px}
  .review-card::after{opacity:1}
  .review-card.is-active::after{opacity:1}
  .review-card .review-foot{text-shadow:0 1px 3px rgba(0,0,0,.7)}
  .review-tag{font-size:12px;top:16px;left:16px}
  .review-quote{font-size:15px;line-height:1.5;margin-bottom:10px}
  .review-result{font-size:13px}

  /* ---- LAWYER (6) ---- */
  .lawyer-photo{width:100%;height:auto;flex:0 0 auto}
  .lawyer-photo>img{height:auto;aspect-ratio:1/1}
  .lawyer-name .name{font-size:20px}
  .lawyer-info h3{font-size:18px;line-height:1.5;margin:10px 0 28px}
  .lawyer-list li{gap:14px;padding:20px 0}
  .lawyer-list .li-ico{width:46px;height:46px}
  .lawyer-list b{font-size:16px}
  .lawyer-list p{font-size:14px}
  /* 대표사례: 좌측정렬 텍스트 → 폭을 채우는 카드로 정돈 */
  .case-cards{margin-top:44px;padding-top:34px}
  .case-cards-title{font-size:18px;margin-bottom:18px}
  .case-cards-grid{gap:12px}
  .cc{
    background:#fff;border:1px solid var(--line-soft);border-radius:14px;
    padding:18px 18px;box-shadow:0 6px 18px rgba(28,33,90,.05);
  }
  .cc-title{font-size:15px;line-height:1.5;margin-bottom:12px}

  /* ---- CTA 배너: 절대배치(left:19%) 해제 → 중앙 정렬 ---- */
  .cta{height:auto;margin-top:60px}
  .cta-overlay{background:linear-gradient(180deg,rgba(255,255,255,.84) 0%,rgba(255,255,255,.92) 100%)}
  .cta-inner{
    position:relative;left:auto;top:auto;width:100%;
    align-items:center;text-align:center;padding:60px 26px;
  }
  .cta-inner,
  .cta-inner.reveal,
  .cta-inner.reveal.in{transform:none}
  .cta-inner h2{font-size:24px;line-height:1.35;margin-bottom:18px}
  .cta-divider{margin-left:auto;margin-right:auto;margin-bottom:24px}
  .cta-inner p{font-size:15px;line-height:1.7;max-width:none;margin-bottom:34px}
  .cta-inner .btn-primary{width:100%;max-width:300px;height:52px}

  /* ---- cta-band ---- */
  .cta-band{padding:52px 24px}
  .cta-band .sm{font-size:14px;line-height:1.7;margin-top:16px}

  /* ---- FAQ ---- */
  .faq-tabs{gap:8px;margin-bottom:40px}
  .faq-tab{padding:0 18px;height:42px;font-size:13px}
  .faq-list summary{font-size:16px;padding:22px 4px;gap:12px}
  .faq-body{padding:0 4px 24px}
  .faq-body p{font-size:14px;line-height:1.75}

  /* ---- LOCATION / CONTACT ---- */
  .company-info h3{font-size:18px}
  .info-item b{font-size:14px}
  .info-item p{font-size:13px}
  .field span{font-size:15px}
  .btn-block{font-size:16px;padding:18px}

  /* ---- FOOTER 정리 ---- */
  .footer{padding:46px 0 124px}                 /* 하단 여백 → 플로팅 버튼이 카피라이트 가리지 않게 */
  .footer-top{flex-direction:column;align-items:flex-start;gap:20px;margin-bottom:24px}
  .footer-brand{min-width:0;gap:10px}
  .footer-tagline{font-size:13px}
  .footer-nav{gap:12px 22px;width:100%}
  .footer-nav a{font-size:14px}
  .footer-divider{margin-bottom:22px}
  .footer-info{flex-direction:column;gap:11px}
  .footer-info li{font-size:13px;gap:12px;align-items:flex-start}
  .footer-info li span{flex:none;min-width:96px;white-space:nowrap}  /* 라벨 정렬 + 주소 '주/소' 쪼개짐 방지 */
  .footer-info li b{line-height:1.55}
  .footer-bottom{flex-direction:column-reverse;align-items:flex-start;gap:14px}

  /* 한글 단어 중간 줄바꿈 방지 (있습/니다 → 있습니다) — 공백 단위로만 줄바꿈 */
  .hero-text, .sec-head, .solution, .stats, .cases, .lawyer,
  .cta-inner, .cta-band, .faq, .location, .contact, .chat-mobile, .footer{word-break:keep-all}
}

/* very small phones */
@media(max-width:380px){
  .hero-headline{font-size:27px}
  .stat-value{font-size:21px}
  .stats-grid{gap:10px}
  .stat-card{padding:20px 10px}
}
