/* Atorni.AI Landing v2 — ported from design handoff (source/styles.css).
 * Scoped under .lpv2 so generic classes (.btn/.section/.wrap…) never clash with
 * components.css / the codebase Header+Footer. Tokens reuse tokens.css values;
 * only the 3-stop gradient / 28px radius / violet shadow are added here.
 * Header & LangSwitcher come from the codebase Header.js (not restyled here).
 */
@import url('https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard-dynamic-subset.min.css');
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=Playfair+Display:ital,wght@1,600;1,700&display=swap');

html{scroll-behavior:smooth}
/* 랜딩은 자체 디자인 푸터(.lpv2 .ftr)를 쓰므로 app_bootstrap의 기본 푸터 숨김(이 CSS는 index.html에서만 로드). */
#orbit-footer{display:none}

.lpv2{
  --grad:linear-gradient(135deg,#06B6D4 0%,#7C3AED 60%,#DB2777 100%);
  --grad-cv:var(--brand-gradient);
  --grad-soft:var(--brand-gradient-soft);
  --r-sm:var(--radius-sm);--r:var(--radius);--r-lg:var(--radius-lg);--r-xl:var(--radius-xl);--r-2xl:28px;--r-pill:var(--radius-pill);
  --sh-card:var(--shadow-card);--sh-md:var(--shadow-md);--sh-lg:var(--shadow-lg);--sh-violet:0 12px 40px rgba(124,58,237,.16);
  --brand-pink:#DB2777;--maxw:1120px;--on:#fff;
  word-break:keep-all;line-height:1.6;color:var(--text);
}
.lpv2 *{box-sizing:border-box}
.lpv2 .wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.lpv2 .nowrap-block{white-space:pre-line}

/* ---- buttons ---- */
.lpv2 .btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 22px;border-radius:var(--r);font-weight:700;font-size:15px;transition:transform .15s,box-shadow .15s,filter .15s,background .15s;border:1px solid var(--border);background:var(--surface-alt);color:var(--text);white-space:nowrap;cursor:pointer;text-decoration:none}
.lpv2 .btn-primary{background:var(--grad-cv);color:#fff;border-color:transparent;box-shadow:0 6px 18px rgba(124,58,237,.22)}
.lpv2 .btn-primary:hover{transform:translateY(-1px);box-shadow:0 10px 26px rgba(124,58,237,.34);filter:brightness(1.04)}
.lpv2 .btn-ghost{background:#fff;border-color:var(--border)}
.lpv2 .btn-ghost:hover{background:var(--surface-alt);transform:translateY(-1px)}
.lpv2 .btn-lg{padding:16px 30px;font-size:16px;border-radius:14px}
.lpv2 .btn-block{width:100%}
.lpv2 .btn-white{background:#fff;color:var(--brand-primary);border-color:transparent}
.lpv2 .btn-white:hover{transform:translateY(-1px);box-shadow:0 10px 26px rgba(0,0,0,.18)}

/* ---- generic section ---- */
.lpv2 .section{padding:96px 0}
.lpv2 .section-alt{background:var(--surface-alt)}
.lpv2 .eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:700;letter-spacing:.02em;color:var(--brand-primary);background:var(--grad-soft);border:1px solid #7C3AED22;padding:7px 15px;border-radius:var(--r-pill);margin-bottom:18px;white-space:nowrap}
.lpv2 .section-h2{font-family:var(--font-display);font-size:clamp(28px,4vw,42px);font-weight:800;letter-spacing:-.02em;line-height:1.18;color:var(--text)}
.lpv2 .section-lede{font-size:clamp(15px,1.6vw,18px);color:var(--text-sub);margin-top:14px;max-width:560px}
.lpv2 .center{text-align:center}
.lpv2 .center .section-lede{margin-left:auto;margin-right:auto}
.lpv2 .grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.lpv2 .won{display:inline-block;font-style:normal;vertical-align:baseline}

/* ============================ HERO (lavender / split / trust-in) ============================ */
.lpv2 .hero{position:relative;overflow:hidden;padding:64px 0 84px;background:linear-gradient(160deg,#F5F3FF 0%,#EDE9FE 32%,#E6EAFE 66%,#DEEBFE 100%)}
.lpv2 .hero::before{content:'';position:absolute;top:-220px;right:-180px;width:620px;height:620px;background:radial-gradient(circle,#C4B5FD55 0%,transparent 70%);pointer-events:none}
.lpv2 .hero::after{content:'';position:absolute;bottom:-320px;left:-140px;width:720px;height:720px;background:radial-gradient(circle,#06B6D433 0%,transparent 70%);pointer-events:none}
.lpv2 .hero-inner{position:relative;z-index:2}
.lpv2 .hero-grid{display:grid;gap:48px;align-items:center;grid-template-columns:1.05fr .95fr}
.lpv2 .hero-badge{display:inline-flex;align-items:center;gap:8px;background:#ffffffcc;backdrop-filter:blur(8px);border:1px solid #ffffff;border-radius:var(--r-pill);padding:8px 16px;font-size:13px;font-weight:700;color:var(--brand-primary);box-shadow:0 2px 12px rgba(79,70,229,.08);margin-bottom:24px}
.lpv2 .hero-badge .dot{width:8px;height:8px;border-radius:50%;background:var(--success);animation:lp-pulse 2s ease-in-out infinite}
.lpv2 .hero h1{font-family:var(--font-display);font-weight:800;font-size:clamp(38px,6vw,68px);line-height:1.08;letter-spacing:-.025em;color:var(--text)}
.lpv2 .hero h1 .grad-text{display:inline}
.lpv2 .hero-sub{margin-top:24px;font-size:clamp(20px,2.6vw,30px);font-weight:700;line-height:1.32;color:var(--text);letter-spacing:-.01em;min-height:1.32em}
.lpv2 .hero-rot{display:inline-block;position:relative}
.lpv2 .hero-rot .rot-word{display:inline-block;color:#7C3AED;font-weight:800;white-space:nowrap;transition:opacity .24s ease,transform .24s cubic-bezier(.16,1,.3,1)}
.lpv2 .hero-cta-row{display:flex;align-items:center;gap:16px;margin-top:36px;flex-wrap:wrap}
.lpv2 .hero-micro{font-size:13.5px;color:var(--text-sub);font-weight:600}
.lpv2 .hero-micro .ic{color:var(--success);font-weight:800;margin-right:5px}
.lpv2 .hero-trust{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px}
.lpv2 .trust-chip{display:inline-flex;align-items:center;gap:9px;background:#ffffffcc;backdrop-filter:blur(6px);border:1px solid #ffffffcc;border-radius:var(--r-pill);padding:9px 20px 9px 16px;font-size:13px;font-weight:600;color:var(--text-sub);box-shadow:0 2px 10px rgba(15,23,42,.05)}
.lpv2 .trust-chip .tico{color:var(--brand-primary);display:inline-flex}

/* phone mockup */
.lpv2 .hero-phone-col{display:flex;justify-content:center;position:relative}
.lpv2 .phone{position:relative;width:300px;height:610px;border-radius:42px;background:#0d1117;padding:11px;box-shadow:0 30px 70px rgba(40,30,90,.30),0 8px 20px rgba(0,0,0,.18);flex:0 0 auto}
.lpv2 .phone::before{content:'';position:absolute;top:14px;left:50%;transform:translateX(-50%);width:120px;height:26px;background:#0d1117;border-radius:0 0 16px 16px;z-index:4}
.lpv2 .phone-screen{position:relative;width:100%;height:100%;border-radius:32px;overflow:hidden;background:#fff;display:flex;flex-direction:column}
.lpv2 .phone-status{display:flex;justify-content:space-between;align-items:center;padding:14px 22px 6px;font-size:12px;font-weight:700;color:var(--text)}
.lpv2 .phone-body{flex:1;overflow:hidden;position:relative}

/* ============================ HOW IT WORKS ============================ */
.lpv2 .how-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:56px}
.lpv2 .how-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:26px 22px 24px;box-shadow:var(--sh-card);position:relative;transition:transform .18s,box-shadow .18s}
.lpv2 .how-card:hover{transform:translateY(-4px);box-shadow:var(--sh-md)}
.lpv2 .how-step{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.lpv2 .how-num{width:38px;height:38px;flex:0 0 auto;border-radius:11px;background:var(--grad-cv);color:#fff;font-family:var(--font-display);font-weight:800;font-size:18px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(124,58,237,.22)}
.lpv2 .how-ico{color:var(--brand-primary);display:inline-flex}
.lpv2 .how-card h3{font-size:18px;font-weight:800;letter-spacing:-.01em;margin-bottom:7px}
.lpv2 .how-card p{font-size:14px;color:var(--text-sub);line-height:1.55;min-height:44px}
.lpv2 .how-tag{display:inline-block;margin-top:2px;margin-bottom:14px;font-size:11px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;color:var(--free-text);background:var(--free-bg);padding:3px 9px;border-radius:var(--r-pill)}
.lpv2 .how-shot{margin-top:16px;height:210px;position:relative}
.lpv2 .how-shot::after{content:'';position:absolute;left:0;right:0;bottom:0;height:34px;background:linear-gradient(transparent,rgba(255,255,255,.85));pointer-events:none;border-radius:0 0 var(--r) var(--r)}
.lpv2 .how-footer{margin-top:48px;text-align:center}
.lpv2 .how-footer-line{display:inline-flex;align-items:center;gap:12px;font-family:var(--font-display);font-size:clamp(20px,2.6vw,30px);font-weight:800;letter-spacing:-.02em;color:var(--text)}
.lpv2 .how-footer-line .x{color:var(--brand-primary)}

/* ============================ PRICING ============================ */
.lpv2 .price-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:24px;margin-top:52px;align-items:start}
.lpv2 .price-main{position:relative;background:var(--surface);border:1.5px solid #7C3AED33;border-radius:var(--r-2xl);padding:40px;box-shadow:var(--sh-violet);overflow:hidden}
.lpv2 .price-main::before{content:'';position:absolute;top:0;left:0;right:0;height:5px;background:var(--grad)}
.lpv2 .price-tag{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:var(--brand-primary);background:var(--grad-soft);border-radius:var(--r-pill);padding:7px 15px;margin-bottom:20px;white-space:nowrap}
.lpv2 .price-amount{font-family:var(--font-display);font-size:clamp(46px,6vw,68px);font-weight:800;letter-spacing:-.03em;line-height:1;color:var(--text)}
.lpv2 .price-main-sub{font-size:16px;color:var(--text-sub);margin-top:12px;max-width:420px;line-height:1.55}
.lpv2 .price-inc{margin:26px 0;padding:22px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.lpv2 .price-inc-title{font-size:12px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;color:var(--text-mute);margin-bottom:14px}
.lpv2 .price-inc-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 20px}
.lpv2 .price-inc-item{display:flex;align-items:center;gap:10px;font-size:15px;font-weight:600;color:var(--text)}
.lpv2 .price-inc-item .ck{width:22px;height:22px;flex:0 0 auto;border-radius:50%;background:var(--success-light);color:var(--success);display:flex;align-items:center;justify-content:center;font-weight:900;font-size:12px}
.lpv2 .price-badges{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}
.lpv2 .price-badge{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:700;color:var(--text-sub);background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--r-pill);padding:7px 13px;white-space:nowrap}
.lpv2 .price-badge .pb-dot{width:6px;height:6px;border-radius:50%;background:var(--success)}
.lpv2 .price-sla{display:flex;align-items:center;gap:10px;font-size:13.5px;font-weight:600;color:var(--text-sub);background:var(--grad-soft);border-radius:var(--r);padding:13px 16px;margin-bottom:24px;line-height:1.4}
.lpv2 .price-sla .sico{color:var(--brand-primary);flex:0 0 auto}
.lpv2 .price-side{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-2xl);padding:30px 28px;box-shadow:var(--sh-card)}
.lpv2 .price-side .price-tag{background:var(--free-bg);color:var(--free-text)}
.lpv2 .price-side-amt{font-family:var(--font-display);font-size:38px;font-weight:800;letter-spacing:-.02em;color:var(--text);display:flex;align-items:baseline;gap:8px;white-space:nowrap}
.lpv2 .price-side-amt .unit{font-size:16px;font-weight:600;color:var(--text-mute)}
.lpv2 .badge-paid{font-size:11px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;color:var(--paid-text);background:var(--paid-bg);padding:3px 9px;border-radius:var(--r-pill)}
.lpv2 .price-side-desc{font-size:14px;color:var(--text-sub);line-height:1.6;margin:16px 0 24px}
.lpv2 .price-note{margin-top:28px;font-size:13.5px;color:var(--text-mute);text-align:center;line-height:1.6;max-width:680px;margin-left:auto;margin-right:auto}

/* ============================ PEOPLE ============================ */
.lpv2 .people-h2{white-space:pre-line}
.lpv2 .people-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:28px;margin-top:52px;align-items:start}
.lpv2 .lawyer-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-2xl);padding:34px;box-shadow:var(--sh-md);position:relative;overflow:hidden}
.lpv2 .lawyer-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:5px;background:var(--grad)}
.lpv2 .lawyer-eyebrow{font-size:12.5px;font-weight:800;letter-spacing:.3px;color:var(--brand-primary);text-transform:uppercase;margin-bottom:18px}
.lpv2 .lawyer-top{display:flex;gap:20px;align-items:flex-start}
.lpv2 .lawyer-top>div{min-width:0}
.lpv2 .lawyer-photo{width:120px;height:140px;flex:0 0 auto;border-radius:var(--r-lg);overflow:hidden;background:linear-gradient(160deg,#EDE9FE,#DDEBFE);position:relative}
.lpv2 .lawyer-photo img{width:100%;height:100%;object-fit:cover;object-position:50% 16%;display:block}
.lpv2 .lawyer-name{font-family:var(--font-display);font-size:24px;font-weight:800;letter-spacing:-.01em}
.lpv2 .lawyer-meta{font-size:13.5px;color:var(--text-sub);margin-top:5px;font-weight:600;line-height:1.4}
.lpv2 .lawyer-bar{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;color:var(--text-mute);margin-top:8px;font-weight:600}
.lpv2 .lawyer-bar .bico{color:var(--brand-primary)}
.lpv2 .lawyer-verified{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:700;color:var(--success);background:var(--success-light);border-radius:var(--r-pill);padding:5px 11px;margin-top:9px}
.lpv2 .lawyer-cred{display:grid;grid-template-columns:1fr 1fr;gap:18px 22px;margin:20px 0 22px;padding:18px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.lpv2 .cred-label{font-size:11px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;color:var(--text-mute);margin-bottom:11px}
.lpv2 .cred-item{display:flex;align-items:flex-start;gap:9px;font-size:13px;font-weight:600;color:var(--text);line-height:1.4;margin-bottom:9px}
.lpv2 .cred-item:last-child{margin-bottom:0}
.lpv2 .cred-ico{width:24px;height:24px;flex:0 0 auto;border-radius:7px;background:var(--grad-soft);color:var(--brand-primary);display:flex;align-items:center;justify-content:center;margin-top:-1px}
.lpv2 .cred-now{font-style:normal;font-size:9.5px;font-weight:800;letter-spacing:.3px;text-transform:uppercase;color:#fff;background:var(--grad-cv);border-radius:999px;padding:2px 7px;margin-left:7px;vertical-align:middle}
.lpv2 .lawyer-promise{font-size:16px;font-weight:700;line-height:1.55;margin:24px 0 18px;color:var(--text)}
/* [P3c-2] 旧 전문분야 칩(.lawyer-spec-label/.spec-chips/.spec-chip) 제거 — FB-E2(ID97)에서 마크업 제거된 사장 스타일 */
.lpv2 .coord-head{margin-bottom:18px}
.lpv2 .coord-head h3{font-family:var(--font-display);font-size:20px;font-weight:800;letter-spacing:-.01em}
.lpv2 .coord-head p{font-size:14px;color:var(--text-sub);margin-top:6px;line-height:1.55}
.lpv2 .coord-list{display:flex;flex-direction:column;gap:12px}
.lpv2 .coord-card{display:flex;align-items:center;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px 18px;box-shadow:var(--sh-card);transition:transform .18s,box-shadow .18s,border-color .2s;position:relative}
.lpv2 .coord-card.rich{flex-direction:column;align-items:stretch;gap:14px}
.lpv2 .coord-main{display:flex;align-items:center;gap:16px}
.lpv2 .coord-card:hover{transform:translateY(-2px);box-shadow:var(--sh-md)}
.lpv2 .coord-card.yours{border-color:#7C3AED;box-shadow:0 8px 28px rgba(124,58,237,.16);background:linear-gradient(135deg,#faf8ff 0%,#fff 60%)}
.lpv2 .coord-yours-tag{position:absolute;top:-10px;left:18px;font-size:11px;font-weight:800;letter-spacing:.3px;color:#fff;background:var(--grad-cv);padding:3px 11px;border-radius:var(--r-pill);box-shadow:0 4px 10px rgba(124,58,237,.3);white-space:nowrap}
.lpv2 .coord-photo{width:60px;height:60px;flex:0 0 auto;border-radius:50%;overflow:hidden;background:linear-gradient(160deg,#EDE9FE,#DDEBFE);display:flex;align-items:center;justify-content:center}
.lpv2 .coord-soon-mark{font-size:26px;line-height:1;filter:grayscale(.15)}
.lpv2 .coord-card.upcoming{border-style:dashed;border-color:var(--border-strong);background:repeating-linear-gradient(135deg,#fbfbfd 0 10px,#f7f8fb 10px 20px)}
.lpv2 .coord-card.upcoming .coord-photo{background:#eef0f4;opacity:.9}
.lpv2 .coord-card.upcoming .coord-speaks-txt{color:var(--text-sub)}
.lpv2 .coord-card.upcoming.yours{border-color:#7C3AED;background:linear-gradient(135deg,#faf8ff,#fff 60%)}
.lpv2 .coord-soon-badge{font-size:10px;font-weight:800;letter-spacing:.3px;text-transform:uppercase;color:var(--warn);background:#FEF3E2;border:1px solid #F7D9A8;border-radius:999px;padding:2px 8px;margin-left:2px;white-space:nowrap}
.lpv2 .coord-yours-tag.soon{background:linear-gradient(135deg,#F09A38,#DB2777)}
.lpv2 .coord-body{flex:1;min-width:0}
.lpv2 .coord-speaks{display:flex;align-items:center;gap:9px;margin-bottom:4px}
.lpv2 .coord-flag{font-size:24px;line-height:1}
.lpv2 .coord-speaks-txt{font-family:var(--font-display);font-size:18px;font-weight:800;letter-spacing:-.01em;color:var(--text);white-space:nowrap}
.lpv2 .coord-name{font-size:13.5px;font-weight:700;color:var(--text)}
.lpv2 .coord-career{font-size:12.5px;color:var(--text-mute);margin-top:2px;line-height:1.4}
.lpv2 .coord-stat{display:flex;align-items:center;gap:9px;font-size:13px;font-weight:700;color:var(--brand-primary);background:var(--grad-soft);border:1px solid #7C3AED1f;border-radius:var(--r);padding:10px 13px}
.lpv2 .coord-stat svg{flex:0 0 auto}
.lpv2 .coord-edu{display:flex;flex-direction:column;gap:8px;padding-top:13px;border-top:1px solid var(--border)}
.lpv2 .coord-edu-item{display:flex;align-items:flex-start;gap:9px;font-size:12.5px;font-weight:600;color:var(--text-sub);line-height:1.4}
.lpv2 .coord-edu-item .cred-ico{width:22px;height:22px;flex:0 0 auto;border-radius:6px;background:var(--grad-soft);color:var(--brand-primary);display:flex;align-items:center;justify-content:center;margin-top:-1px}

/* ============================ WIZARD DEMO ============================ */
.lpv2 .demo-wrap{max-width:920px;margin:52px auto 0}
.lpv2 .demo-browser{background:#fff;border:1px solid var(--border);border-radius:18px;overflow:hidden;box-shadow:0 24px 70px rgba(40,30,90,.16),0 6px 18px rgba(0,0,0,.06)}
.lpv2 .db-bar{display:flex;align-items:center;gap:14px;height:48px;padding:0 16px;background:linear-gradient(180deg,#fbfbfd,#f3f4f7);border-bottom:1px solid var(--border)}
.lpv2 .db-dots{display:flex;gap:7px}
.lpv2 .db-dots i{width:12px;height:12px;border-radius:50%;display:block}
.lpv2 .db-dots i:nth-child(1){background:#ff5f57}.lpv2 .db-dots i:nth-child(2){background:#febc2e}.lpv2 .db-dots i:nth-child(3){background:#28c840}
.lpv2 .db-url{flex:1;max-width:360px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:7px;height:30px;background:#fff;border:1px solid var(--border);border-radius:999px;font-size:13px;font-weight:600;color:var(--text-sub);font-variant-numeric:tabular-nums}
.lpv2 .db-lock{font-size:11px}
.lpv2 .db-spacer{width:52px}
.lpv2 .db-screen{position:relative;min-height:452px;padding:26px 28px 30px;background:linear-gradient(180deg,#fcfcfe,#f7f8fc);overflow:hidden}
.lpv2 .dw-progress{margin-bottom:22px}
.lpv2 .dw-dots{display:flex;gap:6px;align-items:center;justify-content:center;margin-bottom:12px}
.lpv2 .dw-dot{width:8px;height:8px;border-radius:50%;background:#e4e8ee;transition:all .25s ease}
.lpv2 .dw-dot.done{background:#7C3AED}
.lpv2 .dw-dot.cur{width:13px;height:13px;background:linear-gradient(135deg,#06B6D4,#7C3AED);box-shadow:0 0 0 3px rgba(124,58,237,.2)}
.lpv2 .dw-bar{height:7px;background:#eef0f4;border-radius:999px;overflow:hidden;max-width:420px;margin:0 auto}
.lpv2 .dw-fill{height:100%;background:var(--grad-cv);border-radius:999px;transition:width .5s cubic-bezier(.4,0,.2,1)}
.lpv2 .dw-step{animation:lp-wizup .32s cubic-bezier(.16,1,.3,1)}
.lpv2 .dw-title{font-size:22px;font-weight:800;letter-spacing:-.01em;text-align:center;margin-bottom:6px}
.lpv2 .dw-help{font-size:14px;color:var(--text-sub);text-align:center;margin-bottom:22px}
.lpv2 .dw-options{display:grid;gap:11px;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));max-width:620px;margin:0 auto}
.lpv2 .dw-option{display:flex;align-items:center;gap:11px;padding:15px 16px;border:2px solid var(--border);border-radius:14px;background:#fff;font-size:14.5px;font-weight:600;word-break:keep-all}
/* [handoff §5 trap#1] 선택 채움/체크에는 transition 금지 — 재렌더 시 0프레임(흰색) 정지 방지 */
.lpv2 .dw-option.has-sub{grid-column:1/-1}
.lpv2 .dw-option.active{border-color:var(--brand-primary);background:var(--grad-soft);color:var(--brand-primary);box-shadow:0 6px 16px rgba(124,58,237,.14)}
.lpv2 .dw-ico{font-size:20px;line-height:1;flex:0 0 auto}
.lpv2 .dw-opt-body{display:flex;flex-direction:column;gap:3px;min-width:0;flex:1}
.lpv2 .dw-opt-label{line-height:1.35}
.lpv2 .dw-opt-sub{font-size:12.5px;font-weight:500;color:var(--text-mute)}
.lpv2 .dw-option.active .dw-opt-sub{color:#9168d8}
.lpv2 .dw-check{width:20px;height:20px;flex:0 0 auto;border-radius:6px;border:2px solid var(--border-strong);background:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:900;color:#fff}
.lpv2 .dw-check.on{background:var(--brand-primary);border-color:var(--brand-primary)}
.lpv2 .dw-success{text-align:center;padding:34px 16px;animation:lp-wizup .4s cubic-bezier(.16,1,.3,1)}
.lpv2 .dw-success-ring{width:74px;height:74px;margin:0 auto 18px;border-radius:50%;background:var(--success-light);color:var(--success);display:flex;align-items:center;justify-content:center;animation:lp-popring .45s cubic-bezier(.16,1.4,.4,1)}
.lpv2 .dw-success h3{font-size:24px;font-weight:800;letter-spacing:-.01em;margin-bottom:8px}
.lpv2 .dw-success p{font-size:14.5px;color:var(--text-sub);max-width:420px;margin:0 auto 20px;line-height:1.55}
.lpv2 .dw-success-cta{display:inline-flex;align-items:center;gap:9px;font-size:14px;font-weight:700;color:var(--brand-primary);background:var(--grad-soft);border:1px solid #7C3AED22;border-radius:999px;padding:10px 18px}
.lpv2 .dw-av{font-size:18px}
.lpv2 .demo-cursor{position:absolute;top:0;left:0;z-index:20;pointer-events:none;filter:drop-shadow(0 3px 5px rgba(0,0,0,.28));transition:transform .76s cubic-bezier(.45,.05,.2,1)}
.lpv2 .demo-cursor.tapping svg{transform:scale(.82)}
.lpv2 .demo-cursor svg{transition:transform .12s;transform-origin:6px 4px}
.lpv2 .demo-ripple{position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:rgba(124,58,237,.35);animation:lp-rip .5s ease-out forwards}

/* ============================ APP SCREENS (product mockups) ============================ */
.lpv2 .appscreen{position:absolute;inset:0;display:flex;flex-direction:column;background:#fff;font-size:13px;text-align:left}
.lpv2 .how-shot .appscreen{position:relative;inset:auto;height:100%}
.lpv2 .as-bar{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border);background:#fff;flex:0 0 auto}
.lpv2 .as-av{width:34px;height:34px;border-radius:50%;overflow:hidden;flex:0 0 auto;box-shadow:0 1px 4px rgba(0,0,0,.1)}
.lpv2 .as-bar-tx{min-width:0}
.lpv2 .as-title{font-size:14px;font-weight:800;letter-spacing:-.01em;color:var(--text);line-height:1.2}
.lpv2 .as-sub{font-size:11px;color:var(--text-mute);font-weight:600;display:flex;align-items:center;gap:5px;margin-top:2px}
.lpv2 .as-dot{width:6px;height:6px;border-radius:50%;background:var(--success);flex:0 0 auto}
.lpv2 .as-body{flex:1;overflow:hidden;background:var(--surface-alt)}
.lpv2 .as-body.pad{padding:16px}
.lpv2 .as-body.chat{padding:14px 14px 6px;display:flex;flex-direction:column;gap:9px}
.lpv2 .cb{max-width:82%;padding:10px 13px;border-radius:16px;font-size:12.5px;line-height:1.45;font-weight:500}
.lpv2 .cb.in{align-self:flex-start;background:#fff;color:var(--text);border:1px solid var(--border);border-bottom-left-radius:5px}
.lpv2 .cb.out{align-self:flex-end;background:var(--grad-cv);color:#fff;border-bottom-right-radius:5px}
.lpv2 .cb.short{max-width:60%}
.lpv2 .cb.typing{display:flex;gap:4px;padding:13px 14px;align-items:center}
.lpv2 .cb.typing i{width:6px;height:6px;border-radius:50%;background:var(--text-mute);animation:lp-tdot 1.2s infinite}
.lpv2 .cb.typing i:nth-child(2){animation-delay:.18s}.lpv2 .cb.typing i:nth-child(3){animation-delay:.36s}
.lpv2 .as-input{display:flex;align-items:center;gap:8px;padding:10px 14px;border-top:1px solid var(--border);background:#fff;flex:0 0 auto}
.lpv2 .as-input-ph{flex:1;font-size:12.5px;color:var(--text-mute);background:var(--surface-alt);border-radius:999px;padding:9px 14px}
.lpv2 .as-send{width:34px;height:34px;border-radius:50%;background:var(--grad-cv);color:#fff;display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.lpv2 .as-q{font-size:16px;font-weight:800;letter-spacing:-.01em;margin-bottom:12px;color:var(--text)}
.lpv2 .as-textarea{background:#fff;border:1.5px solid var(--brand-primary);border-radius:12px;padding:13px 14px;font-size:13px;line-height:1.5;color:var(--text);min-height:96px;box-shadow:0 0 0 3px var(--paid-bg)}
.lpv2 .as-caret{display:inline-block;width:2px;height:15px;background:var(--brand-primary);margin-left:2px;vertical-align:-2px;animation:lp-blink 1s steps(1) infinite}
.lpv2 .as-chips{display:flex;gap:7px;margin-top:14px;flex-wrap:wrap}
.lpv2 .as-chip{font-size:12px;font-weight:700;padding:7px 13px;border-radius:999px;border:1px solid var(--border);color:var(--text-sub);background:#fff}
.lpv2 .as-chip.on{background:var(--grad-soft);border-color:#7C3AED33;color:var(--brand-primary)}
.lpv2 .as-cta{margin:0 16px 16px;height:46px;display:flex;align-items:center;justify-content:center;gap:8px;background:var(--grad-cv);color:#fff;border-radius:13px;font-weight:700;font-size:14px;box-shadow:0 6px 16px rgba(124,58,237,.22);flex:0 0 auto}
.lpv2 .as-note{background:#fff;border:1px solid var(--border);border-left:4px solid var(--brand-primary);border-radius:12px;padding:13px 15px}
.lpv2 .as-note-by{display:flex;align-items:center;gap:7px;font-size:12.5px;font-weight:800;color:var(--text);margin-bottom:6px}
.lpv2 .as-note-ico{width:22px;height:22px;border-radius:7px;background:var(--paid-bg);color:var(--brand-primary);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.lpv2 .as-note p{font-size:12.5px;color:var(--text-sub);line-height:1.5}
.lpv2 .as-docs-label{font-size:11px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;color:var(--text-mute);margin:16px 0 9px}
.lpv2 .as-doclist{display:flex;flex-direction:column;gap:8px}
.lpv2 .as-doc{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--border);border-radius:11px;padding:11px 13px;font-size:13px;font-weight:600;color:var(--text)}
.lpv2 .as-doc-ck{width:20px;height:20px;border-radius:6px;border:2px solid var(--border-strong);display:flex;align-items:center;justify-content:center;color:#fff;flex:0 0 auto}
.lpv2 .as-doc.done .as-doc-ck{background:var(--success);border-color:var(--success)}
.lpv2 .as-timeline{display:flex;flex-direction:column;gap:0}
.lpv2 .as-tl{display:flex;align-items:center;gap:12px;position:relative;padding:9px 0}
.lpv2 .as-tl:not(:last-child)::before{content:'';position:absolute;left:13px;top:30px;bottom:-9px;width:2px;background:var(--border)}
.lpv2 .as-tl.done:not(:last-child)::before{background:var(--success)}
.lpv2 .as-tl-node{width:28px;height:28px;border-radius:50%;flex:0 0 auto;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;background:var(--surface-alt);color:var(--text-mute);z-index:1}
.lpv2 .as-tl.done .as-tl-node{background:var(--success-light);color:var(--success)}
.lpv2 .as-tl.now .as-tl-node{background:var(--grad-cv);color:#fff;box-shadow:0 0 0 4px var(--paid-bg)}
.lpv2 .as-tl-txt{font-size:13.5px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:8px}
.lpv2 .as-tl.todo .as-tl-txt{color:var(--text-mute);font-weight:600}
.lpv2 .as-tl-tag{font-style:normal;font-size:10px;font-weight:800;letter-spacing:.3px;text-transform:uppercase;padding:2px 7px;border-radius:999px}
.lpv2 .as-tl-tag.done{background:var(--success-light);color:var(--success)}
.lpv2 .as-tl-tag.now{background:var(--paid-bg);color:var(--brand-primary)}
.lpv2 .as-eta{margin-top:14px;display:flex;align-items:center;gap:8px;font-size:12.5px;font-weight:700;color:var(--brand-primary);background:var(--grad-soft);border-radius:11px;padding:11px 13px}

/* ============================ FAQ ============================ */
.lpv2 .faq-wrap{max-width:780px;margin:48px auto 0}
.lpv2 .faq-item{border-bottom:1px solid var(--border)}
.lpv2 .faq-q{display:flex;align-items:center;gap:16px;width:100%;text-align:left;padding:24px 4px;font-size:17px;font-weight:700;color:var(--text);transition:color .15s;background:none;border:none;cursor:pointer}
.lpv2 .faq-q:hover{color:var(--brand-primary)}
.lpv2 .faq-q .qtxt{flex:1}
.lpv2 .faq-toggle{width:28px;height:28px;flex:0 0 auto;border-radius:50%;background:var(--surface-alt);display:flex;align-items:center;justify-content:center;position:relative;transition:background .2s}
.lpv2 .faq-item.open .faq-toggle{background:var(--grad-cv)}
.lpv2 .faq-toggle::before,.lpv2 .faq-toggle::after{content:'';position:absolute;top:50%;left:50%;background:var(--text-sub);border-radius:2px;transition:transform .25s,background .2s,opacity .2s}
.lpv2 .faq-toggle::before{width:13px;height:2.4px;transform:translate(-50%,-50%)}
.lpv2 .faq-toggle::after{width:2.4px;height:13px;transform:translate(-50%,-50%)}
.lpv2 .faq-item.open .faq-toggle::before,.lpv2 .faq-item.open .faq-toggle::after{background:#fff}
.lpv2 .faq-item.open .faq-toggle::after{transform:translate(-50%,-50%) rotate(90deg);opacity:0}
.lpv2 .faq-a{overflow:hidden;max-height:0;transition:max-height .3s ease}
.lpv2 .faq-a-inner{padding:0 48px 26px 4px;font-size:15px;color:var(--text-sub);line-height:1.7}

/* ============================ FINAL CTA ============================ */
.lpv2 .final{position:relative;overflow:hidden;background:var(--grad);color:#fff;text-align:center;padding:100px 0}
.lpv2 .final::before{content:'';position:absolute;top:-200px;right:-150px;width:560px;height:560px;background:radial-gradient(circle,#ffffff22 0%,transparent 70%)}
.lpv2 .final::after{content:'';position:absolute;bottom:-260px;left:-120px;width:620px;height:620px;background:radial-gradient(circle,#ffffff1a 0%,transparent 70%)}
.lpv2 .final-inner{position:relative;z-index:2}
.lpv2 .final h2{font-family:var(--font-display);font-size:clamp(28px,4.4vw,48px);font-weight:800;letter-spacing:-.025em;line-height:1.18;white-space:pre-line}
.lpv2 .final-micro{margin-top:18px;font-size:14.5px;opacity:.9;font-weight:600}
.lpv2 .final .btn-white{margin-top:34px}

/* ============================ FOOTER ============================ */
.lpv2 .ftr{background:#0e1320;color:#aeb6c5;padding:64px 0 40px;margin-top:0}
.lpv2 .ftr-top{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;padding-bottom:36px;border-bottom:1px solid #ffffff14}
.lpv2 .ftr-brand{max-width:340px}
.lpv2 .ftr-logo{margin-bottom:16px}
.lpv2 .ftr-tagline{font-size:14px;line-height:1.6;color:#8a93a6}
.lpv2 .ftr-cols{display:flex;gap:64px;flex-wrap:wrap}
.lpv2 .ftr-col h4{font-size:12px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;color:#6b7488;margin-bottom:14px}
.lpv2 .ftr-col a,.lpv2 .ftr-col span{display:block;font-size:14px;color:#aeb6c5;margin-bottom:10px;transition:color .15s;text-decoration:none}
.lpv2 .ftr-col a:hover{color:#fff}
.lpv2 .ftr-langs{display:flex;gap:8px;flex-wrap:wrap}
.lpv2 .ftr-lang{font-size:13px;font-weight:600;color:#aeb6c5;border:1px solid #ffffff1f;border-radius:var(--r-pill);padding:5px 13px;transition:all .15s;white-space:nowrap;background:none;cursor:pointer}
.lpv2 .ftr-lang:hover{color:#fff;border-color:#ffffff44}
.lpv2 .ftr-lang.active{color:#fff;background:var(--grad-cv);border-color:transparent}
.lpv2 .ftr-bottom{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;padding-top:28px;font-size:13px;color:#6b7488}
.lpv2 .ftr-brandmark{font-family:var(--font-brand);font-style:italic;font-weight:700;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

/* ============================ KEYFRAMES ============================ */
@keyframes lp-pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.55;transform:scale(1.2)}}
@keyframes lp-wizup{from{transform:translateY(9px)}to{transform:translateY(0)}}
@keyframes lp-popring{from{transform:scale(.6)}to{transform:scale(1)}}
@keyframes lp-rip{from{transform:scale(.4);opacity:.8}to{transform:scale(3.4);opacity:0}}
@keyframes lp-tdot{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}
@keyframes lp-blink{50%{opacity:0}}

/* ============================ RESPONSIVE ============================ */
@media (max-width:980px){
  .lpv2 .hero-grid{grid-template-columns:1fr;text-align:center}
  .lpv2 .hero-trust{justify-content:center}
  .lpv2 .hero-cta-row{justify-content:center}
  .lpv2 .hero-badge{margin-left:auto;margin-right:auto}
  .lpv2 .hero-phone-col{margin-top:18px}
  .lpv2 .how-grid{grid-template-columns:1fr 1fr}
  .lpv2 .price-grid{grid-template-columns:1fr}
  .lpv2 .people-grid{grid-template-columns:1fr}
}
@media (max-width:720px){
  .lpv2 .section{padding:64px 0}
  .lpv2 .hero{padding:44px 0 60px}
  .lpv2 .how-grid{grid-template-columns:1fr;gap:16px}
  .lpv2 .how-card p{min-height:0}
  .lpv2 .how-shot{height:200px}
  .lpv2 .price-main{padding:28px 22px}
  .lpv2 .price-inc-grid{grid-template-columns:1fr}
  .lpv2 .price-side{padding:24px 22px}
  .lpv2 .ftr-top{flex-direction:column;gap:32px}
  .lpv2 .ftr-cols{gap:40px}
  .lpv2 .phone{width:270px;height:556px}
  .lpv2 .db-screen{min-height:430px;padding:22px 18px 26px}
  .lpv2 .dw-options{grid-template-columns:1fr;max-width:none}
  .lpv2 .dw-option.has-sub{grid-column:auto}
  .lpv2 .dw-title{font-size:19px}
  .lpv2 .db-url{max-width:200px;font-size:12px}
}
@media (max-width:420px){
  .lpv2 .wrap{padding:0 18px}
  .lpv2 .hero h1{font-size:34px}
  .lpv2 .price-amount{font-size:44px}
}
