/* ============================================================
   견적서 메이커 — styles.css
   디자인 시스템 "Quoot Clear Line"
   white + cool gray · thin line · floating cards · A4 인쇄 보존
   ============================================================ */

/* ===================== Tokens (Light) ===================== */
:root {
  color-scheme: light;

  /* 표면 — 깔끔한 뉴트럴 (그린에 맞는 클린 오프화이트) */
  --bg:        #F6F8F6;
  --surface:   #EDF1ED;
  --content1:  #FFFFFF;
  --content2:  #F3F6F3;
  --content3:  #E9EEE9;
  --content4:  #DDE5DD;
  --elevated:  #FFFFFF;
  --card:      var(--content1);
  --card-2:    var(--content2);

  /* 텍스트 — 클린 다크 */
  --fg:        #14191A;
  --fg-soft:   #2B3134;
  --muted:     #5E6A63;
  --muted-2:   #93A099;
  --on-accent: #FFFFFF;
  --ink:       var(--fg);

  /* 라인 */
  --border:        #E3E9E3;
  --border-strong: #D1DAD1;
  --divider:       rgba(20,30,24,.08);
  --input-bg:      #FFFFFF;
  --input-bd:      #D4DCD4;
  --line:          var(--border);
  --line-strong:   var(--border-strong);

  /* 액센트 — Quoot 그린 */
  --brand:        #0F7A46;
  --brand-hover:  #0C6A3C;
  --brand-active: #0A5A33;
  --brand-rgb:    15,122,70;
  --brand-soft:   #E2F3E5;
  --brand-soft-fg:#0C5733;
  --ring:         rgba(15,122,70,.30);
  --ring-quiet:   rgba(15,122,70,.12);
  --accent:       #1AA85C;
  --accent-fg:    #FFFFFF;
  --accent-soft:  #DDF3E3;

  --grad-accent:     linear-gradient(135deg,#1AA85C 0%,#0F3E1C 100%);
  --grad-brand-fill: linear-gradient(180deg,#138A4F 0%,#0E5A30 100%);
  --grad-shine:      linear-gradient(110deg,transparent 40%,rgba(255,255,255,.20) 50%,transparent 60%);

  /* 상태 */
  --success:#15924F; --success-soft:#E2F3E5;
  --warning:#C77A12; --warning-soft:#FBF1E2;
  --danger:#C44A33;  --danger-hover:#AD3E2A; --danger-soft:#F7E6DF;

  /* 모노 (라벨/숫자) */
  --font-mono:"Fragment Mono","Roboto Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
  /* 브랜드 (로고 = Inter) */
  --font-brand:"Inter","Pretendard Variable","Pretendard",-apple-system,system-ui,"맑은 고딕",sans-serif;

  /* 반경 */
  --r-xs:6px; --r-sm:9px; --r-md:11px; --r-lg:14px; --r-xl:18px; --r-pill:9999px;

  /* 간격 (4px grid) */
  --sp-1:4px; --sp-2:8px; --sp-3:12px; --sp-4:16px;
  --sp-5:20px; --sp-6:24px; --sp-8:32px; --sp-10:40px; --sp-12:48px;

  /* 타이포 */
  --font:"Pretendard","Pretendard Variable",-apple-system,BlinkMacSystemFont,system-ui,"Segoe UI",Roboto,"Malgun Gothic","맑은 고딕",sans-serif;
  --fs-tiny:12px; --fs-cap:13px; --fs-body:14px; --fs-md:15px;
  --fs-lg:17px; --fs-h2:19px; --fs-h1:24px; --fs-display:30px;
  --lh-tight:1.2; --lh-body:1.55;
  --tracking-tight:0; --tracking-head:0; --tracking-snug:0;
  --w-reg:400; --w-med:500; --w-semi:600; --w-bold:700; --w-black:800;

  /* 섀도우 — 다층 소프트 확산 */
  --sh-xs:    0 1px 2px rgba(11,14,20,.05);
  --sh-sm:    0 1px 2px rgba(11,14,20,.05), 0 0 8px rgba(11,14,20,.025);
  --sh-md:    0 4px 12px -2px rgba(11,14,20,.07), 0 0 16px rgba(11,14,20,.03);
  --sh-lg:    0 12px 28px -6px rgba(11,14,20,.10), 0 0 30px rgba(11,14,20,.04);
  --sh-xl:    0 24px 48px -12px rgba(11,14,20,.16), 0 8px 16px -8px rgba(11,14,20,.08);
  --sh-brand: 0 10px 22px -10px rgba(15,122,70,.45);
  --sh-brand-ring: 0 0 0 2px rgba(15,122,70,.2);
  --sh-inset: inset 0 1px 0 rgba(255,255,255,.6);

  /* 글래스 */
  --glass-bg:   rgba(255,254,251,.80);
  --glass-line: rgba(22,20,15,.08);
  --glass-blur: 14px;
  --backdrop:   rgba(11,14,20,.42);

  /* 메시 배경 */
  --mesh: linear-gradient(transparent, transparent);

  /* 모션 */
  --ease:cubic-bezier(.4,0,.2,1);
  --ease-spring:cubic-bezier(.22,.61,.36,1);
  --dur-fast:.12s; --dur:.18s; --dur-slow:.26s;
}

/* ===================== Tokens (Dark) ===================== */
[data-theme="dark"] {
  color-scheme: dark;

  /* 표면 — 들어올린 차콜(검정 아님) + 초록 한 방울.
     bg→card 단계를 크게 벌려 카드가 '떠 보이게' = 입체감 */
  --bg:        #181C1B;   /* 캔버스 ~11% (이전 6%) */
  --surface:   #1E2321;   /* 살짝 들어간 섹션 */
  --content1:  #232A27;   /* 카드 — 캔버스보다 확실히 밝게 */
  --content2:  #2B322E;   /* 카드 hover / 보조면 */
  --content3:  #353D39;
  --content4:  #424B45;
  --elevated:  #272F2B;   /* 메뉴·팝오버 (카드 위) */
  --card:      var(--content1);
  --card-2:    var(--content2);

  --fg:        #EEF2EB;
  --fg-soft:   #D3D9CF;
  --muted:     #99A39A;
  --muted-2:   #717C73;
  --on-accent: #07170E;
  --ink:       var(--fg);

  --border:        #2F3733;   /* 들어올린 표면에서도 보이게 강화 */
  --border-strong: #3F4943;
  --divider:       rgba(255,255,255,.075);
  --input-bg:      #1B201E;
  --input-bd:      rgba(255,255,255,.13);
  --line:          var(--border);
  --line-strong:   var(--border-strong);

  --brand:        #3FC684;
  --brand-hover:  #57D196;
  --brand-active: #34B576;
  --brand-rgb:    63,198,132;
  --brand-soft:   rgba(63,198,132,.15);
  --brand-soft-fg:#A6EDC6;
  --ring:         rgba(63,198,132,.42);
  --ring-quiet:   rgba(63,198,132,.16);
  --accent:       #3FC684;
  --accent-fg:    #07170E;
  --accent-soft:  rgba(63,198,132,.15);

  --grad-accent:     linear-gradient(135deg,#6FE0A2 0%,#2A9A63 100%);
  --grad-brand-fill: linear-gradient(180deg,#46CE85 0%,#23A468 100%);
  --grad-shine:      linear-gradient(110deg,transparent 40%,rgba(255,255,255,.06) 50%,transparent 60%);

  --success:#3FC684; --success-soft:rgba(63,198,132,.15);
  --warning:#E6AC44; --warning-soft:rgba(230,172,68,.14);
  --danger:#F08A6E;  --danger-hover:#F59A80; --danger-soft:rgba(240,138,110,.16);

  --sh-xs:    0 0 0 1px rgba(0,0,0,.30);
  --sh-sm:    0 1px 2px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.045);
  --sh-md:    0 8px 22px -10px rgba(0,0,0,.55), inset 0 1px 0 rgba(255,255,255,.05);
  --sh-lg:    0 18px 42px -14px rgba(0,0,0,.62), inset 0 1px 0 rgba(255,255,255,.055);
  --sh-xl:    0 30px 60px -18px rgba(0,0,0,.68), inset 0 1px 0 rgba(255,255,255,.06);
  --sh-brand: 0 10px 24px -10px rgba(63,198,132,.40);
  --sh-brand-ring: 0 0 0 2px rgba(63,198,132,.24);
  --sh-inset: inset 0 1px 0 rgba(255,255,255,.05);

  --glass-bg:   rgba(22,26,25,.72);
  --glass-line: rgba(255,255,255,.08);
  --backdrop:   rgba(0,0,0,.55);

  --mesh: linear-gradient(transparent, transparent);
}

/* 다크: 캔버스 상단에 브랜드 글로우 한 줌 — 납작함 방지(은은하게) */
[data-theme="dark"] body {
  background:
    radial-gradient(125% 80% at 50% -12%, rgba(63,198,132,.06), transparent 56%),
    var(--bg);
  background-attachment: fixed, scroll;
}

/* ===================== Base ===================== */
* { box-sizing: border-box; }
[hidden] { display: none !important; }
html, body { margin: 0; padding: 0; }
body {
  position: relative;
  font-family: var(--font);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  color: var(--fg-soft);
  background: var(--bg);
  letter-spacing: var(--tracking-snug);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  font-feature-settings: "tnum";
}
body::before { content: none; }

:focus { outline: none; }
:focus-visible { outline: 2px solid var(--brand); outline-offset: 2px; border-radius: var(--r-xs); }
button { font-family: inherit; }

/* ===================== App Header ===================== */
.app-header {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; gap: var(--sp-3);
  min-height: 58px; padding: 8px var(--sp-6);
  background: var(--glass-bg);
  -webkit-backdrop-filter: saturate(180%) blur(var(--glass-blur));
  backdrop-filter: saturate(180%) blur(var(--glass-blur));
  border-bottom: 1px solid var(--glass-line);
  flex-wrap: wrap;
}
.app-header::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -1px; height: 1px;
  background: var(--fg); opacity: .10; pointer-events: none;
  -webkit-mask: linear-gradient(90deg,transparent,#000 16%,#000 84%,transparent);
          mask: linear-gradient(90deg,transparent,#000 16%,#000 84%,transparent);
}
.app-header .logo {
  appearance: none; border: 0; padding: 0; cursor: pointer; font-family: inherit;
  display: inline-flex; align-items: center; gap: 8px;
  background: transparent; color: var(--fg); white-space: nowrap;
}
.app-header .logo:hover { opacity: .82; }
.app-header .logo img { display: block; width: 112px; height: auto; }
.app-header .logo small {
  font-weight: var(--w-semi); font-size: 11px; margin-left: 5px;
  color: var(--muted-2);
}
[data-theme="dark"] .app-header .logo img { filter: invert(1) hue-rotate(180deg) saturate(.8); }
.tabs { display: flex; gap: 4px; margin-left: var(--sp-2); flex-wrap: wrap; }
.tab {
  appearance: none; border: 0; cursor: pointer;
  padding: 7px 13px; border-radius: var(--r-sm);
  font-size: var(--fs-body); font-weight: var(--w-med);
  color: var(--muted); background: transparent;
  transition: color var(--dur-fast) var(--ease), background var(--dur-fast) var(--ease);
}
.tab:hover { color: var(--fg); background: var(--surface); }
.tab.active { color: var(--fg); background: var(--content2); font-weight: var(--w-semi); box-shadow: var(--sh-inset); }
.header-spacer { flex: 1; min-width: 12px; }

/* 회사(워크스페이스) 전환 바 */
.company-bar { display: flex; align-items: center; gap: 6px; }
.company-select {
  width: auto; min-width: 120px; max-width: 200px; height: 34px;
  padding: 0 28px 0 12px; font-size: var(--fs-cap); font-weight: var(--w-med);
  border-radius: var(--r-sm); cursor: pointer;
}
#btnAddCompany { white-space: nowrap; }

/* ===================== Home ===================== */
.home-hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(280px, .62fr);
  gap: 34px;
  align-items: stretch;
  min-height: 250px;
  padding: 32px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background:
    radial-gradient(120% 150% at 90% -12%, rgba(var(--brand-rgb), .10), transparent 58%),
    linear-gradient(180deg, var(--content1) 0%, var(--surface) 100%);
  box-shadow: var(--sh-md);
  overflow: hidden;
}
.home-hero::after {
  content: "";
  position: absolute;
  left: 44%;
  top: -46px;
  width: 440px;
  height: 190px;
  border: 1px solid var(--divider);
  border-bottom: 0;
  border-radius: 50% 50% 0 0;
  transform: rotate(-8deg);
  pointer-events: none;
}
.home-copy { display: flex; flex-direction: column; justify-content: center; min-width: 0; }
.home-hero .home-hi {
  width: fit-content;
  padding: 5px 12px;
  border: 1px solid var(--border);
  border-radius: var(--r-pill);
  font-size: 12px;
  font-weight: var(--w-semi);
  color: var(--brand-soft-fg);
  background: var(--content1);
  box-shadow: var(--sh-xs);
}
.home-hero .home-hi i {
  display: inline-block;
  width: 7px;
  height: 7px;
  margin-right: 6px;
  border-radius: 999px;
  background: var(--success);
  box-shadow: 0 0 0 4px var(--success-soft);
}
.home-hero .home-title {
  display: flex;
  flex-direction: column;
  gap: 6px;
  max-width: 640px;
  font-size: clamp(30px, 3.5vw, 42px);
  font-weight: 680;
  letter-spacing: 0;
  line-height: 1.16;
  word-break: keep-all;
  color: var(--fg);
  margin: 16px 0 12px;
}
.home-hero .home-title .grad {
  position: relative;
  width: fit-content;
  color: var(--brand);
  background: var(--grad-accent);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}
.home-hero .home-title .grad::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -4px;
  height: 3px;
  border-radius: 999px;
  background: var(--grad-accent);
  opacity: .55;
}
.home-hero .home-sub { font-size: 14px; color: var(--muted); }
.home-actions { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 24px; }
.home-command {
  position: relative; overflow: hidden;
  align-self: stretch;
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 22px;
  border: 1px solid transparent;
  border-radius: var(--r-lg);
  color: #fff;
  background: linear-gradient(155deg, #15945A 0%, #0F5E33 55%, #0F3E1C 100%);
  box-shadow: var(--sh-lg);
}
.home-command::before {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(80% 60% at 92% -4%, rgba(255,255,255,.20), transparent 70%);
}
.command-top {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(255,255,255,.20);
}
.command-top span, .command-line span { color: rgba(255,255,255,.72); font-size: var(--fs-cap); }
.command-top b { color: #fff; font-size: 30px; line-height: 1; font-weight: 700; }
.home-command .command-line b { color: #fff; }
.home-command .command-line { position: relative; border-color: rgba(255,255,255,.14); }
.command-line {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  min-height: 40px;
}
.command-line b {
  max-width: 58%;
  color: #fff;
  font-size: var(--fs-md);
  font-weight: 680;
  text-align: right;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.home-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin: 0;
}
.home-email-card {
  position: relative; display: flex; flex-direction: row; align-items: center; gap: 14px; text-align: left; cursor: pointer; width: 100%;
  background: var(--content1); border: 1px solid var(--border); border-radius: var(--r-lg);
  padding: 16px 20px; margin-top: 12px; box-shadow: var(--sh-sm);
  transition: transform var(--dur) var(--ease-spring), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.home-email-card:hover { transform: translateY(-2px); box-shadow: var(--sh-md); border-color: var(--brand); }
.home-email-card .hc-ic { font-size: 22px; color: var(--brand); font-weight: 400; margin: 0; }
.home-email-card b { font-size: 15px; color: var(--fg); }
.home-email-card small { color: var(--muted); font-size: 12px; }
/* DB 관리 = 정보 대시보드 */
.db-stats { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; margin: 18px 0 16px; }
@media (max-width: 640px) { .db-stats { grid-template-columns: repeat(2, 1fr); } }
.db-stat { background: var(--content1); border: 1px solid var(--border); border-radius: var(--r-md); padding: 16px 18px; }
.db-stat b { display: block; font-size: 26px; font-weight: 700; color: var(--fg); font-variant-numeric: tabular-nums; line-height: 1.1; }
.db-stat span { font-size: 12px; color: var(--muted); }
.db-panels { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
@media (max-width: 760px) { .db-panels { grid-template-columns: 1fr; } }
.db-panel { padding: 16px 18px; }
.db-panel-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
.db-panel-head h3 { font-size: 14px; margin: 0; }
.db-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.db-table td { padding: 8px 6px; border-bottom: 1px solid var(--border); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 0; }
.db-table tr:last-child td { border-bottom: none; }
.db-table td:first-child { font-weight: 600; color: var(--fg); }
.db-table .db-c2, .db-table .db-c3 { color: var(--muted); }
.db-table td.num { text-align: right; font-variant-numeric: tabular-nums; }
.db-muted { color: var(--muted-2); }
.db-table .db-more td, .db-table .db-empty { color: var(--muted); font-size: 12px; text-align: center; padding: 10px 6px; white-space: normal; }
.acc-aiuse .inbox-usage { margin: 6px 2px 0; }

/* 프로액티브 "챙길 것" 패널 (홈 최상단) */
.proactive-panel { margin: 16px 0 4px; border-left: 3px solid var(--brand); }
.pa-head { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.pa-head h2 { margin: 0; font-size: 16px; }
.pa-count { font-size: 13px; background: var(--brand-soft); color: var(--brand); padding: 1px 9px; border-radius: 12px; vertical-align: middle; }
.pa-warn { font-size: 12.5px; color: var(--danger, #c0392b); font-weight: 600; }
.pa-empty { font-size: 13px; color: var(--muted); padding: 4px 2px; }
.pa-list { display: flex; flex-direction: column; gap: 8px; }
.pa-row { display: flex; align-items: center; gap: 12px; padding: 10px 12px; background: var(--content1); border: 1px solid var(--border); border-radius: 10px; }
.pa-row.over { border-color: var(--danger, #c0392b); background: rgba(192,57,43,.05); }
.pa-info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.pa-info b { font-size: 13.5px; }
.pa-info span { font-size: 12.5px; color: var(--muted); }
.pa-d { font-size: 12px; font-weight: 700; padding: 2px 9px; border-radius: 8px; background: var(--surface); color: var(--muted); white-space: nowrap; }
.pa-d.today { background: var(--brand-soft); color: var(--brand); }
.pa-d.over { background: rgba(192,57,43,.12); color: var(--danger, #c0392b); }
.pa-acts { display: flex; gap: 6px; }
.pa-row.pa-mail { border-color: var(--brand); background: var(--brand-soft); }

/* 일정 캘린더 */
.cal-panel { margin: 14px 0 4px; }
.cal-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 10px; }
.cal-head h2 { margin: 0; font-size: 16px; }
.cal-nav { display: flex; align-items: center; gap: 6px; }
.cal-nav b { font-size: 13.5px; min-width: 88px; text-align: center; font-variant-numeric: tabular-nums; }
.cal-legend { display: flex; flex-wrap: wrap; gap: 4px 14px; margin-bottom: 10px; font-size: 11px; color: var(--muted); }
.cal-legend span { display: inline-flex; align-items: center; gap: 4px; }
.cal-dot { display: inline-block; width: 6px; height: 6px; border-radius: 50%; }
.cal-dot.k-check { background: #2a86d6; }
.cal-dot.k-part { background: #e6a544; }
.cal-dot.k-warr { background: #c0392b; }
.cal-dot.k-quote { background: var(--brand); }
.cal-dot.k-mail { background: #8a7bd8; }
.cal-dot.k-etc { background: var(--muted); }
.cal-grid-head { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; margin-bottom: 4px; }
.cal-grid-head span { text-align: center; font-size: 11px; color: var(--muted); font-weight: 600; }
.cal-grid-head .sun { color: #c0392b; } .cal-grid-head .sat { color: #2a86d6; }
.cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; }
.cal-cell { min-height: 46px; border: 1px solid var(--border); border-radius: 8px; padding: 4px 5px; display: flex; flex-direction: column; gap: 3px; background: var(--content1); }
.cal-cell.empty { border: none; background: transparent; }
.cal-cell.has { cursor: pointer; }
.cal-cell.has:hover { border-color: var(--brand); }
.cal-cell.today { border-color: var(--brand); box-shadow: inset 0 0 0 1px var(--brand); }
.cal-cell.sel { background: var(--brand-soft); border-color: var(--brand); }
.cal-num { font-size: 12px; color: var(--text); font-variant-numeric: tabular-nums; }
.cal-num.sun { color: #c0392b; } .cal-num.sat { color: #2a86d6; }
.cal-dots { display: flex; gap: 3px; flex-wrap: wrap; }
.cal-day { margin-top: 14px; border-top: 1px solid var(--border); padding-top: 12px; }
.cal-day-h { font-size: 12px; font-weight: 700; color: var(--muted); margin-bottom: 8px; }
.cal-li { display: flex; align-items: center; gap: 8px; padding: 6px 2px; font-size: 13px; }
.cal-li b { font-weight: 600; }
.cal-li span { color: var(--muted); font-size: 12.5px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cal-li.empty { color: var(--muted); font-size: 12.5px; }
@media (max-width: 900px) {
  .home-hero { grid-template-columns: 1fr; padding: 28px; gap: 24px; }
  .home-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 540px) {
  .home-hero .home-title { font-size: 29px; }
  .home-grid { grid-template-columns: 1fr; }
}
.home-card {
  position: relative;
  display: flex; flex-direction: column; align-items: flex-start; gap: 4px; text-align: left; cursor: pointer;
  background: var(--content1); border: 1px solid var(--border); border-radius: var(--r-lg);
  min-height: 132px;
  padding: 20px 18px; box-shadow: var(--sh-sm);
  transition: transform var(--dur) var(--ease-spring), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.home-card:hover { transform: translateY(-2px); box-shadow: var(--sh-md); border-color: var(--border-strong); }
.home-card.primary-card {
  border: 1px solid transparent;
  background:
    linear-gradient(var(--content1),var(--content1)) padding-box,
    var(--grad-accent) border-box;
}
.home-card .hc-ic {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: auto;
  height: auto;
  margin-bottom: 12px;
  border-radius: var(--r-pill);
  background: transparent;
  color: var(--muted-2);
  font-size: 11px;
  font-weight: 800;
}
.home-card.primary-card .hc-ic { color: var(--brand); }
.home-card b { font-size: 15px; color: var(--fg); }
.home-card small { color: var(--muted); font-size: 12px; line-height: 1.5; word-break: keep-all; }
.home-dashboard { display: grid; grid-template-columns: minmax(0, 1fr) minmax(340px, .72fr); gap: 22px; }
#homeDash { display: contents; }   /* 래퍼는 레이아웃 투명 — .view의 flex 간격을 자식이 그대로 받게 */
.item-reg-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
tr.grp-head td { background: var(--surface); padding: 9px 10px; border-bottom: 1.5px solid var(--border-strong); }
tr.grp-head b { color: var(--brand-soft-fg); font-size: var(--fs-cap); font-weight: var(--w-bold); }
tr.grp-head .hint { margin-left: 6px; }
/* 견적 작성 품목 픽커 (그룹 칩 → 품목 칩) */
.picker-head { display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap; margin-bottom: 8px; }
.picker-label { font-weight: var(--w-semi); }
.picker-empty { padding: 12px 14px; background: var(--surface); border-radius: var(--r-md); }
.picker-groups { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 8px; }
.pg-chip { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; border: 1px solid var(--border); border-radius: var(--r-pill); background: var(--content1); color: var(--muted); cursor: pointer; font-size: 13px; }
.pg-chip:hover { border-color: var(--brand); color: var(--fg); }
.pg-chip.on { background: var(--brand); border-color: var(--brand); color: #fff; font-weight: var(--w-semi); }
.pg-chip i { font-style: normal; font-size: 11px; opacity: .7; }
.picker-items { display: flex; flex-wrap: wrap; gap: 8px; padding: 12px; background: var(--surface); border-radius: var(--r-md); min-height: 48px; }
.pi-chip { display: inline-flex; flex-direction: column; align-items: flex-start; gap: 2px; padding: 8px 12px; border: 1px solid var(--border); border-radius: var(--r-sm); background: var(--content1); cursor: pointer; text-align: left; transition: border-color .12s, transform .06s; }
.pi-chip:hover { border-color: var(--brand); }
.pi-chip:active { transform: scale(.97); }
.pi-chip span { font-weight: var(--w-semi); }
.pi-chip em { font-style: normal; font-size: 12px; color: var(--muted); }
/* 선택된 견적 줄 (품목 넣을 대상) */
#linesBody tr.is-target > td { background: var(--brand-soft); }
#linesBody tr.is-target .col-no { position: relative; }
#linesBody tr.is-target .col-no::before { content: "▸"; position: absolute; left: 2px; color: var(--brand); font-weight: 700; }
/* 그룹 관리 바 (품목 목록) */
.group-mgr { margin-bottom: 12px; padding: 12px 14px; background: var(--surface); border-radius: var(--r-md); }
.gm-head { display: flex; align-items: baseline; gap: 8px; margin-bottom: 8px; }
.gm-chips { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.gm-chip { display: inline-flex; align-items: center; gap: 6px; padding: 5px 6px 5px 12px; border: 1px solid var(--border); border-radius: var(--r-pill); background: var(--content1); }
.gm-chip > b { font-weight: var(--w-semi); }
.gm-chip > i { font-style: normal; font-size: 11px; color: var(--muted-2); }
.gm-ico { width: 22px; height: 22px; display: inline-flex; align-items: center; justify-content: center; border: none; border-radius: var(--r-pill); background: transparent; color: var(--muted); cursor: pointer; font-size: 12px; }
.gm-ico:hover { background: var(--surface); color: var(--fg); }
.gm-ico.gm-x:hover { background: #fde8e8; color: #c0392b; }
.gm-add { padding: 6px 12px; border: 1px dashed var(--border-strong); border-radius: var(--r-pill); background: transparent; color: var(--brand-soft-fg); cursor: pointer; font-size: 13px; }
.gm-add:hover { border-color: var(--brand); background: var(--brand-soft); }
.row-grp { max-width: 120px; margin-right: 6px; font-size: 12px; padding: 3px 6px; }
/* 세부 스펙 불릿 에디터 (품목 등록) */
.spec-editor { display: flex; flex-direction: column; gap: 6px; margin-bottom: 8px; }
.spec-row { display: flex; align-items: center; gap: 8px; }
.spec-dot { color: var(--brand); font-weight: 800; flex: none; }
.spec-input { flex: 1; }
.spec-del { flex: none; width: 30px; height: 30px; padding: 0; border: 1px solid var(--border); border-radius: var(--r-sm); background: transparent; color: var(--muted); cursor: pointer; line-height: 1; }
.spec-del:hover { border-color: var(--danger); color: var(--danger); background: var(--danger-soft); }
/* 견적 줄 스펙 불러오기 */
.ln-spec-load { margin-top: 5px; padding: 4px 11px; border: 1px solid var(--border); border-radius: var(--r-pill); background: var(--surface); color: var(--brand-soft-fg); font-size: 11px; font-weight: 600; cursor: pointer; }
.ln-spec-load:hover { border-color: var(--brand); color: var(--brand); background: var(--brand-soft); }
/* ===================== 계정 / 헤더 계정 칩 ===================== */
.account-chip {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 4px 12px 4px 4px;
  border: 1px solid var(--border); border-radius: var(--r-pill);
  background: var(--content1); color: var(--fg); cursor: pointer;
  font-size: 13px; font-weight: var(--w-semi);
  transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.account-chip:hover { border-color: var(--brand); box-shadow: var(--sh-brand-ring); }
.acc-ava {
  width: 26px; height: 26px; flex: none;
  display: grid; place-items: center;
  border-radius: var(--r-pill);
  background: var(--grad-brand-fill); color: var(--on-accent);
  font-size: 12px; font-weight: var(--w-bold);
}
.acc-chip-name { max-width: 120px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.acc-hero { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.acc-id { display: flex; align-items: center; gap: 14px; }
.acc-ava.lg { width: 52px; height: 52px; font-size: 20px; }
.acc-email { font-size: var(--fs-md); font-weight: var(--w-bold); color: var(--fg); }
.acc-meta { margin-top: 2px; }
.acc-grid { display: grid; grid-template-columns: minmax(0, .92fr) minmax(0, 1.08fr); gap: var(--sp-6); align-items: start; }
@media (max-width: 900px) { .acc-grid { grid-template-columns: 1fr; } }
.storage-bar { height: 10px; border-radius: var(--r-pill); background: var(--surface); border: 1px solid var(--border); overflow: hidden; margin: 4px 0 8px; }
.storage-bar > i { display: block; height: 100%; background: var(--grad-brand-fill); border-radius: var(--r-pill); transition: width .3s var(--ease); }
.storage-meta { display: flex; justify-content: space-between; align-items: baseline; font-size: var(--fs-cap); color: var(--muted); }
.storage-meta span:first-child { font-weight: var(--w-semi); color: var(--fg); }
.acc-stat-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-top: 16px; }
.acc-stat-row > div { text-align: center; padding: 12px 8px; background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md); }
.acc-stat-row b { display: block; font-size: 20px; font-weight: var(--w-bold); color: var(--fg); font-variant-numeric: tabular-nums; }
.acc-stat-row span { font-size: var(--fs-tiny); color: var(--muted); }
.acc-link-panel { display: flex; align-items: center; justify-content: space-between; gap: 14px; flex-wrap: wrap; }
.acc-link-copy { display: flex; flex-direction: column; gap: 2px; }
.acc-link-copy b { font-weight: var(--w-semi); }
.target-price {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) minmax(180px, 220px) minmax(120px, 150px) auto;
  gap: 10px 12px;
  align-items: end;
  margin-top: 12px;
  padding: 14px;
  background: var(--brand-soft);
  border: 1px solid color-mix(in srgb, var(--brand) 18%, transparent);
  border-radius: var(--r-md);
}
.target-price-head { align-self: center; }
.target-price-head b { display: block; font-size: var(--fs-body); font-weight: var(--w-semi); color: var(--fg); }
.target-price-head span { display: block; margin-top: 2px; font-size: var(--fs-cap); color: var(--brand-soft-fg); }
.target-price .field { margin: 0; }
.target-price .field.compact { max-width: 150px; }
.target-price .hint { grid-column: 2 / -1; color: var(--brand-soft-fg); }
.quote-actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--content2);
}
.quote-action-copy { min-width: 220px; }
.quote-action-copy b { display: block; font-size: var(--fs-body); font-weight: var(--w-semi); color: var(--fg); }
.quote-action-copy .hint { display: block; margin-top: 3px; }
.home-panel {
  height: 100%;
  border-radius: var(--r-lg);
  border-color: var(--border);
  background: var(--content1);
  box-shadow: var(--sh-sm);
}
.home-panel h2 { color: var(--fg); font-size: 22px; margin-bottom: 18px; }
.home-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
@media (max-width: 900px) { .home-dashboard { grid-template-columns: 1fr; } }
@media (max-width: 720px) { .home-stats { grid-template-columns: 1fr 1fr; } }
@media (max-width: 760px) {
  .target-price { grid-template-columns: 1fr; }
  .target-price .field.compact { max-width: none; }
  .target-price .hint { grid-column: 1; }
  .quote-actions { align-items: flex-start; flex-direction: column; }
}
.home-stats > div {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 18px 14px;
  text-align: center;
}
.home-stats b { display: block; font-size: 28px; font-weight: 760; color: var(--fg); font-variant-numeric: tabular-nums; }
.home-stats span { font-size: var(--fs-cap); color: var(--muted); }
.flow-list { display: grid; gap: 0; }
.flow-list > div {
  display: grid;
  grid-template-columns: 34px 1fr;
  column-gap: 14px;
  row-gap: 2px;
  align-items: center;
  padding: 17px 0;
  border-bottom: 1px solid var(--divider);
}
.flow-list > div:last-child { border-bottom: 0; }
.flow-list span {
  grid-row: 1 / span 2;
  width: 30px;
  height: 30px;
  display: grid;
  place-items: center;
  border-radius: var(--r-sm);
  color: var(--brand-soft-fg);
  background: var(--brand-soft);
  font-weight: 800;
  font-size: 12px;
}
.flow-list b { color: var(--fg); }
.flow-list small { color: var(--muted); font-size: var(--fs-tiny); }

/* ===================== Company cards (회사 설정) ===================== */
.company-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: var(--sp-3); }
.co-card {
  display: flex; flex-direction: column; gap: 6px; text-align: left; cursor: pointer;
  background: var(--content1); border: 1px solid var(--border); border-radius: var(--r-md);
  padding: var(--sp-4); box-shadow: var(--sh-xs);
  transition: transform var(--dur) var(--ease-spring), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.co-card:hover { transform: translateY(-2px); box-shadow: var(--sh-md); border-color: var(--border-strong); }
.co-card.active { border-color: var(--brand); box-shadow: var(--sh-brand-ring), var(--sh-sm); }
.co-card-top { display: flex; align-items: center; justify-content: space-between; min-height: 40px; }
.co-card-top img { max-height: 38px; max-width: 110px; object-fit: contain; }
.co-card .co-ini { width: 40px; height: 40px; border-radius: var(--r-sm); display: grid; place-items: center; font-size: 18px; font-weight: 800; color: var(--brand); background: var(--brand-soft); }
.co-card .co-badge { font-size: 10px; font-weight: 700; color: var(--brand-soft-fg); background: var(--brand-soft); padding: 2px 7px; border-radius: var(--r-pill); }
.co-card .co-name { font-size: var(--fs-md); font-weight: 700; color: var(--fg); }
.co-card .co-sub { font-size: var(--fs-tiny); color: var(--muted); }
.co-card.co-add { align-items: center; justify-content: center; flex-direction: row; gap: 6px; border-style: dashed; color: var(--muted); font-weight: 600; min-height: 100px; }
.co-card.co-add:hover { color: var(--brand); border-color: var(--brand); }
.co-card.co-add .co-plus { font-size: 18px; }

/* 다크모드 토글 */
.theme-toggle {
  appearance: none; cursor: pointer;
  display: inline-grid; place-items: center;
  width: 34px; height: 34px; border-radius: var(--r-sm);
  color: var(--muted); background: transparent; border: 1px solid var(--border);
  transition: color var(--dur-fast) var(--ease), background var(--dur-fast) var(--ease), border-color var(--dur-fast) var(--ease);
}
.theme-toggle:hover { color: var(--fg); background: var(--surface); border-color: var(--border-strong); }
.theme-toggle .sun { display: none; }
.theme-toggle .moon { display: block; }
[data-theme="dark"] .theme-toggle .sun { display: block; }
[data-theme="dark"] .theme-toggle .moon { display: none; }

/* ===================== Layout ===================== */
.main { max-width: 1100px; margin: 0 auto; padding: var(--sp-8) var(--sp-6) var(--sp-12); }
.view { display: none; }
.view.active { display: flex; flex-direction: column; gap: var(--sp-6); }
.back-btn { align-self: flex-start; color: var(--muted); margin-bottom: calc(var(--sp-6) * -1 + var(--sp-2)); }
.back-btn:hover { color: var(--brand); }

.panel {
  position: relative;
  background: var(--content1);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: var(--sp-6) var(--sp-6) var(--sp-5);
  box-shadow: none;
  animation: revealUp .4s var(--ease-spring) backwards;
  transition: transform var(--dur-slow) var(--ease-spring),
              box-shadow var(--dur-slow) var(--ease-spring),
              border-color var(--dur) var(--ease);
}
.panel:hover { transform: none; box-shadow: none; border-color: var(--border-strong); }
.view.active > .panel:nth-child(1) { animation-delay: .02s; }
.view.active > .panel:nth-child(2) { animation-delay: .07s; }
.view.active > .panel:nth-child(3) { animation-delay: .12s; }
.view.active > .panel:nth-child(4) { animation-delay: .17s; }
.view.active > .panel:nth-child(5) { animation-delay: .22s; }
.view.active > .panel:nth-child(6) { animation-delay: .26s; }
.panel > h2 {
  margin: 0 0 3px; font-size: var(--fs-h2); font-weight: var(--w-semi);
  letter-spacing: var(--tracking-head); color: var(--fg);
}
.panel > h2 .chip { vertical-align: middle; margin-left: 6px; }
.panel > .sub { margin: 0 0 var(--sp-5); font-size: var(--fs-cap); color: var(--muted); }
.panel h3 { font-size: var(--fs-md); font-weight: var(--w-semi); color: var(--fg); margin: 0 0 4px; }

.row { display: flex; gap: var(--sp-3); flex-wrap: wrap; }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-3); }
.grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: var(--sp-3); }
@media (max-width: 720px) { .grid-2, .grid-3 { grid-template-columns: 1fr; } }
.divider { height: 1px; background: var(--border); margin: var(--sp-4) 0; }

/* ===================== Form ===================== */
label.field { display: flex; flex-direction: column; gap: 6px; margin-bottom: var(--sp-3); }
label.field > span { font-size: var(--fs-cap); font-weight: var(--w-med); color: var(--muted); letter-spacing: var(--tracking-snug); }

.question-flow {
  display: grid;
  grid-template-columns: repeat(5, minmax(130px, 1fr));
  gap: var(--sp-3);
  margin: 2px 0 var(--sp-3);
  padding: var(--sp-3);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: color-mix(in srgb, var(--content1) 74%, var(--surface));
}
.question-field { margin-bottom: 0; }
.field-summary {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  min-height: 34px;
  margin: 0 0 var(--sp-3);
  color: var(--muted);
  font-size: var(--fs-cap);
}
.summary-label { font-weight: var(--w-semi); color: var(--fg); margin-right: 2px; }
.summary-note { margin-left: 4px; }
.field-pill {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 2px 8px;
  border: 1px solid var(--border);
  border-radius: 999px;
  color: var(--fg);
  background: var(--content1);
}
@media (max-width: 1080px) { .question-flow { grid-template-columns: repeat(3, minmax(140px, 1fr)); } }
@media (max-width: 720px) { .question-flow { grid-template-columns: 1fr; } }

.column-editor {
  margin: 2px 0 var(--sp-4);
  padding: var(--sp-3);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--content1);
}
.quote-wizard {
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--content1);
  padding: var(--sp-4);
}
.wizard-progress {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(18px, 1fr));
  gap: 6px;
  margin-bottom: var(--sp-4);
}
.wizard-progress span {
  height: 4px;
  border-radius: 999px;
  background: var(--border);
}
.wizard-progress span.active,
.wizard-progress span.done { background: var(--brand); }
.wizard-step { min-height: 210px; display: flex; flex-direction: column; gap: var(--sp-3); }
.wizard-kicker { font-size: var(--fs-tiny); color: var(--muted); font-weight: var(--w-semi); }
.wizard-step h3 { margin: 0; font-size: 22px; }
.wizard-step p { margin: 0; color: var(--muted); }
.wizard-options {
  display: grid;
  grid-template-columns: repeat(3, minmax(150px, 1fr));
  gap: var(--sp-3);
}
.wizard-option {
  min-height: 72px;
  padding: var(--sp-3);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--surface);
  color: var(--fg);
  font: inherit;
  font-weight: var(--w-semi);
  text-align: left;
  cursor: pointer;
}
.wizard-option-title { display: block; font-weight: var(--w-semi); }
.wizard-option small { display: block; margin-top: 4px; color: var(--muted); font-size: var(--fs-tiny); line-height: 1.4; }
.wizard-option.selected {
  border-color: var(--brand);
  box-shadow: var(--sh-brand-ring);
  background: var(--brand-soft);
}
.wizard-designs { grid-template-columns: repeat(4, minmax(150px, 1fr)); }
.wizard-design-option { min-height: 150px; display: flex; flex-direction: column; gap: 9px; }
.design-thumb {
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  grid-template-rows: 18px 28px 20px;
  gap: 6px;
  width: 100%;
  aspect-ratio: 1.7 / 1;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  background: #fff;
}
.design-thumb i,
.design-thumb b,
.design-thumb em,
.design-thumb strong { display: block; min-width: 0; border-radius: 3px; background: #d8dee8; }
.design-thumb i { grid-column: 1 / 2; background: #223b54; }
.design-thumb b { grid-column: 2 / 3; justify-self: end; width: 70%; background: #edf0f5; }
.design-thumb em { grid-column: 1 / 3; background: #f5f6f8; border: 1px solid #d9dee7; }
.design-thumb strong { grid-column: 1 / 3; background: #223b54; height: 4px; align-self: end; }
.design-thumb.design-compact { grid-template-rows: 12px 18px 18px; gap: 4px; }
.design-thumb.design-formal i,
.design-thumb.design-formal strong { background: #222; }
.design-thumb.design-studio i { width: 78%; height: 26px; background: #143c64; }
.design-thumb.design-studio strong { background: #c9a45a; }
.wizard-review-meta { display: flex; flex-wrap: wrap; gap: 8px; }
.wizard-review-meta span {
  padding: 7px 10px;
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  background: var(--surface);
  color: var(--muted);
  font-size: var(--fs-cap);
}
.wizard-review-meta b { color: var(--fg); }
.wizard-table-preview {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.wizard-table-preview span {
  padding: 7px 10px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--surface);
  font-size: var(--fs-cap);
  font-weight: var(--w-semi);
}
@media (max-width: 720px) { .wizard-options { grid-template-columns: 1fr; } }
.item-set-toolbar {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto auto;
  gap: var(--sp-2);
  align-items: end;
  margin-bottom: var(--sp-4);
}
.item-set-toolbar .field { margin: 0; }
.item-set-picker {
  margin: 0 0 var(--sp-3);
  padding: var(--sp-3);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--content1);
}
.item-picker-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--sp-3);
  margin-bottom: var(--sp-2);
}
.item-picker-list { display: flex; flex-wrap: wrap; gap: 7px; align-items: center; }
.item-pick {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-height: 32px;
  padding: 6px 10px;
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  background: var(--surface);
  color: var(--fg);
  font: inherit;
  font-size: var(--fs-cap);
  cursor: pointer;
}
.item-pick:hover { border-color: var(--brand); background: var(--brand-soft); }
.item-pick em { font-style: normal; color: var(--muted); font-size: var(--fs-tiny); }
@media (max-width: 720px) {
  .wizard-designs,
  .item-set-toolbar { grid-template-columns: 1fr; }
}
.column-editor-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  margin-bottom: var(--sp-2);
}
.quote-col-row {
  display: grid;
  grid-template-columns: minmax(120px, 240px) auto;
  gap: var(--sp-2);
  align-items: center;
  margin-bottom: var(--sp-2);
}
.ln-spec {
  margin-top: 6px;
  min-height: 44px;
  height: auto;
  padding: 7px 9px;
  font-size: var(--fs-cap);
  color: var(--muted);
  background: var(--surface);
}
.qd-spec {
  margin: 5px 0 0 14px;
  padding: 0;
  font-size: 11px;
  line-height: 1.45;
  color: var(--muted);
  font-weight: 400;
}
.qd-spec li { margin: 1px 0; }

input, select, textarea {
  width: 100%; height: 38px; padding: 0 var(--sp-3);
  font-family: inherit; font-size: var(--fs-body); color: var(--fg);
  background: var(--input-bg);
  border: 1px solid var(--input-bd); border-radius: var(--r-sm);
  box-shadow: var(--sh-xs);
  transition: border-color var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease), background var(--dur-fast) var(--ease);
}
textarea { height: auto; min-height: 96px; padding: var(--sp-3); line-height: var(--lh-body); resize: vertical; }
input::placeholder, textarea::placeholder { color: var(--muted-2); }
input:hover, select:hover, textarea:hover { border-color: var(--border-strong); }
input:focus, select:focus, textarea:focus { outline: none; border-color: var(--brand); box-shadow: var(--sh-brand-ring); }
input[type="number"] { text-align: right; }
input[type="checkbox"], input[type="radio"] { width: auto; height: auto; box-shadow: none; accent-color: var(--brand); }
input[type="file"] { height: auto; padding: 7px 10px; }

/* ===================== Buttons ===================== */
.btn {
  appearance: none; cursor: pointer; user-select: none;
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  height: 38px; padding: 0 var(--sp-4);
  border-radius: var(--r-md);
  font-family: inherit; font-size: var(--fs-body); font-weight: var(--w-med);
  letter-spacing: var(--tracking-snug);
  color: var(--fg); background: var(--content1);
  border: 1px solid var(--border); box-shadow: var(--sh-xs);
  transition: transform var(--dur-fast) var(--ease), background var(--dur-fast) var(--ease),
              border-color var(--dur-fast) var(--ease), box-shadow var(--dur) var(--ease), filter var(--dur-fast) var(--ease);
}
.btn:hover { background: var(--surface); border-color: var(--border-strong); box-shadow: var(--sh-sm); }
.btn:active { transform: scale(.97); }
.btn.sm { height: 30px; padding: 0 var(--sp-3); font-size: var(--fs-cap); border-radius: var(--r-sm); }

.btn.primary {
  position: relative; overflow: hidden;
  color: var(--on-accent); background: var(--grad-brand-fill);
  border-color: transparent; box-shadow: none;
}
.btn.primary::after {
  display: none;
}
.btn.primary:hover { filter: brightness(1.03); transform: translateY(-1px); box-shadow: var(--sh-sm); }
.btn.primary:active { transform: translateY(0) scale(.98); filter: brightness(.98); }

.btn.ghost { background: transparent; border-color: var(--border); box-shadow: none; color: var(--fg); }
.btn.ghost:hover { background: var(--surface); border-color: var(--border-strong); }

.btn.danger { color: #fff; background: var(--danger); border-color: transparent; box-shadow: 0 6px 18px -6px rgba(229,72,77,.5); }
.btn.danger:hover { background: var(--danger-hover); transform: translateY(-1px); }
.btn.ghost.danger { background: transparent; color: var(--danger); box-shadow: none; }
.btn.ghost.danger:hover { background: var(--danger-soft); }

.btn:disabled { opacity: .5; cursor: not-allowed; transform: none; filter: none; box-shadow: none; }
.btn:disabled::after { display: none; }
.btn-row { display: flex; gap: var(--sp-2); flex-wrap: wrap; align-items: center; }

/* ===================== Mode tabs (3-카드 선택형) ===================== */
.mode-tabs { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-3); margin-bottom: var(--sp-4); }
@media (max-width: 640px) { .mode-tabs { grid-template-columns: 1fr; } }
.mode-tab {
  position: relative; cursor: pointer; text-align: left;
  display: flex; flex-direction: column; gap: 5px;
  padding: var(--sp-4); border-radius: 6px;
  background: var(--content1); border: 1px solid var(--border); box-shadow: none;
  transition: transform var(--dur) var(--ease-spring), box-shadow var(--dur) var(--ease),
              border-color var(--dur) var(--ease), background var(--dur) var(--ease);
}
.mode-tab:hover { transform: translateY(-1px); box-shadow: none; border-color: var(--border-strong); }
.mode-tab:active { transform: scale(.98); }
.mode-tab .ico {
  width: fit-content; height: 20px; border-radius: 999px;
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: 2px; padding: 0 8px; font-size: 10px; font-weight: var(--w-bold);
  background: var(--content2); color: var(--muted-2);
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.mode-tab .t { font-size: var(--fs-md); font-weight: var(--w-semi); color: var(--fg); letter-spacing: var(--tracking-snug); }
.mode-tab .d { font-size: var(--fs-tiny); color: var(--muted); }
.mode-tab.active { background: var(--content1); border-color: var(--brand); box-shadow: var(--sh-brand-ring); }
.mode-tab.active .ico { background: var(--fg); color: var(--bg); }
.mode-tab.active::before {
  content: ""; position: absolute; left: var(--sp-4); right: var(--sp-4); top: 0; height: 2px;
  border-radius: 0 0 2px 2px; background: var(--fg); opacity: .72; pointer-events: none;
}
.mode-panel { display: none; }
.mode-panel.active { display: block; animation: revealUp .25s var(--ease) backwards; }
.manual-hint {
  display: flex; align-items: center; gap: var(--sp-3); flex-wrap: wrap;
  background: var(--content2); border: 1px solid var(--border); border-radius: var(--r-md);
  padding: var(--sp-4) var(--sp-5);
}
.manual-hint b { color: var(--brand-soft-fg); }

/* ===================== Tables ===================== */
table.list { width: 100%; border-collapse: collapse; font-size: var(--fs-body); }
table.list thead th {
  text-align: left; padding: 10px var(--sp-3);
  font-size: var(--fs-tiny); font-weight: var(--w-semi);
  text-transform: uppercase; letter-spacing: .04em;
  color: var(--muted); background: var(--content2);
  border-bottom: 1px solid var(--border);
}
table.list thead th:first-child { border-top-left-radius: var(--r-sm); }
table.list thead th:last-child { border-top-right-radius: var(--r-sm); }
table.list tbody td { padding: 11px var(--sp-3); border-bottom: 1px solid var(--divider); color: var(--fg-soft); vertical-align: middle; }
table.list tbody tr { transition: background var(--dur-fast) var(--ease); }
table.list tbody tr:hover td { background: var(--content2); }
table.list td.num, table.list th.num { text-align: right; font-variant-numeric: tabular-nums; }
table.list td.act { text-align: right; white-space: nowrap; }
.empty { text-align: center; color: var(--muted-2); padding: 28px 10px; font-size: var(--fs-cap); }

/* 견적 라인 입력 테이블 */
table.lines { width: 100%; border-collapse: collapse; }
table.lines thead th {
  text-align: left; padding: 8px var(--sp-2);
  font-size: var(--fs-tiny); font-weight: var(--w-semi);
  color: var(--muted); background: var(--content2);
  border-bottom: 1px solid var(--border); border-top: 1px solid var(--border);
}
table.lines tbody td { padding: 5px var(--sp-1); border-bottom: 1px solid var(--divider); }
table.lines input, table.lines select { height: 34px; box-shadow: none; border-radius: var(--r-xs); border-color: transparent; background: transparent; }
table.lines input:hover, table.lines select:hover { border-color: var(--input-bd); background: var(--input-bg); }
table.lines input:focus, table.lines select:focus { border-color: var(--brand); background: var(--input-bg); }
table.lines td.amt { text-align: right; padding-right: var(--sp-2); font-variant-numeric: tabular-nums; color: var(--muted); }
.col-no { width: 38px; } .col-unit { width: 78px; } .col-qty { width: 84px; } .col-extra { min-width: 100px; }
.col-price { width: 120px; } .col-amt { width: 130px; } .col-del { width: 42px; }
table.lines td.col-no { text-align: center; color: var(--muted-2); font-variant-numeric: tabular-nums; }

/* ===================== Totals ===================== */
.totals {
  margin-top: var(--sp-4);
  margin-left: auto; max-width: 360px;
  background: var(--content2); border: 1px solid var(--border);
  border-radius: var(--r-md); padding: var(--sp-4) var(--sp-5);
  box-shadow: var(--sh-inset);
  display: flex; flex-direction: column; gap: var(--sp-2);
}
.totals .row { display: flex; justify-content: space-between; align-items: baseline; padding: 2px 0; gap: var(--sp-4); flex-wrap: nowrap; }
.totals .row > * { flex: 0 1 auto; }
.totals .lbl { color: var(--muted); font-size: var(--fs-cap); }
.totals .val { font-variant-numeric: tabular-nums; font-weight: var(--w-med); color: var(--fg-soft); margin-left: auto; }
.totals .grand { margin-top: var(--sp-2); padding-top: var(--sp-3); border-top: 1px solid var(--border-strong); }
.totals .grand .lbl { color: var(--fg); font-weight: var(--w-semi); font-size: var(--fs-md); }
.totals .grand .val {
  font-size: var(--fs-h1); font-weight: var(--w-bold);
  letter-spacing: var(--tracking-head);
  font-variant-numeric: tabular-nums; color: var(--brand);
}
@supports ((-webkit-background-clip: text) or (background-clip: text)) {
  .totals .grand .val {
    background: var(--grad-accent);
    -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
  }
}

/* ===================== Dropzone / OCR ===================== */
.dropzone {
  position: relative; overflow: hidden;
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: var(--sp-2);
  border: 1.5px dashed var(--border-strong); border-radius: var(--r-lg);
  background: var(--content2);
  padding: var(--sp-10) var(--sp-6); text-align: center;
  color: var(--muted); font-size: var(--fs-cap);
  transition: border-color var(--dur) var(--ease), background var(--dur) var(--ease);
}
.dropzone::before {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(42% 56% at 50% 30%, rgba(var(--brand-rgb),.06), transparent 70%);
}
.dropzone strong { color: var(--fg); font-weight: var(--w-semi); }
.dropzone.drag { border-color: var(--brand); background: var(--brand-soft); color: var(--brand-soft-fg); }
.ocr-preview { margin-top: var(--sp-3); }
.ocr-preview img { max-width: 220px; border: 1px solid var(--border); border-radius: var(--r-sm); }
.progress { height: 6px; background: var(--content3); border-radius: var(--r-pill); overflow: hidden; margin-top: var(--sp-3); display: none; }
.progress.show { display: block; }
.progress > i { display: block; height: 100%; width: 0; background: var(--grad-brand-fill); transition: width .2s; }

/* ===================== Chip / Hint ===================== */
.chip {
  display: inline-flex; align-items: center; gap: 5px;
  height: 22px; padding: 0 10px; border-radius: var(--r-pill);
  font-size: var(--fs-tiny); font-weight: var(--w-semi);
  background: var(--brand-soft); color: var(--brand-soft-fg);
}
.hint { font-size: var(--fs-cap); color: var(--muted-2); }
pre { background: var(--content2); border: 1px solid var(--border); border-radius: var(--r-sm); padding: 10px 12px; font-size: 11.5px; color: var(--fg-soft); overflow: auto; }
details summary { cursor: pointer; }

/* ===================== Toast ===================== */
#toast {
  position: fixed; bottom: 24px; left: 50%;
  transform: translateX(-50%) translateY(16px);
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--glass-bg); color: var(--fg);
  -webkit-backdrop-filter: saturate(180%) blur(12px); backdrop-filter: saturate(180%) blur(12px);
  border: 1px solid var(--glass-line); border-radius: var(--r-md);
  padding: var(--sp-3) var(--sp-4); font-size: var(--fs-body); font-weight: var(--w-med);
  box-shadow: var(--sh-lg), var(--sh-inset);
  opacity: 0; pointer-events: none; z-index: 110;
  transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease-spring);
}
#toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }

/* ===================== Modal ===================== */
.modal-back {
  position: fixed; inset: 0; z-index: 100; background: var(--backdrop);
  -webkit-backdrop-filter: blur(3px) saturate(130%); backdrop-filter: blur(3px) saturate(130%);
  display: none; align-items: center; justify-content: center; padding: 20px;
}
.modal-back.show { display: flex; animation: fadeIn .15s var(--ease) both; }
.modal {
  background: var(--elevated); color: var(--fg);
  border: 1px solid var(--border); border-radius: var(--r-lg);
  width: min(520px, 92vw); max-height: 90vh; overflow: auto;
  box-shadow: var(--sh-xl), var(--sh-inset);
  animation: modalIn .2s var(--ease-spring) both;
}
.modal header { padding: var(--sp-4) var(--sp-5); border-bottom: 1px solid var(--border); font-weight: var(--w-semi); font-size: var(--fs-md); }
.modal .body { padding: var(--sp-5); color: var(--fg-soft); }
.modal footer { padding: var(--sp-4) var(--sp-5); border-top: 1px solid var(--border); display: flex; justify-content: flex-end; gap: var(--sp-2); }

/* ===================== Login gate ===================== */
.auth-gate {
  position: fixed; inset: 0; z-index: 200;
  background: var(--bg);
  display: flex; align-items: center; justify-content: center; padding: 20px;
}
.auth-gate[hidden] { display: none; }
/* 첫 페인트 FOUC 방지: head 동기 스크립트가 html 클래스 부여, boot()가 해제 */
html.auth-none #authGate { display: block !important; }   /* 비로그인: 랜딩 즉시(대시보드 가림) */
html.auth-has #authGate { display: none !important; }      /* 로그인 추정: 게이트 숨김(앱 바로) */
.auth-gate::before { content: none; }
.auth-card {
  position: relative;
  width: min(380px, 92vw);
  background: var(--content1); border: 1px solid var(--border-strong);
  border-radius: 6px; box-shadow: var(--sh-sm);
  padding: var(--sp-8) var(--sp-6);
  display: flex; flex-direction: column; gap: var(--sp-3);
  animation: revealUp .35s var(--ease-spring) backwards;
}
.auth-logo {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: var(--fs-h1); font-weight: var(--w-black); letter-spacing: var(--tracking-head);
}
.auth-logo img { width: 118px; height: auto; display: block; }
.auth-logo span { color: var(--muted-2); font-size: 12px; font-weight: var(--w-semi); margin-left: 4px; }
.auth-sub { margin: 2px 0 var(--sp-2); color: var(--muted); font-size: var(--fs-cap); line-height: 1.5; }
.auth-err { color: var(--danger); font-size: var(--fs-cap); min-height: 18px; }
.auth-toggle { display: flex; align-items: center; justify-content: center; gap: 6px; margin-top: var(--sp-1); color: var(--muted); font-size: var(--fs-cap); }
.btn.google { width: 100%; background: #fff; color: #1f2430; border: 1px solid var(--border-strong); box-shadow: var(--sh-xs); gap: 9px; }
.btn.google:hover { background: var(--surface); border-color: var(--muted-2); }
[data-theme="dark"] .btn.google { background: var(--content2); color: var(--fg); border-color: var(--border-strong); }
.auth-or { display: flex; align-items: center; gap: 10px; color: var(--muted-2); font-size: var(--fs-cap); margin: 2px 0; }
.auth-or::before, .auth-or::after { content: ""; flex: 1; height: 1px; background: var(--border); }

/* ===================== 홍보 랜딩 (로그인 전 메인) ===================== */
.auth-gate.landing {
  display: block; padding: 0; overflow-y: auto; scroll-behavior: smooth; background: var(--bg);
  overflow-anchor: none;
}
.auth-gate.landing::before { content: none; }
.lp-nav, .lp-hero, .lp-section, .lp-footer { position: relative; z-index: 1; }
.lp-nav {
  position: sticky; top: 0; z-index: 5;
  display: flex; align-items: center; justify-content: space-between;
  max-width: 1200px; margin: 20px auto 0; padding: 10px 12px 10px 22px;
  background: var(--glass-bg);
  border: 1px solid var(--glass-line);
  border-radius: 22px;
  box-shadow: var(--sh-md);
  -webkit-backdrop-filter: blur(18px) saturate(150%);
  backdrop-filter: blur(18px) saturate(150%);
}
.lp-logo, .lp-foot-logo { display: inline-flex; align-items: center; }
.lp-logo img { width: 128px; height: auto; display: block; }
.lp-foot-logo img { width: 108px; height: auto; display: block; }
[data-theme="dark"] .lp-logo img,
[data-theme="dark"] .lp-foot-logo img,
[data-theme="dark"] .auth-logo img { filter: invert(1) hue-rotate(180deg) saturate(.8); }
.lp-navbtn {
  height: 38px;
  display: inline-flex; align-items: center;
  padding: 0 18px;
  border: 1px solid transparent;
  border-radius: var(--r-pill);
  color: var(--on-accent);
  background: var(--grad-brand-fill);
  box-shadow: var(--sh-brand);
}
.lp-navbtn:hover { filter: brightness(1.05); }

.lp-hero { max-width: 1180px; margin: 0 auto; padding: 28px 20px 64px; }
.lp-hero-inner {
  position: relative; overflow: hidden;
  display: grid; grid-template-columns: 1.1fr .9fr; align-items: center; gap: 44px;
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 72px 60px;
  background:
    radial-gradient(100% 130% at 94% -16%, rgba(var(--brand-rgb),.13), transparent 56%),
    radial-gradient(70% 90% at -4% 112%, rgba(var(--brand-rgb),.07), transparent 60%),
    linear-gradient(180deg, var(--content1), var(--surface));
  box-shadow: var(--sh-md);
}
.lp-hero-copy {
  position: relative; z-index: 2;
  display: flex; flex-direction: column; align-items: flex-start;
  text-align: left;
}
.lp-badge {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 7px 14px; border-radius: var(--r-pill); font-size: 13px; font-weight: var(--w-semi);
  color: var(--brand-soft-fg); background: var(--brand-soft);
  border: 1px solid color-mix(in srgb, var(--brand) 22%, transparent);
}
.lp-badge i { width: 8px; height: 8px; border-radius: 50%; background: var(--success); box-shadow: 0 0 0 4px var(--success-soft); }
.lp-h1 {
  font-size: clamp(40px, 5vw, 62px);
  line-height: 1.05; font-weight: 640; letter-spacing: -.025em;
  color: var(--fg); margin: 22px 0 18px; word-break: keep-all;
}
.lp-h1 .grad {
  color: var(--brand);
  background: var(--grad-accent); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.lp-lead { font-size: 16px; line-height: 1.7; color: var(--muted); max-width: 460px; margin: 0; word-break: keep-all; }
.lp-hero-cta { display: flex; gap: 12px; flex-wrap: wrap; margin: 30px 0 22px; }
.btn.lp-cta-main { height: 50px; padding: 0 26px; font-size: 15px; background: var(--accent); color: var(--accent-fg); border: 1px solid var(--accent); font-weight: var(--w-bold); box-shadow: 0 8px 20px -8px rgba(20,51,75,.3); }
.btn.lp-cta-main:hover { filter: brightness(1.04); transform: translateY(-1px); }
.btn.lp-cta-sub { height: 50px; padding: 0 22px; font-size: 15px; }
.lp-plus { display: flex; gap: 18px; flex-wrap: wrap; font-family: var(--font-mono); font-size: 13px; color: var(--muted); }
.lp-plus span { white-space: nowrap; }
.lp-trust { display: flex; gap: 18px; flex-wrap: wrap; color: var(--muted-2); font-size: 13px; }
.lp-trust span { display: inline-flex; align-items: center; gap: 6px; }
.lp-trust span::before { content: "✓"; color: var(--brand); font-weight: 800; }
.lp-hero-visual { position: relative; z-index: 1; display: flex; justify-content: center; align-items: center; }
.lp-doc-svg { width: 100%; max-width: 460px; height: auto; overflow: visible; }
.lp-float-a { transform-box: fill-box; animation: lpFloatA 6s ease-in-out infinite; }
.lp-float-b { transform-box: fill-box; animation: lpFloatB 7s ease-in-out infinite; }
@keyframes lpFloatA { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-9px)} }
@keyframes lpFloatB { 0%,100%{transform:translateY(0)} 50%{transform:translateY(7px)} }
.lp-hero-copy > * { animation: lpRise .6s var(--ease-spring) backwards; }
.lp-hero-copy > *:nth-child(1){ animation-delay:.02s }
.lp-hero-copy > *:nth-child(2){ animation-delay:.08s }
.lp-hero-copy > *:nth-child(3){ animation-delay:.14s }
.lp-hero-copy > *:nth-child(4){ animation-delay:.20s }
.lp-hero-copy > *:nth-child(5){ animation-delay:.26s }
.lp-hero-visual { animation: lpRise .7s var(--ease-spring) .12s backwards; }
@keyframes lpRise { from{ opacity:0; transform:translateY(16px) } to{ opacity:1; transform:translateY(0) } }

/* (옛 lp-art 떠다니는 가짜 카드 제거 → SVG 일러스트 lp-doc-svg 로 대체) */

.lp-section { max-width: 1080px; margin: 0 auto; padding: 64px 24px; }
.lp-section-head {
  display: grid;
  grid-template-columns: 64px minmax(0, 1fr);
  column-gap: 24px;
  row-gap: 8px;
  align-items: start;
  margin-bottom: 22px;
}
.lp-section-head span {
  display: inline-grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: #fff;
  color: var(--muted);
  font-size: 12px;
  font-weight: 760;
}
.lp-section-head h2 {
  margin: 0;
  color: var(--fg);
  font-size: clamp(26px, 3.1vw, 38px);
  line-height: 1.16;
  font-weight: 650;
  letter-spacing: 0;
  word-break: keep-all;
}
.lp-section-head p {
  grid-column: 2;
  margin: 0;
  max-width: 620px;
  color: var(--muted);
  font-size: 16px;
  line-height: 1.65;
}
.lp-h2 { font-size: clamp(25px, 2.8vw, 34px); font-weight: 650; letter-spacing: 0; color: var(--fg); text-align: center; margin: 0 0 28px; word-break: keep-all; }
.lp-feat-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.lp-feat {
  min-height: 146px;
  background: var(--content1);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 22px 20px;
  box-shadow: var(--sh-sm);
  transition: transform var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.lp-feat:hover { transform: translateY(-2px); border-color: var(--border-strong); }
.lp-feat-ic { width: auto; height: auto; border-radius: 0; display: block; font-size: 12px; background: transparent; color: var(--brand); margin-bottom: 16px; font-weight: 760; }
.lp-feat b { display: block; font-size: 16px; color: var(--fg); margin-bottom: 8px; }
.lp-feat p { font-size: 13px; color: var(--muted); line-height: 1.65; margin: 0; }
.lp-flow-band {
  max-width: 980px;
  margin-top: 8px;
  padding-top: 58px;
  padding-bottom: 58px;
  border-top: 1px solid var(--border);
}
.lp-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.lp-step {
  position: relative;
  text-align: left;
  padding: 24px 22px;
  background: var(--content1);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--sh-sm);
}
.lp-step span { display: inline-grid; place-items: center; width: 34px; height: 34px; border-radius: 999px; background: var(--brand-soft); color: var(--brand-soft-fg); border: 0; font-weight: 760; box-shadow: none; margin-bottom: 18px; }
.lp-step b { display: block; font-size: 16px; color: var(--fg); margin-bottom: 8px; }
.lp-step p { font-size: 13px; color: var(--muted); margin: 0; line-height: 1.55; }

.lp-start {
  max-width: none;
  background:
    radial-gradient(60% 90% at 50% 0%, rgba(var(--brand-rgb),.08), transparent 60%),
    linear-gradient(180deg, var(--surface), var(--content1));
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 64px 24px;
  margin-top: 24px;
}
.lp-start-inner { max-width: 1040px; margin: 0 auto; display: grid; grid-template-columns: minmax(0, 1fr) min(390px, 92vw); gap: 56px; align-items: center; }
.lp-start-copy .lp-h2 { text-align: left; margin-bottom: 14px; max-width: 560px; }
.lp-start-kicker {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  margin-bottom: 16px;
  padding: 6px 12px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--content1);
  color: var(--brand-soft-fg);
  font-size: 12px;
  font-weight: 760;
}
.lp-start-sub { max-width: 520px; font-size: 16px; color: var(--muted); line-height: 1.7; margin: 0 0 22px; }
.lp-mini-doc {
  width: min(470px, 100%);
  display: grid;
  gap: 0;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--content1);
  box-shadow: var(--sh-md);
  overflow: hidden;
}
.lp-mini-doc div { display: grid; grid-template-columns: 92px 1fr; gap: 16px; padding: 15px 18px; border-bottom: 1px solid var(--border); }
.lp-mini-doc div:last-child { border-bottom: 0; }
.lp-mini-doc span { color: var(--muted); font-size: 12px; }
.lp-mini-doc b { color: var(--fg); font-size: 14px; font-weight: 650; }
.lp-start .auth-card {
  width: 100%;
  border-color: var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--sh-lg);
}

.lp-footer { max-width: 1080px; margin: 0 auto; padding: 36px 24px 56px; display: flex; align-items: center; gap: 14px; flex-wrap: wrap; color: var(--muted-2); font-size: 13px; }
.lp-footer .lp-foot-logo { font-size: 18px; }
.lp-foot-copy { margin-left: auto; }

/* ============ 랜딩 v2 — easehealth식 스토리텔링 구조 ============ */
.lp-nav-links { display: flex; gap: 26px; margin-right: auto; margin-left: 30px; }
.lp-nav-links a { color: var(--muted); font-size: 14px; font-weight: var(--w-med); text-decoration: none; }
.lp-nav-links a:hover { color: var(--brand); }
@media (max-width: 820px) { .lp-nav-links { display: none; } }

/* eyebrow */
.lp-eyebrow { display: inline-block; font-family: var(--font-mono); font-size: 12px; font-weight: 400; letter-spacing: .01em; text-transform: none; color: var(--muted); margin-bottom: 16px; }
.lp-eyebrow.muted { color: var(--muted-2); }
.lp-eyebrow.on-dark { color: #BFEFD2; }
/* 모노 숫자(titanintake 결) */
.lp-strip-stats b, .mk-head em, .lp-cmp-num { font-family: var(--font-mono); }
/* Lenis 스무스 스크롤 */
html.lenis, html.lenis body { height: auto; }
.lenis.lenis-smooth { scroll-behavior: auto !important; }
.lenis.lenis-smooth [data-lenis-prevent] { overscroll-behavior: contain; }
.lenis.lenis-stopped { overflow: hidden; }
/* 스크롤 등장 애니메이션 */
[data-reveal] { opacity: 0; transform: translateY(30px); transition: opacity .8s cubic-bezier(.16,1,.3,1), transform .8s cubic-bezier(.16,1,.3,1); will-change: opacity, transform; }
[data-reveal].is-in { opacity: 1; transform: none; }
[data-reveal][data-d="1"] { transition-delay: .07s; }
[data-reveal][data-d="2"] { transition-delay: .14s; }
[data-reveal][data-d="3"] { transition-delay: .21s; }
[data-reveal][data-d="4"] { transition-delay: .28s; }
@media (prefers-reduced-motion: reduce) { [data-reveal] { opacity: 1 !important; transform: none !important; transition: none !important; } }

/* 업종 스트립 + 값 */
.lp-strip { max-width: 1080px; margin: 0 auto; padding: 40px 24px 8px; text-align: center; }
.lp-strip-label { color: var(--muted); font-size: 14px; margin: 0 0 18px; }
.lp-tags { display: flex; flex-wrap: wrap; justify-content: center; gap: 8px; margin-bottom: 40px; }
.lp-tags span { padding: 7px 15px; border: 1px solid var(--border); border-radius: var(--r-pill); background: var(--content1); color: var(--fg-soft); font-size: 13px; font-weight: var(--w-med); }
.lp-strip-stats { display: flex; justify-content: center; gap: clamp(28px, 6vw, 64px); flex-wrap: wrap; }
.lp-strip-stats > div { text-align: center; }
.lp-strip-stats b { display: block; font-size: clamp(28px, 3.4vw, 40px); font-weight: var(--w-bold); color: var(--brand); letter-spacing: -.02em; line-height: 1; }
.lp-strip-stats span { display: block; margin-top: 8px; color: var(--muted); font-size: 13px; }

/* 문제 → 해결 */
.lp-ps { max-width: 1000px; margin: 0 auto; padding: 60px 24px; display: grid; gap: 24px; }
@media (min-width: 760px) { .lp-ps { grid-template-columns: 1fr 1fr; } }
.lp-ps-block { padding: 38px 40px; border: 1px solid var(--border); border-radius: var(--r-xl); background: var(--content1); }
.lp-ps-block:last-child { background: linear-gradient(170deg, var(--brand-soft), var(--content1) 80%); border-color: color-mix(in srgb, var(--brand) 28%, transparent); }
.lp-ps-h { margin: 0; font-size: clamp(21px, 2.4vw, 29px); line-height: 1.34; font-weight: 600; color: var(--fg); word-break: keep-all; letter-spacing: -.01em; }
.lp-ps-h b { color: var(--brand); font-weight: 700; }
.lp-ps-h .grad { color: var(--brand); -webkit-text-fill-color: currentColor; background: none; font-weight: 700; }

/* 섹션 헤더 */
.lp-section-head2 { margin-bottom: 38px; }
.lp-section-head2.center { text-align: center; }
.lp-h2.left { text-align: left; }

/* 베네핏 3 */
.lp-why { padding-top: 44px; padding-bottom: 44px; }
.lp-bene-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.lp-bene { padding: 30px 26px; border: 1px solid var(--border); border-radius: var(--r-lg); background: var(--content1); box-shadow: var(--sh-sm); }
.lp-bene-ic { width: 46px; height: 46px; display: grid; place-items: center; border-radius: 13px; background: var(--brand-soft); color: var(--brand); margin-bottom: 18px; }
.lp-bene b { display: block; font-size: 18px; font-weight: var(--w-bold); color: var(--fg); margin-bottom: 8px; letter-spacing: -.01em; }
.lp-bene p { margin: 0; color: var(--muted); font-size: 14px; line-height: 1.65; word-break: keep-all; }
@media (max-width: 820px) { .lp-bene-grid { grid-template-columns: 1fr; } }

/* 제품 모듈 (교차) */
.lp-modules { display: flex; flex-direction: column; gap: 24px; padding-top: 16px; }
.lp-module { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; padding: 40px 44px; border: 1px solid var(--border); border-radius: var(--r-xl); background: var(--content1); }
.lp-module.reverse .lp-module-copy { order: 2; }
.lp-mod-h { font-size: clamp(22px, 2.4vw, 30px); font-weight: 620; letter-spacing: -.02em; color: var(--fg); margin: 0 0 12px; word-break: keep-all; }
.lp-module-copy p { color: var(--muted); font-size: 15px; line-height: 1.7; margin: 0 0 18px; max-width: 430px; word-break: keep-all; }
.lp-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.lp-chips span { padding: 6px 12px; border-radius: var(--r-sm); background: var(--surface); border: 1px solid var(--border); color: var(--fg-soft); font-size: 12.5px; font-family: var(--font-mono); }
.lp-chips span::before { content: "+ "; color: var(--muted-2); }
.lp-module-visual { display: flex; justify-content: center; }
@media (max-width: 820px) { .lp-module { grid-template-columns: 1fr; gap: 28px; padding: 30px 26px; } .lp-module.reverse .lp-module-copy { order: 0; } }

/* 미니 목업 */
.mk { width: 100%; max-width: 360px; background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 16px; box-shadow: var(--sh-md); }
.mk-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 12px; }
.mk-head b { font-weight: var(--w-bold); color: var(--fg); }
.mk-head em { font-style: normal; font-size: 12px; color: var(--muted); }
.mk-pick { padding: 9px 12px; border: 1px dashed var(--border-strong); border-radius: var(--r-sm); color: var(--brand); font-size: 13px; font-weight: var(--w-semi); margin-bottom: 10px; background: var(--brand-soft); }
.mk-line { display: grid; grid-template-columns: 1fr auto auto; gap: 12px; align-items: center; padding: 9px 4px; border-bottom: 1px solid var(--divider); font-size: 13px; }
.mk-items .mk-line { grid-template-columns: 1fr auto; }
.mk-line span { color: var(--fg); font-weight: var(--w-med); }
.mk-line i { font-style: normal; color: var(--muted); font-variant-numeric: tabular-nums; }
.mk-total { display: flex; justify-content: space-between; align-items: center; margin-top: 12px; padding: 12px 14px; border-radius: var(--r-sm); background: var(--brand); color: var(--on-accent); }
.mk-total b { font-weight: var(--w-bold); font-variant-numeric: tabular-nums; }
.mk-grp { margin: 12px 0 2px; font-size: 12px; font-weight: var(--w-bold); color: var(--brand-soft-fg); }
.mk-grp em { font-style: normal; color: var(--muted-2); margin-left: 4px; }
.mk-cust-card { padding: 12px 14px; border: 1px solid var(--border); border-radius: var(--r-sm); background: var(--content1); margin-bottom: 8px; }
.mk-cust-card b { display: block; color: var(--fg); }
.mk-cust-card span { font-size: 12px; color: var(--muted); }
.mk-forms { display: flex; gap: 8px; margin-top: 10px; }
.mk-forms i { flex: 1; text-align: center; padding: 16px 4px; border: 1px solid var(--border); border-radius: var(--r-sm); background: var(--content1); font-style: normal; font-size: 12px; color: var(--muted); }
.mk-forms i:first-child { border-color: var(--brand); color: var(--brand); background: var(--brand-soft); }

/* 데이터 보관 */
.lp-trust-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.lp-trust-card { padding: 28px 24px; border: 1px solid var(--border); border-radius: var(--r-lg); background: var(--content1); }
.lp-trust-card b { display: block; font-size: 16px; color: var(--fg); margin-bottom: 8px; letter-spacing: -.01em; }
.lp-trust-card p { margin: 0; color: var(--muted); font-size: 14px; line-height: 1.65; word-break: keep-all; }
@media (max-width: 820px) { .lp-trust-grid { grid-template-columns: 1fr; } }

/* 최종 CTA — 포레스트 그린 밴드 */
.lp-cta-final { position: relative; margin-top: 0; padding: 96px 24px 104px; background: linear-gradient(160deg, #15945A 0%, #0F5E33 55%, #0F3E1C 100%); color: #fff; }
.lp-cta-final .lp-start-inner { max-width: 1040px; margin: 0 auto; display: grid; grid-template-columns: minmax(0,1fr) min(390px, 92vw); gap: 56px; align-items: center; }
.lp-cta-h { font-size: clamp(30px, 3.6vw, 46px); font-weight: 640; letter-spacing: -.025em; line-height: 1.08; color: #fff; margin: 0 0 16px; word-break: keep-all; }
.lp-cta-h .grad { color: #BFEFD2; -webkit-text-fill-color: #BFEFD2; background: none; }
.lp-cta-final .lp-start-sub { color: rgba(255,255,255,.82); max-width: 460px; font-size: 16px; line-height: 1.7; margin: 0 0 22px; }
.lp-cta-points { list-style: none; margin: 0; padding: 0; display: grid; gap: 10px; }
.lp-cta-points li { position: relative; padding-left: 26px; color: rgba(255,255,255,.92); font-size: 14px; }
.lp-cta-points li::before { content: "✓"; position: absolute; left: 0; color: #8FE7B5; font-weight: 800; }
.lp-cta-final .auth-card { box-shadow: 0 30px 60px -20px rgba(0,0,0,.5); }
@media (max-width: 820px) { .lp-cta-final .lp-start-inner { grid-template-columns: 1fr; gap: 32px; } }

/* ============ 랜딩 v3 — titanintake 구조(큰 타입·큰 섹션·제품 목업·스크롤) ============ */
.lp-progress { position: fixed; top: 0; left: 0; height: 3px; width: 0; background: var(--brand); z-index: 300; }
/* HERO */
.lp-hero2 { max-width: 1200px; margin: 0 auto; padding: clamp(40px,7vw,88px) 24px clamp(36px,5vw,64px); text-align: center; }
.lp-hero2-inner { max-width: 920px; margin: 0 auto; display: flex; flex-direction: column; align-items: center; }
.lp-display { font-size: clamp(42px, 8vw, 104px); font-weight: 660; line-height: 1.0; letter-spacing: -.035em; color: var(--fg); margin: 18px 0 22px; word-break: keep-all; }
.lp-display .grad { color: var(--brand); background: var(--grad-accent); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.lp-lead2 { font-size: clamp(16px,1.6vw,19px); line-height: 1.65; color: var(--muted); max-width: 580px; margin: 0 0 30px; word-break: keep-all; }
.lp-hero2 .lp-hero-cta, .lp-hero2 .lp-plus { justify-content: center; }
/* 제품 화면 목업 (app-shot) */
.lp-hero2-shot { position: relative; max-width: 940px; margin: clamp(40px,6vw,72px) auto 0; }
.app-shot { width: 100%; background: var(--content1); border: 1px solid var(--border); border-radius: 16px; box-shadow: var(--sh-xl); overflow: hidden; }
.app-shot .as-bar { display: none; }
.app-shot .as-body { padding-top: 6px; }
.as-bar { display: flex; align-items: center; gap: 7px; padding: 12px 16px; border-bottom: 1px solid var(--border); background: var(--surface); }
.as-bar i { width: 11px; height: 11px; border-radius: 50%; background: var(--border-strong); }
.as-bar i:nth-child(1){ background:#EC6A5E } .as-bar i:nth-child(2){ background:#F3BF4F } .as-bar i:nth-child(3){ background:#61C554 }
.as-bar span { margin-left: 12px; font-size: 12px; color: var(--muted); font-family: var(--font-mono); }
.as-body { display: grid; grid-template-columns: 150px 1fr; min-height: 300px; }
.as-side { padding: 16px; border-right: 1px solid var(--border); background: var(--surface); display: flex; flex-direction: column; gap: 9px; }
.as-side b { font-weight: 800; color: var(--brand); margin-bottom: 6px; }
.as-side u { height: 30px; border-radius: 8px; background: var(--content3); }
.as-side u.on { background: var(--brand-soft); }
.as-main { padding: 18px 22px; }
.as-pick { padding: 11px 14px; border: 1px dashed var(--border-strong); border-radius: 9px; background: var(--brand-soft); color: var(--brand-soft-fg); font-size: 13px; font-weight: 600; margin-bottom: 14px; }
.as-thead, .as-row { display: grid; grid-template-columns: 1fr 50px 92px 96px; gap: 10px; align-items: center; padding: 10px 4px; }
.as-main .as-row:not(:has(i:nth-child(3))) { grid-template-columns: 1fr 60px 110px; }
.as-thead { font-size: 11px; color: var(--muted-2); font-family: var(--font-mono); border-bottom: 1px solid var(--border); padding: 8px 4px; }
.as-thead span:not(:first-child), .as-row i { text-align: right; }
.as-row { border-bottom: 1px solid var(--divider); font-size: 13px; }
.as-row span { color: var(--fg); font-weight: 500; }
.as-row i { font-style: normal; color: var(--muted); font-variant-numeric: tabular-nums; }
.as-total { display: flex; justify-content: space-between; align-items: center; margin-top: 14px; padding: 14px 16px; border-radius: 10px; background: var(--brand); color: var(--on-accent); }
.as-total b { font-weight: 800; font-variant-numeric: tabular-nums; font-size: 16px; }
.as-grp { margin: 12px 0 4px; font-size: 12px; font-weight: 800; color: var(--brand-soft-fg); font-family: var(--font-mono); }
.as-grp em { font-style: normal; color: var(--muted-2); }
.as-doc { padding: 6px 10px; }
.as-doc-head { display: flex; align-items: baseline; gap: 10px; justify-content: center; margin-bottom: 16px; }
.as-doc-head b { font-size: 18px; letter-spacing: 4px; } .as-doc-head u { font-size: 10px; color: var(--muted); font-family: var(--font-mono); }
.as-dl { height: 9px; border-radius: 5px; background: var(--content3); margin: 9px 0; } .as-dl.w70 { width: 70% } .as-dl.w50 { width: 50% }
.as-doc-total { margin-top: 16px; padding-top: 12px; border-top: 1px solid var(--border); text-align: right; color: var(--fg); } .as-doc-total b { color: var(--brand); }
.as-chip { position: absolute; background: var(--content1); border: 1px solid var(--border); border-radius: 12px; box-shadow: var(--sh-lg); padding: 11px 16px; font-size: 13px; font-weight: 700; }
.as-chip-a { top: -20px; left: 3%; color: var(--brand); }
.as-chip-b { bottom: -20px; right: 3%; background: var(--brand); color: var(--on-accent); display: flex; flex-direction: column; gap: 2px; }
.as-chip-b span { font-size: 11px; opacity: .85; font-weight: 500; } .as-chip-b b { font-size: 16px; font-variant-numeric: tabular-nums; }
@media (max-width: 680px){ .as-chip { display: none; } .as-body { grid-template-columns: 1fr; } .as-side { display: none; } .as-thead, .as-row { grid-template-columns: 1fr 40px 80px; } .as-thead span:nth-child(4), .as-row i:nth-child(4) { display: none; } }
/* 업종 스트립 */
.lp-strip2 { max-width: 1080px; margin: 0 auto; padding: 16px 24px 8px; text-align: center; }
.lp-strip2 .lp-strip-label { color: var(--muted); font-size: 14px; margin: 0 0 18px; }
.lp-strip2 .lp-tags { display: flex; flex-wrap: wrap; justify-content: center; gap: 8px; }
/* 큰 섹션 헤드라인 */
.lp-h2x { font-size: clamp(30px, 5vw, 60px); font-weight: 640; letter-spacing: -.025em; line-height: 1.06; color: var(--fg); margin: 0; word-break: keep-all; }
/* 스크롤 데모 — 저장된 칩이 견적서로 불러와짐 */
.lp-demo { position: relative; height: 360vh; padding: 0 24px; }
.lp-demo-sticky { position: sticky; top: 0; height: 100vh; display: grid; grid-template-columns: .82fr 1.18fr; gap: 56px; align-items: center; max-width: 1180px; margin: 0 auto; }
.lp-demo-kicker { font-family: var(--font-mono); font-size: 13px; color: var(--brand); letter-spacing: .02em; }
.lp-demo-caps { position: relative; min-height: 150px; margin: 22px 0 8px; }
.lp-cap { position: absolute; inset: 0; opacity: 0; transform: translateY(16px); transition: opacity .5s var(--ease), transform .55s var(--ease); pointer-events: none; }
.lp-cap.is-on { opacity: 1; transform: none; }
.lp-cap h3 { font-size: clamp(28px, 3.6vw, 48px); font-weight: 660; letter-spacing: -.03em; line-height: 1.1; margin: 0 0 14px; color: var(--fg); }
.lp-cap p { color: var(--muted); font-size: 16px; line-height: 1.6; margin: 0; max-width: 340px; word-break: keep-all; }
.lp-demo-dots { display: flex; gap: 8px; }
.lp-demo-dots i { width: 28px; height: 4px; border-radius: 2px; background: var(--border-strong); transition: background .4s; }
.lp-demo-dots i.on { background: var(--brand); }
.lp-demo-stage { position: relative; }
.lp-demo-stage .paper { max-width: 470px; margin-left: auto; }
.src-chip { position: absolute; left: -6px; z-index: 3; display: inline-flex; align-items: center; gap: 9px; padding: 10px 15px; background: var(--content1); border: 1px solid var(--border); border-radius: 11px; box-shadow: var(--sh-lg); font-size: 13px; font-weight: 600; color: var(--fg); white-space: nowrap; opacity: 0; transform: translateX(-26px) scale(.95); transition: opacity .5s var(--ease), transform .65s cubic-bezier(.5,0,.2,1); }
.src-chip em { font-style: normal; color: var(--brand); font-variant-numeric: tabular-nums; }
.src-chip[data-chip="0"] { top: 12%; } .src-chip[data-chip="1"] { top: 40%; } .src-chip[data-chip="2"] { top: 66%; }
.src-chip.appear { opacity: 1; transform: translateX(0) scale(1); }
.src-chip.fly { opacity: 0; transform: translateX(240px) scale(.65); }
.demo-item, .demo-total { opacity: 0; transform: translateY(12px); transition: opacity .5s var(--ease), transform .5s var(--ease); }
.demo-item.show, .demo-total.show { opacity: 1; transform: none; }
@media (max-width: 820px){ .lp-demo { height: 320vh; } .lp-demo-sticky { grid-template-columns: 1fr; gap: 14px; align-content: center; } .lp-demo-stage .paper { margin: 0 auto; max-width: 94%; } .src-chip { display: none; } .lp-demo-caps { min-height: 120px; } }
/* STATS */
.lp-stats2 { max-width: 1200px; margin: 0 auto; padding: clamp(56px,9vw,110px) 24px; }
.lp-stats2 .lp-section-head2 { text-align: center; margin-bottom: 48px; }
.lp-stats-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 24px; text-align: center; }
.lp-statbig b { display: block; font-size: clamp(46px, 8vw, 92px); font-weight: 700; color: var(--brand); letter-spacing: -.03em; line-height: 1; font-variant-numeric: tabular-nums; font-family: var(--font-mono); }
.lp-statbig b u { font-size: .38em; text-decoration: none; font-weight: 600; color: var(--muted); margin-left: 2px; }
.lp-statbig span { display: block; margin-top: 14px; color: var(--muted); font-size: 14px; }
@media (max-width: 820px){ .lp-stats-grid { grid-template-columns: 1fr 1fr; gap: 36px 18px; } }
/* 토글 대시보드 */
.lp-toggle .lp-section-head2 { margin-bottom: 28px; }
.lp-toggle-pills { display: flex; width: fit-content; gap: 6px; padding: 6px; border: 1px solid var(--border); border-radius: 999px; background: var(--surface); margin: 0 auto 40px; }
.tg-pill { padding: 10px 22px; border: 0; border-radius: 999px; background: transparent; color: var(--muted); font-weight: 600; font-size: 14px; cursor: pointer; transition: background .2s, color .2s; }
.tg-pill.on { background: var(--brand); color: var(--on-accent); }
.lp-toggle-stage { max-width: 1080px; margin: 0 auto; }
.tg-panel { display: none; grid-template-columns: .82fr 1.18fr; gap: 48px; align-items: center; }
.tg-panel.on { display: grid; animation: lpRise .5s var(--ease) backwards; }
.tg-copy h3 { font-size: clamp(22px,2.6vw,30px); font-weight: 640; margin: 0 0 16px; letter-spacing: -.02em; line-height: 1.2; word-break: keep-all; }
.app-shot.sm .as-body { min-height: 220px; grid-template-columns: 1fr; }
@media (max-width: 820px){ .tg-panel.on { grid-template-columns: 1fr; gap: 24px; } }
/* With / Without 비교 */
.lp-compare { max-width: 920px; }
.lp-compare .lp-section-head2 { margin-bottom: 36px; }
.lp-cmp { border: 1px solid var(--border); border-radius: 16px; overflow: hidden; background: var(--content1); box-shadow: var(--sh-sm); }
.lp-cmp-head, .lp-cmp-row { display: grid; grid-template-columns: 1.4fr 1fr 1fr; align-items: stretch; }
.lp-cmp-head { background: var(--surface); }
.lp-cmp-head span, .lp-cmp-head b, .lp-cmp-row span, .lp-cmp-row b { padding: 16px 20px; display: flex; align-items: center; }
.lp-cmp-head b { font-family: var(--font-mono); font-size: 13px; }
.lp-cmp-row { border-top: 1px solid var(--border); }
.lp-cmp-row span { color: var(--muted); font-size: 14px; }
.lp-cmp .cmp-good { color: var(--brand); font-weight: 700; background: var(--brand-soft); }
.lp-cmp .cmp-bad { color: var(--muted-2); font-weight: 600; }
@media (max-width: 560px){ .lp-cmp-head span, .lp-cmp-head b, .lp-cmp-row span, .lp-cmp-row b { padding: 12px; font-size: 13px; } }
/* 벤토 */
.lp-bento-grid { display: grid; grid-template-columns: repeat(3, 1fr); grid-auto-rows: 1fr; gap: 16px; }
.bento { padding: 28px; border: 1px solid var(--border); border-radius: 16px; background: var(--content1); box-shadow: var(--sh-sm); }
.bento.b-lg { grid-row: span 2; background: linear-gradient(168deg, var(--brand-soft), var(--content1) 72%); }
.bento.b-wide { grid-column: span 2; }
.bento b { display: block; font-size: 18px; font-weight: 700; margin-bottom: 8px; color: var(--fg); letter-spacing: -.01em; }
.bento p { margin: 0; color: var(--muted); font-size: 14px; line-height: 1.6; word-break: keep-all; }
.bento-tag { display: inline-block; margin-top: 16px; padding: 5px 12px; border-radius: 999px; background: var(--brand); color: var(--on-accent); font-size: 12px; font-family: var(--font-mono); }
@media (max-width: 820px){ .lp-bento-grid { grid-template-columns: 1fr; } .bento.b-lg, .bento.b-wide { grid-column: auto; grid-row: auto; } }
/* 후기/철학 */
.lp-quote { max-width: 920px; margin: 0 auto; padding: clamp(56px,9vw,110px) 24px; text-align: center; }
.lp-quote-text { font-size: clamp(24px,3.4vw,42px); font-weight: 600; line-height: 1.4; letter-spacing: -.015em; color: var(--fg); margin: 0 0 26px; word-break: keep-all; }
.lp-quote-by b { color: var(--brand); font-weight: 700; } .lp-quote-by span { color: var(--muted); margin-left: 8px; }

/* ===== 실제 견적서 페이퍼 (흰 종이 · .docx 느낌, 라이트/다크 공통 흰색) ===== */
.paper { display: flex; justify-content: center; perspective: 1600px; }
.paper-sheet {
  position: relative; width: 100%; max-width: 440px; aspect-ratio: 1 / 1.33;
  background: #ffffff; color: #20242B;
  border: 1px solid #ededed; border-radius: 4px;
  box-shadow: 0 50px 90px -34px rgba(18,26,36,.36), 0 8px 22px -10px rgba(18,26,36,.14);
  padding: clamp(24px, 3.2vw, 38px); display: flex; flex-direction: column;
  font-size: 12.5px; line-height: 1.5; overflow: hidden;
}
.pp-head { display: flex; justify-content: space-between; align-items: flex-start; padding-bottom: 14px; border-bottom: 2px solid #20242B; }
.pp-title { font-size: 21px; font-weight: 800; letter-spacing: 7px; }
.pp-sub { font-size: 9px; letter-spacing: 3px; color: #aab0b8; margin-top: 3px; font-family: var(--font-mono); }
.pp-logo { font-family: var(--font-brand); font-weight: 700; letter-spacing: -.02em; color: #0F7A46; font-size: 15px; }
.pp-meta { display: flex; justify-content: space-between; gap: 14px; padding: 13px 0; border-bottom: 1px solid #ededed; font-size: 11.5px; }
.pp-meta span { color: #aab0b8; margin-right: 7px; }
.pp-meta b { font-weight: 600; }
.pp-thead { display: grid; grid-template-columns: 1fr 30px 66px 74px; gap: 8px; padding: 12px 0 8px; font-size: 9.5px; color: #aab0b8; border-bottom: 1px solid #20242B; font-family: var(--font-mono); }
.pp-thead span:not(:first-child) { text-align: right; }
.pp-row { display: grid; grid-template-columns: 1fr 30px 66px 74px; gap: 8px; padding: 11px 0; border-bottom: 1px solid #f3f3f3; }
.pp-row span { font-weight: 600; color: #20242B; }
.pp-row i { font-style: normal; text-align: right; color: #565c64; font-variant-numeric: tabular-nums; }
.pp-total { display: flex; justify-content: space-between; align-items: center; margin-top: 14px; padding: 13px 16px; background: #EEF6F0; border-radius: 5px; }
.pp-total > span { font-weight: 700; color: #20242B; }
.pp-total b { font-size: 18px; font-weight: 800; color: #0F7A46; font-variant-numeric: tabular-nums; }
.pp-foot { margin-top: auto; padding-top: 18px; display: flex; justify-content: flex-end; align-items: flex-end; }
.pp-sign { position: relative; color: #565c64; font-size: 11px; padding-right: 46px; }
.pp-stamp { position: absolute; right: -6px; top: 50%; transform: translateY(-50%) rotate(-11deg); width: 42px; height: 42px; border: 2px solid #C0392B; border-radius: 50%; color: #C0392B; display: grid; place-items: center; font-size: 8.5px; font-weight: 800; letter-spacing: 1px; }
/* 데모: 스크롤로 채워짐 */
.paper.demo .pp-item, .paper.demo .pp-total, .paper.demo .pp-stamp { opacity: 0; transform: translateY(10px); transition: opacity .55s var(--ease), transform .55s var(--ease); }
.paper.demo .pp-item.show, .paper.demo .pp-total.show, .paper.demo .pp-stamp.show { opacity: 1; transform: translateY(0); }
.paper.demo .pp-stamp { transform: translateY(-50%) rotate(-11deg) scale(.6); }
.paper.demo .pp-stamp.show { transform: translateY(-50%) rotate(-11deg) scale(1); }
.paper-float { animation: lpFloatA 7s ease-in-out infinite; }
/* 브랜드 선언 */
.lp-manifesto { max-width: 1000px; margin: 0 auto; padding: clamp(64px,11vw,140px) 24px; text-align: center; }
.lp-manifesto-text { font-size: clamp(27px, 4.6vw, 56px); font-weight: 600; line-height: 1.34; letter-spacing: -.02em; color: var(--fg); margin: 0; word-break: keep-all; }
.lp-manifesto-text em { font-style: normal; color: var(--brand); font-weight: 700; }

@media (max-width: 880px) {
  .lp-nav { margin: 12px 12px 0; }
  .lp-hero { padding: 12px 12px 44px; }
  .lp-hero-inner { grid-template-columns: 1fr; gap: 28px; padding: 40px 28px; }
  .lp-h1 { font-size: clamp(32px, 8vw, 46px); }
  .lp-hero-visual { order: 2; }
  .lp-doc-svg { max-width: 380px; }
  .lp-feat-grid { grid-template-columns: 1fr 1fr; }
  .lp-steps { grid-template-columns: 1fr; }
  .lp-start-inner { grid-template-columns: 1fr; gap: 28px; }
  .lp-start-copy .lp-h2 { text-align: left; }
}
@media (max-width: 520px) {
  .lp-nav { padding-left: 16px; }
  .lp-logo img { width: 112px; }
  .lp-navbtn { height: 34px; padding: 0 14px; }
  .lp-hero-inner { padding: 32px 22px; }
  .lp-h1 { font-size: 30px; line-height: 1.18; }
  .lp-lead { font-size: 15px; }
  .lp-hero-cta { width: 100%; }
  .btn.lp-cta-main, .btn.lp-cta-sub { flex: 1; justify-content: center; }
  .lp-doc-svg { max-width: 320px; }
  .lp-feat-grid { grid-template-columns: 1fr; }
}

/* ===================== Motion ===================== */
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes revealUp { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }
@keyframes modalIn { from { opacity: 0; transform: translateY(8px) scale(.97); } to { opacity: 1; transform: translateY(0) scale(1); } }
@keyframes logoShine { 0% { background-position: 0% center; } 100% { background-position: 200% center; } }
@keyframes btnShine { 0% { background-position: -160% 0; } 58%, 100% { background-position: 260% 0; } }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .001ms !important; animation-iteration-count: 1 !important;
    transition-duration: .001ms !important; scroll-behavior: auto !important;
  }
  .panel:hover, .mode-tab:hover, .btn.primary:hover { transform: none; }
  .app-header .logo, .btn.primary::after { animation: none !important; }
  body::before { background-attachment: scroll; }
}

/* ============================================================
   견적서 미리보기 (A4) — 화면 & 인쇄
   ============================================================ */
.doc-wrap { display: flex; justify-content: center; }
.doc {
  position: relative;
  width: 210mm; height: 297mm; min-height: 297mm; background: #fff; padding: 16mm 14mm;
  color: #111; border: 1px solid var(--border); border-radius: var(--r-md);
  box-shadow: var(--sh-lg);
  font-size: 12px; line-height: 1.45;
}
[data-theme="dark"] .doc { border-color: rgba(0,0,0,.12); box-shadow: var(--sh-xl); }
/* ===== 모던 한국형 견적서 (세미안 레이아웃 + 영신알에프 날인) ===== */
.qd {
  --navy: #1d3b53; --ink: #171b22; --qmuted: #6b7682; --qline: #e4e8ed;
  --mono: "Consolas", "SF Mono", "Roboto Mono", ui-monospace, monospace;
  color: var(--ink);
  display: flex; flex-direction: column;   /* 푸터를 페이지 맨 밑으로 */
}
.qd::before,
.qd::after {
  content: "";
  position: absolute;
  pointer-events: none;
  border-radius: 2px;
}
.qd::before {
  inset: 10mm;
  border: 1px dashed rgba(29,59,83,.22);
}
.qd::after {
  inset: 3mm;
  border: 1px dotted rgba(229,72,77,.18);
}
.qd .qd-mono { font-family: var(--mono); font-variant-numeric: tabular-nums; letter-spacing: -.2px; }
.qd .qd-mlabel { font-family: var(--mono); font-size: 9px; letter-spacing: 1.2px; text-transform: uppercase; color: var(--qmuted); }
.qd .qd-ph { color: #c2c8cf; }   /* 빈 값 placeholder */

.qd .qd-head { display: flex; justify-content: space-between; align-items: flex-start; padding-bottom: 16px; border-bottom: 2px solid var(--navy); }
.qd .qd-logo { max-height: 54px; max-width: 250px; object-fit: contain; }
.qd .qd-brandname { font-size: 26px; font-weight: 800; letter-spacing: -.5px; color: var(--navy); }
.qd .qd-titlebox { text-align: right; }
.qd .qd-qlabel { font-family: var(--mono); font-size: 10px; letter-spacing: 3px; color: var(--qmuted); }
.qd .qd-qtitle { font-size: 23px; font-weight: 800; letter-spacing: 6px; color: var(--navy); margin: 2px 0; }
.qd .qd-qno { font-size: 12px; }

.qd .qd-parties { display: flex; gap: 24px; margin-top: 18px; }
.qd .qd-party { flex: 1; min-width: 0; }
.qd .qd-pname { display: flex; align-items: center; gap: 10px; min-height: 30px; font-size: 15px; font-weight: 700; margin: 6px 0 8px; color: var(--navy); }
.qd .qd-pname em { font-style: normal; font-weight: 500; color: var(--qmuted); font-size: 12px; }
/* 날인/서명: 회사명 라인에 수직 중앙정렬 (중심선 align) */
.qd .qd-sealwrap { display: inline-flex; align-items: center; gap: 8px; }
.qd .qd-seal { height: 46px; width: auto; object-fit: contain; opacity: .95; }
.qd .qd-sign { height: 34px; width: auto; object-fit: contain; }
.qd .qd-pline { display: flex; gap: 8px; font-size: 11.5px; line-height: 1.7; }
.qd .qd-pline > span { flex: 0 0 60px; color: var(--qmuted); }
.qd .qd-pline > i { font-style: normal; }
.qd .qd-rep i b { color: var(--navy); font-weight: 700; }

.qd .qd-meta { display: flex; flex-wrap: wrap; column-gap: 52px; row-gap: 18px; margin: 26px 0 12px; padding: 18px 2px; border-top: 1px solid var(--qline); border-bottom: 1px solid var(--qline); }
.qd .qd-meta > div { display: flex; flex-direction: column; gap: 7px; }
.qd .qd-meta b { font-size: 12.5px; font-weight: 600; line-height: 1.35; }
.qd .qd-meta .qd-mlabel { margin-bottom: 1px; }
.qd .qd-phrase { font-size: 12px; color: var(--qmuted); margin: 18px 0; }

table.qd-items { width: 100%; border-collapse: collapse; margin-top: 2px; }
table.qd-items th { font-family: var(--mono); font-size: 9.5px; letter-spacing: .6px; text-transform: uppercase; color: var(--qmuted); text-align: left; padding: 8px; border-bottom: 1.5px solid var(--navy); white-space: nowrap; }
table.qd-items td { padding: 9px 8px; border-bottom: 1px solid var(--qline); font-size: 11.5px; vertical-align: top; }
table.qd-items .qd-no { width: 34px; color: var(--qmuted); }
table.qd-items .qd-c, table.qd-items th.qd-c { text-align: center; }
table.qd-items .qd-r, table.qd-items th.qd-r { text-align: right; }
table.qd-items .qd-desc b { font-weight: 700; color: var(--ink); }
table.qd-items .qd-emptyrow { text-align: center; color: var(--qmuted); padding: 24px; }

.qd .qd-bottom { display: flex; justify-content: space-between; gap: 28px; margin-top: 18px; }
.qd .qd-terms { flex: 1; min-width: 0; }
.qd .qd-note { white-space: pre-wrap; font-size: 11px; line-height: 1.6; margin-top: 3px; }
.qd .qd-sum { flex: 0 0 250px; }
.qd .qd-srow { display: flex; justify-content: space-between; padding: 6px 0; font-size: 12px; border-bottom: 1px solid var(--qline); }
.qd .qd-srow span:first-child { color: var(--qmuted); }
.qd .qd-grand { border-bottom: none; border-top: 2px solid var(--navy); margin-top: 2px; padding-top: 10px; }
.qd .qd-grand span { font-size: 17px; font-weight: 800; color: var(--navy); }
.qd .qd-hangul { text-align: right; font-size: 12px; font-weight: 500; color: var(--ink); margin-top: 7px; }

/* 하단 바 + 회사정보 칼럼 (세미안 푸터식) */
.qd .qd-footer { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 24px; margin-top: auto; padding-top: 13px; border-top: 2px solid var(--navy); font-size: 10.5px; color: var(--qmuted); line-height: 1.7; }
.qd .qd-footcol { min-width: 0; }
.qd .qd-footcol .qd-fname { font-weight: 800; color: var(--navy); font-size: 12px; margin-bottom: 2px; }
.qd .qd-footcol .qd-mlabel { display: block; margin-bottom: 3px; }

.qd.design-simple {
  --navy: #20384f;
  --qline: #e3e7ed;
}
.qd.design-compact {
  --navy: #263238;
  --qline: #dfe4e9;
  padding: 12mm 10mm;
  font-size: 11px;
}
.qd.design-compact .qd-head { padding-bottom: 10px; }
.qd.design-compact .qd-brandname { font-size: 22px; }
.qd.design-compact .qd-qtitle { font-size: 19px; }
.qd.design-compact .qd-parties { gap: 16px; margin-top: 12px; }
.qd.design-compact .qd-meta { margin: 12px 0 0; padding: 8px 0; }
.qd.design-compact table.qd-items th { padding: 6px; font-size: 8.5px; }
.qd.design-compact table.qd-items td { padding: 6px; font-size: 10.5px; }
.qd.design-compact .qd-bottom { margin-top: 12px; }
.qd.design-compact .qd-footer { font-size: 9.5px; gap: 16px; }

.qd.design-formal {
  --navy: #111827;
  --ink: #111;
  --qmuted: #555f6c;
  --qline: #d8dce2;
}
.qd.design-formal .qd-brandname { color: #111; font-weight: 700; }
.qd.design-formal .qd-head,
.qd.design-formal .qd-grand,
.qd.design-formal .qd-footer { border-color: #111; }
.qd.design-formal .qd-qtitle { letter-spacing: 4px; }

.qd.design-studio {
  --navy: #12395d;
  --qline: #dce3ea;
}
.qd.design-studio .qd-head {
  align-items: flex-end;
  padding-bottom: 18px;
  border-bottom-width: 3px;
}
.qd.design-studio .qd-brandname {
  font-size: 34px;
  line-height: 1;
}
.qd.design-studio .qd-titlebox {
  padding: 8px 0 0 18px;
  border-left: 4px solid #c9a45a;
}
.qd.design-studio .qd-qtitle { font-size: 21px; letter-spacing: 3px; }
.qd.design-studio table.qd-items th { border-bottom-width: 2px; }

/* ===================== 견적 작성 퍼널 (세트 → 항목 → 디자인) ===================== */
.funnel { max-width: 880px; margin: 0 auto; padding: 8px 0 40px; }
.funnel-rail { display: flex; align-items: center; justify-content: center; gap: 8px; margin: 8px 0 30px; flex-wrap: wrap; }
.rail-step { display: inline-flex; align-items: center; gap: 8px; font-size: var(--fs-cap); font-weight: var(--w-med); color: var(--muted-2); }
.rail-step i { display: grid; place-items: center; width: 22px; height: 22px; border-radius: var(--r-pill); background: var(--content3); color: var(--muted); font-style: normal; font-size: 12px; font-weight: var(--w-semi); }
.rail-step.active { color: var(--fg); }
.rail-step.active i { background: var(--brand); color: var(--on-accent); box-shadow: var(--sh-brand-ring); }
.rail-step.done i { background: var(--brand-soft); color: var(--brand-soft-fg); }
.rail-bar { width: 34px; height: 2px; border-radius: 2px; background: var(--border); }

.funnel-stage { min-height: 320px; }
.funnel-q { animation: funnelIn .26s var(--ease-spring); }
@keyframes funnelIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
.funnel-kicker { font-size: var(--fs-cap); font-weight: var(--w-semi); color: var(--brand-soft-fg); letter-spacing: .04em; }
.funnel-title { margin: 6px 0 4px; font-size: var(--fs-h1); font-weight: var(--w-bold); color: var(--fg); }
.funnel-help { margin: 0 0 22px; color: var(--muted); font-size: var(--fs-md); }

.funnel-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 14px; }
.funnel-card { display: flex; flex-direction: column; gap: 6px; align-items: flex-start; padding: 20px; border: 1.5px solid var(--border); border-radius: var(--r-lg); background: var(--content1); cursor: pointer; text-align: left; transition: border-color var(--dur) var(--ease), transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease); }
.funnel-card:hover { border-color: var(--border-strong); transform: translateY(-2px); box-shadow: var(--sh-md); }
.funnel-card.sel { border-color: var(--brand); box-shadow: var(--sh-brand-ring); }
.funnel-card b { font-size: var(--fs-lg); color: var(--fg); }
.funnel-card span { font-size: var(--fs-cap); color: var(--muted); }

.funnel-itembar { display: flex; gap: 10px; margin-bottom: 14px; }
.funnel-itembar input { flex: 1; }
.funnel-items { display: flex; flex-direction: column; gap: 8px; max-height: 380px; overflow: auto; padding: 2px; }
.funnel-item { display: flex; align-items: center; gap: 8px; border: 1.5px solid var(--border); border-radius: var(--r-md); background: var(--content1); overflow: hidden; transition: border-color var(--dur) var(--ease), background var(--dur) var(--ease); }
.funnel-item.on { border-color: var(--brand); background: var(--brand-soft); }
.fi-toggle { flex: 1; display: flex; align-items: center; gap: 12px; padding: 12px 14px; background: none; border: none; cursor: pointer; text-align: left; min-width: 0; }
.fi-check { flex: none; display: grid; place-items: center; width: 24px; height: 24px; border-radius: var(--r-pill); border: 1.5px solid var(--border-strong); color: var(--muted-2); font-weight: var(--w-bold); font-size: 14px; }
.funnel-item.on .fi-check { background: var(--brand); border-color: var(--brand); color: var(--on-accent); }
.fi-name { flex: 1; display: flex; flex-direction: column; color: var(--fg); font-weight: var(--w-med); min-width: 0; }
.fi-name em { font-style: normal; font-size: var(--fs-tiny); color: var(--muted); font-weight: var(--w-reg); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.fi-price { flex: none; font-size: var(--fs-cap); color: var(--muted); font-feature-settings: "tnum"; }
.fi-qty { flex: none; display: flex; align-items: center; gap: 8px; padding-right: 12px; }
.fi-qty.dim { opacity: .35; }
.fi-qty button { width: 26px; height: 26px; border-radius: var(--r-sm); border: 1px solid var(--border-strong); background: var(--content1); color: var(--fg); cursor: pointer; font-size: 15px; line-height: 1; }
.fi-qty b { min-width: 20px; text-align: center; font-feature-settings: "tnum"; }
.funnel-empty { padding: 28px; text-align: center; color: var(--muted); background: var(--surface); border-radius: var(--r-md); }
.funnel-pickbar { margin-top: 14px; text-align: right; color: var(--muted); font-size: var(--fs-cap); }
.funnel-pickbar b { color: var(--fg); font-feature-settings: "tnum"; }

.funnel-designs { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 14px; }
.design-card { display: flex; flex-direction: column; gap: 4px; padding: 14px; border: 1.5px solid var(--border); border-radius: var(--r-lg); background: var(--content1); cursor: pointer; text-align: left; transition: border-color var(--dur) var(--ease), transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease); }
.design-card:hover { border-color: var(--border-strong); transform: translateY(-2px); box-shadow: var(--sh-md); }
.design-card.sel { border-color: var(--brand); box-shadow: var(--sh-brand-ring); }
.design-card b { font-size: var(--fs-md); color: var(--fg); }
.design-desc { font-size: var(--fs-tiny); color: var(--muted); }
.design-mini { display: block; position: relative; aspect-ratio: 1 / 1.414; background: #fff; border: 1px solid var(--border); border-radius: 6px; margin-bottom: 8px; overflow: hidden; padding: 10px 9px; }
.design-mini i { display: block; background: #e6e8ee; border-radius: 2px; height: 5px; margin-bottom: 5px; }
.design-mini i:nth-child(1) { width: 50%; }
.design-mini i:nth-child(2) { width: 100%; height: 26px; background: #f1f2f6; margin-top: 8px; }
.design-mini i:nth-child(3) { width: 38%; margin-top: 8px; margin-left: auto; background: #d8dbe3; }
.design-mini-simple i:nth-child(1) { background: var(--brand); width: 40%; }
.design-mini-compact { padding: 7px; }
.design-mini-compact i { height: 4px; margin-bottom: 3px; }
.design-mini-compact i:nth-child(2) { height: 34px; }
.design-mini-formal i:nth-child(1) { width: 70%; margin: 0 auto 8px; height: 6px; background: #111; }
.design-mini-formal i:nth-child(2) { border: 1px solid #cfd3da; background: #fff; }
.design-mini-studio i:nth-child(1) { width: 64%; height: 12px; background: #12395d; }
.design-mini-studio i:nth-child(3) { background: #c9a45a; width: 44%; }

.funnel-nav { display: flex; align-items: center; gap: 10px; margin-top: 28px; padding-top: 18px; border-top: 1px solid var(--divider); }
.funnel-spacer { flex: 1; }
.funnel-nav .btn.primary { min-width: 120px; }

.editor-bar { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-bottom: 16px; padding: 10px 14px; background: var(--brand-soft); border-radius: var(--r-md); }
.editor-bar .hint { color: var(--brand-soft-fg); }

/* 견적표 컬럼 선택 엔진 */
.col-summary-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; flex-wrap: wrap; }
.col-chips { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 12px; }
.cp { display: inline-flex; align-items: center; padding: 5px 12px; border-radius: var(--r-pill); font-size: var(--fs-cap); font-weight: var(--w-med); }
.cp.fix { background: var(--content3); color: var(--muted); }
.cp.ext { background: var(--brand-soft); color: var(--brand-soft-fg); box-shadow: inset 0 0 0 1px var(--brand); }
.cp.cond { background: var(--content2); color: var(--fg-soft); box-shadow: inset 0 0 0 1px var(--border-strong); }

/* 견적 구성 — 거래 성격 1클릭 엔진 */
.col-engine h2 { font-size: var(--fs-h2); font-weight: var(--w-bold); color: var(--fg); }
.biz-cards { display: flex; flex-wrap: wrap; gap: 9px; margin-bottom: 20px; }
.biz-card { display: inline-flex; align-items: center; gap: 8px; padding: 10px 14px; border: 1.5px solid var(--border); border-radius: var(--r-pill); background: transparent; cursor: pointer; font-size: var(--fs-body); font-weight: var(--w-med); color: var(--fg); transition: border-color var(--dur) var(--ease), transform var(--dur) var(--ease), background var(--dur) var(--ease); }
.biz-card:hover { border-color: var(--border-strong); transform: translateY(-1px); }
.biz-card.sel { border-color: var(--brand); background: transparent; color: var(--fg); box-shadow: var(--sh-brand-ring); }
.biz-emoji { display: none; }
.ce-hint { padding: 20px; text-align: center; color: var(--muted); background: var(--surface); border-radius: var(--r-md); }
.ce-result { padding: 16px 18px; background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md); }
.ce-result-lbl { font-size: var(--fs-cap); color: var(--muted); margin-bottom: 12px; }
.ce-result-lbl span { color: var(--muted-2); }
.ce-row { display: flex; align-items: flex-start; gap: 10px; margin-bottom: 10px; }
.ce-row:last-child { margin-bottom: 0; }
.ce-rl { font-size: var(--fs-tiny); color: var(--muted-2); width: 56px; flex: none; padding-top: 5px; }
.ce-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.ce-actions { display: flex; align-items: center; gap: 14px; margin-top: 16px; }
.ce-tweak { margin-top: 14px; padding: 16px; border: 1px dashed var(--border-strong); border-radius: var(--r-md); }
.ce-tweak-lbl { font-size: var(--fs-cap); font-weight: var(--w-semi); color: var(--fg-soft); margin-bottom: 9px; }
.ce-tweak-lbl span { font-weight: var(--w-reg); color: var(--muted-2); }
.tog-row { display: flex; flex-wrap: wrap; gap: 7px; }
.tog { padding: 6px 12px; border-radius: var(--r-pill); border: 1px solid var(--border-strong); background: var(--content1); color: var(--muted); cursor: pointer; font-size: var(--fs-cap); transition: border-color var(--dur) var(--ease), background var(--dur) var(--ease), color var(--dur) var(--ease); }
.tog:hover { border-color: var(--brand); color: var(--fg); }
.tog.on { border-color: var(--brand); background: var(--brand-soft); color: var(--brand-soft-fg); }
.qf-label { font-size: var(--fs-cap); font-weight: var(--w-semi); color: var(--fg-soft); margin: 18px 0 10px; }
.cat-bar { display: flex; flex-wrap: wrap; gap: 7px; margin-bottom: 12px; }
.cat-chip { padding: 5px 12px; border-radius: var(--r-pill); border: 1px solid var(--border-strong); background: var(--content1); color: var(--muted); cursor: pointer; font-size: var(--fs-cap); }
.cat-chip:hover { border-color: var(--brand); color: var(--fg); }
.cat-chip.on { border-color: var(--brand); background: var(--brand-soft); color: var(--brand-soft-fg); }
.cat-tag { display: inline-flex; align-items: center; padding: 1px 9px; border-radius: var(--r-pill); background: var(--content3); color: var(--muted); font-size: var(--fs-tiny); font-weight: var(--w-med); margin-left: 6px; vertical-align: middle; }
.onboard-biz { margin-top: 16px; }
.onboard-biz-lbl { font-size: var(--fs-md); font-weight: var(--w-semi); color: var(--fg); margin-bottom: 10px; }

/* 따라다니는 튜토리얼 바 */
.tutor-bar { position: sticky; top: 58px; z-index: 45; display: flex; align-items: center; gap: 12px; flex-wrap: wrap; padding: 10px 20px; background: var(--content1); border-bottom: 1px solid var(--border-strong); }
.tutor-badge { font-size: var(--fs-tiny); font-weight: var(--w-bold); color: var(--fg); background: transparent; padding: 3px 0; border-radius: 0; flex: none; }
.tutor-dots { display: flex; gap: 5px; }
.tutor-dot { display: grid; place-items: center; width: 20px; height: 20px; border-radius: var(--r-pill); background: transparent; border: 1px solid var(--border); color: var(--muted); font-size: 11px; font-weight: var(--w-bold); }
.tutor-dot.cur { background: transparent; border-color: var(--fg); color: var(--fg); }
.tutor-dot.done { background: transparent; border-color: var(--border-strong); color: var(--muted); }
.tutor-msg { font-size: var(--fs-cap); color: var(--fg-soft); }
.tutor-msg b { color: var(--fg); font-weight: var(--w-semi); }
.tutor-msg b.ok { color: var(--success); }
.tutor-spacer { flex: 1; min-width: 8px; }

/* 첫 사용 온보딩 워크스루 */
.onboard { border: 1.5px solid var(--fg); }
.onboard-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; }
.onboard-kicker { font-size: var(--fs-cap); font-weight: var(--w-semi); color: var(--brand-soft-fg); }
.onboard-title { font-size: var(--fs-h1); font-weight: var(--w-bold); color: var(--fg); margin-top: 2px; }
.onboard-steps { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 10px; margin-top: 16px; }
.onboard-step { display: flex; align-items: center; gap: 12px; padding: 14px; border: 1px solid var(--border); border-radius: 6px; background: var(--content1); cursor: pointer; text-align: left; transition: border-color var(--dur) var(--ease), transform var(--dur) var(--ease); }
.onboard-step:hover { border-color: var(--border-strong); transform: translateY(-1px); }
.onboard-step.current { border-color: var(--fg); box-shadow: var(--sh-brand-ring); }
.onboard-step.done { opacity: .72; }
.os-num { flex: none; display: grid; place-items: center; width: 26px; height: 26px; border-radius: var(--r-pill); background: transparent; border: 1px solid var(--border); color: var(--muted); font-weight: var(--w-bold); font-size: 13px; }
.onboard-step.current .os-num { background: transparent; border-color: var(--fg); color: var(--fg); }
.onboard-step.done .os-num { background: transparent; border-color: var(--border-strong); color: var(--muted); }
.os-body { flex: 1; display: flex; flex-direction: column; min-width: 0; }
.os-body b { font-size: var(--fs-md); color: var(--fg); font-weight: var(--w-semi); }
.os-body b em { font-style: normal; font-weight: var(--w-reg); color: var(--muted-2); font-size: var(--fs-tiny); }
.os-body span { font-size: var(--fs-cap); color: var(--muted); }
.os-cta { flex: none; font-size: var(--fs-cap); color: var(--brand-soft-fg); font-weight: var(--w-med); }
.onboard-step.done .os-cta { color: var(--muted); }
.col-preview { margin-top: 18px; padding: 12px 14px; background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md); display: flex; flex-wrap: wrap; gap: 7px; align-items: center; }
.col-preview-lbl { font-size: var(--fs-tiny); font-weight: var(--w-semi); color: var(--muted-2); letter-spacing: .03em; margin-right: 4px; }
.col-preview .cp { font-size: var(--fs-tiny); padding: 4px 10px; }

/* ===================== Print ===================== */
#printArea { display: none; }
@media print {
  @page { size: A4; margin: 0; }
  :root, [data-theme="dark"] {
    --bg: #fff; --content1: #fff; --content2: #fff; --card: #fff; --card-2: #fff;
    --fg: #000; --fg-soft: #000; --muted: #333; --border: #000;
  }
  * { animation: none !important; transition: none !important; box-shadow: none !important;
      text-shadow: none !important; backdrop-filter: none !important; -webkit-backdrop-filter: none !important; }
  html, body {
    width: 210mm !important;
    min-height: 297mm !important;
    margin: 0 !important;
    padding: 0 !important;
  }
  body { background: #fff !important; }
  body::before { display: none !important; }
  .app-header, .app-header::after, .no-print, .mode-tabs, .dropzone, .btn, #toast,
  .modal-back, .theme-toggle { display: none !important; }
  .view { display: none !important; }
  .main { max-width: none; margin: 0; padding: 0; }
  #printArea { display: block !important; width: 210mm !important; min-height: 297mm !important; }
  .doc-wrap { display: block; width: 210mm !important; min-height: 297mm !important; }
  .doc {
    width: 210mm !important;
    height: 297mm !important;
    min-height: 297mm !important;
    padding: 16mm 14mm !important;
    margin: 0 !important;
    background: #fff !important; color: #000 !important;
    border: none !important; border-radius: 0 !important;
    box-shadow: none !important;
  }
  .qd, .qd * { -webkit-print-color-adjust: exact; print-color-adjust: exact; }
  .qd::before, .qd::after { display: none !important; }
  .qd .qd-footer {
    position: absolute !important;
    left: 14mm !important;
    right: 14mm !important;
    bottom: 16mm !important;
    margin-top: 0 !important;
    background: #fff !important;
  }
  .qd .qd-bottom { margin-bottom: 34mm !important; }
  table.qd-items tr { break-inside: avoid; }
  .qd .qd-parties, .qd .qd-bottom { break-inside: avoid; }
}

/* 받은 견적 요청함 (Phase 1) */
.inbox-list { display: grid; gap: 12px; margin-top: 14px; }
.inbox-empty { padding: 32px 16px; text-align: center; color: var(--muted); border: 1px dashed var(--border); border-radius: 12px; line-height: 1.7; }
.inbox-card { background: var(--content1); border: 1px solid var(--border); border-radius: 12px; padding: 14px 16px; }
.inbox-card-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; flex-wrap: wrap; margin-bottom: 10px; }
.inbox-who { display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap; }
.inbox-who b { font-size: 15px; }
.inbox-when { font-size: 12px; color: var(--muted); }
.inbox-tag { font-size: 12px; padding: 2px 9px; border-radius: 20px; white-space: nowrap; }
.inbox-tag.ok { background: rgba(15,122,70,.12); color: var(--brand); }
.inbox-tag.new { background: rgba(120,120,120,.14); color: var(--muted); }
.inbox-usage { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--muted); margin: 0 2px 12px; }
.inbox-usage b { color: var(--text); font-variant-numeric: tabular-nums; }
.inbox-usage-bar { flex: 1; max-width: 160px; height: 6px; border-radius: 4px; background: var(--border); overflow: hidden; }
.inbox-usage-bar i { display: block; height: 100%; background: var(--brand); transition: width .3s; }
.inbox-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin: 0 2px 10px; }
.inbox-count { font-size: 12.5px; color: var(--muted); }
.inbox-count b { color: var(--text); }
.btn.xs { font-size: 11.5px; padding: 3px 10px; border-radius: 8px; }

/* 컴팩트 받은함 리스트 + 클릭 펼침 */
.ib-list { display: flex; flex-direction: column; gap: 6px; }
.ib-row { display: flex; align-items: center; gap: 10px; padding: 9px 13px; background: var(--content1); border: 1px solid var(--border); border-radius: 10px; cursor: pointer; transition: border-color .15s, background .15s; }
.ib-row:hover { border-color: var(--brand); }
.ib-row.open { border-color: var(--brand); background: var(--content2); border-bottom-left-radius: 0; border-bottom-right-radius: 0; }
.ib-from { font-weight: 650; font-size: 13px; white-space: nowrap; max-width: 38%; overflow: hidden; text-overflow: ellipsis; flex-shrink: 0; }
.ib-subj { flex: 1; min-width: 0; color: var(--muted); font-size: 13px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ib-badge { font-size: 11px; background: var(--brand-soft); color: var(--brand); padding: 1px 8px; border-radius: 10px; white-space: nowrap; }
.ib-when { font-size: 11.5px; color: var(--muted); white-space: nowrap; }
.ib-chev { color: var(--muted); font-size: 11px; width: 12px; text-align: center; }
/* 받은함 — 상태 탭 + intent 색칩 + 태그 */
.ib-tabs { display: flex; gap: 2px; margin-bottom: 10px; border-bottom: 1px solid var(--border); }
.ib-tab { background: none; border: none; padding: 8px 15px; font-size: 13.5px; font-weight: 600; color: var(--muted); cursor: pointer; border-bottom: 2px solid transparent; margin-bottom: -1px; }
.ib-tab b { font-weight: 700; }
.ib-tab.active { color: var(--brand); border-bottom-color: var(--brand); }
.ib-chips { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 12px; }
.ib-chip { display: inline-flex; align-items: center; gap: 5px; padding: 4px 11px; border-radius: 999px; border: 1px solid var(--border); background: var(--content1); font-size: 12px; font-weight: 600; color: var(--muted); cursor: pointer; transition: border-color .12s, background .12s, color .12s; }
.ib-chip:hover { border-color: var(--brand); }
.ib-chip-n { font-size: 10.5px; opacity: .7; }
.ib-chip.active { background: var(--brand); border-color: var(--brand); color: #fff; }
.ib-chip.c-quote.active { background: #0F7A46; border-color: #0F7A46; }
.ib-chip.c-as.active { background: #C2410C; border-color: #C2410C; }
.ib-chip.c-doc.active { background: #2563EB; border-color: #2563EB; }
.ib-chip.c-inspect.active { background: #7C3AED; border-color: #7C3AED; }
.ib-chip.c-inq.active { background: #475569; border-color: #475569; }
.ib-chip.c-etc.active { background: #64748B; border-color: #64748B; }
.ib-itag { font-size: 10.5px; font-weight: 700; padding: 2px 8px; border-radius: 6px; white-space: nowrap; flex-shrink: 0; letter-spacing: .02em; }
.ib-itag.c-quote { background: rgba(15,122,70,.13); color: #0F7A46; }
.ib-itag.c-as { background: rgba(194,65,12,.13); color: #C2410C; }
.ib-itag.c-doc { background: rgba(37,99,235,.12); color: #2563EB; }
.ib-itag.c-inspect { background: rgba(124,58,237,.12); color: #7C3AED; }
.ib-itag.c-inq { background: rgba(71,85,105,.14); color: #475569; }
.ib-itag.c-etc { background: rgba(120,120,120,.14); color: var(--muted); }
.ib-stat { font-size: 10.5px; font-weight: 700; padding: 1px 7px; border-radius: 6px; white-space: nowrap; flex-shrink: 0; background: rgba(120,120,120,.16); color: var(--muted); }
.ib-stat.done { background: rgba(15,122,70,.13); color: var(--brand); }
.inbox-empty.sm { font-size: 13px; padding: 18px 4px; }
.ib-detail { border: 1px solid var(--brand); border-top: none; border-radius: 0 0 10px 10px; padding: 12px 15px 14px; background: var(--content1); }
.ib-meta { display: flex; flex-wrap: wrap; gap: 6px 22px; font-size: 12.5px; color: var(--text); padding: 2px 0 10px; margin-bottom: 4px; border-bottom: 1px solid var(--border); }
.ib-meta > div { display: inline-flex; align-items: center; gap: 5px; min-height: 24px; }
.ib-meta-k { font-size: 10.5px; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: .04em; margin-right: 0; white-space: nowrap; }
.ib-meta-em { color: var(--muted); }
.ib-meta .btn.xs { margin-left: 2px; line-height: 1; }
.ib-sec-label { font-size: 10.5px; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: .05em; margin: 12px 0 6px; }
.ib-sec-label:first-child { margin-top: 2px; }
.ib-reqsum { font-size: 13.5px; color: var(--text); background: var(--surface); border-radius: 8px; padding: 9px 11px; line-height: 1.5; }
.ib-prods { display: flex; flex-direction: column; gap: 6px; }
.ib-prod { font-size: 13px; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; padding: 4px 0; }
.ib-prod b { font-weight: 650; }
.ib-qty { color: var(--brand); font-weight: 650; }
.ib-dbtag { font-size: 11px; background: rgba(15,122,70,.12); color: var(--brand); padding: 1px 8px; border-radius: 8px; white-space: nowrap; }
.ib-spec { font-size: 11.5px; color: var(--muted); }
.ib-rawnote { font-size: 11.5px; color: var(--muted); font-style: italic; }
.ib-prod.new b { color: var(--text); }
.ib-cost { font-size: 10.5px; opacity: .65; margin-left: 2px; }
.ib-srctag { font-size: 10px; font-weight: 700; padding: 1px 7px; border-radius: 8px; margin-left: 6px; letter-spacing: 0; text-transform: none; vertical-align: middle; }
.ib-srctag.rule { background: rgba(120,120,120,.14); color: var(--muted); }
.ib-srctag.ai { background: var(--brand-soft); color: var(--brand); }
.ib-nomatch, .ib-loading { font-size: 12.5px; color: var(--muted); padding: 4px 0; }
.ib-loading { color: var(--brand); }
.ib-miss { font-size: 12.5px; color: var(--warning); margin-top: 8px; }
.ib-aierr { font-size: 12px; color: var(--danger, #c0392b); margin-top: 8px; display: flex; align-items: center; gap: 8px; }
.ib-body { font-size: 12.5px; color: var(--text); white-space: pre-wrap; line-height: 1.6; max-height: 300px; overflow: auto; background: var(--surface); border-radius: 8px; padding: 11px 13px; }
.inbox-tbl { width: 100%; border-collapse: collapse; font-size: 13px; }
.inbox-tbl th { text-align: left; font-weight: 500; color: var(--muted); font-size: 12px; padding: 4px 8px; border-bottom: 1px solid var(--border); }
.inbox-tbl td { padding: 5px 8px; border-bottom: 1px solid var(--border); }
.inbox-tbl .num { text-align: right; white-space: nowrap; }
.inbox-tbl tfoot td { border-bottom: none; padding-top: 8px; }
.inbox-muted { color: var(--muted); }
.inbox-noitems { font-size: 13px; color: var(--muted); padding: 6px 0; }
.inbox-msg { margin-top: 10px; padding: 8px 12px; background: var(--content2, rgba(127,127,127,.08)); border-radius: 8px; font-size: 13px; line-height: 1.5; }
.inbox-card-actions { display: flex; gap: 8px; margin-top: 12px; flex-wrap: wrap; }

/* 받은함 — 메일 전달주소 카드 */
.inbox-fwd { background: var(--brand-soft); border: 1px solid var(--brand); border-radius: 14px; padding: 16px 18px; }
.inbox-fwd-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 10px; flex-wrap: wrap; }
.inbox-fwd-label { font-weight: 700; font-size: 14px; color: var(--brand-soft-fg); }
.inbox-fwd-status { font-size: 12px; color: var(--brand); font-weight: 600; white-space: nowrap; }
.inbox-fwd-row { display: flex; align-items: stretch; gap: 8px; }
.inbox-fwd-addr { flex: 1; min-width: 0; font-family: var(--font-mono); font-size: 13.5px; font-weight: 600; color: var(--fg); background: var(--content1); border: 1px solid var(--border); border-radius: 9px; padding: 10px 12px; overflow-x: auto; white-space: nowrap; user-select: all; -webkit-user-select: all; }
.inbox-fwd-row .btn { white-space: nowrap; align-self: center; }
.inbox-fwd-how { margin: 11px 0 0; font-size: 12.5px; line-height: 1.6; color: var(--muted); }
.inbox-fwd-priv { color: var(--muted-2); }
.inbox-manual { margin-top: 14px; }
.inbox-manual > summary { cursor: pointer; font-size: 13px; color: var(--muted); padding: 6px 2px; user-select: none; }
.inbox-manual > summary:hover { color: var(--fg); }
.inbox-manual .panel { margin-top: 10px; }

/* 받은함 — Gmail 연결 카드 */
.gmail-card { border: 1px solid var(--border-strong); border-radius: 14px; padding: 16px 18px; background: var(--content1); box-shadow: var(--sh-sm); }
.gmail-head { display: flex; align-items: flex-start; gap: 12px; }
.gmail-ic { flex: 0 0 auto; width: 40px; height: 40px; display: grid; place-items: center; background: var(--content2); border: 1px solid var(--border); border-radius: 10px; }
.gmail-head-tx { min-width: 0; }
.gmail-title { font-weight: 700; font-size: 15px; color: var(--fg); }
.gmail-sub { font-size: 12.5px; color: var(--muted); line-height: 1.5; margin-top: 3px; }
.gmail-actions { display: flex; gap: 8px; margin-top: 14px; flex-wrap: wrap; align-items: center; }
.gmail-tf { font-size: 13px; padding: 7px 10px; border-radius: 9px; border: 1px solid var(--border); background: var(--content1); color: var(--text); }
.gmail-tf-note { font-size: 12px; color: var(--warning); margin-top: 8px; line-height: 1.5; }
.gmail-progress { margin-top: 12px; font-size: 13px; color: var(--fg-soft); background: var(--content2); border: 1px solid var(--border); border-radius: 9px; padding: 9px 12px; line-height: 1.5; }
.gmail-progress.busy { color: var(--brand); border-color: var(--ring-quiet); }
.gmail-progress.busy::before { content: "⟳"; display: inline-block; margin-right: 7px; animation: gm-spin .9s linear infinite; }
@keyframes gm-spin { to { transform: rotate(360deg); } }

/* 받은함 — AI 정밀분석 패널 */
.ai-panel { margin-top: 12px; border: 1px solid var(--brand); border-radius: 12px; background: var(--brand-soft); padding: 12px 14px; }
.ai-head { font-weight: 700; font-size: 13px; color: var(--brand-soft-fg); display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
.ai-intent { font-size: 11px; font-weight: 600; background: var(--brand); color: var(--on-accent); padding: 2px 9px; border-radius: 20px; }
.ai-tbl { width: 100%; border-collapse: collapse; font-size: 13px; }
.ai-tbl th { text-align: left; font-weight: 500; color: var(--muted); font-size: 11px; padding: 3px 8px; border-bottom: 1px solid var(--border); }
.ai-tbl td { padding: 5px 8px; border-bottom: 1px solid var(--divider); }
.ai-tbl .num { text-align: right; white-space: nowrap; }
.ai-noterow td { padding: 0 8px 5px; border-bottom: 1px solid var(--divider); font-size: 11.5px; color: var(--muted); }
.ai-sub { color: var(--muted); font-size: 11px; margin-left: 6px; }
.ai-flag { display: inline-block; font-size: 10.5px; font-weight: 700; color: var(--warning); background: var(--warning-soft); padding: 1px 6px; border-radius: 6px; margin-left: 4px; }
.ai-empty { font-size: 13px; color: var(--muted); padding: 4px 0; }
.ai-row { font-size: 12.5px; margin-top: 8px; line-height: 1.5; }
.ai-row b { color: var(--fg); margin-right: 6px; }
.ai-row.ai-miss b { color: var(--warning); }
.ai-reply { margin-top: 10px; }
.ai-reply > summary { cursor: pointer; font-size: 12.5px; color: var(--brand); font-weight: 600; }
.ai-reply-body { margin-top: 6px; padding: 10px 12px; background: var(--content1); border: 1px solid var(--border); border-radius: 9px; font-size: 13px; line-height: 1.6; white-space: pre-wrap; }
