
:root {
  --bg: #f7f8fb;
  --paper: #ffffff;
  --ink: #101828;
  --text: #1f2937;
  --muted: #667085;
  --light: #98a2b3;
  --line: #e6ebf2;
  --line2: #d8e0ec;
  --blue: #2563eb;
  --blue2: #1d4ed8;
  --blueSoft: #edf4ff;
  --sky: #e7f7ff;
  --green: #16a34a;
  --greenSoft: #dcfce7;
  --amber: #f59e0b;
  --amberSoft: #fffbeb;
  --purple: #7c3aed;
  --purpleSoft: #f3e8ff;
  --radius: 24px;
  --shadow: 0 18px 50px rgba(16, 24, 40, .08);
  --shadow2: 0 28px 80px rgba(16, 24, 40, .10);
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: auto;
}

body {
  margin: 0;
  min-height: 100vh;
  color: var(--ink);
  background:
    radial-gradient(circle at 12% 8%, rgba(37,99,235,.10), transparent 26%),
    radial-gradient(circle at 86% 2%, rgba(14,165,233,.10), transparent 25%),
    linear-gradient(180deg, #ffffff 0%, #f7f8fb 100%);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Pretendard", "Noto Sans KR", Arial, sans-serif;
  letter-spacing: -0.02em;
  word-break: keep-all;
  overflow-x: hidden;
}

a {
  color: inherit;
  text-decoration: none;
}

button,
input {
  font-family: inherit;
}

#snowCanvas {
  position: fixed;
  inset: 0;
  width: 100vw;
  height: 100vh;
  z-index: 0;
  pointer-events: none;
  opacity: .38;
}

.page {
  position: relative;
  z-index: 1;
}

.container {
  width: min(1120px, calc(100% - 40px));
  margin: 0 auto;
}

.header {
  position: sticky;
  top: 0;
  z-index: 20;
  background: rgba(255, 255, 255, .84);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(16, 24, 40, .06);
}

.nav {
  height: 72px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
}

.logo {
  display: flex;
  align-items: center;
  gap: 11px;
}

.logo-mark {
  width: 38px;
  height: 38px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  color: #fff;
  background: linear-gradient(135deg, #2563eb, #0ea5e9);
  box-shadow: 0 14px 36px rgba(37, 99, 235, .22);
  font-size: 14px;
  font-weight: 850;
}

.logo-name {
  display: block;
  font-size: 23px;
  line-height: 1;
  font-weight: 850;
  letter-spacing: -.055em;
}

.logo-sub {
  display: block;
  margin-top: 5px;
  color: var(--light);
  font-size: 12px;
  font-weight: 600;
}

.nav-links {
  display: flex;
  align-items: center;
  gap: 22px;
  color: #344054;
  font-size: 14px;
  font-weight: 720;
}

.nav-links a:hover,
.nav-links a.active {
  color: var(--blue);
}

.nav-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.btn {
  min-height: 43px;
  padding: 0 17px;
  border-radius: 13px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid transparent;
  font-size: 14px;
  font-weight: 760;
  white-space: nowrap;
  transition: .18s ease;
  cursor: pointer;
}

.btn:hover {
  transform: translateY(-1px);
}

.btn-primary {
  color: #fff;
  background: var(--blue);
  box-shadow: 0 12px 28px rgba(37, 99, 235, .22);
}

.btn-primary:hover {
  background: var(--blue2);
}

.btn-ghost {
  color: #344054;
  background: rgba(255,255,255,.68);
  border-color: var(--line);
}

.btn-soft {
  color: var(--blue);
  background: var(--blueSoft);
  border-color: #dce9ff;
}

.btn-dark {
  color: #fff;
  background: #101828;
  box-shadow: 0 12px 28px rgba(16,24,40,.18);
}

.menu-button {
  display: none;
  width: 44px;
  height: 44px;
  border-radius: 13px;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--ink);
  font-size: 20px;
  font-weight: 800;
}

.mobile-panel {
  display: none;
  padding: 0 0 16px;
}

.mobile-panel a {
  display: block;
  padding: 14px 0;
  border-top: 1px solid var(--line);
  color: #344054;
  font-size: 15px;
  font-weight: 720;
}

/* shared */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  color: var(--blue);
  background: rgba(237, 244, 255, .92);
  border: 1px solid #dce9ff;
  font-size: 13px;
  font-weight: 760;
}

.badge::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 99px;
  background: var(--blue);
  box-shadow: 0 0 0 5px rgba(37,99,235,.10);
}

.hero {
  padding: 84px 0 72px;
}

.hero-inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: 42px;
}

.hero-copy {
  max-width: 850px;
  margin: 0 auto;
  text-align: center;
}

.hero h1 {
  margin: 22px auto 18px;
  max-width: 860px;
  font-size: clamp(38px, 5vw, 64px);
  line-height: 1.06;
  letter-spacing: -.075em;
  font-weight: 860;
}

.hero h1 span {
  color: var(--blue);
}

.hero p {
  max-width: 720px;
  margin: 0 auto;
  color: var(--muted);
  font-size: 18px;
  line-height: 1.78;
  font-weight: 500;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 11px;
  margin-top: 30px;
}

.section {
  padding: 76px 0;
}

.section-head {
  max-width: 740px;
  margin: 0 auto 38px;
  text-align: center;
}

.eyebrow {
  margin: 0 0 11px;
  color: var(--blue);
  font-size: 12px;
  font-weight: 820;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.section-head h2 {
  margin: 0;
  font-size: clamp(30px, 3.7vw, 44px);
  line-height: 1.17;
  letter-spacing: -.06em;
  font-weight: 840;
}

.section-head p {
  margin: 15px 0 0;
  color: var(--muted);
  font-size: 16.5px;
  line-height: 1.74;
}

.icon {
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  margin-bottom: 13px;
  border-radius: 14px;
  background: #fff;
  border: 1px solid var(--line);
}

.icon svg {
  width: 20px;
  height: 20px;
  stroke: var(--blue);
  stroke-width: 2.1;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

/* Home */
.platform {
  max-width: 980px;
  margin: 0 auto;
  border-radius: 32px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(16,24,40,.08);
  box-shadow: var(--shadow2);
  overflow: hidden;
}

.platform-top {
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 18px;
  background: #fbfdff;
  border-bottom: 1px solid var(--line);
}

.dots {
  display: flex;
  gap: 7px;
}

.dots i {
  width: 9px;
  height: 9px;
  border-radius: 99px;
  background: #cbd5e1;
}

.platform-pill {
  padding: 7px 10px;
  border-radius: 99px;
  color: #047857;
  background: #dcfce7;
  font-size: 12px;
  font-weight: 820;
}

.platform-body {
  padding: 26px;
}

.platform-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 22px;
  margin-bottom: 20px;
}

.platform-head h2 {
  margin: 0;
  font-size: 26px;
  letter-spacing: -.055em;
  font-weight: 840;
}

.platform-head p {
  max-width: 560px;
  margin: 9px 0 0;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.65;
}

.status {
  flex: 0 0 auto;
  padding: 8px 11px;
  border-radius: 99px;
  color: var(--blue);
  background: var(--blueSoft);
  font-size: 12px;
  font-weight: 800;
}

.tile-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}

.tile {
  min-height: 142px;
  padding: 17px;
  border-radius: 21px;
  background: #f7faff;
  border: 1px solid #e4ecf7;
}

.tile b,
.feature b,
.roadmap b {
  display: block;
  font-size: 15.5px;
  letter-spacing: -.035em;
  font-weight: 790;
}

.tile span,
.feature span {
  display: block;
  margin-top: 6px;
  color: #667085;
  font-size: 13.5px;
  line-height: 1.55;
}

.about-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.about-card {
  min-height: 216px;
  padding: 24px;
  border-radius: 24px;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(16,24,40,.08);
  box-shadow: var(--shadow);
}

.about-card h3 {
  margin: 16px 0 10px;
  font-size: 20px;
  letter-spacing: -.045em;
}

.about-card p {
  margin: 0;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.7;
}

.program-section {
  padding: 78px 0;
}

.program-wrap {
  display: grid;
  grid-template-columns: .9fr 1.1fr;
  gap: 28px;
  align-items: stretch;
}

.program-copy {
  padding: 32px;
  border-radius: 28px;
  color: #fff;
  background:
    radial-gradient(circle at 88% 8%, rgba(103,232,249,.22), transparent 34%),
    linear-gradient(135deg, #101828, #172033);
  box-shadow: var(--shadow2);
}

.program-copy h2 {
  margin: 16px 0 14px;
  font-size: clamp(30px, 3.7vw, 44px);
  line-height: 1.15;
  letter-spacing: -.065em;
}

.program-copy p {
  margin: 0;
  color: #cbd5e1;
  font-size: 16px;
  line-height: 1.74;
}

.program-card {
  display: grid;
  grid-template-columns: 72px 1fr auto;
  gap: 18px;
  align-items: center;
  padding: 24px;
  border-radius: 28px;
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(16,24,40,.08);
  box-shadow: var(--shadow);
  transition: .18s ease;
}

.program-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow2);
}

.program-icon {
  width: 72px;
  height: 72px;
  display: grid;
  place-items: center;
  border-radius: 24px;
  background: var(--blueSoft);
  border: 1px solid #dce9ff;
}

.program-icon svg {
  width: 30px;
  height: 30px;
  stroke: var(--blue);
  stroke-width: 2.1;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.program-card h3 {
  margin: 0;
  font-size: 23px;
  letter-spacing: -.055em;
}

.program-card p {
  margin: 8px 0 0;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.68;
}

.pill {
  padding: 8px 11px;
  border-radius: 99px;
  color: #047857;
  background: #dcfce7;
  font-size: 12px;
  font-weight: 820;
  white-space: nowrap;
}

.roadmap-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.roadmap {
  padding: 24px;
  border-radius: 24px;
  background: rgba(255,255,255,.72);
  border: 1px dashed #cbd5e1;
}

.roadmap p {
  margin: 10px 0 0;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.68;
}

/* Purchase */
.purchase-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.price-card {
  position: relative;
  padding: 26px;
  border-radius: 28px;
  background: rgba(255,255,255,.84);
  border: 1px solid rgba(16,24,40,.08);
  box-shadow: var(--shadow);
  overflow: hidden;
}

.price-card.featured {
  border-color: rgba(37,99,235,.35);
  box-shadow: 0 28px 90px rgba(37,99,235,.14);
}

.price-card.featured::before {
  content: "추천";
  position: absolute;
  right: 22px;
  top: 22px;
  padding: 7px 10px;
  border-radius: 999px;
  background: var(--blue);
  color: #fff;
  font-size: 12px;
  font-weight: 820;
}

.price-card h3 {
  margin: 18px 0 8px;
  font-size: 24px;
  letter-spacing: -.055em;
}

.price-card p {
  margin: 0;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.65;
}

.price {
  margin: 24px 0 18px;
  padding: 16px;
  border-radius: 18px;
  background: #f7faff;
  border: 1px solid #e4ecf7;
}

.price strong {
  display: block;
  font-size: 22px;
  letter-spacing: -.045em;
}

.price span {
  display: block;
  margin-top: 5px;
  color: var(--muted);
  font-size: 13px;
}

.check-list {
  display: grid;
  gap: 10px;
  margin: 18px 0 0;
  padding: 0;
  list-style: none;
}

.check-list li {
  display: flex;
  gap: 8px;
  color: #475467;
  font-size: 14px;
  line-height: 1.55;
}

.check-list li::before {
  content: "✓";
  color: var(--blue);
  font-weight: 900;
}

.release-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}

.release-card {
  padding: 22px;
  border-radius: 22px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(16,24,40,.08);
  box-shadow: var(--shadow);
}

.release-card b {
  display: block;
  font-size: 18px;
  letter-spacing: -.04em;
}

.release-card p {
  margin: 9px 0 0;
  color: var(--muted);
  font-size: 14.5px;
  line-height: 1.65;
}

.release-card em {
  display: inline-flex;
  margin-top: 16px;
  padding: 7px 9px;
  border-radius: 999px;
  background: #f1f5f9;
  color: #475467;
  font-style: normal;
  font-size: 12px;
  font-weight: 780;
}

/* Auth */
.auth-shell {
  min-height: calc(100vh - 72px);
  padding: 70px 0;
  display: grid;
  align-items: center;
}

.auth-grid {
  display: grid;
  grid-template-columns: .9fr 1.1fr;
  gap: 32px;
  align-items: center;
}

.auth-copy h1 {
  margin: 20px 0 16px;
  font-size: clamp(36px, 4.6vw, 56px);
  line-height: 1.08;
  letter-spacing: -.07em;
}

.auth-copy p {
  max-width: 520px;
  color: var(--muted);
  font-size: 17px;
  line-height: 1.75;
}

.auth-card {
  padding: 30px;
  border-radius: 30px;
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(16,24,40,.08);
  box-shadow: var(--shadow2);
}

.auth-card h2 {
  margin: 0 0 8px;
  font-size: 28px;
  letter-spacing: -.055em;
}

.auth-card > p {
  margin: 0 0 24px;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.65;
}

.form-grid {
  display: grid;
  gap: 15px;
}

.field label {
  display: block;
  margin-bottom: 8px;
  color: #344054;
  font-size: 14px;
  font-weight: 760;
}

.field input {
  width: 100%;
  height: 50px;
  padding: 0 14px;
  border-radius: 15px;
  border: 1px solid var(--line2);
  background: #fff;
  color: var(--ink);
  font-size: 15px;
  outline: none;
  transition: .18s ease;
}

.field input:focus {
  border-color: rgba(37,99,235,.55);
  box-shadow: 0 0 0 4px rgba(37,99,235,.10);
}

.form-note {
  margin-top: 16px;
  color: var(--muted);
  font-size: 13.5px;
  line-height: 1.6;
}

.auth-switch {
  margin-top: 18px;
  text-align: center;
  color: var(--muted);
  font-size: 14px;
}

.auth-switch a {
  color: var(--blue);
  font-weight: 800;
}

/* Download */
.download-layout {
  display: grid;
  grid-template-columns: .92fr 1.08fr;
  gap: 30px;
  align-items: center;
}

.download-card {
  padding: 34px;
  border-radius: 32px;
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(16,24,40,.08);
  box-shadow: var(--shadow2);
}

.download-card h2 {
  margin: 18px 0 12px;
  font-size: clamp(30px, 3.8vw, 44px);
  line-height: 1.15;
  letter-spacing: -.065em;
}

.download-card p {
  margin: 0;
  color: var(--muted);
  font-size: 16.5px;
  line-height: 1.75;
}

.download-meta {
  display: grid;
  gap: 12px;
  margin-top: 24px;
}

.meta-row {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 16px;
  border-radius: 16px;
  background: #f7faff;
  border: 1px solid #e4ecf7;
  color: #475467;
  font-size: 14px;
}

.meta-row b {
  color: var(--ink);
}

.download-visual {
  overflow: hidden;
  border-radius: 32px;
  background:
    radial-gradient(circle at 80% 12%, rgba(37,99,235,.16), transparent 30%),
    linear-gradient(135deg, #101828, #172033);
  box-shadow: var(--shadow2);
  color: #fff;
  padding: 28px;
}

.download-window {
  border-radius: 26px;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.14);
  padding: 22px;
}

.download-window h3 {
  margin: 0 0 12px;
  font-size: 24px;
  letter-spacing: -.055em;
}

.download-window p {
  margin: 0 0 20px;
  color: #cbd5e1;
  line-height: 1.68;
}

.download-steps {
  display: grid;
  gap: 10px;
}

.download-step {
  padding: 14px;
  border-radius: 16px;
  background: rgba(255,255,255,.09);
  border: 1px solid rgba(255,255,255,.12);
  color: #e5e7eb;
  font-size: 14px;
}

/* Detail */
.detail-hero {
  padding: 82px 0 70px;
}

.detail-grid {
  display: grid;
  grid-template-columns: 1fr .98fr;
  gap: 54px;
  align-items: center;
}

.breadcrumb {
  margin-bottom: 18px;
  color: var(--muted);
  font-size: 14px;
}

.breadcrumb a {
  color: var(--blue);
  font-weight: 760;
}

.detail-hero h1 {
  margin: 22px 0 18px;
  font-size: clamp(38px, 5vw, 58px);
  line-height: 1.08;
  letter-spacing: -.07em;
}

.detail-hero p {
  max-width: 650px;
  margin: 0;
  color: var(--muted);
  font-size: 18px;
  line-height: 1.78;
}

.mock {
  padding: 20px;
  border-radius: 30px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(16,24,40,.08);
  box-shadow: var(--shadow2);
}

.mock-inner {
  padding: 22px;
  border-radius: 24px;
  background: #fff;
  color: #0f172a;
}

.mock-head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: center;
  margin-bottom: 16px;
}

.mock-head b {
  font-size: 20px;
  letter-spacing: -.045em;
}

.mock-head span {
  padding: 7px 10px;
  border-radius: 99px;
  background: #dcfce7;
  color: #047857;
  font-size: 12px;
  font-weight: 820;
}

.mock-list {
  display: grid;
  gap: 10px;
}

.mock-row {
  display: grid;
  grid-template-columns: 1fr 86px;
  gap: 12px;
  align-items: center;
  padding: 14px;
  border-radius: 17px;
  background: #f7faff;
  border: 1px solid #e4ecf7;
}

.mock-row b {
  display: block;
  font-size: 14.5px;
}

.mock-row small {
  display: block;
  margin-top: 4px;
  color: #64748b;
  line-height: 1.45;
}

.mock-row em {
  justify-self: end;
  padding: 7px 9px;
  border-radius: 99px;
  color: var(--blue);
  background: var(--blueSoft);
  font-style: normal;
  font-size: 12px;
  font-weight: 760;
}

.info-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.feature {
  padding: 24px;
  border-radius: 24px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(16,24,40,.08);
  box-shadow: var(--shadow);
}

.feature h3 {
  margin: 16px 0 10px;
  font-size: 20px;
  letter-spacing: -.045em;
}

.feature p {
  margin: 0;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.7;
}

.process-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}

.process {
  padding: 22px;
  border-radius: 24px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(16,24,40,.08);
  box-shadow: var(--shadow);
}

.process strong {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  margin-bottom: 18px;
  border-radius: 12px;
  background: var(--blue);
  color: #fff;
  font-size: 14px;
}

.process b {
  display: block;
  font-size: 18px;
  letter-spacing: -.045em;
}

.process p {
  margin: 9px 0 0;
  color: var(--muted);
  font-size: 14.5px;
  line-height: 1.65;
}

.contact-page {
  min-height: calc(100vh - 72px);
  padding: 84px 0;
}

.contact-box {
  max-width: 790px;
  margin: 0 auto;
  padding: 40px;
  border-radius: 30px;
  background: rgba(255,255,255,.84);
  border: 1px solid rgba(16,24,40,.08);
  box-shadow: var(--shadow2);
  text-align: center;
}

.contact-box h1 {
  margin: 18px 0 14px;
  font-size: clamp(34px, 4vw, 48px);
  letter-spacing: -.065em;
}

.contact-box p {
  max-width: 600px;
  margin: 0 auto;
  color: var(--muted);
  font-size: 16.5px;
  line-height: 1.75;
}

.contact-methods {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
  margin-top: 30px;
}

.contact-method {
  padding: 22px;
  border-radius: 22px;
  background: #f7faff;
  border: 1px solid #e4ecf7;
  text-align: left;
}

.contact-method b {
  display: block;
  font-size: 18px;
}

.contact-method span {
  display: block;
  margin-top: 8px;
  color: var(--muted);
}

.footer {
  padding: 28px 0;
  color: #667085;
  border-top: 1px solid rgba(16,24,40,.08);
  background: rgba(255,255,255,.76);
  font-size: 14px;
}

.footer-inner {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  flex-wrap: wrap;
}

.footer strong {
  color: var(--ink);
}

@media (max-width: 1040px) {
  .nav-links,
  .nav-actions {
    display: none;
  }

  .menu-button {
    display: block;
  }

  .mobile-panel.is-open {
    display: block;
  }

  .program-wrap,
  .detail-grid,
  .auth-grid,
  .download-layout {
    grid-template-columns: 1fr;
  }

  .tile-grid,
  .about-grid,
  .info-grid,
  .roadmap-grid,
  .purchase-grid,
  .release-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .process-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 680px) {
  .container {
    width: min(100% - 28px, 1120px);
  }

  .hero,
  .detail-hero,
  .contact-page,
  .auth-shell {
    padding: 58px 0 52px;
  }

  .hero h1,
  .detail-hero h1,
  .auth-copy h1 {
    font-size: clamp(34px, 10.5vw, 48px);
  }

  .hero p,
  .detail-hero p {
    font-size: 16px;
  }

  .section,
  .program-section {
    padding: 58px 0;
  }

  .tile-grid,
  .about-grid,
  .info-grid,
  .roadmap-grid,
  .process-grid,
  .contact-methods,
  .purchase-grid,
  .release-grid {
    grid-template-columns: 1fr;
  }

  .platform-body,
  .program-copy,
  .contact-box,
  .auth-card,
  .download-card {
    padding: 24px 20px;
  }

  .program-card {
    grid-template-columns: 64px 1fr;
  }

  .program-card .pill {
    grid-column: 1 / -1;
    justify-self: start;
  }

  .hero-actions {
    flex-direction: column;
  }

  .btn {
    width: 100%;
  }

  .platform-head {
    flex-direction: column;
  }
}


/* v2 updates */
.program-copy {
  color: var(--ink) !important;
  background:
    radial-gradient(circle at 88% 8%, rgba(37,99,235,.13), transparent 34%),
    linear-gradient(135deg, rgba(255,255,255,.94), rgba(237,244,255,.88)) !important;
  border: 1px solid rgba(16,24,40,.08);
}
.program-copy p { color: var(--muted) !important; }
.program-copy .badge { background: #fff; }

.download-visual {
  color: var(--ink) !important;
  background:
    radial-gradient(circle at 86% 12%, rgba(37,99,235,.13), transparent 34%),
    linear-gradient(135deg, rgba(255,255,255,.94), rgba(237,244,255,.86)) !important;
  border: 1px solid rgba(16,24,40,.08);
}
.download-window {
  background: #fff !important;
  border: 1px solid #e4ecf7 !important;
}
.download-window p { color: var(--muted) !important; }
.download-step {
  background: #f7faff !important;
  border-color: #e4ecf7 !important;
  color: #475467 !important;
}
.notice {
  padding: 14px 16px;
  border-radius: 16px;
  margin-bottom: 18px;
  font-size: 14px;
  line-height: 1.55;
  font-weight: 700;
}
.notice.ok { background: #dcfce7; color: #047857; border: 1px solid #bbf7d0; }
.notice.error { background: #fef2f2; color: #b91c1c; border: 1px solid #fecaca; }
.notice.info { background: #edf4ff; color: #1d4ed8; border: 1px solid #dbeafe; }

.admin-shell { padding: 70px 0; }
.admin-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-bottom: 22px;
}
.admin-stat {
  padding: 24px;
  border-radius: 24px;
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(16,24,40,.08);
  box-shadow: var(--shadow);
}
.admin-stat b {
  display: block;
  font-size: 34px;
  letter-spacing: -.06em;
}
.admin-stat span {
  display: block;
  margin-top: 6px;
  color: var(--muted);
  font-size: 14px;
  font-weight: 700;
}
.admin-panel {
  margin-top: 18px;
  padding: 24px;
  border-radius: 26px;
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(16,24,40,.08);
  box-shadow: var(--shadow);
  overflow: hidden;
}
.admin-panel h2 {
  margin: 0 0 16px;
  font-size: 24px;
  letter-spacing: -.05em;
}
.table-wrap { overflow-x: auto; }
.admin-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 760px;
}
.admin-table th,
.admin-table td {
  padding: 14px 12px;
  border-bottom: 1px solid #e6ebf2;
  text-align: left;
  font-size: 14px;
}
.admin-table th {
  color: #344054;
  background: #f7faff;
  font-weight: 800;
}
.admin-table td { color: #475467; }
.admin-table tr:last-child td { border-bottom: 0; }

@media (max-width: 900px) {
  .admin-grid { grid-template-columns: 1fr; }
}


/* v6 Ant Design inspired home */
body.home-ant {
  background:
    radial-gradient(circle at 6% 18%, rgba(37,99,235,.08), transparent 18%),
    radial-gradient(circle at 92% 8%, rgba(14,165,233,.08), transparent 20%),
    linear-gradient(180deg, #ffffff 0%, #f6f9ff 72%, #ffffff 100%);
}

.home-ant #snowCanvas {
  opacity: .18;
}

.ant-home {
  position: relative;
  overflow: hidden;
}

.ant-home::before {
  content: "";
  position: absolute;
  left: -80px;
  top: 70px;
  width: 250px;
  height: 250px;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(37,99,235,.08), rgba(14,165,233,.04));
  z-index: -1;
}

.ant-home::after {
  content: "";
  position: absolute;
  right: -110px;
  top: 40px;
  width: 330px;
  height: 330px;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(37,99,235,.06), rgba(14,165,233,.03));
  z-index: -1;
}

.ant-hero {
  position: relative;
  padding: 98px 0 74px;
}

.ant-hero-copy {
  max-width: 860px;
  margin: 0 auto;
  text-align: center;
}

.ant-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 34px;
  padding: 0 14px;
  border-radius: 999px;
  color: #2563eb;
  background: #f0f6ff;
  border: 1px solid #dbeafe;
  font-size: 13px;
  font-weight: 760;
}

.ant-kicker i {
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: #2563eb;
  box-shadow: 0 0 0 5px rgba(37,99,235,.10);
}

.ant-hero h1 {
  margin: 26px auto 14px;
  max-width: 820px;
  font-size: clamp(42px, 5vw, 68px);
  line-height: 1.08;
  letter-spacing: -.07em;
  font-weight: 850;
  color: #202633;
}

.ant-hero h1 span {
  color: #1677ff;
}

.ant-hero p {
  max-width: 690px;
  margin: 0 auto;
  color: #667085;
  font-size: 17px;
  line-height: 1.82;
  font-weight: 500;
}

.ant-hero-actions {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 26px;
}

.ant-btn {
  min-height: 40px;
  padding: 0 17px;
  border-radius: 7px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid transparent;
  font-size: 14px;
  font-weight: 720;
  transition: .18s ease;
}

.ant-btn:hover {
  transform: translateY(-1px);
}

.ant-btn-primary {
  color: #fff;
  background: #1677ff;
  box-shadow: 0 10px 24px rgba(22,119,255,.20);
}

.ant-btn-primary:hover {
  background: #0958d9;
}

.ant-btn-default {
  color: #1f2937;
  background: #fff;
  border-color: #d9d9d9;
}

.ant-floating-stage {
  position: relative;
  max-width: 960px;
  height: 210px;
  margin: 34px auto 0;
}

.ant-float-card {
  position: absolute;
  width: 340px;
  border-radius: 14px;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(16,24,40,.08);
  box-shadow: 0 20px 60px rgba(16,24,40,.12);
  overflow: hidden;
  backdrop-filter: blur(16px);
}

.ant-float-card.main {
  right: 20px;
  top: 0;
  transform: rotate(6deg);
}

.ant-float-card.sub {
  left: 70px;
  bottom: 18px;
  transform: rotate(-4deg);
}

.ant-float-card.mid {
  left: 50%;
  top: 58px;
  transform: translateX(-50%);
}

.ant-card-head {
  height: 42px;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 0 14px;
  border-bottom: 1px solid #edf0f5;
  background: #fbfdff;
}

.ant-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #cbd5e1;
}

.ant-card-body {
  padding: 15px;
}

.ant-line {
  height: 10px;
  border-radius: 999px;
  background: #eef2f7;
  margin-bottom: 10px;
}

.ant-line.blue {
  width: 54%;
  background: linear-gradient(90deg, #1677ff, #69b1ff);
}

.ant-line.short {
  width: 70%;
}

.ant-progress {
  display: grid;
  grid-template-columns: 1fr 58px;
  gap: 12px;
  align-items: center;
  margin-top: 12px;
}

.ant-progress-track {
  height: 8px;
  border-radius: 999px;
  background: #eef2f7;
  overflow: hidden;
}

.ant-progress-track span {
  display: block;
  width: 68%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #1677ff, #69b1ff);
}

.ant-progress em {
  font-style: normal;
  color: #1677ff;
  font-size: 12px;
  font-weight: 800;
}

.ant-mini-row {
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 10px;
  align-items: center;
  padding: 10px;
  border-radius: 10px;
  background: #f7faff;
  border: 1px solid #edf2fa;
  margin-top: 8px;
}

.ant-mini-icon {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  background: #eaf2ff;
  color: #1677ff;
  font-size: 13px;
  font-weight: 900;
}

.ant-news-grid {
  max-width: 980px;
  margin: 34px auto 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.ant-news-card {
  min-height: 132px;
  padding: 18px;
  border-radius: 10px;
  background: rgba(255,255,255,.88);
  border: 1px solid #eef1f6;
  box-shadow: 0 12px 36px rgba(16,24,40,.06);
  transition: .18s ease;
}

.ant-news-card:hover {
  transform: translateY(-3px);
  border-color: #dbeafe;
  box-shadow: 0 18px 50px rgba(16,24,40,.09);
}

.ant-news-card strong {
  display: block;
  color: #202633;
  font-size: 15px;
  letter-spacing: -.025em;
  margin-bottom: 8px;
}

.ant-news-card p {
  margin: 0;
  color: #667085;
  font-size: 13.5px;
  line-height: 1.6;
}

.ant-news-date {
  margin-top: 14px;
  color: #98a2b3;
  font-size: 12px;
}

.ant-section-soft {
  padding: 82px 0;
  background:
    radial-gradient(circle at 6% 100%, rgba(37,99,235,.10), transparent 20%),
    linear-gradient(180deg, rgba(246,249,255,.70), #ffffff);
}

.ant-section-title {
  text-align: center;
  max-width: 760px;
  margin: 0 auto 38px;
}

.ant-section-title h2 {
  margin: 0;
  color: #202633;
  font-size: clamp(30px, 3.6vw, 44px);
  line-height: 1.16;
  letter-spacing: -.06em;
}

.ant-section-title p {
  margin: 14px 0 0;
  color: #667085;
  font-size: 16px;
  line-height: 1.7;
}

.ant-product-panel {
  max-width: 1040px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: .92fr 1.08fr;
  gap: 18px;
}

.ant-product-copy,
.ant-product-card {
  border-radius: 16px;
  background: #fff;
  border: 1px solid #edf0f5;
  box-shadow: 0 16px 46px rgba(16,24,40,.07);
}

.ant-product-copy {
  padding: 30px;
}

.ant-product-copy h3 {
  margin: 14px 0 12px;
  color: #202633;
  font-size: 34px;
  line-height: 1.16;
  letter-spacing: -.06em;
}

.ant-product-copy p {
  margin: 0;
  color: #667085;
  font-size: 15.5px;
  line-height: 1.75;
}

.ant-product-card {
  display: grid;
  grid-template-columns: 70px 1fr auto;
  gap: 18px;
  align-items: center;
  padding: 24px;
  transition: .18s ease;
}

.ant-product-card:hover {
  transform: translateY(-3px);
  border-color: #dbeafe;
  box-shadow: 0 22px 58px rgba(16,24,40,.10);
}

.ant-product-icon {
  width: 70px;
  height: 70px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  background: #f0f6ff;
  border: 1px solid #dbeafe;
}

.ant-product-icon svg {
  width: 30px;
  height: 30px;
  stroke: #1677ff;
  stroke-width: 2.1;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.ant-product-card h3 {
  margin: 0;
  color: #202633;
  font-size: 22px;
  letter-spacing: -.045em;
}

.ant-product-card p {
  margin: 8px 0 0;
  color: #667085;
  font-size: 14.5px;
  line-height: 1.65;
}

.ant-tag {
  padding: 7px 10px;
  border-radius: 999px;
  background: #f6ffed;
  border: 1px solid #b7eb8f;
  color: #389e0d;
  font-size: 12px;
  font-weight: 800;
  white-space: nowrap;
}

.ant-roadmap {
  padding: 82px 0;
}

.ant-roadmap-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.ant-roadmap-card {
  padding: 22px;
  border-radius: 14px;
  background: rgba(255,255,255,.88);
  border: 1px solid #edf0f5;
  box-shadow: 0 14px 38px rgba(16,24,40,.06);
}

.ant-roadmap-card b {
  display: block;
  color: #202633;
  font-size: 18px;
  letter-spacing: -.04em;
}

.ant-roadmap-card p {
  margin: 9px 0 0;
  color: #667085;
  font-size: 14px;
  line-height: 1.65;
}

@media (max-width: 980px) {
  .ant-floating-stage {
    height: auto;
    display: grid;
    gap: 12px;
  }

  .ant-float-card,
  .ant-float-card.main,
  .ant-float-card.sub,
  .ant-float-card.mid {
    position: static;
    width: 100%;
    transform: none;
  }

  .ant-news-grid,
  .ant-product-panel,
  .ant-roadmap-grid {
    grid-template-columns: 1fr;
  }

  .ant-product-card {
    grid-template-columns: 70px 1fr;
  }

  .ant-product-card .ant-tag {
    grid-column: 1 / -1;
    justify-self: start;
  }
}

@media (max-width: 680px) {
  .ant-hero {
    padding: 62px 0 52px;
  }

  .ant-hero h1 {
    font-size: clamp(34px, 10vw, 48px);
  }

  .ant-news-grid {
    grid-template-columns: 1fr;
  }

  .ant-product-copy,
  .ant-product-card {
    padding: 22px;
  }
}


/* v7 smoother home redesign */
.home-v7 {
  background:
    radial-gradient(circle at 12% 4%, rgba(37,99,235,.08), transparent 22%),
    radial-gradient(circle at 92% 12%, rgba(14,165,233,.07), transparent 24%),
    linear-gradient(180deg, #ffffff 0%, #f8fbff 52%, #ffffff 100%);
}

.home-v7 #snowCanvas {
  opacity: .10;
}

.v7-main {
  position: relative;
  overflow: hidden;
}

.v7-hero {
  position: relative;
  padding: 92px 0 58px;
}

.v7-hero::before {
  content: "";
  position: absolute;
  left: 4%;
  top: 120px;
  width: 160px;
  height: 160px;
  border-radius: 52px;
  background: linear-gradient(135deg, rgba(22,119,255,.10), rgba(105,177,255,.02));
  transform: rotate(18deg);
}

.v7-hero::after {
  content: "";
  position: absolute;
  right: 7%;
  top: 70px;
  width: 210px;
  height: 210px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(22,119,255,.10), transparent 64%);
}

.v7-copy {
  position: relative;
  z-index: 2;
  max-width: 860px;
  margin: 0 auto;
  text-align: center;
}

.v7-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 34px;
  padding: 0 14px;
  border-radius: 999px;
  color: #1677ff;
  background: #f0f6ff;
  border: 1px solid #dbeafe;
  font-size: 13px;
  font-weight: 760;
}

.v7-badge i {
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: #1677ff;
  box-shadow: 0 0 0 5px rgba(22,119,255,.10);
}

.v7-copy h1 {
  margin: 24px auto 16px;
  max-width: 820px;
  color: #202633;
  font-size: clamp(40px, 5vw, 66px);
  line-height: 1.08;
  letter-spacing: -.072em;
  font-weight: 850;
}

.v7-copy h1 span {
  color: #1677ff;
}

.v7-copy p {
  max-width: 700px;
  margin: 0 auto;
  color: #667085;
  font-size: 17px;
  line-height: 1.82;
}

.v7-actions {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 27px;
}

.v7-btn {
  min-height: 41px;
  padding: 0 18px;
  border-radius: 9px;
  border: 1px solid transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 740;
  transition: .18s ease;
}

.v7-btn:hover {
  transform: translateY(-1px);
}

.v7-btn.primary {
  background: #1677ff;
  color: #fff;
  box-shadow: 0 12px 28px rgba(22,119,255,.22);
}

.v7-btn.default {
  background: #fff;
  color: #1f2937;
  border-color: #d9d9d9;
}

.v7-showcase {
  position: relative;
  z-index: 2;
  max-width: 1040px;
  margin: 44px auto 0;
  padding: 18px;
  border-radius: 26px;
  background: rgba(255,255,255,.68);
  border: 1px solid rgba(16,24,40,.07);
  box-shadow: 0 28px 90px rgba(16,24,40,.10);
  backdrop-filter: blur(14px);
}

.v7-window {
  overflow: hidden;
  border-radius: 20px;
  background: #fff;
  border: 1px solid #edf0f5;
}

.v7-window-top {
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 16px;
  background: #fbfdff;
  border-bottom: 1px solid #edf0f5;
}

.v7-dots {
  display: flex;
  gap: 7px;
}

.v7-dots span {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #cbd5e1;
}

.v7-window-pill {
  padding: 7px 10px;
  border-radius: 999px;
  background: #f6ffed;
  border: 1px solid #b7eb8f;
  color: #389e0d;
  font-size: 12px;
  font-weight: 800;
}

.v7-dashboard {
  display: grid;
  grid-template-columns: 1fr 330px;
  gap: 18px;
  padding: 22px;
}

.v7-dash-main {
  min-height: 300px;
  padding: 24px;
  border-radius: 18px;
  background:
    radial-gradient(circle at 88% 6%, rgba(22,119,255,.12), transparent 30%),
    linear-gradient(180deg, #f8fbff, #ffffff);
  border: 1px solid #edf2fa;
}

.v7-dash-main h2 {
  margin: 0;
  color: #202633;
  font-size: 28px;
  letter-spacing: -.055em;
}

.v7-dash-main p {
  max-width: 560px;
  margin: 10px 0 0;
  color: #667085;
  line-height: 1.7;
  font-size: 15px;
}

.v7-flow {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 13px;
  margin-top: 26px;
}

.v7-flow-card {
  min-height: 126px;
  padding: 16px;
  border-radius: 16px;
  background: #fff;
  border: 1px solid #e6effb;
  box-shadow: 0 10px 28px rgba(16,24,40,.045);
}

.v7-flow-num {
  width: 31px;
  height: 31px;
  display: grid;
  place-items: center;
  margin-bottom: 14px;
  border-radius: 10px;
  color: #1677ff;
  background: #eaf2ff;
  font-size: 13px;
  font-weight: 850;
}

.v7-flow-card b {
  display: block;
  color: #202633;
  font-size: 15px;
  letter-spacing: -.025em;
}

.v7-flow-card span {
  display: block;
  margin-top: 6px;
  color: #667085;
  font-size: 13px;
  line-height: 1.55;
}

.v7-side {
  display: grid;
  gap: 12px;
}

.v7-side-card {
  padding: 16px;
  border-radius: 16px;
  background: #f7faff;
  border: 1px solid #e6effb;
}

.v7-side-card strong {
  display: block;
  color: #202633;
  font-size: 15px;
  letter-spacing: -.025em;
}

.v7-side-card p {
  margin: 6px 0 0;
  color: #667085;
  font-size: 13px;
  line-height: 1.55;
}

.v7-bar {
  height: 8px;
  margin-top: 14px;
  overflow: hidden;
  border-radius: 999px;
  background: #e5edf7;
}

.v7-bar span {
  display: block;
  height: 100%;
  width: var(--w);
  border-radius: inherit;
  background: linear-gradient(90deg, #1677ff, #69b1ff);
}

.v7-info-row {
  max-width: 1040px;
  margin: 20px auto 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 15px;
}

.v7-info-card {
  padding: 18px;
  border-radius: 16px;
  background: rgba(255,255,255,.86);
  border: 1px solid #edf0f5;
  box-shadow: 0 14px 38px rgba(16,24,40,.055);
}

.v7-info-card b {
  display: block;
  color: #202633;
  font-size: 15px;
  letter-spacing: -.03em;
}

.v7-info-card p {
  margin: 8px 0 0;
  color: #667085;
  font-size: 13.5px;
  line-height: 1.62;
}

.v7-section {
  padding: 80px 0;
}

.v7-section.soft {
  background:
    radial-gradient(circle at 10% 100%, rgba(22,119,255,.08), transparent 20%),
    linear-gradient(180deg, #f8fbff, #ffffff);
}

.v7-section-title {
  max-width: 760px;
  margin: 0 auto 36px;
  text-align: center;
}

.v7-section-title h2 {
  margin: 0;
  color: #202633;
  font-size: clamp(30px, 3.6vw, 44px);
  line-height: 1.16;
  letter-spacing: -.06em;
}

.v7-section-title p {
  margin: 14px 0 0;
  color: #667085;
  font-size: 16px;
  line-height: 1.72;
}

.v7-product {
  max-width: 1040px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: .92fr 1.08fr;
  gap: 18px;
}

.v7-product-copy,
.v7-product-card {
  border-radius: 18px;
  background: rgba(255,255,255,.9);
  border: 1px solid #edf0f5;
  box-shadow: 0 16px 46px rgba(16,24,40,.065);
}

.v7-product-copy {
  padding: 30px;
}

.v7-product-copy h3 {
  margin: 14px 0 12px;
  color: #202633;
  font-size: 34px;
  line-height: 1.16;
  letter-spacing: -.06em;
}

.v7-product-copy p {
  margin: 0;
  color: #667085;
  font-size: 15.5px;
  line-height: 1.75;
}

.v7-product-card {
  display: grid;
  grid-template-columns: 70px 1fr auto;
  gap: 18px;
  align-items: center;
  padding: 24px;
  transition: .18s ease;
}

.v7-product-card:hover {
  transform: translateY(-3px);
  border-color: #dbeafe;
  box-shadow: 0 22px 58px rgba(16,24,40,.10);
}

.v7-product-icon {
  width: 70px;
  height: 70px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  background: #f0f6ff;
  border: 1px solid #dbeafe;
}

.v7-product-icon svg {
  width: 30px;
  height: 30px;
  stroke: #1677ff;
  stroke-width: 2.1;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.v7-product-card h3 {
  margin: 0;
  color: #202633;
  font-size: 22px;
  letter-spacing: -.045em;
}

.v7-product-card p {
  margin: 8px 0 0;
  color: #667085;
  font-size: 14.5px;
  line-height: 1.65;
}

.v7-tag {
  padding: 7px 10px;
  border-radius: 999px;
  background: #f6ffed;
  border: 1px solid #b7eb8f;
  color: #389e0d;
  font-size: 12px;
  font-weight: 800;
  white-space: nowrap;
}

.v7-roadmap {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.v7-roadmap-card {
  padding: 22px;
  border-radius: 16px;
  background: rgba(255,255,255,.9);
  border: 1px solid #edf0f5;
  box-shadow: 0 14px 38px rgba(16,24,40,.055);
}

.v7-roadmap-card b {
  display: block;
  color: #202633;
  font-size: 18px;
  letter-spacing: -.04em;
}

.v7-roadmap-card p {
  margin: 9px 0 0;
  color: #667085;
  font-size: 14px;
  line-height: 1.65;
}

@media (max-width: 980px) {
  .v7-dashboard,
  .v7-product {
    grid-template-columns: 1fr;
  }

  .v7-flow,
  .v7-info-row,
  .v7-roadmap {
    grid-template-columns: 1fr;
  }

  .v7-product-card {
    grid-template-columns: 70px 1fr;
  }

  .v7-product-card .v7-tag {
    grid-column: 1 / -1;
    justify-self: start;
  }
}

@media (max-width: 680px) {
  .v7-hero {
    padding: 62px 0 48px;
  }

  .v7-copy h1 {
    font-size: clamp(34px, 10vw, 48px);
  }

  .v7-showcase {
    padding: 10px;
    border-radius: 22px;
  }

  .v7-dashboard {
    padding: 16px;
  }

  .v7-dash-main,
  .v7-product-copy,
  .v7-product-card {
    padding: 20px;
  }
}


/* v8 consultation modal */
.consult-modal {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 22px;
}

.consult-modal.is-open {
  display: flex;
}

.consult-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, .42);
  backdrop-filter: blur(8px);
}

.consult-box {
  position: relative;
  width: min(520px, 100%);
  padding: 28px;
  border-radius: 28px;
  background: rgba(255,255,255,.96);
  border: 1px solid rgba(16,24,40,.10);
  box-shadow: 0 34px 110px rgba(15,23,42,.24);
}

.consult-box h2 {
  margin: 0;
  font-size: 28px;
  letter-spacing: -.055em;
}

.consult-box p {
  margin: 10px 0 22px;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.7;
}

.consult-plan {
  display: inline-flex;
  margin-bottom: 16px;
  padding: 8px 11px;
  border-radius: 999px;
  background: var(--blueSoft);
  color: var(--blue);
  font-size: 13px;
  font-weight: 800;
}

.consult-close {
  position: absolute;
  right: 18px;
  top: 18px;
  width: 38px;
  height: 38px;
  border-radius: 12px;
  border: 1px solid var(--line);
  background: #fff;
  color: #475467;
  font-size: 20px;
  cursor: pointer;
}

.consult-actions {
  display: flex;
  gap: 10px;
  margin-top: 18px;
}

.consult-actions .btn {
  flex: 1;
}

@media (max-width: 680px) {
  .consult-box {
    padding: 24px 20px;
  }

  .consult-actions {
    flex-direction: column;
  }
}


/* v9 purchase/download flexible redesign */
.v9-page {
  position: relative;
  overflow: hidden;
}

.v9-page::before {
  content: "";
  position: absolute;
  left: -120px;
  top: 120px;
  width: 300px;
  height: 300px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(22,119,255,.10), transparent 68%);
  pointer-events: none;
}

.v9-page::after {
  content: "";
  position: absolute;
  right: -90px;
  top: 70px;
  width: 260px;
  height: 260px;
  border-radius: 70px;
  transform: rotate(18deg);
  background: linear-gradient(135deg, rgba(22,119,255,.08), rgba(105,177,255,.02));
  pointer-events: none;
}

.v9-hero {
  position: relative;
  z-index: 1;
  padding: 82px 0 42px;
}

.v9-copy {
  max-width: 820px;
  margin: 0 auto;
  text-align: center;
}

.v9-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 34px;
  padding: 0 14px;
  border-radius: 999px;
  color: #1677ff;
  background: #f0f6ff;
  border: 1px solid #dbeafe;
  font-size: 13px;
  font-weight: 760;
}

.v9-kicker i {
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: #1677ff;
  box-shadow: 0 0 0 5px rgba(22,119,255,.10);
}

.v9-copy h1 {
  margin: 24px auto 14px;
  max-width: 760px;
  color: #202633;
  font-size: clamp(38px, 4.8vw, 62px);
  line-height: 1.08;
  letter-spacing: -.07em;
  font-weight: 850;
}

.v9-copy h1 span {
  color: #1677ff;
}

.v9-copy p {
  max-width: 690px;
  margin: 0 auto;
  color: #667085;
  font-size: 17px;
  line-height: 1.8;
}

.v9-actions {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 27px;
}

.v9-btn {
  min-height: 42px;
  padding: 0 18px;
  border-radius: 10px;
  border: 1px solid transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 760;
  cursor: pointer;
  transition: .18s ease;
}

.v9-btn:hover {
  transform: translateY(-1px);
}

.v9-btn.primary {
  color: #fff;
  background: #1677ff;
  box-shadow: 0 12px 28px rgba(22,119,255,.22);
}

.v9-btn.primary:hover {
  background: #0958d9;
}

.v9-btn.default {
  color: #1f2937;
  background: #fff;
  border-color: #d9d9d9;
}

.v9-stage {
  position: relative;
  z-index: 1;
  padding: 28px 0 76px;
}

.v9-panel {
  max-width: 1080px;
  margin: 0 auto;
  padding: 18px;
  border-radius: 28px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(16,24,40,.07);
  box-shadow: 0 28px 90px rgba(16,24,40,.10);
  backdrop-filter: blur(14px);
}

.v9-window {
  overflow: hidden;
  border-radius: 21px;
  background: #fff;
  border: 1px solid #edf0f5;
}

.v9-window-top {
  height: 48px;
  padding: 0 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: #fbfdff;
  border-bottom: 1px solid #edf0f5;
}

.v9-dots {
  display: flex;
  gap: 7px;
}

.v9-dots span {
  width: 8px;
  height: 8px;
  border-radius: 99px;
  background: #cbd5e1;
}

.v9-pill {
  padding: 7px 10px;
  border-radius: 999px;
  background: #f6ffed;
  border: 1px solid #b7eb8f;
  color: #389e0d;
  font-size: 12px;
  font-weight: 820;
}

.v9-body {
  padding: 24px;
}

.v9-purchase-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}

.v9-plan {
  padding: 20px;
  border-radius: 18px;
  background: #f8fbff;
  border: 1px solid #e6effb;
  transition: .18s ease;
}

.v9-plan:hover {
  transform: translateY(-3px);
  background: #fff;
  border-color: #dbeafe;
  box-shadow: 0 18px 48px rgba(16,24,40,.08);
}

.v9-plan.featured {
  background: #fff;
  border-color: rgba(22,119,255,.34);
  box-shadow: 0 18px 48px rgba(22,119,255,.10);
}

.v9-plan-type {
  display: inline-flex;
  align-items: center;
  height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  background: #edf4ff;
  color: #1677ff;
  font-size: 12px;
  font-weight: 820;
}

.v9-plan h3 {
  margin: 18px 0 8px;
  color: #202633;
  font-size: 24px;
  line-height: 1.15;
  letter-spacing: -.055em;
}

.v9-plan p {
  margin: 0;
  min-height: 70px;
  color: #667085;
  font-size: 14px;
  line-height: 1.65;
}

.v9-price {
  margin: 18px 0 14px;
  padding: 14px;
  border-radius: 14px;
  background: #fff;
  border: 1px solid #edf0f5;
}

.v9-price strong {
  display: block;
  color: #202633;
  font-size: 20px;
  letter-spacing: -.04em;
}

.v9-price span {
  display: block;
  margin-top: 5px;
  color: #667085;
  font-size: 12.5px;
}

.v9-mini-list {
  display: grid;
  gap: 8px;
  margin: 14px 0 0;
  padding: 0;
  list-style: none;
}

.v9-mini-list li {
  display: flex;
  gap: 8px;
  color: #475467;
  font-size: 13.5px;
  line-height: 1.5;
}

.v9-mini-list li::before {
  content: "✓";
  color: #1677ff;
  font-weight: 900;
}

.v9-download-layout {
  display: grid;
  grid-template-columns: .92fr 1.08fr;
  gap: 18px;
  align-items: stretch;
}

.v9-download-main {
  padding: 28px;
  border-radius: 20px;
  background:
    radial-gradient(circle at 90% 0%, rgba(22,119,255,.12), transparent 30%),
    linear-gradient(180deg, #f8fbff, #fff);
  border: 1px solid #e6effb;
}

.v9-download-main h2 {
  margin: 16px 0 12px;
  color: #202633;
  font-size: clamp(30px, 3.7vw, 44px);
  line-height: 1.15;
  letter-spacing: -.065em;
}

.v9-download-main p {
  margin: 0;
  color: #667085;
  font-size: 15.5px;
  line-height: 1.75;
}

.v9-download-meta {
  display: grid;
  gap: 10px;
  margin-top: 22px;
}

.v9-meta {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding: 13px 14px;
  border-radius: 13px;
  background: #fff;
  border: 1px solid #edf0f5;
  color: #667085;
  font-size: 13.5px;
}

.v9-meta b {
  color: #202633;
}

.v9-install {
  padding: 24px;
  border-radius: 20px;
  background: #fff;
  border: 1px solid #edf0f5;
}

.v9-install h3 {
  margin: 0 0 12px;
  color: #202633;
  font-size: 24px;
  letter-spacing: -.055em;
}

.v9-install p {
  margin: 0 0 18px;
  color: #667085;
  font-size: 14.5px;
  line-height: 1.7;
}

.v9-install-steps {
  display: grid;
  gap: 10px;
}

.v9-step {
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 11px;
  align-items: center;
  padding: 12px;
  border-radius: 14px;
  background: #f8fbff;
  border: 1px solid #e6effb;
}

.v9-step-num {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 11px;
  color: #1677ff;
  background: #edf4ff;
  font-size: 13px;
  font-weight: 850;
}

.v9-step b {
  display: block;
  color: #202633;
  font-size: 14px;
}

.v9-step span {
  display: block;
  margin-top: 3px;
  color: #667085;
  font-size: 12.5px;
}

.v9-roadmap-lite {
  max-width: 1080px;
  margin: 18px auto 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}

.v9-roadmap-lite .release-card {
  box-shadow: 0 14px 38px rgba(16,24,40,.055);
}

@media (max-width: 1080px) {
  .v9-purchase-grid,
  .v9-roadmap-lite {
    grid-template-columns: repeat(2, 1fr);
  }

  .v9-download-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 680px) {
  .v9-hero {
    padding: 60px 0 34px;
  }

  .v9-copy h1 {
    font-size: clamp(34px, 10vw, 48px);
  }

  .v9-stage {
    padding-bottom: 58px;
  }

  .v9-panel {
    padding: 10px;
    border-radius: 22px;
  }

  .v9-body,
  .v9-download-main,
  .v9-install {
    padding: 20px;
  }

  .v9-purchase-grid,
  .v9-roadmap-lite {
    grid-template-columns: 1fr;
  }

  .v9-actions,
  .consult-actions {
    flex-direction: column;
  }

  .v9-btn {
    width: 100%;
  }
}


/* v10 utility page */
.utility-page{position:relative;overflow:hidden}.utility-page:before{content:"";position:absolute;left:-120px;top:120px;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(22,119,255,.10),transparent 68%);pointer-events:none}.utility-page:after{content:"";position:absolute;right:-120px;top:80px;width:300px;height:300px;border-radius:76px;transform:rotate(16deg);background:linear-gradient(135deg,rgba(22,119,255,.08),rgba(105,177,255,.02));pointer-events:none}.utility-hero{position:relative;z-index:1;padding:82px 0 34px}.utility-copy{max-width:820px;margin:0 auto;text-align:center}.utility-kicker{display:inline-flex;align-items:center;gap:8px;height:34px;padding:0 14px;border-radius:999px;color:#1677ff;background:#f0f6ff;border:1px solid #dbeafe;font-size:13px;font-weight:760}.utility-kicker i{width:6px;height:6px;border-radius:999px;background:#1677ff;box-shadow:0 0 0 5px rgba(22,119,255,.10)}.utility-copy h1{margin:24px auto 14px;max-width:760px;color:#202633;font-size:clamp(38px,4.8vw,62px);line-height:1.08;letter-spacing:-.07em;font-weight:850}.utility-copy h1 span{color:#1677ff}.utility-copy p{max-width:690px;margin:0 auto;color:#667085;font-size:17px;line-height:1.8}.utility-stage{position:relative;z-index:1;padding:28px 0 76px}.utility-panel{max-width:1160px;margin:0 auto;padding:18px;border-radius:28px;background:rgba(255,255,255,.72);border:1px solid rgba(16,24,40,.07);box-shadow:0 28px 90px rgba(16,24,40,.10);backdrop-filter:blur(14px)}.utility-window{overflow:hidden;border-radius:21px;background:#fff;border:1px solid #edf0f5}.utility-window-top{height:48px;padding:0 16px;display:flex;align-items:center;justify-content:space-between;background:#fbfdff;border-bottom:1px solid #edf0f5}.utility-dots{display:flex;gap:7px}.utility-dots span{width:8px;height:8px;border-radius:99px;background:#cbd5e1}.utility-pill{padding:7px 10px;border-radius:999px;background:#f6ffed;border:1px solid #b7eb8f;color:#389e0d;font-size:12px;font-weight:820}.utility-body{padding:24px}.utility-grid{display:grid;grid-template-columns:310px 1fr;gap:18px;align-items:start}.utility-sidebar{display:grid;gap:14px}.utility-card{padding:20px;border-radius:18px;background:#f8fbff;border:1px solid #e6effb}.utility-card h3{margin:0 0 8px;color:#202633;font-size:20px;letter-spacing:-.045em}.utility-card p{margin:0;color:#667085;font-size:14px;line-height:1.65}.utility-upload{display:grid;gap:10px;margin-top:16px}.utility-upload input[type=file]{width:100%;padding:13px;border-radius:14px;background:#fff;border:1px solid #dbe4f0;color:#475467;font-size:13px}.utility-actions{display:grid;gap:9px}.utility-btn{min-height:42px;padding:0 14px;border-radius:11px;border:1px solid transparent;background:#fff;color:#1f2937;font-size:14px;font-weight:760;cursor:pointer;transition:.18s ease}.utility-btn:hover{transform:translateY(-1px)}.utility-btn.primary{color:#fff;background:#1677ff;box-shadow:0 12px 28px rgba(22,119,255,.20)}.utility-btn.soft{color:#1677ff;background:#edf4ff;border-color:#dbeafe}.utility-btn.danger{color:#dc2626;background:#fef2f2;border-color:#fecaca}.utility-toolbar{display:flex;gap:12px;align-items:center;margin-bottom:12px}.utility-status{min-height:42px;flex:1;display:flex;align-items:center;padding:0 14px;border-radius:14px;background:#f8fbff;border:1px solid #e6effb;color:#667085;font-size:14px;font-weight:700}.utility-table-wrap{height:570px;overflow:auto;border-radius:18px;border:1px solid #e6effb;background:#fff}.utility-table{width:max-content;min-width:100%;border-collapse:collapse;font-size:13px}.utility-table th,.utility-table td{min-width:120px;max-width:260px;padding:10px 12px;border:1px solid #edf0f5;text-align:left;white-space:nowrap}.utility-table th{position:sticky;top:0;z-index:2;background:#f7faff;color:#344054;font-weight:800}.utility-table td{color:#475467;background:#fff}.utility-table td:focus{outline:2px solid rgba(22,119,255,.32);outline-offset:-2px;background:#f8fbff}.utility-empty{height:570px;display:grid;place-items:center;border-radius:18px;border:1px dashed #cbd5e1;background:#f8fbff;color:#667085;text-align:center;padding:24px}.utility-empty b{display:block;color:#202633;font-size:20px;margin-bottom:8px}.utility-help-list{display:grid;gap:8px;margin:14px 0 0;padding:0;list-style:none}.utility-help-list li{display:flex;gap:8px;color:#475467;font-size:13.5px;line-height:1.5}.utility-help-list li:before{content:"✓";color:#1677ff;font-weight:900}@media(max-width:980px){.utility-grid{grid-template-columns:1fr}.utility-toolbar{align-items:stretch}.utility-table-wrap,.utility-empty{height:460px}}@media(max-width:680px){.utility-hero{padding:58px 0 30px}.utility-copy h1{font-size:clamp(34px,10vw,48px)}.utility-stage{padding-bottom:56px}.utility-panel{padding:10px;border-radius:22px}.utility-body{padding:18px}.utility-toolbar{flex-direction:column}.utility-toolbar .utility-btn{width:100%}}


/* v11 utility landing */
.utility-home-grid {
  max-width: 1080px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.utility-home-card {
  min-height: 260px;
  padding: 26px;
  border-radius: 24px;
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(16,24,40,.08);
  box-shadow: 0 18px 54px rgba(16,24,40,.08);
  transition: .18s ease;
}

.utility-home-card:hover {
  transform: translateY(-4px);
  border-color: #dbeafe;
  box-shadow: 0 26px 74px rgba(16,24,40,.11);
}

.utility-home-icon {
  width: 54px;
  height: 54px;
  margin-bottom: 20px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  background: #edf4ff;
  border: 1px solid #dbeafe;
  color: #1677ff;
  font-weight: 900;
  font-size: 18px;
}

.utility-home-card h3 {
  margin: 0;
  color: #202633;
  font-size: 24px;
  letter-spacing: -.055em;
}

.utility-home-card p {
  margin: 12px 0 0;
  color: #667085;
  font-size: 15px;
  line-height: 1.72;
}

.utility-home-card .v9-btn {
  margin-top: 22px;
}

.utility-locked {
  opacity: .62;
}

.utility-locked .utility-home-icon {
  background: #f8fafc;
  color: #94a3b8;
  border-color: #e2e8f0;
}

@media (max-width: 980px) {
  .utility-home-grid {
    grid-template-columns: 1fr;
  }
}


/* v12 utility excel template + table visibility fix */
.utility-table-wrap {
  width: 100%;
  max-width: 100%;
  overflow: auto !important;
}

.utility-table {
  table-layout: auto;
}

.utility-table th,
.utility-table td {
  min-width: 150px;
  max-width: none;
}

.utility-table th:first-child,
.utility-table td:first-child {
  min-width: 70px;
}

.utility-template-box {
  margin-top: 12px;
  padding: 14px;
  border-radius: 14px;
  background: #ffffff;
  border: 1px solid #e6effb;
}

.utility-template-box b {
  display: block;
  color: #202633;
  font-size: 14px;
  margin-bottom: 6px;
}

.utility-template-box span {
  display: block;
  color: #667085;
  font-size: 12.5px;
  line-height: 1.55;
}

.utility-template-actions {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  margin-top: 12px;
}

.utility-table-wrap::-webkit-scrollbar {
  height: 12px;
  width: 12px;
}

.utility-table-wrap::-webkit-scrollbar-thumb {
  background: #cbd5e1;
  border-radius: 999px;
  border: 3px solid #f8fbff;
}

.utility-table-wrap::-webkit-scrollbar-track {
  background: #f8fbff;
}


/* v14 patch: Excel utility full-width table */
.utility-grid {
  grid-template-columns: 1fr !important;
}

.utility-sidebar {
  grid-template-columns: repeat(3, 1fr) !important;
  align-items: stretch;
}

.utility-main {
  min-width: 0;
  width: 100%;
}

.utility-table-wrap {
  width: 100%;
  max-width: 100%;
  overflow-x: auto !important;
  overflow-y: auto !important;
}

.utility-table {
  width: 100%;
  min-width: 980px;
  table-layout: fixed;
}

.utility-table th,
.utility-table td {
  min-width: 0 !important;
  max-width: none !important;
  overflow: hidden;
  text-overflow: ellipsis;
}

.utility-table th:nth-child(1),
.utility-table td:nth-child(1) { width: 80px; }

.utility-table th:nth-child(2),
.utility-table td:nth-child(2) { width: 110px; }

.utility-table th:nth-child(3),
.utility-table td:nth-child(3) { width: 130px; }

.utility-table th:nth-child(4),
.utility-table td:nth-child(4) { width: 150px; }

.utility-table th:nth-child(5),
.utility-table td:nth-child(5) { width: 120px; }

.utility-table th:nth-child(6),
.utility-table td:nth-child(6) { width: 120px; }

.utility-table th:nth-child(7),
.utility-table td:nth-child(7) { width: 150px; }

.utility-table th:nth-child(8),
.utility-table td:nth-child(8) { width: 220px; }

.utility-table td:focus {
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
}

@media (max-width: 980px) {
  .utility-sidebar {
    grid-template-columns: 1fr !important;
  }

  .utility-table {
    min-width: 980px;
  }
}


/* v16 patch: table toolbar near Excel viewer */
.utility-grid {
  grid-template-columns: 300px 1fr !important;
  align-items: start;
}

.utility-sidebar {
  grid-template-columns: 1fr !important;
}

.utility-main {
  min-width: 0;
  width: 100%;
}

.utility-table-toolbar {
  display: grid !important;
  grid-template-columns: 1fr;
  gap: 10px;
  margin-bottom: 12px;
  padding: 12px;
  border-radius: 18px;
  background: #f8fbff;
  border: 1px solid #e6effb;
}

.utility-table-toolbar .utility-status {
  width: 100%;
}

.utility-inline-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.utility-inline-actions .utility-btn {
  min-height: 36px;
  padding: 0 13px;
  border-radius: 10px;
  font-size: 13px;
}

.utility-table td.is-selected {
  background: #edf4ff !important;
  outline: 2px solid rgba(22,119,255,.45);
  outline-offset: -2px;
}

@media (max-width: 1100px) {
  .utility-grid {
    grid-template-columns: 1fr !important;
  }

  .utility-sidebar {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media (max-width: 700px) {
  .utility-sidebar {
    grid-template-columns: 1fr !important;
  }

  .utility-inline-actions {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
  }

  .utility-inline-actions .utility-btn {
    width: 100%;
  }
}


/* v17 patch: show A~H columns at once */
.utility-grid {
  grid-template-columns: 1fr !important;
  gap: 16px !important;
}

.utility-sidebar {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 14px !important;
  align-items: stretch !important;
}

.utility-card {
  min-height: auto !important;
}

.utility-main {
  width: 100% !important;
  min-width: 0 !important;
}

.utility-table-wrap {
  width: 100% !important;
  max-width: 100% !important;
  overflow-x: auto !important;
  overflow-y: auto !important;
}

.utility-table {
  width: 100% !important;
  min-width: 0 !important;
  table-layout: fixed !important;
}

.utility-table th,
.utility-table td {
  min-width: 0 !important;
  max-width: none !important;
  padding: 10px 12px !important;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* 자동발송봇 기본 8개 컬럼 기준 */
.utility-table th:nth-child(1),
.utility-table td:nth-child(1) { width: 8% !important; }

.utility-table th:nth-child(2),
.utility-table td:nth-child(2) { width: 10% !important; }

.utility-table th:nth-child(3),
.utility-table td:nth-child(3) { width: 13% !important; }

.utility-table th:nth-child(4),
.utility-table td:nth-child(4) { width: 15% !important; }

.utility-table th:nth-child(5),
.utility-table td:nth-child(5) { width: 12% !important; }

.utility-table th:nth-child(6),
.utility-table td:nth-child(6) { width: 12% !important; }

.utility-table th:nth-child(7),
.utility-table td:nth-child(7) { width: 14% !important; }

.utility-table th:nth-child(8),
.utility-table td:nth-child(8) { width: 16% !important; }

.utility-table td:focus {
  white-space: normal !important;
  overflow: visible !important;
  text-overflow: clip !important;
}

@media (max-width: 980px) {
  .utility-sidebar {
    grid-template-columns: 1fr !important;
  }

  .utility-table {
    min-width: 860px !important;
  }
}


/* v18 AI utility */
.utility-home-grid {
  grid-template-columns: repeat(4, 1fr);
}

.ai-layout {
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: 18px;
  align-items: start;
}

.ai-form-card,
.ai-result-card {
  padding: 24px;
  border-radius: 22px;
  background: #f8fbff;
  border: 1px solid #e6effb;
}

.ai-form-card h3,
.ai-result-card h3 {
  margin: 0 0 10px;
  color: #202633;
  font-size: 24px;
  letter-spacing: -.055em;
}

.ai-form-card p,
.ai-result-card p {
  margin: 0;
  color: #667085;
  font-size: 14.5px;
  line-height: 1.7;
}

.ai-field {
  margin-top: 16px;
}

.ai-field label {
  display: block;
  margin-bottom: 8px;
  color: #344054;
  font-size: 14px;
  font-weight: 800;
}

.ai-field input,
.ai-field select,
.ai-field textarea {
  width: 100%;
  border-radius: 14px;
  border: 1px solid #dbe4f0;
  background: #fff;
  color: #1f2937;
  font-size: 14px;
  outline: none;
}

.ai-field input,
.ai-field select {
  height: 46px;
  padding: 0 13px;
}

.ai-field input[type="file"] {
  height: auto;
  padding: 13px;
}

.ai-field textarea {
  min-height: 130px;
  padding: 13px;
  resize: vertical;
  line-height: 1.65;
}

.ai-actions {
  display: flex;
  gap: 9px;
  margin-top: 18px;
}

.ai-actions .utility-btn {
  flex: 1;
}

.ai-result-box {
  min-height: 520px;
  margin-top: 16px;
  padding: 22px;
  border-radius: 18px;
  background: #fff;
  border: 1px solid #e6effb;
  color: #334155;
  font-size: 15px;
  line-height: 1.75;
  white-space: pre-wrap;
}

.ai-result-box.is-loading {
  display: grid;
  place-items: center;
  color: #1677ff;
  font-weight: 800;
}

.ai-note {
  margin-top: 14px;
  padding: 13px;
  border-radius: 14px;
  background: #fff;
  border: 1px solid #e6effb;
  color: #64748b;
  font-size: 12.5px;
  line-height: 1.6;
}

@media (max-width: 1100px) {
  .utility-home-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .ai-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 700px) {
  .utility-home-grid {
    grid-template-columns: 1fr;
  }

  .ai-actions {
    flex-direction: column;
  }
}


/* v20 AI utility chat redesign */
.ai-chat-page {
  position: relative;
  min-height: calc(100vh - 72px);
  background:
    radial-gradient(circle at 14% 8%, rgba(124,58,237,.07), transparent 25%),
    radial-gradient(circle at 90% 4%, rgba(37,99,235,.08), transparent 28%),
    linear-gradient(180deg, #fbfdff 0%, #f7f8ff 100%);
}

.ai-chat-wrap {
  width: min(1220px, calc(100% - 40px));
  margin: 0 auto;
  padding: 48px 0 70px;
}

.ai-chat-shell {
  display: grid;
  grid-template-columns: 270px 1fr;
  min-height: 720px;
  overflow: hidden;
  border-radius: 28px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(16,24,40,.08);
  box-shadow: 0 28px 90px rgba(16,24,40,.12);
  backdrop-filter: blur(18px);
}

.ai-sidebar {
  display: flex;
  flex-direction: column;
  gap: 18px;
  padding: 22px;
  background:
    radial-gradient(circle at 0% 20%, rgba(124,58,237,.13), transparent 36%),
    linear-gradient(180deg, #f7f3ff, #ffffff);
  border-right: 1px solid #edf0f5;
}

.ai-sidebar-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  color: #202633;
  font-size: 18px;
  font-weight: 860;
  letter-spacing: -.045em;
}

.ai-sidebar-brand span {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 12px;
  background: linear-gradient(135deg, #7c3aed, #1677ff);
  color: #fff;
  font-size: 13px;
  font-weight: 900;
  box-shadow: 0 16px 36px rgba(124,58,237,.22);
}

.ai-sidebar-help {
  margin-top: auto;
  padding: 18px;
  border-radius: 22px;
  background: rgba(255,255,255,.78);
  border: 1px solid #ebe7ff;
  text-align: center;
}

.ai-sidebar-help-icon {
  width: 56px;
  height: 56px;
  margin: 0 auto 12px;
  display: grid;
  place-items: center;
  border-radius: 18px;
  background: linear-gradient(135deg, #ede9fe, #dbeafe);
  color: #7c3aed;
  font-size: 28px;
}

.ai-sidebar-help b {
  display: block;
  color: #202633;
  font-size: 16px;
  letter-spacing: -.035em;
}

.ai-sidebar-help p {
  margin: 8px 0 0;
  color: #667085;
  font-size: 13px;
  line-height: 1.6;
}

.ai-upload-label {
  display: block;
  margin-top: 16px;
  padding: 13px 14px;
  border-radius: 12px;
  background: #8b5cf6;
  color: #fff;
  font-size: 14px;
  font-weight: 800;
  text-align: center;
  cursor: pointer;
  transition: .18s ease;
}

.ai-upload-label:hover {
  transform: translateY(-1px);
  background: #7c3aed;
}

.ai-file-name {
  margin-top: 10px;
  color: #667085;
  font-size: 12.5px;
  line-height: 1.5;
  word-break: break-all;
}

.ai-sidebar-note {
  padding: 14px;
  border-radius: 16px;
  background: rgba(255,255,255,.70);
  border: 1px solid #ebe7ff;
  color: #667085;
  font-size: 12.5px;
  line-height: 1.6;
}

.ai-main {
  display: grid;
  grid-template-rows: auto 1fr auto;
  min-width: 0;
  background: #fbfbff;
}

.ai-chat-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 22px;
  border-bottom: 1px solid #edf0f5;
  background: rgba(255,255,255,.78);
}

.ai-chat-head h1 {
  margin: 0;
  color: #202633;
  font-size: 22px;
  letter-spacing: -.055em;
}

.ai-chat-head p {
  margin: 4px 0 0;
  color: #667085;
  font-size: 13px;
}

.ai-type-select {
  min-width: 160px;
  height: 40px;
  padding: 0 12px;
  border-radius: 12px;
  border: 1px solid #dbe4f0;
  background: #fff;
  color: #344054;
  font-size: 13px;
  font-weight: 760;
  outline: none;
}

.ai-messages {
  min-height: 0;
  padding: 28px;
  overflow-y: auto;
}

.ai-message {
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr);
  gap: 12px;
  margin-bottom: 20px;
}

.ai-message.user {
  grid-template-columns: minmax(0, 1fr) 38px;
}

.ai-avatar {
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border-radius: 14px;
  background: #ede9fe;
  color: #7c3aed;
  font-size: 16px;
  font-weight: 900;
}

.ai-message.user .ai-avatar {
  grid-column: 2;
  background: #e0f2fe;
  color: #0284c7;
}

.ai-bubble {
  width: fit-content;
  max-width: min(760px, 100%);
  padding: 16px 18px;
  border-radius: 18px;
  background: #eeeafe;
  color: #334155;
  line-height: 1.75;
  font-size: 14.5px;
  white-space: pre-wrap;
  box-shadow: 0 12px 34px rgba(16,24,40,.055);
}

.ai-message.user .ai-bubble {
  justify-self: end;
  grid-column: 1;
  background: #ffffff;
  border: 1px solid #edf0f5;
}

.ai-bubble-tools {
  display: flex;
  gap: 8px;
  margin-top: 11px;
  color: #667085;
  font-size: 12px;
}

.ai-copy-btn {
  border: 0;
  background: transparent;
  color: #667085;
  cursor: pointer;
  font-size: 12px;
  padding: 0;
}

.ai-composer {
  padding: 16px 22px 20px;
  border-top: 1px solid #edf0f5;
  background: rgba(255,255,255,.86);
}

.ai-composer-inner {
  display: grid;
  grid-template-columns: 1fr 48px;
  gap: 10px;
  align-items: end;
  padding: 12px;
  border-radius: 18px;
  border: 1px solid #d9cfff;
  background: #fff;
  box-shadow: 0 14px 38px rgba(124,58,237,.10);
}

.ai-composer textarea {
  width: 100%;
  min-height: 54px;
  max-height: 160px;
  border: 0;
  outline: none;
  resize: vertical;
  color: #202633;
  font-size: 14px;
  line-height: 1.6;
  background: transparent;
}

.ai-send-btn {
  width: 48px;
  height: 48px;
  border: 0;
  border-radius: 15px;
  background: linear-gradient(135deg, #8b5cf6, #1677ff);
  color: #fff;
  font-size: 20px;
  font-weight: 900;
  cursor: pointer;
  box-shadow: 0 16px 34px rgba(124,58,237,.20);
}

.ai-composer-meta {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-top: 9px;
  color: #98a2b3;
  font-size: 11.5px;
}

.ai-loading-dots {
  display: inline-flex;
  gap: 5px;
}

.ai-loading-dots i {
  width: 7px;
  height: 7px;
  border-radius: 99px;
  background: #8b5cf6;
  animation: aiDot 1s infinite ease-in-out;
}

.ai-loading-dots i:nth-child(2) { animation-delay: .15s; }
.ai-loading-dots i:nth-child(3) { animation-delay: .3s; }

@keyframes aiDot {
  0%, 80%, 100% { opacity: .3; transform: translateY(0); }
  40% { opacity: 1; transform: translateY(-4px); }
}

@media (max-width: 920px) {
  .ai-chat-shell {
    grid-template-columns: 1fr;
  }

  .ai-sidebar {
    border-right: 0;
    border-bottom: 1px solid #edf0f5;
  }

  .ai-sidebar-help {
    text-align: left;
  }

  .ai-sidebar-help-icon {
    margin: 0 0 12px;
  }

  .ai-chat-head {
    align-items: flex-start;
    flex-direction: column;
  }

  .ai-type-select {
    width: 100%;
  }
}

@media (max-width: 640px) {
  .ai-chat-wrap {
    width: min(100% - 24px, 1220px);
    padding: 28px 0 48px;
  }

  .ai-messages {
    padding: 18px;
  }

  .ai-bubble {
    font-size: 14px;
  }

  .ai-composer {
    padding: 12px;
  }
}


/* v21 patch: AI chat scroll inside message panel */
.ai-chat-page {
  min-height: calc(100vh - 72px);
}

.ai-chat-wrap {
  height: calc(100vh - 72px);
  min-height: 720px;
  padding: 34px 0 !important;
  box-sizing: border-box;
}

.ai-chat-shell {
  height: 100%;
  min-height: 0 !important;
}

.ai-main {
  height: 100%;
  min-height: 0 !important;
  overflow: hidden;
}

.ai-messages {
  height: 100%;
  min-height: 0 !important;
  overflow-y: auto !important;
  overflow-x: hidden;
  overscroll-behavior: contain;
}

.ai-bubble {
  max-width: min(760px, calc(100vw - 430px));
  overflow-wrap: anywhere;
  word-break: keep-all;
}

.ai-composer {
  flex-shrink: 0;
}

.ai-sidebar {
  min-height: 0;
  overflow-y: auto;
}

@media (max-width: 920px) {
  .ai-chat-wrap {
    height: auto;
    min-height: calc(100vh - 72px);
    padding: 24px 0 42px !important;
  }

  .ai-chat-shell {
    height: auto;
    min-height: calc(100vh - 140px) !important;
  }

  .ai-main {
    min-height: 620px !important;
  }

  .ai-messages {
    max-height: 520px;
  }

  .ai-bubble {
    max-width: 100%;
  }
}


/* v34 AI utility - bright Gemini-like spacious redesign */
.ai-gem-page {
  min-height: calc(100vh - 72px);
  background:
    radial-gradient(circle at 80% 0%, rgba(66,133,244,.10), transparent 28%),
    radial-gradient(circle at 18% 16%, rgba(147,112,219,.10), transparent 28%),
    linear-gradient(180deg, #fbfcff 0%, #f7f9fe 100%);
}

.ai-gem-shell {
  display: grid;
  grid-template-columns: 282px minmax(0, 1fr);
  min-height: calc(100vh - 72px);
  max-width: 1480px;
  margin: 0 auto;
}

.ai-gem-sidebar {
  border-right: 1px solid rgba(15, 23, 42, .07);
  padding: 22px 18px;
  background: rgba(255,255,255,.55);
  backdrop-filter: blur(20px);
}

.ai-gem-side-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 24px;
}

.ai-gem-side-title strong {
  color: #1f2937;
  font-size: 18px;
  font-weight: 850;
  letter-spacing: -.04em;
}

.ai-gem-side-pill {
  height: 30px;
  padding: 0 11px;
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  background: #eef4ff;
  color: #2563eb;
  border: 1px solid #dbeafe;
  font-size: 12px;
  font-weight: 800;
}

.ai-gem-new {
  width: 100%;
  height: 44px;
  border: 0;
  border-radius: 14px;
  background: #f1f5ff;
  color: #1d4ed8;
  font-size: 14px;
  font-weight: 850;
  cursor: pointer;
  transition: .18s ease;
}

.ai-gem-new:hover {
  background: #e7efff;
}

.ai-gem-side-section {
  margin-top: 24px;
}

.ai-gem-side-label {
  color: #94a3b8;
  font-size: 12px;
  font-weight: 850;
  letter-spacing: .02em;
  margin-bottom: 10px;
}

.ai-gem-side-list {
  display: grid;
  gap: 8px;
}

.ai-gem-side-item {
  display: block;
  padding: 11px 12px;
  border-radius: 13px;
  color: #475569;
  background: transparent;
  font-size: 13px;
  line-height: 1.45;
}

.ai-gem-side-item.is-active {
  background: rgba(255,255,255,.72);
  border: 1px solid #e5e7eb;
  color: #111827;
  box-shadow: 0 10px 28px rgba(15,23,42,.05);
}

.ai-gem-upload {
  margin-top: 26px;
  padding: 16px;
  border-radius: 18px;
  background: rgba(255,255,255,.80);
  border: 1px solid #e7edf7;
}

.ai-gem-upload b {
  display: block;
  color: #111827;
  font-size: 15px;
  letter-spacing: -.035em;
}

.ai-gem-upload p {
  margin: 7px 0 14px;
  color: #64748b;
  font-size: 12.5px;
  line-height: 1.55;
}

.ai-gem-upload-btn {
  height: 40px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  background: #111827;
  color: #fff;
  font-size: 13px;
  font-weight: 850;
  cursor: pointer;
  transition: .18s ease;
}

.ai-gem-upload-btn:hover {
  background: #2563eb;
}

.ai-gem-file-name {
  margin-top: 10px;
  color: #64748b;
  font-size: 12px;
  line-height: 1.45;
  word-break: break-all;
}

.ai-gem-main {
  min-width: 0;
  display: grid;
  grid-template-rows: auto 1fr auto;
  height: calc(100vh - 72px);
  overflow: hidden;
}

.ai-gem-top {
  height: 74px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 34px;
  border-bottom: 1px solid rgba(15,23,42,.07);
  background: rgba(255,255,255,.55);
  backdrop-filter: blur(18px);
}

.ai-gem-top h1 {
  margin: 0;
  color: #111827;
  font-size: 20px;
  font-weight: 850;
  letter-spacing: -.045em;
}

.ai-gem-top p {
  margin: 3px 0 0;
  color: #64748b;
  font-size: 13px;
}

.ai-gem-select {
  width: 164px;
  height: 42px;
  padding: 0 13px;
  border-radius: 14px;
  border: 1px solid #dde6f3;
  background: rgba(255,255,255,.86);
  color: #334155;
  font-size: 13px;
  font-weight: 780;
  outline: none;
}

.ai-gem-messages {
  overflow-y: auto;
  padding: 30px 38px;
  min-height: 0;
}

.ai-gem-welcome {
  min-height: 100%;
  display: grid;
  place-items: center;
  text-align: center;
}

.ai-gem-welcome-inner {
  max-width: 760px;
  transform: translateY(-6vh);
}

.ai-gem-welcome h2 {
  margin: 0;
  color: #111827;
  font-size: clamp(42px, 5vw, 68px);
  line-height: 1.06;
  letter-spacing: -.08em;
  font-weight: 850;
}

.ai-gem-welcome h2 span {
  background: linear-gradient(90deg, #2563eb, #7c3aed, #0ea5e9);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.ai-gem-welcome p {
  max-width: 600px;
  margin: 18px auto 0;
  color: #64748b;
  font-size: 16px;
  line-height: 1.8;
}

.ai-gem-suggestions {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 28px;
}

.ai-gem-suggestion {
  border: 1px solid #e2e8f0;
  background: rgba(255,255,255,.88);
  color: #334155;
  padding: 11px 14px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 720;
  cursor: pointer;
  transition: .18s ease;
}

.ai-gem-suggestion:hover {
  border-color: #bfdbfe;
  color: #1d4ed8;
  transform: translateY(-1px);
}

.ai-gem-message {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 14px;
  max-width: 900px;
  margin: 0 auto 22px;
}

.ai-gem-message.user {
  grid-template-columns: minmax(0, 1fr) 42px;
}

.ai-gem-avatar {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: #eef2ff;
  color: #4f46e5;
  font-size: 13px;
  font-weight: 900;
}

.ai-gem-message.user .ai-gem-avatar {
  grid-column: 2;
  background: #dff3ff;
  color: #0284c7;
}

.ai-gem-bubble {
  width: fit-content;
  max-width: min(780px, 100%);
  padding: 16px 18px;
  border-radius: 22px;
  background: rgba(255,255,255,.92);
  border: 1px solid #e9eef6;
  color: #334155;
  font-size: 15px;
  line-height: 1.78;
  white-space: pre-wrap;
  box-shadow: 0 16px 42px rgba(15,23,42,.05);
}

.ai-gem-message.assistant .ai-gem-bubble {
  background: #f4f1ff;
  border-color: #eee8ff;
}

.ai-gem-message.user .ai-gem-bubble {
  justify-self: end;
  grid-column: 1;
  background: #ffffff;
}

.ai-gem-tools {
  margin-top: 12px;
}

.ai-gem-copy {
  border: 0;
  background: transparent;
  padding: 0;
  color: #94a3b8;
  font-size: 12px;
  cursor: pointer;
}

.ai-gem-loading {
  display: inline-flex;
  gap: 5px;
  align-items: center;
}

.ai-gem-loading i {
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: #7c3aed;
  animation: aiGemDot 1s infinite ease-in-out;
}

.ai-gem-loading i:nth-child(2) { animation-delay: .15s; }
.ai-gem-loading i:nth-child(3) { animation-delay: .3s; }

@keyframes aiGemDot {
  0%, 80%, 100% { opacity: .3; transform: translateY(0); }
  40% { opacity: 1; transform: translateY(-4px); }
}

.ai-gem-composer {
  padding: 18px 34px 28px;
  background: linear-gradient(180deg, rgba(247,249,254,0), rgba(247,249,254,.98) 28%);
}

.ai-gem-composer-box {
  max-width: 860px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 10px;
  align-items: end;
  padding: 10px;
  border-radius: 28px;
  border: 1px solid #d8e2f0;
  background: rgba(255,255,255,.92);
  box-shadow: 0 18px 52px rgba(15,23,42,.08);
}

.ai-gem-file-mini {
  width: 42px;
  height: 42px;
  border: 0;
  border-radius: 18px;
  background: #f1f5f9;
  color: #334155;
  font-size: 22px;
  cursor: pointer;
}

.ai-gem-composer textarea {
  min-height: 44px;
  max-height: 160px;
  border: 0;
  outline: none;
  resize: vertical;
  background: transparent;
  color: #1f2937;
  font-size: 15px;
  line-height: 1.65;
  padding: 10px 4px;
}

.ai-gem-send {
  width: 46px;
  height: 46px;
  border: 0;
  border-radius: 18px;
  background: #2563eb;
  color: #fff;
  font-size: 20px;
  cursor: pointer;
  box-shadow: 0 12px 28px rgba(37,99,235,.22);
}

.ai-gem-send:disabled {
  opacity: .58;
  cursor: not-allowed;
}

.ai-gem-meta {
  max-width: 850px;
  margin: 8px auto 0;
  color: #94a3b8;
  font-size: 12px;
  display: flex;
  justify-content: space-between;
}

.ai-gem-empty-hidden {
  display: none !important;
}

@media (max-width: 1040px) {
  .ai-gem-shell {
    grid-template-columns: 1fr;
  }

  .ai-gem-sidebar {
    display: none;
  }

  .ai-gem-main {
    height: calc(100vh - 72px);
  }

  .ai-gem-top {
    padding: 0 20px;
  }

  .ai-gem-messages {
    padding: 24px 18px;
  }

  .ai-gem-composer {
    padding: 14px 18px 22px;
  }
}

@media (max-width: 640px) {
  .ai-gem-top {
    height: auto;
    min-height: 76px;
    align-items: flex-start;
    flex-direction: column;
    padding: 16px;
    gap: 12px;
  }

  .ai-gem-select {
    width: 100%;
  }

  .ai-gem-welcome h2 {
    font-size: 38px;
  }

  .ai-gem-message,
  .ai-gem-message.user {
    grid-template-columns: 1fr;
  }

  .ai-gem-avatar {
    display: none;
  }

  .ai-gem-message.user .ai-gem-bubble {
    grid-column: auto;
  }

  .ai-gem-meta {
    display: none;
  }
}


/* v35 main page current tools cards */
.v7-product-expanded {
  max-width: 1120px;
  grid-template-columns: .76fr 1.24fr;
  align-items: stretch;
}

.v7-product-list {
  display: grid;
  gap: 14px;
}

.v7-product-list .v7-product-card {
  grid-template-columns: 1fr auto;
  min-height: 116px;
  padding: 24px 26px;
}

.v7-product-list .v7-product-card h3 {
  font-size: 23px;
}

.v7-product-list .v7-product-card p {
  max-width: 560px;
}

.v7-tag.beta {
  background: #f5f3ff;
  border-color: #ddd6fe;
  color: #7c3aed;
}

@media (max-width: 980px) {
  .v7-product-expanded {
    grid-template-columns: 1fr;
  }

  .v7-product-list .v7-product-card {
    grid-template-columns: 1fr;
  }

  .v7-product-list .v7-tag {
    justify-self: start;
  }
}


/* v36 main current tools clean list */
.v7-tools-clean {
  width: min(1120px, 100%);
  margin: 0 auto;
  display: grid;
  gap: 16px;
}

.v7-tool-row {
  min-height: 148px;
  padding: 32px 38px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 24px;
  border-radius: 24px;
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(16,24,40,.075);
  box-shadow: 0 20px 62px rgba(16,24,40,.075);
  transition: .18s ease;
}

.v7-tool-row:hover {
  transform: translateY(-3px);
  border-color: #dbeafe;
  box-shadow: 0 28px 80px rgba(16,24,40,.105);
}

.v7-tool-row h3 {
  margin: 0;
  color: #111827;
  font-size: clamp(25px, 2.2vw, 34px);
  line-height: 1.16;
  letter-spacing: -.065em;
  font-weight: 850;
}

.v7-tool-row p {
  max-width: 760px;
  margin: 13px 0 0;
  color: #64748b;
  font-size: 16px;
  line-height: 1.75;
  word-break: keep-all;
}

.v7-tool-row .v7-tag {
  min-width: 86px;
  justify-content: center;
}

.v7-tag.free {
  background: #eef4ff;
  border-color: #dbeafe;
  color: #2563eb;
}

@media (max-width: 760px) {
  .v7-tool-row {
    grid-template-columns: 1fr;
    min-height: auto;
    padding: 26px;
  }

  .v7-tool-row .v7-tag {
    justify-self: start;
  }
}


/* v37 main tools UI cleanup */
.v7-tools-clean {
  width: min(1120px, calc(100% - 32px)) !important;
  margin: 0 auto !important;
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 18px !important;
}

.v7-tool-row {
  position: relative !important;
  min-height: 238px !important;
  padding: 34px 30px 30px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
  align-items: flex-start !important;
  gap: 22px !important;
  border-radius: 28px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,251,255,.88)) !important;
  border: 1px solid rgba(16,24,40,.075) !important;
  box-shadow: 0 18px 58px rgba(15,23,42,.075) !important;
  overflow: hidden !important;
}

.v7-tool-row::before {
  content: "" !important;
  position: absolute !important;
  left: 30px !important;
  right: 30px !important;
  top: 0 !important;
  height: 3px !important;
  border-radius: 0 0 999px 999px !important;
  background: linear-gradient(90deg, #2563eb, #60a5fa) !important;
  opacity: .82 !important;
}

.v7-tool-row:hover {
  transform: translateY(-4px) !important;
  border-color: #bfdbfe !important;
  box-shadow: 0 26px 78px rgba(15,23,42,.11) !important;
}

.v7-tool-row h3 {
  margin: 0 !important;
  padding-right: 0 !important;
  color: #111827 !important;
  font-size: 28px !important;
  line-height: 1.18 !important;
  letter-spacing: -.06em !important;
  font-weight: 880 !important;
}

.v7-tool-row p {
  max-width: none !important;
  margin: 14px 0 0 !important;
  color: #64748b !important;
  font-size: 15px !important;
  line-height: 1.72 !important;
  word-break: keep-all !important;
}

.v7-tool-row .v7-tag {
  min-width: auto !important;
  height: 34px !important;
  padding: 0 14px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  align-self: flex-start !important;
  border-radius: 999px !important;
  font-size: 13px !important;
  font-weight: 850 !important;
  white-space: nowrap !important;
  box-shadow: none !important;
}

.v7-tool-row .v7-tag.free {
  background: #eef4ff !important;
  border-color: #dbeafe !important;
  color: #2563eb !important;
}

@media (max-width: 1020px) {
  .v7-tools-clean {
    grid-template-columns: 1fr !important;
  }

  .v7-tool-row {
    min-height: auto !important;
    padding: 30px 28px !important;
  }
}

@media (max-width: 640px) {
  .v7-tools-clean {
    width: min(100% - 24px, 1120px) !important;
  }

  .v7-tool-row h3 {
    font-size: 24px !important;
  }
}


/* v38 global design polish */
:root{--sf-ink:#0f172a;--sf-muted:#667085;--sf-blue:#2563eb;--sf-purple:#8b5cf6;--sf-shadow:0 22px 70px rgba(15,23,42,.085);--sf-shadow-hover:0 32px 92px rgba(15,23,42,.125)}
html{scroll-behavior:smooth}body{color:var(--sf-ink);text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;background:radial-gradient(circle at 16% 8%,rgba(96,165,250,.16),transparent 28%),radial-gradient(circle at 84% 0%,rgba(139,92,246,.12),transparent 26%),radial-gradient(circle at 50% 100%,rgba(37,99,235,.08),transparent 32%),linear-gradient(180deg,#fbfdff 0%,#f6f9ff 100%)!important}body:before,body:after{content:"";position:fixed;z-index:-1;pointer-events:none;border-radius:999px;filter:blur(28px);opacity:.42;animation:sfFloatAura 15s ease-in-out infinite alternate}body:before{width:360px;height:360px;left:-120px;top:150px;background:radial-gradient(circle,rgba(96,165,250,.28),transparent 66%)}body:after{width:430px;height:430px;right:-160px;top:80px;background:radial-gradient(circle,rgba(139,92,246,.20),transparent 68%);animation-duration:18s}@keyframes sfFloatAura{from{transform:translate3d(0,0,0) scale(1)}to{transform:translate3d(22px,28px,0) scale(1.05)}}
.header{position:sticky!important;top:0;z-index:50;background:rgba(255,255,255,.78)!important;backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid rgba(15,23,42,.07)!important;box-shadow:0 10px 32px rgba(15,23,42,.035)}.logo-mark{box-shadow:0 14px 32px rgba(37,99,235,.22)!important}.nav-links a,.mobile-panel a{transition:color .18s ease,background .18s ease,transform .18s ease}.nav-links a:hover{color:var(--sf-blue)!important;transform:translateY(-1px)}
.btn,.v7-btn,.v9-btn,.utility-btn,.ai-gem-send,.ai-gem-new,.ai-gem-upload-btn,.ai-gem-suggestion{transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease,background .18s ease,color .18s ease!important}.btn:hover,.v7-btn:hover,.v9-btn:hover,.utility-btn:hover,.ai-gem-send:hover,.ai-gem-new:hover,.ai-gem-upload-btn:hover,.ai-gem-suggestion:hover{transform:translateY(-2px)}.btn-primary,.v7-btn.primary,.v9-btn.primary,.utility-btn.primary{background:linear-gradient(135deg,#2563eb,#1677ff)!important;box-shadow:0 18px 42px rgba(37,99,235,.22)!important}.btn-primary:hover,.v7-btn.primary:hover,.v9-btn.primary:hover,.utility-btn.primary:hover{box-shadow:0 24px 58px rgba(37,99,235,.30)!important}
section,.v7-section,.v9-stage,.utility-stage{animation:sfSectionUp .58s ease both}@keyframes sfSectionUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
.v7-tool-row,.v7-product-card,.v9-card,.v9-price-card,.utility-home-card,.utility-card,.utility-main,.utility-panel,.ai-gem-upload,.ai-gem-side-item.is-active,.ai-gem-bubble{border-color:rgba(15,23,42,.075)!important;box-shadow:var(--sf-shadow)!important}.v7-tool-row:hover,.v7-product-card:hover,.v9-card:hover,.v9-price-card:hover,.utility-home-card:hover,.utility-card:hover{box-shadow:var(--sf-shadow-hover)!important;transform:translateY(-4px)}.v7-tag,.utility-pill,.v7-badge,.utility-kicker,.ai-gem-side-pill{backdrop-filter:blur(12px)}
.v7-tools-clean{padding:4px 0 10px}.v7-tool-row{isolation:isolate}.v7-tool-row:after{content:"";position:absolute;inset:auto -70px -80px auto;width:170px;height:170px;border-radius:999px;background:radial-gradient(circle,rgba(37,99,235,.10),transparent 70%);z-index:-1}.v7-tool-row .v7-tag{margin-top:auto!important}
input,textarea,select{transition:border-color .16s ease,box-shadow .16s ease,background .16s ease}input:focus,textarea:focus,select:focus{border-color:#93c5fd!important;box-shadow:0 0 0 4px rgba(37,99,235,.10)!important}
.ai-gem-page{background:radial-gradient(circle at 75% 0%,rgba(96,165,250,.14),transparent 30%),radial-gradient(circle at 8% 20%,rgba(139,92,246,.12),transparent 30%),linear-gradient(180deg,#fbfdff 0%,#f7f9fe 100%)!important}.ai-gem-sidebar{background:rgba(255,255,255,.62)!important}.ai-gem-top{background:rgba(255,255,255,.72)!important}.ai-gem-composer-box{border-color:rgba(147,197,253,.72)!important}.ai-gem-file-mini:hover{background:#eaf2ff;color:var(--sf-blue)}.ai-gem-send:hover{box-shadow:0 18px 38px rgba(37,99,235,.30)}
.utility-window,.utility-panel,.utility-card,.utility-main{background:rgba(255,255,255,.86)!important}.utility-table-toolbar{background:rgba(248,251,255,.92)!important}.utility-table th{background:#f5f9ff!important}.v9-price-card,.v9-download-card,.v9-card{background:rgba(255,255,255,.90)!important}.v9-price-card.recommend,.v9-card.recommend{border-color:rgba(37,99,235,.32)!important;box-shadow:0 28px 80px rgba(37,99,235,.12)!important}#snowCanvas{opacity:.22!important;mix-blend-mode:normal}p,li,.v7-tool-row p,.ai-gem-bubble,.utility-card p{word-break:keep-all;overflow-wrap:anywhere}
@media(max-width:760px){body:before,body:after{opacity:.22}.header{position:sticky!important}.v7-tool-row,.v9-card,.v9-price-card,.utility-card{border-radius:22px!important}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.001ms!important}}


/* v39 visual pop pass - brighter SaaS depth */
.home-v7 .v7-main {
  position: relative;
  overflow: hidden;
}

.home-v7 .v7-main::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(37,99,235,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(37,99,235,.045) 1px, transparent 1px);
  background-size: 42px 42px;
  mask-image: linear-gradient(180deg, rgba(0,0,0,.6), transparent 52%);
  opacity: .78;
}

.v7-hero {
  position: relative;
  overflow: hidden;
}

.v7-hero::before {
  content: "";
  position: absolute;
  width: 720px;
  height: 720px;
  left: 50%;
  top: -260px;
  transform: translateX(-50%);
  border-radius: 999px;
  background:
    radial-gradient(circle at 42% 42%, rgba(96,165,250,.22), transparent 32%),
    radial-gradient(circle at 62% 52%, rgba(139,92,246,.18), transparent 36%),
    radial-gradient(circle, rgba(255,255,255,.72), transparent 62%);
  filter: blur(16px);
  opacity: .95;
  pointer-events: none;
  animation: v39Orb 12s ease-in-out infinite alternate;
}

@keyframes v39Orb {
  from { transform: translateX(-50%) translateY(0) scale(1); }
  to { transform: translateX(-48%) translateY(18px) scale(1.04); }
}

.v7-hero .container {
  position: relative;
  z-index: 1;
}

.v7-copy h1 {
  letter-spacing: -.085em !important;
  text-shadow: 0 18px 60px rgba(15,23,42,.08);
}

.v7-copy h1 span {
  position: relative;
  background: linear-gradient(90deg, #2563eb 0%, #7c3aed 52%, #0ea5e9 100%) !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
  color: transparent !important;
}

.v7-copy h1 span::after {
  content: "";
  position: absolute;
  left: 2px;
  right: 2px;
  bottom: .06em;
  height: .16em;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(37,99,235,.18), rgba(14,165,233,.22));
  z-index: -1;
}

.v39-hero-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  margin-top: 26px;
}

.v39-hero-chips span {
  height: 36px;
  padding: 0 14px;
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(37,99,235,.12);
  color: #334155;
  font-size: 13px;
  font-weight: 820;
  box-shadow: 0 12px 34px rgba(15,23,42,.055);
  backdrop-filter: blur(14px);
}

.v7-showcase {
  perspective: 1200px;
}

.v7-window {
  position: relative;
  transform-style: preserve-3d;
  animation: v39WindowFloat 7s ease-in-out infinite alternate;
  box-shadow:
    0 34px 90px rgba(15,23,42,.14),
    inset 0 1px 0 rgba(255,255,255,.76) !important;
}

@keyframes v39WindowFloat {
  from { transform: translateY(0) rotateX(0deg) rotateY(-1.2deg); }
  to { transform: translateY(-12px) rotateX(1deg) rotateY(1.1deg); }
}

.v7-window::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  background: linear-gradient(115deg, transparent 0%, transparent 34%, rgba(255,255,255,.42) 44%, transparent 54%, transparent 100%);
  transform: translateX(-65%);
  animation: v39WindowShine 5.8s ease-in-out infinite;
}

@keyframes v39WindowShine {
  0%, 42% { transform: translateX(-70%); opacity: 0; }
  55% { opacity: .8; }
  78%, 100% { transform: translateX(72%); opacity: 0; }
}

.v7-dash-main h2 {
  font-size: clamp(30px, 2.6vw, 44px) !important;
  letter-spacing: -.07em !important;
}

.v39-mini-rail {
  display: grid;
  grid-template-columns: 1.2fr .8fr 1fr;
  gap: 8px;
  margin: 20px 0 4px;
}

.v39-mini-rail span {
  height: 7px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(37,99,235,.18), rgba(96,165,250,.62));
  overflow: hidden;
  position: relative;
}

.v39-mini-rail span::after {
  content: "";
  position: absolute;
  inset: 0;
  width: 42%;
  border-radius: 999px;
  background: rgba(255,255,255,.92);
  filter: blur(1px);
  animation: v39RailMove 2.6s ease-in-out infinite;
}

.v39-mini-rail span:nth-child(2)::after { animation-delay: .35s; }
.v39-mini-rail span:nth-child(3)::after { animation-delay: .7s; }

@keyframes v39RailMove {
  from { transform: translateX(-120%); opacity: .15; }
  50% { opacity: .75; }
  to { transform: translateX(260%); opacity: .1; }
}

.v7-flow-card {
  position: relative;
  overflow: hidden;
}

.v7-flow-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 10% 10%, rgba(37,99,235,.10), transparent 36%);
  opacity: 0;
  transition: opacity .18s ease;
}

.v7-flow-card:hover::before {
  opacity: 1;
}

.v7-side-card {
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.v7-side-card:hover {
  transform: translateX(-4px);
  border-color: rgba(37,99,235,.22) !important;
}

.v7-section-title h2 {
  letter-spacing: -.075em !important;
}

.v7-section-title p {
  font-size: 17px !important;
}

.v7-tools-clean {
  position: relative;
}

.v7-tools-clean::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 38px;
  width: min(860px, 82vw);
  height: 180px;
  transform: translateX(-50%);
  border-radius: 999px;
  background: radial-gradient(circle, rgba(37,99,235,.10), transparent 64%);
  filter: blur(18px);
  pointer-events: none;
}

.v7-tool-row {
  z-index: 1;
  background:
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(250,252,255,.90)) !important;
}

.v7-tool-row h3 {
  position: relative;
  display: inline-block;
}

.v7-tool-row h3::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -.22em;
  width: 42px;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, #2563eb, #60a5fa);
  opacity: .76;
}

.v7-roadmap {
  gap: 18px !important;
}

.v7-roadmap-card {
  position: relative;
  overflow: hidden;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.v7-roadmap-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 3px;
  background: linear-gradient(90deg, rgba(37,99,235,.55), rgba(139,92,246,.45));
  opacity: .6;
}

.v7-roadmap-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--sf-shadow-hover) !important;
  border-color: rgba(37,99,235,.14) !important;
}

.footer {
  background: rgba(255,255,255,.60) !important;
  backdrop-filter: blur(14px);
  border-top: 1px solid rgba(15,23,42,.07);
}

/* Make main less flat on large monitors */
@media (min-width: 1200px) {
  .v7-hero {
    padding-top: 92px !important;
    padding-bottom: 98px !important;
  }

  .v7-section {
    padding-top: 92px !important;
    padding-bottom: 96px !important;
  }
}

@media (max-width: 900px) {
  .v39-hero-chips {
    justify-content: center;
  }

  .v7-window {
    animation: none;
  }
}


/* v40 main hub wording/layout cleanup */
.v39-hero-chips {
  display: none !important;
}

.v7-dash-main h2 {
  background: linear-gradient(90deg, #0f172a 0%, #1d4ed8 56%, #7c3aed 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent !important;
}

.v7-dash-main p {
  max-width: 760px;
}

.v7-side-card {
  background:
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,251,255,.92)) !important;
}

.v7-side-card h3 {
  letter-spacing: -.055em;
}

.v7-side-card p {
  word-break: keep-all;
}

.v7-flow-card h3 {
  letter-spacing: -.045em;
}

.v7-flow-card p {
  word-break: keep-all;
}

/* The hub should look like a platform preview, not one product detail page */
.v7-window .v7-badge {
  background: #eef4ff !important;
  color: #2563eb !important;
  border-color: #dbeafe !important;
}

.v7-progress {
  background: #eaf1fb !important;
}

.v7-progress i {
  background: linear-gradient(90deg, #2563eb, #93c5fd) !important;
}


/* v45 download page fix: restore latest site style + guide modal */
.download-guide-btn,
#readmeOpenBtn {
  white-space: nowrap;
}

.v9-stage > .v9-section-title:first-child,
.download-page > .v9-section-title:first-child,
.download-page .download-hero,
.download-page .v9-hero {
  display: none !important;
}

.download-actions,
.v9-download-actions,
.download-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.sf-modal-open {
  overflow: hidden;
}

.sf-readme-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
}

.sf-readme-modal.is-open {
  display: block;
}

.sf-readme-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, .54);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.sf-readme-dialog {
  position: absolute;
  inset: 34px;
  max-width: 1120px;
  margin: 0 auto;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  border-radius: 28px;
  overflow: hidden;
  background: rgba(255,255,255,.96);
  border: 1px solid rgba(255,255,255,.70);
  box-shadow: 0 36px 110px rgba(15,23,42,.30);
}

.sf-readme-head {
  height: 68px;
  padding: 0 22px 0 28px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  border-bottom: 1px solid rgba(15,23,42,.08);
  background: rgba(255,255,255,.88);
}

.sf-readme-head strong {
  color: #0f172a;
  font-size: 20px;
  font-weight: 850;
  letter-spacing: -.045em;
}

.sf-readme-close {
  height: 40px;
  padding: 0 16px;
  border: 1px solid #dbe4f0;
  border-radius: 999px;
  background: #f8fbff;
  color: #334155;
  font-size: 14px;
  font-weight: 800;
  cursor: pointer;
  transition: .18s ease;
}

.sf-readme-close:hover {
  transform: translateY(-1px);
  border-color: #bfdbfe;
  color: #2563eb;
}

.sf-readme-body {
  min-height: 0;
  padding: 24px;
  overflow: auto;
  background:
    radial-gradient(circle at 15% 5%, rgba(96,165,250,.12), transparent 26%),
    linear-gradient(180deg, #fbfdff 0%, #f7f9ff 100%);
}

.sf-readme-body img {
  display: block;
  width: min(100%, 960px);
  height: auto;
  margin: 0 auto;
  border-radius: 22px;
  box-shadow: 0 20px 70px rgba(15,23,42,.12);
}

@media (max-width: 760px) {
  .sf-readme-dialog {
    inset: 12px;
    border-radius: 20px;
  }

  .sf-readme-head {
    height: 58px;
    padding: 0 14px 0 18px;
  }

  .sf-readme-head strong {
    font-size: 16px;
  }

  .sf-readme-body {
    padding: 12px;
  }

  .sf-readme-body img {
    border-radius: 14px;
  }
}


/* v47 header logo: single app-icon style */
.logo {
  width: 54px !important;
  height: 54px !important;
  min-width: 54px !important;
  padding: 0 !important;
  display: inline-grid !important;
  place-items: center !important;
  gap: 0 !important;
  border-radius: 18px !important;
  background:
    radial-gradient(circle at 28% 22%, rgba(255,255,255,.38), transparent 32%),
    linear-gradient(135deg, #1d4ed8 0%, #2563eb 52%, #0ea5e9 100%) !important;
  border: 1px solid rgba(255,255,255,.74) !important;
  box-shadow:
    0 16px 38px rgba(37,99,235,.24),
    inset 0 1px 0 rgba(255,255,255,.34) !important;
  overflow: hidden !important;
  transition: transform .18s ease, box-shadow .18s ease !important;
}

.logo:hover {
  transform: translateY(-2px) !important;
  box-shadow:
    0 22px 52px rgba(37,99,235,.32),
    inset 0 1px 0 rgba(255,255,255,.38) !important;
}

.logo-mark {
  width: auto !important;
  height: auto !important;
  min-width: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  color: #fff !important;
  font-size: 17px !important;
  font-weight: 950 !important;
  letter-spacing: -.06em !important;
  line-height: 1 !important;
}

.logo-name,
.logo-sub,
.logo > span:not(.logo-mark) {
  display: none !important;
}

@media (max-width: 760px) {
  .logo {
    width: 48px !important;
    height: 48px !important;
    min-width: 48px !important;
    border-radius: 16px !important;
  }

  .logo-mark {
    font-size: 16px !important;
  }
}


/* v49 restore: keep latest site design, uppercase SF logo only */
.logo-mark {
  font-size: 0 !important;
}

.logo-mark::before {
  content: "SF";
  font-size: 17px;
  font-weight: 950;
  letter-spacing: -.06em;
  line-height: 1;
  color: #fff;
}

@media (max-width: 760px) {
  .logo-mark::before {
    font-size: 16px;
  }
}


/* v49 online business card utility */
.business-card-stage {
  padding: 76px 0 110px;
  background:
    radial-gradient(circle at 82% 6%, rgba(37, 99, 235, .10), transparent 28%),
    radial-gradient(circle at 12% 24%, rgba(139, 92, 246, .10), transparent 26%),
    linear-gradient(180deg, #fbfdff 0%, #f7faff 100%);
}

.bc-shell {
  display: grid;
  grid-template-columns: 390px minmax(0, 1fr);
  gap: 22px;
  align-items: start;
}

.bc-panel {
  border-radius: 28px;
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(15,23,42,.08);
  box-shadow: 0 24px 76px rgba(15,23,42,.085);
  overflow: hidden;
}

.bc-panel-head {
  padding: 26px 28px 20px;
  border-bottom: 1px solid rgba(15,23,42,.07);
}

.bc-kicker {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  height: 32px;
  padding: 0 13px;
  border-radius: 999px;
  color: #2563eb;
  background: #eef4ff;
  border: 1px solid #dbeafe;
  font-size: 13px;
  font-weight: 850;
}

.bc-kicker::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: #2563eb;
}

.bc-panel-head h1,
.bc-panel-head h2 {
  margin: 16px 0 0;
  color: #111827;
  font-size: 32px;
  line-height: 1.14;
  letter-spacing: -.065em;
  font-weight: 900;
}

.bc-panel-head p {
  margin: 10px 0 0;
  color: #64748b;
  line-height: 1.72;
  font-size: 15px;
  word-break: keep-all;
}

.bc-form {
  padding: 22px 24px 26px;
  display: grid;
  gap: 14px;
}

.bc-field {
  display: grid;
  gap: 7px;
}

.bc-field label {
  color: #334155;
  font-size: 13px;
  font-weight: 850;
}

.bc-field input,
.bc-field textarea,
.bc-field select {
  width: 100%;
  border: 1px solid #dbe4f0;
  background: #f8fbff;
  border-radius: 15px;
  padding: 13px 14px;
  color: #111827;
  font-size: 14px;
  outline: none;
}

.bc-field textarea {
  min-height: 82px;
  resize: vertical;
  line-height: 1.6;
}

.bc-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.bc-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 6px;
}

.bc-btn {
  height: 48px;
  border: 0;
  border-radius: 16px;
  font-size: 15px;
  font-weight: 880;
  cursor: pointer;
  transition: .18s ease;
}

.bc-btn.primary {
  color: #fff;
  background: linear-gradient(135deg, #2563eb, #1677ff);
  box-shadow: 0 18px 42px rgba(37,99,235,.22);
}

.bc-btn.soft {
  color: #2563eb;
  background: #eef4ff;
  border: 1px solid #dbeafe;
}

.bc-btn:hover {
  transform: translateY(-2px);
}

.bc-preview-wrap {
  padding: 24px;
}

.bc-template-strip {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 20px;
}

.bc-template-btn {
  min-height: 64px;
  border: 1px solid #e2e8f0;
  background: rgba(255,255,255,.88);
  border-radius: 16px;
  color: #334155;
  font-size: 12px;
  font-weight: 820;
  cursor: pointer;
  transition: .16s ease;
}

.bc-template-btn:hover,
.bc-template-btn.active {
  border-color: #93c5fd;
  color: #1d4ed8;
  box-shadow: 0 14px 34px rgba(37,99,235,.11);
  transform: translateY(-2px);
}

.bc-card-canvas {
  width: min(100%, 680px);
  min-height: 390px;
  margin: 0 auto;
  border-radius: 32px;
  padding: 38px;
  position: relative;
  overflow: hidden;
  color: var(--bc-text, #111827);
  background: var(--bc-bg, linear-gradient(135deg, #ffffff, #eef4ff));
  border: 1px solid rgba(15,23,42,.08);
  box-shadow: 0 34px 92px rgba(15,23,42,.14);
}

.bc-card-canvas::before,
.bc-card-canvas::after {
  content: "";
  position: absolute;
  border-radius: 999px;
  pointer-events: none;
}

.bc-card-canvas::before {
  width: 260px;
  height: 260px;
  right: -90px;
  top: -90px;
  background: var(--bc-orb1, rgba(37,99,235,.16));
}

.bc-card-canvas::after {
  width: 180px;
  height: 180px;
  left: -70px;
  bottom: -70px;
  background: var(--bc-orb2, rgba(139,92,246,.14));
}

.bc-card-inner {
  position: relative;
  z-index: 1;
  min-height: 314px;
  display: grid;
  grid-template-rows: auto 1fr auto;
}

.bc-brand-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 18px;
}

.bc-logo-mini {
  width: 52px;
  height: 52px;
  border-radius: 17px;
  display: grid;
  place-items: center;
  color: var(--bc-logo-text, #fff);
  background: var(--bc-logo, #2563eb);
  font-weight: 950;
  letter-spacing: -.07em;
  box-shadow: 0 16px 34px rgba(15,23,42,.18);
}

.bc-company {
  text-align: right;
  color: var(--bc-muted, #64748b);
  font-size: 14px;
  font-weight: 820;
}

.bc-main-info {
  padding: 42px 0 30px;
}

.bc-name {
  margin: 0;
  font-size: clamp(38px, 5vw, 58px);
  line-height: 1;
  letter-spacing: -.085em;
  font-weight: 950;
  color: var(--bc-title, currentColor);
}

.bc-position {
  margin-top: 12px;
  color: var(--bc-muted, #64748b);
  font-size: 17px;
  font-weight: 820;
}

.bc-intro {
  max-width: 500px;
  margin-top: 22px;
  color: var(--bc-muted, #64748b);
  font-size: 15px;
  line-height: 1.72;
  word-break: keep-all;
}

.bc-contact {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px 18px;
  color: var(--bc-muted, #64748b);
  font-size: 14px;
  line-height: 1.5;
}

.bc-contact span {
  display: block;
  min-width: 0;
  overflow-wrap: anywhere;
}

.bc-card-canvas.t-dark {
  --bc-text: #ffffff;
  --bc-title: #ffffff;
  --bc-muted: rgba(255,255,255,.76);
  border-color: rgba(255,255,255,.16);
}

.bc-card-canvas.t-blue {
  --bc-bg: linear-gradient(135deg, #ffffff 0%, #eef5ff 100%);
  --bc-logo: linear-gradient(135deg, #2563eb, #0ea5e9);
  --bc-orb1: rgba(37,99,235,.18);
  --bc-orb2: rgba(14,165,233,.16);
}

.bc-card-canvas.t-navy {
  --bc-bg: linear-gradient(135deg, #0f172a 0%, #172554 100%);
  --bc-logo: rgba(255,255,255,.16);
  --bc-orb1: rgba(96,165,250,.18);
  --bc-orb2: rgba(139,92,246,.18);
}

.bc-card-canvas.t-purple {
  --bc-bg: linear-gradient(135deg, #faf5ff 0%, #eef2ff 100%);
  --bc-logo: linear-gradient(135deg, #7c3aed, #2563eb);
  --bc-orb1: rgba(124,58,237,.18);
  --bc-orb2: rgba(37,99,235,.14);
}

.bc-card-canvas.t-black {
  --bc-bg: linear-gradient(135deg, #111827 0%, #000000 100%);
  --bc-logo: rgba(255,255,255,.14);
  --bc-orb1: rgba(255,255,255,.08);
  --bc-orb2: rgba(37,99,235,.20);
}

.bc-card-canvas.t-green {
  --bc-bg: linear-gradient(135deg, #f0fdf4 0%, #ecfeff 100%);
  --bc-logo: linear-gradient(135deg, #16a34a, #06b6d4);
  --bc-orb1: rgba(22,163,74,.16);
  --bc-orb2: rgba(6,182,212,.14);
}

.bc-card-canvas.t-orange {
  --bc-bg: linear-gradient(135deg, #fff7ed 0%, #fff1f2 100%);
  --bc-logo: linear-gradient(135deg, #f97316, #ef4444);
  --bc-orb1: rgba(249,115,22,.16);
  --bc-orb2: rgba(239,68,68,.12);
}

.bc-card-canvas.t-minimal {
  --bc-bg: #ffffff;
  --bc-logo: #111827;
  --bc-orb1: rgba(15,23,42,.055);
  --bc-orb2: rgba(37,99,235,.08);
}

.bc-card-canvas.layout-center .bc-card-inner {
  text-align: center;
}

.bc-card-canvas.layout-center .bc-brand-row {
  justify-content: center;
}

.bc-card-canvas.layout-center .bc-company {
  display: none;
}

.bc-card-canvas.layout-center .bc-main-info {
  padding-top: 32px;
}

.bc-card-canvas.layout-center .bc-intro {
  margin-left: auto;
  margin-right: auto;
}

.bc-card-canvas.layout-center .bc-contact {
  justify-items: center;
}

.bc-card-canvas.layout-split .bc-card-inner {
  grid-template-rows: auto 1fr;
}

.bc-card-canvas.layout-split .bc-main-info {
  display: grid;
  grid-template-columns: .82fr 1fr;
  gap: 26px;
  align-items: end;
}

.bc-card-canvas.layout-split .bc-intro {
  margin-top: 0;
}

.bc-card-canvas.layout-bold .bc-name {
  font-size: clamp(48px, 6vw, 72px);
}

.bc-card-canvas.layout-bold .bc-contact {
  border-top: 1px solid rgba(148,163,184,.24);
  padding-top: 20px;
}

.bc-note {
  margin-top: 18px;
  padding: 15px 16px;
  border-radius: 18px;
  background: #f8fbff;
  border: 1px solid #e2e8f0;
  color: #64748b;
  font-size: 13px;
  line-height: 1.6;
}

@media (max-width: 1080px) {
  .bc-shell {
    grid-template-columns: 1fr;
  }

  .bc-template-strip {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .business-card-stage {
    padding: 36px 0 70px;
  }

  .bc-grid-2 {
    grid-template-columns: 1fr;
  }

  .bc-template-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .bc-card-canvas {
    padding: 26px;
    border-radius: 24px;
  }

  .bc-contact,
  .bc-card-canvas.layout-split .bc-main-info {
    grid-template-columns: 1fr;
  }
}


/* v50 business card builder upgrade: real layouts + controls */
.bc-builder-shell {
  display: grid;
  grid-template-columns: 390px minmax(0, 1fr);
  gap: 22px;
  align-items: start;
}

.bc-tabs {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  padding: 14px 14px 0;
}

.bc-tab {
  height: 40px;
  border: 1px solid #dbe4f0;
  background: #f8fbff;
  border-radius: 13px;
  color: #64748b;
  font-size: 13px;
  font-weight: 850;
  cursor: pointer;
}

.bc-tab.active {
  background: #2563eb;
  color: #fff;
  border-color: #2563eb;
  box-shadow: 0 14px 30px rgba(37,99,235,.20);
}

.bc-tab-panel {
  display: none;
}

.bc-tab-panel.active {
  display: grid;
  gap: 14px;
}

.bc-check-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 9px;
}

.bc-check {
  min-height: 40px;
  padding: 0 11px;
  display: flex;
  align-items: center;
  gap: 8px;
  border-radius: 13px;
  border: 1px solid #dbe4f0;
  background: #f8fbff;
  color: #334155;
  font-size: 13px;
  font-weight: 760;
  cursor: pointer;
}

.bc-check input {
  width: 15px;
  height: 15px;
  accent-color: #2563eb;
}

.bc-color-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 9px;
}

.bc-color-row input[type="color"] {
  width: 100%;
  height: 46px;
  padding: 5px;
  border-radius: 14px;
  cursor: pointer;
}

.bc-template-strip.v50 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  max-height: 324px;
  overflow: auto;
  padding-right: 4px;
}

.bc-template-btn.v50 {
  min-height: 86px;
  text-align: left;
  padding: 12px;
  position: relative;
  overflow: hidden;
}

.bc-template-btn.v50 strong {
  display: block;
  color: #111827;
  font-size: 12px;
  margin-bottom: 6px;
  letter-spacing: -.02em;
}

.bc-template-btn.v50 small {
  display: block;
  color: #64748b;
  font-size: 11px;
  line-height: 1.35;
}

.bc-template-btn.v50::after {
  content: "";
  position: absolute;
  width: 58px;
  height: 58px;
  right: -18px;
  bottom: -20px;
  border-radius: 999px;
  background: var(--tpl, rgba(37,99,235,.18));
}

.bc-device-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 18px;
  align-items: center;
  justify-content: space-between;
}

.bc-device-left,
.bc-device-right {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.bc-mini-btn {
  height: 36px;
  padding: 0 12px;
  border: 1px solid #dbe4f0;
  border-radius: 999px;
  background: rgba(255,255,255,.82);
  color: #334155;
  font-size: 12px;
  font-weight: 830;
  cursor: pointer;
}

.bc-mini-btn.active {
  background: #eef4ff;
  color: #2563eb;
  border-color: #bfdbfe;
}

.bc-card-canvas.v50 {
  --bc-primary: #2563eb;
  --bc-secondary: #8b5cf6;
  --bc-accent: #0ea5e9;
  width: min(100%, 760px);
  min-height: 420px;
  aspect-ratio: 1.72 / 1;
  display: block;
  padding: 0;
  border-radius: 34px;
  background:
    radial-gradient(circle at 84% 14%, color-mix(in srgb, var(--bc-primary) 22%, transparent), transparent 32%),
    radial-gradient(circle at 10% 88%, color-mix(in srgb, var(--bc-secondary) 18%, transparent), transparent 34%),
    linear-gradient(135deg, #ffffff 0%, #f4f8ff 100%);
  color: #111827;
}

.bc-card-canvas.size-square {
  width: min(100%, 560px);
  aspect-ratio: 1 / 1;
  min-height: auto;
}

.bc-card-canvas.size-vertical {
  width: min(100%, 420px);
  aspect-ratio: 0.64 / 1;
  min-height: auto;
}

.bc-card-canvas.v50::before,
.bc-card-canvas.v50::after {
  display: none;
}

.bc-v50-inner {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  min-height: inherit;
  padding: 38px;
  display: grid;
  gap: 20px;
  overflow: hidden;
}

.bc-v50-logo {
  width: 58px;
  height: 58px;
  display: grid;
  place-items: center;
  border-radius: 20px;
  color: #fff;
  background: linear-gradient(135deg, var(--bc-primary), var(--bc-accent));
  font-size: 18px;
  font-weight: 950;
  letter-spacing: -.07em;
  box-shadow: 0 18px 42px color-mix(in srgb, var(--bc-primary) 24%, transparent);
}

.bc-v50-company {
  color: #64748b;
  font-size: 14px;
  font-weight: 860;
}

.bc-v50-name {
  margin: 0;
  color: #111827;
  font-size: clamp(42px, 5.4vw, 68px);
  line-height: .95;
  letter-spacing: -.085em;
  font-weight: 950;
}

.bc-v50-position {
  margin-top: 12px;
  color: var(--bc-primary);
  font-size: 18px;
  font-weight: 880;
}

.bc-v50-intro {
  max-width: 470px;
  color: #64748b;
  font-size: 15px;
  line-height: 1.7;
  word-break: keep-all;
}

.bc-v50-contact {
  display: grid;
  gap: 9px;
  color: #475569;
  font-size: 14px;
  line-height: 1.45;
}

.bc-v50-contact span {
  overflow-wrap: anywhere;
}

.bc-v50-contact b {
  color: #94a3b8;
  font-size: 11px;
  letter-spacing: .03em;
  margin-right: 8px;
}

.bc-hide {
  display: none !important;
}

/* alignment */
.bc-card-canvas.align-center .bc-v50-inner {
  text-align: center;
  justify-items: center;
}

.bc-card-canvas.align-center .bc-v50-intro {
  margin-left: auto;
  margin-right: auto;
}

.bc-card-canvas.align-right .bc-v50-inner {
  text-align: right;
  justify-items: end;
}

.bc-card-canvas.logo-top-right .bc-v50-logo-wrap {
  justify-self: end;
}

.bc-card-canvas.logo-center .bc-v50-logo-wrap {
  justify-self: center;
}

/* contact placement */
.bc-card-canvas.contact-bottom .bc-v50-contact {
  align-self: end;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.bc-card-canvas.contact-right .bc-v50-inner {
  grid-template-columns: 1fr 240px;
  grid-template-areas:
    "brand contact"
    "main contact"
    "intro contact";
}

.bc-card-canvas.contact-right .bc-v50-brand { grid-area: brand; }
.bc-card-canvas.contact-right .bc-v50-main { grid-area: main; align-self: end; }
.bc-card-canvas.contact-right .bc-v50-intro { grid-area: intro; }
.bc-card-canvas.contact-right .bc-v50-contact {
  grid-area: contact;
  align-self: stretch;
  align-content: center;
  padding-left: 24px;
  border-left: 1px solid rgba(148,163,184,.22);
}

.bc-card-canvas.contact-left .bc-v50-inner {
  grid-template-columns: 220px 1fr;
  grid-template-areas:
    "contact brand"
    "contact main"
    "contact intro";
}

.bc-card-canvas.contact-left .bc-v50-brand { grid-area: brand; }
.bc-card-canvas.contact-left .bc-v50-main { grid-area: main; align-self: end; }
.bc-card-canvas.contact-left .bc-v50-intro { grid-area: intro; }
.bc-card-canvas.contact-left .bc-v50-contact {
  grid-area: contact;
  align-self: stretch;
  align-content: center;
  padding-right: 24px;
  border-right: 1px solid rgba(148,163,184,.22);
}

/* template looks */
.bc-look-glass {
  background:
    linear-gradient(135deg, rgba(255,255,255,.82), rgba(239,246,255,.70)),
    radial-gradient(circle at 86% 10%, color-mix(in srgb, var(--bc-primary) 22%, transparent), transparent 30%) !important;
  backdrop-filter: blur(18px);
}

.bc-look-glass .bc-v50-inner::before {
  content: "";
  position: absolute;
  inset: 22px;
  border-radius: 26px;
  border: 1px solid rgba(255,255,255,.72);
  pointer-events: none;
}

.bc-look-diagonal {
  background:
    linear-gradient(135deg, transparent 0 55%, color-mix(in srgb, var(--bc-primary) 16%, transparent) 55% 100%),
    linear-gradient(135deg, #fff, #f8fbff) !important;
}

.bc-look-diagonal .bc-v50-inner::after {
  content: "";
  position: absolute;
  right: -90px;
  top: -120px;
  width: 330px;
  height: 520px;
  transform: rotate(28deg);
  background: linear-gradient(180deg, var(--bc-primary), var(--bc-secondary));
  opacity: .13;
  border-radius: 60px;
}

.bc-look-frame .bc-v50-inner {
  margin: 18px;
  height: calc(100% - 36px);
  width: calc(100% - 36px);
  border: 2px solid color-mix(in srgb, var(--bc-primary) 42%, #dbeafe);
  border-radius: 24px;
  padding: 32px;
}

.bc-look-line {
  background:
    repeating-linear-gradient(135deg, rgba(37,99,235,.055) 0 1px, transparent 1px 15px),
    linear-gradient(135deg, #ffffff, #f8fbff) !important;
}

.bc-look-line .bc-v50-name {
  text-decoration: underline;
  text-decoration-thickness: .13em;
  text-decoration-color: color-mix(in srgb, var(--bc-primary) 22%, transparent);
  text-underline-offset: -.05em;
}

.bc-look-wave {
  background: linear-gradient(135deg, #ffffff 0%, #eef4ff 100%) !important;
}

.bc-look-wave .bc-v50-inner::before {
  content: "";
  position: absolute;
  right: -90px;
  bottom: -150px;
  width: 520px;
  height: 260px;
  background: linear-gradient(135deg, var(--bc-primary), var(--bc-secondary));
  opacity: .16;
  border-radius: 50% 50% 0 0;
  transform: rotate(-8deg);
}

.bc-look-dark {
  background:
    radial-gradient(circle at 80% 18%, color-mix(in srgb, var(--bc-accent) 30%, transparent), transparent 32%),
    linear-gradient(135deg, #0f172a, #020617) !important;
  color: #fff;
  border-color: rgba(255,255,255,.14);
}

.bc-look-dark .bc-v50-name,
.bc-look-dark .bc-v50-position,
.bc-look-dark .bc-v50-contact b {
  color: #fff;
}

.bc-look-dark .bc-v50-company,
.bc-look-dark .bc-v50-intro,
.bc-look-dark .bc-v50-contact {
  color: rgba(255,255,255,.74);
}

.bc-look-dark .bc-v50-contact {
  border-color: rgba(255,255,255,.18) !important;
}

.bc-look-bold {
  background: linear-gradient(135deg, var(--bc-primary) 0 36%, #ffffff 36% 100%) !important;
}

.bc-look-bold .bc-v50-logo {
  background: rgba(255,255,255,.2);
  color: #fff;
}

.bc-look-bold .bc-v50-company {
  color: rgba(255,255,255,.88);
}

.bc-look-bold .bc-v50-name {
  margin-top: 20px;
}

.bc-look-minimal {
  background: #ffffff !important;
}

.bc-look-minimal .bc-v50-inner::before {
  content: "";
  position: absolute;
  left: 38px;
  top: 38px;
  bottom: 38px;
  width: 5px;
  border-radius: 999px;
  background: var(--bc-primary);
}

.bc-look-minimal .bc-v50-inner {
  padding-left: 62px;
}

.bc-look-luxury {
  background:
    radial-gradient(circle at 80% 12%, rgba(255,255,255,.13), transparent 30%),
    linear-gradient(135deg, #111827, #1e1b4b) !important;
  color: #fff;
}

.bc-look-luxury .bc-v50-name,
.bc-look-luxury .bc-v50-position {
  color: #fff;
}

.bc-look-luxury .bc-v50-company,
.bc-look-luxury .bc-v50-intro,
.bc-look-luxury .bc-v50-contact {
  color: rgba(255,255,255,.74);
}

.bc-look-luxury .bc-v50-logo {
  background: linear-gradient(135deg, #fbbf24, #f97316);
}

.bc-look-card {
  background: #edf4ff !important;
}

.bc-look-card .bc-v50-inner::before {
  content: "";
  position: absolute;
  inset: 28px;
  border-radius: 28px;
  background: rgba(255,255,255,.80);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.8);
  z-index: -1;
}

/* sizes */
.bc-card-canvas.size-square.contact-right .bc-v50-inner,
.bc-card-canvas.size-square.contact-left .bc-v50-inner,
.bc-card-canvas.size-vertical.contact-right .bc-v50-inner,
.bc-card-canvas.size-vertical.contact-left .bc-v50-inner {
  grid-template-columns: 1fr;
  grid-template-areas: none;
}

.bc-card-canvas.size-square .bc-v50-brand,
.bc-card-canvas.size-square .bc-v50-main,
.bc-card-canvas.size-square .bc-v50-intro,
.bc-card-canvas.size-square .bc-v50-contact,
.bc-card-canvas.size-vertical .bc-v50-brand,
.bc-card-canvas.size-vertical .bc-v50-main,
.bc-card-canvas.size-vertical .bc-v50-intro,
.bc-card-canvas.size-vertical .bc-v50-contact {
  grid-area: auto !important;
  border: 0 !important;
  padding: 0 !important;
}

.bc-card-canvas.size-vertical .bc-v50-inner {
  align-content: space-between;
}

.bc-card-canvas.size-vertical .bc-v50-contact,
.bc-card-canvas.size-square .bc-v50-contact {
  grid-template-columns: 1fr;
}

@media (max-width: 1080px) {
  .bc-builder-shell {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .bc-template-strip.v50 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .bc-check-grid,
  .bc-color-row {
    grid-template-columns: 1fr;
  }

  .bc-card-canvas.v50 {
    min-height: 360px;
  }

  .bc-card-canvas.contact-right .bc-v50-inner,
  .bc-card-canvas.contact-left .bc-v50-inner {
    grid-template-columns: 1fr;
    grid-template-areas: none;
  }

  .bc-card-canvas.contact-right .bc-v50-brand,
  .bc-card-canvas.contact-right .bc-v50-main,
  .bc-card-canvas.contact-right .bc-v50-intro,
  .bc-card-canvas.contact-right .bc-v50-contact,
  .bc-card-canvas.contact-left .bc-v50-brand,
  .bc-card-canvas.contact-left .bc-v50-main,
  .bc-card-canvas.contact-left .bc-v50-intro,
  .bc-card-canvas.contact-left .bc-v50-contact {
    grid-area: auto !important;
    border: 0 !important;
    padding: 0 !important;
  }

  .bc-card-canvas.contact-bottom .bc-v50-contact {
    grid-template-columns: 1fr;
  }
}


/* v51 business card editor rebuild */
.bc51-stage {
  min-height: calc(100vh - 74px);
  padding: 42px 0 86px;
  background:
    radial-gradient(circle at 82% 0%, rgba(37,99,235,.10), transparent 28%),
    radial-gradient(circle at 12% 20%, rgba(139,92,246,.10), transparent 30%),
    linear-gradient(180deg, #fbfdff 0%, #f7faff 100%);
}

.bc51-shell {
  display: grid;
  grid-template-columns: 360px minmax(0, 1fr);
  gap: 20px;
  align-items: start;
}

.bc51-panel,
.bc51-preview-panel {
  border-radius: 28px;
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(15,23,42,.08);
  box-shadow: 0 24px 76px rgba(15,23,42,.075);
  overflow: hidden;
}

.bc51-panel {
  position: sticky;
  top: 92px;
  max-height: calc(100vh - 112px);
  overflow-y: auto;
}

.bc51-head {
  padding: 24px 24px 18px;
  border-bottom: 1px solid rgba(15,23,42,.07);
}

.bc51-pill {
  display: inline-flex;
  align-items: center;
  height: 30px;
  padding: 0 12px;
  border-radius: 999px;
  background: #eef4ff;
  border: 1px solid #dbeafe;
  color: #2563eb;
  font-size: 12px;
  font-weight: 900;
}

.bc51-head h1,
.bc51-head h2 {
  margin: 14px 0 0;
  color: #111827;
  font-size: 28px;
  line-height: 1.12;
  letter-spacing: -.065em;
  font-weight: 920;
}

.bc51-head p {
  margin: 9px 0 0;
  color: #64748b;
  font-size: 14px;
  line-height: 1.65;
  word-break: keep-all;
}

.bc51-tabs {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 7px;
  padding: 14px 14px 0;
}

.bc51-tab {
  height: 38px;
  border: 1px solid #dbe4f0;
  border-radius: 13px;
  background: #f8fbff;
  color: #64748b;
  font-size: 13px;
  font-weight: 850;
  cursor: pointer;
}

.bc51-tab.active {
  background: #2563eb;
  color: #fff;
  border-color: #2563eb;
  box-shadow: 0 12px 28px rgba(37,99,235,.20);
}

.bc51-form {
  padding: 18px;
}

.bc51-section {
  display: none;
  gap: 12px;
}

.bc51-section.active {
  display: grid;
}

.bc51-field {
  display: grid;
  gap: 7px;
}

.bc51-field label,
.bc51-label {
  color: #334155;
  font-size: 12.5px;
  font-weight: 880;
}

.bc51-field input,
.bc51-field textarea,
.bc51-field select {
  width: 100%;
  border: 1px solid #dbe4f0;
  background: #f8fbff;
  border-radius: 14px;
  padding: 12px 13px;
  color: #111827;
  font-size: 14px;
  outline: none;
}

.bc51-field textarea {
  min-height: 74px;
  resize: vertical;
  line-height: 1.55;
}

.bc51-grid2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.bc51-checks {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.bc51-check {
  min-height: 40px;
  padding: 0 10px;
  display: flex;
  align-items: center;
  gap: 8px;
  border-radius: 13px;
  background: #f8fbff;
  border: 1px solid #dbe4f0;
  color: #334155;
  font-size: 13px;
  font-weight: 780;
}

.bc51-check input {
  width: 15px;
  height: 15px;
  accent-color: #2563eb;
}

.bc51-font-block {
  padding: 12px;
  border-radius: 16px;
  border: 1px solid #e2e8f0;
  background: #fbfdff;
  display: grid;
  gap: 10px;
}

.bc51-font-title {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  color: #111827;
  font-size: 13px;
  font-weight: 900;
}

.bc51-range-row {
  display: grid;
  grid-template-columns: 1fr 48px;
  gap: 8px;
  align-items: center;
}

.bc51-range-row input[type="range"] {
  padding: 0;
}

.bc51-range-row span {
  text-align: right;
  color: #64748b;
  font-size: 12px;
  font-weight: 820;
}

.bc51-color-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 9px;
}

.bc51-color-row input[type="color"] {
  height: 44px;
  padding: 5px;
  border-radius: 14px;
  cursor: pointer;
}

.bc51-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  padding: 0 18px 18px;
}

.bc51-btn {
  height: 46px;
  border-radius: 15px;
  border: 1px solid #dbe4f0;
  background: #f8fbff;
  color: #2563eb;
  font-size: 14px;
  font-weight: 900;
  cursor: pointer;
  transition: .18s ease;
}

.bc51-btn.primary {
  border: 0;
  color: #fff;
  background: linear-gradient(135deg, #2563eb, #1677ff);
  box-shadow: 0 16px 36px rgba(37,99,235,.22);
}

.bc51-btn:hover {
  transform: translateY(-2px);
}

.bc51-preview-panel {
  min-width: 0;
}

.bc51-preview-top {
  padding: 20px 22px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  border-bottom: 1px solid rgba(15,23,42,.07);
}

.bc51-preview-top h2 {
  margin: 0;
  color: #111827;
  font-size: 24px;
  letter-spacing: -.055em;
  font-weight: 920;
}

.bc51-preview-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.bc51-mini {
  height: 36px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid #dbe4f0;
  background: #fff;
  color: #334155;
  font-size: 12px;
  font-weight: 850;
  cursor: pointer;
}

.bc51-mini.active {
  background: #eef4ff;
  border-color: #bfdbfe;
  color: #2563eb;
}

.bc51-template-wrap {
  padding: 18px 22px 0;
}

.bc51-template-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
  max-height: 198px;
  overflow: auto;
  padding-right: 4px;
}

.bc51-template {
  min-height: 72px;
  border-radius: 16px;
  border: 1px solid #e2e8f0;
  background: #fff;
  padding: 11px;
  text-align: left;
  cursor: pointer;
  position: relative;
  overflow: hidden;
}

.bc51-template strong {
  display: block;
  color: #111827;
  font-size: 12px;
  letter-spacing: -.02em;
  margin-bottom: 5px;
}

.bc51-template small {
  display: block;
  color: #64748b;
  font-size: 11px;
  line-height: 1.32;
}

.bc51-template::after {
  content: "";
  position: absolute;
  right: -16px;
  bottom: -16px;
  width: 54px;
  height: 54px;
  border-radius: 999px;
  background: var(--tpl-color, rgba(37,99,235,.18));
}

.bc51-template.active {
  border-color: #93c5fd;
  box-shadow: 0 14px 34px rgba(37,99,235,.12);
}

.bc51-workspace {
  padding: 26px 22px 32px;
  min-height: 520px;
  display: grid;
  place-items: center;
  overflow: auto;
}

.bc51-card {
  --p: #2563eb;
  --s: #8b5cf6;
  --a: #0ea5e9;
  width: min(100%, 760px);
  aspect-ratio: 1.72 / 1;
  min-height: 390px;
  position: relative;
  overflow: hidden;
  border-radius: 34px;
  border: 1px solid rgba(15,23,42,.08);
  box-shadow: 0 34px 92px rgba(15,23,42,.14);
  background: linear-gradient(135deg, #ffffff 0%, #f2f7ff 100%);
  color: #111827;
  font-family: Pretendard, "Noto Sans KR", "Malgun Gothic", Arial, sans-serif;
}

.bc51-card.square {
  width: min(100%, 560px);
  aspect-ratio: 1 / 1;
  min-height: auto;
}

.bc51-card.vertical {
  width: min(100%, 430px);
  aspect-ratio: .66 / 1;
  min-height: auto;
}

.bc51-bg-orb1,
.bc51-bg-orb2,
.bc51-bg-band,
.bc51-bg-line {
  position: absolute;
  pointer-events: none;
}

.bc51-bg-orb1 {
  width: 260px;
  height: 260px;
  right: -90px;
  top: -90px;
  border-radius: 999px;
  background: rgba(37,99,235,.16);
}

.bc51-bg-orb2 {
  width: 190px;
  height: 190px;
  left: -70px;
  bottom: -70px;
  border-radius: 999px;
  background: rgba(139,92,246,.13);
}

.bc51-bg-band {
  width: 360px;
  height: 680px;
  right: -150px;
  top: -160px;
  border-radius: 80px;
  transform: rotate(25deg);
  background: linear-gradient(180deg, var(--p), var(--s));
  opacity: .12;
}

.bc51-bg-line {
  left: 36px;
  top: 36px;
  bottom: 36px;
  width: 5px;
  border-radius: 999px;
  background: var(--p);
  opacity: 0;
}

.bc51-card-inner {
  position: absolute;
  inset: 0;
  padding: 38px;
}

.bc51-part {
  position: absolute;
  z-index: 3;
  cursor: default;
  max-width: calc(100% - 76px);
}

.bc51-free .bc51-part {
  cursor: move;
}

.bc51-free .bc51-part:hover {
  outline: 1px dashed rgba(37,99,235,.42);
  outline-offset: 6px;
}

.bc51-logo {
  width: 58px;
  height: 58px;
  display: grid;
  place-items: center;
  border-radius: 20px;
  color: #fff;
  background: linear-gradient(135deg, var(--p), var(--a));
  font-size: 18px;
  font-weight: 950;
  letter-spacing: -.07em;
  box-shadow: 0 18px 42px rgba(37,99,235,.22);
}

.bc51-company {
  color: #64748b;
  font-size: 14px;
  font-weight: 870;
}

.bc51-name {
  margin: 0;
  color: #111827;
  font-size: 58px;
  line-height: .96;
  letter-spacing: -.085em;
  font-weight: 950;
  white-space: nowrap;
}

.bc51-position {
  color: var(--p);
  font-size: 18px;
  font-weight: 900;
}

.bc51-intro {
  color: #64748b;
  font-size: 15px;
  line-height: 1.68;
  word-break: keep-all;
}

.bc51-contact {
  display: grid;
  gap: 8px;
  color: #475569;
  font-size: 14px;
  line-height: 1.45;
}

.bc51-contact span {
  display: block;
  overflow-wrap: anywhere;
}

.bc51-contact b {
  display: inline-block;
  min-width: 54px;
  color: #94a3b8;
  font-size: 11px;
  letter-spacing: .03em;
  font-weight: 900;
}

.bc51-hidden {
  display: none !important;
}

/* preset looks */
.bc51-look-glass {
  background: linear-gradient(135deg, #ffffff 0%, #eef4ff 100%);
}

.bc51-look-glass .bc51-bg-orb1 { background: rgba(37,99,235,.18); }
.bc51-look-glass .bc51-bg-orb2 { background: rgba(139,92,246,.13); }

.bc51-look-diagonal {
  background: linear-gradient(135deg, #ffffff 0%, #f8fbff 100%);
}

.bc51-look-diagonal .bc51-bg-band { opacity: .18; }

.bc51-look-frame {
  background: #ffffff;
}

.bc51-look-frame .bc51-card-inner {
  inset: 20px;
  border: 2px solid rgba(37,99,235,.30);
  border-radius: 25px;
}

.bc51-look-line {
  background:
    repeating-linear-gradient(135deg, rgba(37,99,235,.055) 0 1px, transparent 1px 15px),
    linear-gradient(135deg, #fff, #f8fbff);
}

.bc51-look-line .bc51-bg-line { opacity: 1; }

.bc51-look-wave {
  background: linear-gradient(135deg, #ffffff 0%, #f0f7ff 100%);
}

.bc51-look-wave .bc51-bg-band {
  width: 620px;
  height: 240px;
  right: -120px;
  top: auto;
  bottom: -120px;
  border-radius: 999px;
  transform: rotate(-8deg);
  opacity: .16;
}

.bc51-look-dark {
  background: linear-gradient(135deg, #0f172a 0%, #020617 100%);
  color: #fff;
  border-color: rgba(255,255,255,.14);
}

.bc51-look-dark .bc51-name,
.bc51-look-dark .bc51-position {
  color: #fff;
}

.bc51-look-dark .bc51-company,
.bc51-look-dark .bc51-intro,
.bc51-look-dark .bc51-contact {
  color: rgba(255,255,255,.74);
}

.bc51-look-dark .bc51-contact b {
  color: rgba(255,255,255,.58);
}

.bc51-look-bold {
  background: linear-gradient(135deg, #ffffff 0 34%, #f7faff 34% 100%);
}

.bc51-look-bold .bc51-bg-band {
  left: -150px;
  right: auto;
  top: -320px;
  width: 900px;
  height: 410px;
  transform: rotate(0);
  border-radius: 0;
  opacity: 1;
}

.bc51-look-bold .bc51-company,
.bc51-look-bold .bc51-logo {
  color: #fff;
}

.bc51-look-minimal {
  background: #ffffff;
}

.bc51-look-minimal .bc51-bg-line { opacity: 1; }
.bc51-look-minimal .bc51-bg-orb1,
.bc51-look-minimal .bc51-bg-orb2,
.bc51-look-minimal .bc51-bg-band { display: none; }

.bc51-look-luxury {
  background: linear-gradient(135deg, #111827 0%, #1e1b4b 100%);
  color: #fff;
}

.bc51-look-luxury .bc51-logo {
  background: linear-gradient(135deg, #f59e0b, #f97316);
}

.bc51-look-luxury .bc51-name,
.bc51-look-luxury .bc51-position {
  color: #fff;
}

.bc51-look-luxury .bc51-company,
.bc51-look-luxury .bc51-intro,
.bc51-look-luxury .bc51-contact {
  color: rgba(255,255,255,.76);
}

.bc51-look-card {
  background: #edf4ff;
}

.bc51-look-card .bc51-card-inner::before {
  content: "";
  position: absolute;
  inset: 24px;
  border-radius: 28px;
  background: rgba(255,255,255,.82);
  z-index: 0;
}

.bc51-look-card .bc51-part {
  z-index: 2;
}

@media (max-width: 1120px) {
  .bc51-shell {
    grid-template-columns: 1fr;
  }

  .bc51-panel {
    position: static;
    max-height: none;
  }

  .bc51-template-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .bc51-stage {
    padding: 24px 0 64px;
  }

  .bc51-grid2,
  .bc51-checks,
  .bc51-color-row {
    grid-template-columns: 1fr;
  }

  .bc51-preview-top {
    align-items: flex-start;
    flex-direction: column;
  }

  .bc51-template-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .bc51-card-inner {
    padding: 28px;
  }

  .bc51-name {
    font-size: 42px;
    white-space: normal;
  }
}


/* v52 main supported features section */
.v7-section-title h2 {
  letter-spacing: -.075em !important;
}

.v7-tools-clean {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 18px !important;
}

.v7-tools-clean .v7-tool-row {
  min-height: 250px !important;
}

.v7-tools-clean .v7-tool-row h3 {
  font-size: clamp(22px, 1.75vw, 29px) !important;
}

.v7-tools-clean .v7-tool-row p {
  font-size: 15px !important;
  line-height: 1.72 !important;
}

@media (max-width: 1180px) {
  .v7-tools-clean {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 720px) {
  .v7-tools-clean {
    grid-template-columns: 1fr !important;
  }
}


/* v56 utility card alignment */
.utility-home-grid,
.utility-cards,
.utility-list,
.utility-home-list {
  align-items: stretch !important;
}

.utility-home-card {
  min-height: 340px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
}

.utility-home-card p {
  flex: 1 1 auto !important;
}

.utility-home-card .v9-btn,
.utility-home-card .btn,
.utility-home-card .utility-card-link {
  margin-top: auto !important;
}

.utility-home-card.is-disabled {
  opacity: .62;
}

/* v56 business card editor */
.bc56-stage {
  min-height: calc(100vh - 74px);
  padding: 36px 0 80px;
  background:
    radial-gradient(circle at 82% 0%, rgba(37,99,235,.10), transparent 28%),
    radial-gradient(circle at 12% 20%, rgba(139,92,246,.10), transparent 30%),
    linear-gradient(180deg, #fbfdff 0%, #f7faff 100%);
}

.bc56-shell {
  display: grid;
  grid-template-columns: 372px minmax(0, 1fr);
  gap: 20px;
  align-items: start;
}

.bc56-panel,
.bc56-preview-panel {
  border-radius: 28px;
  background: rgba(255,255,255,.90);
  border: 1px solid rgba(15,23,42,.08);
  box-shadow: 0 24px 76px rgba(15,23,42,.075);
  overflow: hidden;
}

.bc56-panel {
  position: sticky;
  top: 92px;
  max-height: calc(100vh - 112px);
  overflow-y: auto;
}

.bc56-head {
  padding: 24px 24px 18px;
  border-bottom: 1px solid rgba(15,23,42,.07);
}

.bc56-pill {
  display: inline-flex;
  align-items: center;
  height: 30px;
  padding: 0 12px;
  border-radius: 999px;
  background: #eef4ff;
  border: 1px solid #dbeafe;
  color: #2563eb;
  font-size: 12px;
  font-weight: 900;
}

.bc56-head h1,
.bc56-head h2 {
  margin: 14px 0 0;
  color: #111827;
  font-size: 28px;
  line-height: 1.12;
  letter-spacing: -.065em;
  font-weight: 920;
}

.bc56-head p {
  margin: 9px 0 0;
  color: #64748b;
  font-size: 14px;
  line-height: 1.65;
  word-break: keep-all;
}

.bc56-tabs {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 7px;
  padding: 14px 14px 0;
}

.bc56-tab {
  height: 38px;
  border: 1px solid #dbe4f0;
  border-radius: 13px;
  background: #f8fbff;
  color: #64748b;
  font-size: 12px;
  font-weight: 850;
  cursor: pointer;
}

.bc56-tab.active {
  background: #2563eb;
  color: #fff;
  border-color: #2563eb;
  box-shadow: 0 12px 28px rgba(37,99,235,.20);
}

.bc56-form {
  padding: 18px;
}

.bc56-section {
  display: none;
  gap: 12px;
}

.bc56-section.active {
  display: grid;
}

.bc56-field {
  display: grid;
  gap: 7px;
}

.bc56-field label,
.bc56-label {
  color: #334155;
  font-size: 12.5px;
  font-weight: 880;
}

.bc56-field input,
.bc56-field textarea,
.bc56-field select {
  width: 100%;
  border: 1px solid #dbe4f0;
  background: #f8fbff;
  border-radius: 14px;
  padding: 12px 13px;
  color: #111827;
  font-size: 14px;
  outline: none;
}

.bc56-field textarea {
  min-height: 74px;
  resize: vertical;
  line-height: 1.55;
}

.bc56-grid2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.bc56-checks {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.bc56-check {
  min-height: 40px;
  padding: 0 10px;
  display: flex;
  align-items: center;
  gap: 8px;
  border-radius: 13px;
  background: #f8fbff;
  border: 1px solid #dbe4f0;
  color: #334155;
  font-size: 13px;
  font-weight: 780;
}

.bc56-check input {
  width: 15px;
  height: 15px;
  accent-color: #2563eb;
}

.bc56-font-block,
.bc56-image-box {
  padding: 12px;
  border-radius: 16px;
  border: 1px solid #e2e8f0;
  background: #fbfdff;
  display: grid;
  gap: 10px;
}

.bc56-font-title,
.bc56-image-title {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  color: #111827;
  font-size: 13px;
  font-weight: 900;
}

.bc56-range-row {
  display: grid;
  grid-template-columns: 1fr 52px;
  gap: 8px;
  align-items: center;
}

.bc56-range-row input[type="range"] {
  padding: 0;
}

.bc56-range-row span {
  text-align: right;
  color: #64748b;
  font-size: 12px;
  font-weight: 820;
}

.bc56-color-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 9px;
}

.bc56-color-row input[type="color"] {
  height: 44px;
  padding: 5px;
  border-radius: 14px;
  cursor: pointer;
}

.bc56-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  padding: 0 18px 18px;
}

.bc56-btn {
  height: 46px;
  border-radius: 15px;
  border: 1px solid #dbe4f0;
  background: #f8fbff;
  color: #2563eb;
  font-size: 14px;
  font-weight: 900;
  cursor: pointer;
  transition: .18s ease;
}

.bc56-btn.primary {
  border: 0;
  color: #fff;
  background: linear-gradient(135deg, #2563eb, #1677ff);
  box-shadow: 0 16px 36px rgba(37,99,235,.22);
}

.bc56-btn.danger {
  color: #dc2626;
  background: #fff5f5;
  border-color: #fecaca;
}

.bc56-btn:hover {
  transform: translateY(-2px);
}

.bc56-preview-panel {
  min-width: 0;
}

.bc56-preview-top {
  padding: 20px 22px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  border-bottom: 1px solid rgba(15,23,42,.07);
}

.bc56-preview-top h2 {
  margin: 0;
  color: #111827;
  font-size: 24px;
  letter-spacing: -.055em;
  font-weight: 920;
}

.bc56-preview-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.bc56-mini {
  height: 36px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid #dbe4f0;
  background: #fff;
  color: #334155;
  font-size: 12px;
  font-weight: 850;
  cursor: pointer;
}

.bc56-mini.active {
  background: #eef4ff;
  border-color: #bfdbfe;
  color: #2563eb;
}

.bc56-template-wrap {
  padding: 18px 22px 0;
}

.bc56-template-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
  max-height: 198px;
  overflow: auto;
  padding-right: 4px;
}

.bc56-template {
  min-height: 76px;
  border-radius: 16px;
  border: 1px solid #e2e8f0;
  background: #fff;
  padding: 11px;
  text-align: left;
  cursor: pointer;
  position: relative;
  overflow: hidden;
}

.bc56-template strong {
  display: block;
  color: #111827;
  font-size: 12px;
  letter-spacing: -.02em;
  margin-bottom: 5px;
}

.bc56-template small {
  display: block;
  color: #64748b;
  font-size: 11px;
  line-height: 1.32;
}

.bc56-template::after {
  content: "";
  position: absolute;
  right: -16px;
  bottom: -16px;
  width: 54px;
  height: 54px;
  border-radius: 999px;
  background: var(--tpl-color, rgba(37,99,235,.18));
}

.bc56-template.active {
  border-color: #93c5fd;
  box-shadow: 0 14px 34px rgba(37,99,235,.12);
}

.bc56-workspace {
  padding: 26px 22px 32px;
  min-height: 540px;
  display: grid;
  place-items: center;
  overflow: auto;
}

.bc56-card {
  --p: #2563eb;
  --s: #8b5cf6;
  --a: #0ea5e9;
  width: min(100%, 760px);
  aspect-ratio: 1.72 / 1;
  min-height: 390px;
  position: relative;
  overflow: hidden;
  border-radius: 34px;
  border: 1px solid rgba(15,23,42,.08);
  box-shadow: 0 34px 92px rgba(15,23,42,.14);
  background: linear-gradient(135deg, #ffffff 0%, #f2f7ff 100%);
  color: #111827;
  font-family: Pretendard, "Noto Sans KR", "Malgun Gothic", Arial, sans-serif;
}

.bc56-card.square {
  width: min(100%, 560px);
  aspect-ratio: 1 / 1;
  min-height: auto;
}

.bc56-card.vertical {
  width: min(100%, 430px);
  aspect-ratio: .66 / 1;
  min-height: auto;
}

.bc56-bg-orb1,
.bc56-bg-orb2,
.bc56-bg-band,
.bc56-bg-line {
  position: absolute;
  pointer-events: none;
}

.bc56-bg-orb1 {
  width: 260px;
  height: 260px;
  right: -90px;
  top: -90px;
  border-radius: 999px;
  background: rgba(37,99,235,.16);
}

.bc56-bg-orb2 {
  width: 190px;
  height: 190px;
  left: -70px;
  bottom: -70px;
  border-radius: 999px;
  background: rgba(139,92,246,.13);
}

.bc56-bg-band {
  width: 360px;
  height: 680px;
  right: -150px;
  top: -160px;
  border-radius: 80px;
  transform: rotate(25deg);
  background: linear-gradient(180deg, var(--p), var(--s));
  opacity: .12;
}

.bc56-bg-line {
  left: 36px;
  top: 36px;
  bottom: 36px;
  width: 5px;
  border-radius: 999px;
  background: var(--p);
  opacity: 0;
}

.bc56-card-inner {
  position: absolute;
  inset: 0;
  padding: 38px;
}

.bc56-part,
.bc56-user-image {
  position: absolute;
  z-index: 3;
  cursor: default;
  max-width: calc(100% - 76px);
}

.bc56-free .bc56-part,
.bc56-free .bc56-user-image {
  cursor: move;
}

.bc56-free .bc56-part:hover,
.bc56-free .bc56-user-image:hover,
.bc56-user-image.selected {
  outline: 1px dashed rgba(37,99,235,.52);
  outline-offset: 6px;
}

.bc56-logo {
  width: 58px;
  height: 58px;
  display: grid;
  place-items: center;
  border-radius: 20px;
  color: #fff;
  background: linear-gradient(135deg, var(--p), var(--a));
  font-size: 18px;
  font-weight: 950;
  letter-spacing: -.07em;
  box-shadow: 0 18px 42px rgba(37,99,235,.22);
}

.bc56-company {
  color: #64748b;
  font-size: 14px;
  font-weight: 870;
}

.bc56-name {
  margin: 0;
  color: #111827;
  font-size: 58px;
  line-height: .96;
  letter-spacing: -.085em;
  font-weight: 950;
  white-space: nowrap;
}

.bc56-position {
  color: var(--p);
  font-size: 18px;
  font-weight: 900;
}

.bc56-intro {
  color: #64748b;
  font-size: 15px;
  line-height: 1.68;
  word-break: keep-all;
}

.bc56-contact {
  display: grid;
  gap: 8px;
  color: #475569;
  font-size: 14px;
  line-height: 1.45;
}

.bc56-contact span {
  display: block;
  overflow-wrap: anywhere;
}

.bc56-contact b {
  display: inline-block;
  min-width: 54px;
  color: #94a3b8;
  font-size: 11px;
  letter-spacing: .03em;
  font-weight: 900;
}

.bc56-hidden {
  display: none !important;
}

.bc56-user-image {
  width: 120px;
  height: auto;
  border-radius: 14px;
  object-fit: contain;
  z-index: 2;
}

.bc56-image-list {
  display: grid;
  gap: 8px;
  max-height: 140px;
  overflow: auto;
}

.bc56-image-item {
  min-height: 38px;
  padding: 0 10px;
  border: 1px solid #dbe4f0;
  border-radius: 12px;
  background: #f8fbff;
  color: #334155;
  font-size: 12px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
}

.bc56-image-item.active {
  border-color: #93c5fd;
  color: #2563eb;
}

/* looks */
.bc56-look-glass { background: linear-gradient(135deg, #ffffff 0%, #eef4ff 100%); }
.bc56-look-diagonal { background: linear-gradient(135deg, #ffffff 0%, #f8fbff 100%); }
.bc56-look-diagonal .bc56-bg-band { opacity: .18; }
.bc56-look-frame { background: #ffffff; }
.bc56-look-frame .bc56-card-inner { inset: 20px; border: 2px solid rgba(37,99,235,.30); border-radius: 25px; }
.bc56-look-line { background: repeating-linear-gradient(135deg, rgba(37,99,235,.055) 0 1px, transparent 1px 15px), linear-gradient(135deg, #fff, #f8fbff); }
.bc56-look-line .bc56-bg-line { opacity: 1; }
.bc56-look-wave { background: linear-gradient(135deg, #ffffff 0%, #f0f7ff 100%); }
.bc56-look-wave .bc56-bg-band { width: 620px; height: 240px; right: -120px; top: auto; bottom: -120px; border-radius: 999px; transform: rotate(-8deg); opacity: .16; }
.bc56-look-dark { background: linear-gradient(135deg, #0f172a 0%, #020617 100%); color: #fff; border-color: rgba(255,255,255,.14); }
.bc56-look-dark .bc56-name, .bc56-look-dark .bc56-position { color: #fff; }
.bc56-look-dark .bc56-company, .bc56-look-dark .bc56-intro, .bc56-look-dark .bc56-contact { color: rgba(255,255,255,.74); }
.bc56-look-dark .bc56-contact b { color: rgba(255,255,255,.58); }
.bc56-look-bold { background: linear-gradient(135deg, #ffffff 0 34%, #f7faff 34% 100%); }
.bc56-look-bold .bc56-bg-band { left: -150px; right: auto; top: -320px; width: 900px; height: 410px; transform: rotate(0); border-radius: 0; opacity: 1; }
.bc56-look-bold .bc56-company, .bc56-look-bold .bc56-logo { color: #fff; }
.bc56-look-minimal { background: #ffffff; }
.bc56-look-minimal .bc56-bg-line { opacity: 1; }
.bc56-look-minimal .bc56-bg-orb1, .bc56-look-minimal .bc56-bg-orb2, .bc56-look-minimal .bc56-bg-band { display: none; }
.bc56-look-luxury { background: linear-gradient(135deg, #111827 0%, #1e1b4b 100%); color: #fff; }
.bc56-look-luxury .bc56-logo { background: linear-gradient(135deg, #f59e0b, #f97316); }
.bc56-look-luxury .bc56-name, .bc56-look-luxury .bc56-position { color: #fff; }
.bc56-look-luxury .bc56-company, .bc56-look-luxury .bc56-intro, .bc56-look-luxury .bc56-contact { color: rgba(255,255,255,.76); }
.bc56-look-card { background: #edf4ff; }
.bc56-look-card .bc56-card-inner::before { content: ""; position: absolute; inset: 24px; border-radius: 28px; background: rgba(255,255,255,.82); z-index: 0; }
.bc56-look-card .bc56-part { z-index: 2; }
.bc56-look-photo { background: linear-gradient(135deg, #e0f2fe 0%, #f5f3ff 100%); }
.bc56-look-photo .bc56-bg-orb1 { width: 360px; height: 360px; right: -120px; top: -140px; }
.bc56-look-editorial { background: linear-gradient(90deg, #0f172a 0 32%, #ffffff 32% 100%); }
.bc56-look-editorial .bc56-logo, .bc56-look-editorial .bc56-company { color: #fff; }
.bc56-look-editorial .bc56-bg-orb1, .bc56-look-editorial .bc56-bg-orb2, .bc56-look-editorial .bc56-bg-band { display: none; }
.bc56-look-pastel { background: linear-gradient(135deg, #fdf2f8 0%, #eff6ff 50%, #f0fdf4 100%); }

@media (max-width: 1120px) {
  .bc56-shell { grid-template-columns: 1fr; }
  .bc56-panel { position: static; max-height: none; }
  .bc56-template-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}

@media (max-width: 720px) {
  .bc56-stage { padding: 24px 0 64px; }
  .bc56-grid2, .bc56-checks, .bc56-color-row { grid-template-columns: 1fr; }
  .bc56-preview-top { align-items: flex-start; flex-direction: column; }
  .bc56-template-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .bc56-card-inner { padding: 28px; }
  .bc56-name { font-size: 42px; white-space: normal; }
}


/* v57 business card editor: resize handles, z-order, separated contacts, colors, logo styles */
.bc56-resize-handle {
  position: absolute;
  right: -8px;
  bottom: -8px;
  width: 18px;
  height: 18px;
  border-radius: 6px;
  background: #2563eb;
  border: 2px solid #ffffff;
  box-shadow: 0 8px 18px rgba(37,99,235,.24);
  cursor: nwse-resize;
  z-index: 20;
  display: none;
}

.bc56-user-image.selected .bc56-resize-handle {
  display: block;
}

.bc56-user-image-wrap {
  position: absolute;
  z-index: 2;
  cursor: move;
  line-height: 0;
}

.bc56-user-image-wrap img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: inherit;
  pointer-events: none;
}

.bc56-user-image-wrap.selected {
  outline: 1px dashed rgba(37,99,235,.62);
  outline-offset: 6px;
}

.bc56-user-image-wrap.selected .bc56-resize-handle {
  display: block;
}

.bc56-card .bc56-part {
  z-index: 5;
}

.bc56-logo.style-circle {
  border-radius: 999px;
}

.bc56-logo.style-square {
  border-radius: 8px;
}

.bc56-logo.style-outline {
  color: var(--p);
  background: transparent;
  border: 2px solid var(--p);
  box-shadow: none;
}

.bc56-logo.style-dark {
  color: #fff;
  background: #111827;
}

.bc56-logo.style-gradient {
  color: #fff;
  background: linear-gradient(135deg, var(--p), var(--s), var(--a));
}

.bc56-logo.style-text {
  width: auto;
  height: auto;
  border-radius: 0;
  background: transparent;
  color: var(--p);
  box-shadow: none;
  font-size: 24px;
}

.bc56-logo.style-hidden {
  display: none;
}

.bc56-contact {
  gap: 7px;
}

.bc56-contact-line {
  display: block;
  overflow-wrap: anywhere;
}

.bc56-contact-line b {
  display: inline-block;
  min-width: 54px;
  color: #94a3b8;
  font-size: 11px;
  letter-spacing: .03em;
  font-weight: 900;
}

.bc56-z-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.bc56-small-note {
  margin: 0;
  color: #64748b;
  font-size: 12px;
  line-height: 1.55;
}

.bc56-color-block {
  padding: 12px;
  border-radius: 16px;
  border: 1px solid #e2e8f0;
  background: #fbfdff;
  display: grid;
  gap: 10px;
}

.bc56-color-title {
  color: #111827;
  font-size: 13px;
  font-weight: 900;
}

.bc56-color-grid {
  display: grid;
  grid-template-columns: 1fr 52px;
  gap: 9px;
  align-items: center;
}

.bc56-color-grid span {
  color: #334155;
  font-size: 13px;
  font-weight: 780;
}

.bc56-color-grid input[type="color"] {
  width: 52px;
  height: 38px;
  padding: 4px;
  border-radius: 12px;
  cursor: pointer;
}

.bc56-image-tools {
  display: grid;
  gap: 9px;
}

.bc56-layer-label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  border-radius: 999px;
  background: #f8fbff;
  border: 1px solid #dbe4f0;
  color: #64748b;
  font-size: 12px;
  font-weight: 820;
}


/* v58 business card editor refinements */
.bc56-intro {
  white-space: pre-wrap;
}

.bc56-free-top {
  height: 38px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid #bfdbfe;
  background: #eef4ff;
  color: #2563eb;
  font-size: 12px;
  font-weight: 900;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  cursor: pointer;
}

.bc56-free-top input {
  width: 15px;
  height: 15px;
  accent-color: #2563eb;
}

.bc56-free-top.is-on {
  color: #fff;
  background: linear-gradient(135deg, #2563eb, #1677ff);
  border-color: transparent;
  box-shadow: 0 14px 30px rgba(37,99,235,.22);
}

.bc56-resize-handle {
  position: absolute;
  background: #2563eb;
  border: 2px solid #ffffff;
  box-shadow: 0 8px 18px rgba(37,99,235,.24);
  z-index: 30;
  display: none;
}

.bc56-user-image-wrap.selected .bc56-resize-handle {
  display: block;
}

.bc56-resize-handle.corner {
  right: -8px;
  bottom: -8px;
  width: 18px;
  height: 18px;
  border-radius: 6px;
  cursor: nwse-resize;
}

.bc56-resize-handle.right {
  right: -7px;
  top: 50%;
  width: 14px;
  height: 34px;
  margin-top: -17px;
  border-radius: 999px;
  cursor: ew-resize;
}

.bc56-resize-handle.bottom {
  left: 50%;
  bottom: -7px;
  width: 34px;
  height: 14px;
  margin-left: -17px;
  border-radius: 999px;
  cursor: ns-resize;
}

.bc56-user-image-wrap {
  min-width: 20px;
  min-height: 20px;
}

.bc56-user-image-wrap img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

/* more logo styles */
.bc56-logo.style-soft {
  color: var(--p);
  background: rgba(37,99,235,.10);
  border: 1px solid rgba(37,99,235,.18);
  box-shadow: 0 12px 26px rgba(37,99,235,.10);
}

.bc56-logo.style-glass {
  color: #fff;
  background: rgba(255,255,255,.18);
  border: 1px solid rgba(255,255,255,.35);
  backdrop-filter: blur(10px);
}

.bc56-logo.style-neon {
  color: #fff;
  background: #0f172a;
  border: 1px solid rgba(56,189,248,.55);
  box-shadow: 0 0 0 4px rgba(56,189,248,.10), 0 0 28px rgba(56,189,248,.45);
  text-shadow: 0 0 12px rgba(56,189,248,.9);
}

.bc56-logo.style-badge {
  color: #fff;
  background: linear-gradient(135deg, #111827 0%, var(--p) 100%);
  border-radius: 14px 24px 14px 24px;
  transform: rotate(-4deg);
}

.bc56-logo.style-pill {
  width: auto;
  min-width: 74px;
  padding: 0 18px;
  border-radius: 999px;
  color: #fff;
  background: linear-gradient(135deg, var(--p), var(--a));
}

.bc56-logo.style-shadow {
  color: #111827;
  background: #fff;
  border: 1px solid #e2e8f0;
  box-shadow: 10px 10px 0 rgba(37,99,235,.18);
}

.bc56-logo.style-kakao {
  color: #3a1d1d;
  background: #fee500;
  border-radius: 18px;
  box-shadow: 0 14px 30px rgba(254,229,0,.25);
}


/* v60 notice board */
.notice-stage {
  padding: 70px 0 110px;
  min-height: calc(100vh - 74px);
  background:
    radial-gradient(circle at 12% 8%, rgba(37,99,235,.10), transparent 28%),
    radial-gradient(circle at 86% 18%, rgba(14,165,233,.10), transparent 24%),
    linear-gradient(180deg, #fbfdff 0%, #f7faff 100%);
}

.notice-hero {
  position: relative;
  text-align: center;
  padding: 26px 0 42px;
}

.notice-kicker {
  display: inline-flex;
  height: 34px;
  align-items: center;
  padding: 0 14px;
  border-radius: 999px;
  background: #eef4ff;
  border: 1px solid #dbeafe;
  color: #2563eb;
  font-size: 13px;
  font-weight: 900;
}

.notice-hero h1 {
  margin: 18px 0 0;
  color: #111827;
  font-size: clamp(44px, 5vw, 72px);
  line-height: .98;
  letter-spacing: -.09em;
  font-weight: 950;
}

.notice-hero p {
  max-width: 720px;
  margin: 18px auto 0;
  color: #64748b;
  font-size: 17px;
  line-height: 1.75;
  word-break: keep-all;
}

.notice-write-btn {
  min-height: 46px;
  padding: 0 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: 15px;
  color: #fff;
  background: linear-gradient(135deg, #2563eb, #1677ff);
  box-shadow: 0 16px 38px rgba(37,99,235,.22);
  text-decoration: none;
  font-size: 14px;
  font-weight: 900;
  cursor: pointer;
}

.notice-write-btn.soft {
  color: #2563eb;
  background: #eef4ff;
  border: 1px solid #dbeafe;
  box-shadow: none;
}

.notice-hero .notice-write-btn {
  margin-top: 24px;
}

.notice-list {
  display: grid;
  gap: 16px;
}

.notice-card {
  border-radius: 26px;
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(15,23,42,.08);
  box-shadow: 0 22px 70px rgba(15,23,42,.075);
  overflow: hidden;
  transition: .18s ease;
}

.notice-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 30px 88px rgba(15,23,42,.11);
}

.notice-card.is-pinned {
  border-color: rgba(37,99,235,.22);
  background:
    radial-gradient(circle at 96% 0%, rgba(37,99,235,.09), transparent 24%),
    rgba(255,255,255,.92);
}

.notice-card-main {
  display: block;
  padding: 24px 26px;
  color: inherit;
  text-decoration: none;
}

.notice-card-top {
  display: flex;
  align-items: center;
  gap: 10px;
  color: #94a3b8;
  font-size: 13px;
  font-weight: 800;
}

.notice-badge {
  display: inline-flex;
  height: 28px;
  align-items: center;
  padding: 0 10px;
  border-radius: 999px;
  color: #2563eb;
  background: #eef4ff;
  border: 1px solid #dbeafe;
  font-size: 12px;
  font-weight: 900;
}

.notice-card h2 {
  margin: 14px 0 0;
  color: #111827;
  font-size: clamp(22px, 2vw, 30px);
  letter-spacing: -.055em;
  font-weight: 920;
}

.notice-card p {
  max-width: 820px;
  margin: 12px 0 0;
  color: #64748b;
  font-size: 15px;
  line-height: 1.72;
}

.notice-admin-actions {
  display: flex;
  gap: 8px;
  padding: 0 26px 22px;
}

.notice-admin-actions a {
  min-height: 36px;
  padding: 0 12px;
  display: inline-flex;
  align-items: center;
  border-radius: 12px;
  background: #f8fbff;
  border: 1px solid #dbe4f0;
  color: #2563eb;
  font-size: 13px;
  font-weight: 850;
  text-decoration: none;
}

.notice-empty {
  padding: 70px 24px;
  border-radius: 28px;
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(15,23,42,.08);
  text-align: center;
  box-shadow: 0 22px 70px rgba(15,23,42,.075);
}

.notice-empty strong {
  display: block;
  color: #111827;
  font-size: 24px;
  letter-spacing: -.04em;
}

.notice-empty p {
  margin: 10px 0 0;
  color: #64748b;
}

.notice-view,
.notice-editor {
  border-radius: 30px;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(15,23,42,.08);
  box-shadow: 0 26px 86px rgba(15,23,42,.085);
  overflow: hidden;
}

.notice-view-head {
  padding: 36px 38px 26px;
  border-bottom: 1px solid rgba(15,23,42,.08);
}

.notice-view-head h1 {
  margin: 16px 0 0;
  color: #111827;
  font-size: clamp(34px, 4vw, 58px);
  line-height: 1.08;
  letter-spacing: -.075em;
  font-weight: 950;
}

.notice-view-head p {
  margin: 12px 0 0;
  color: #94a3b8;
  font-size: 14px;
  font-weight: 800;
}

.notice-content {
  padding: 38px;
  color: #1f2937;
  font-size: 16px;
  line-height: 1.82;
  word-break: keep-all;
}

.notice-content img {
  max-width: 100%;
  height: auto;
  border-radius: 18px;
  box-shadow: 0 18px 48px rgba(15,23,42,.10);
}

.notice-content a {
  color: #2563eb;
  font-weight: 800;
}

.notice-content blockquote {
  margin: 20px 0;
  padding: 18px 20px;
  border-left: 4px solid #2563eb;
  background: #f8fbff;
  border-radius: 16px;
  color: #475569;
}

.notice-view-bottom {
  padding: 0 38px 38px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.notice-editor-head {
  padding: 28px 30px 20px;
  border-bottom: 1px solid rgba(15,23,42,.08);
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
}

.notice-editor-head h1 {
  margin: 14px 0 0;
  color: #111827;
  font-size: 38px;
  letter-spacing: -.075em;
  font-weight: 950;
}

.notice-editor-actions {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.notice-pin {
  min-height: 42px;
  padding: 0 14px;
  border-radius: 14px;
  display: inline-flex;
  gap: 8px;
  align-items: center;
  color: #334155;
  background: #f8fbff;
  border: 1px solid #dbe4f0;
  font-size: 13px;
  font-weight: 850;
}

.notice-pin input {
  accent-color: #2563eb;
}

.notice-title-field {
  padding: 24px 30px 0;
}

.notice-title-field input {
  width: 100%;
  border: 1px solid #dbe4f0;
  background: #f8fbff;
  border-radius: 18px;
  padding: 17px 18px;
  color: #111827;
  font-size: 22px;
  font-weight: 850;
  outline: none;
}

.notice-toolbar {
  margin: 18px 30px 0;
  padding: 12px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  border-radius: 18px;
  background: #f8fbff;
  border: 1px solid #dbe4f0;
}

.notice-toolbar button,
.notice-toolbar select,
.notice-toolbar input[type="color"] {
  min-height: 38px;
  border: 1px solid #dbe4f0;
  background: #fff;
  border-radius: 12px;
  padding: 0 10px;
  color: #334155;
  font-size: 13px;
  font-weight: 800;
  cursor: pointer;
}

.notice-toolbar input[type="color"] {
  width: 44px;
  padding: 4px;
}

.notice-editor-box {
  min-height: 460px;
  margin: 18px 30px 30px;
  padding: 24px;
  border-radius: 22px;
  border: 1px solid #dbe4f0;
  background: #fff;
  outline: none;
  color: #1f2937;
  font-size: 16px;
  line-height: 1.82;
}

.notice-editor-box:empty::before {
  content: "공지 내용을 입력하세요. 이미지, 링크, 글꼴, 색상, 정렬을 사용할 수 있습니다.";
  color: #94a3b8;
}

.notice-editor-box img {
  max-width: 100%;
  height: auto;
  border-radius: 16px;
}

@media (max-width: 760px) {
  .notice-stage {
    padding: 38px 0 70px;
  }

  .notice-editor-head,
  .notice-view-head {
    padding: 24px 20px 18px;
    flex-direction: column;
  }

  .notice-content,
  .notice-view-bottom {
    padding-left: 20px;
    padding-right: 20px;
  }

  .notice-title-field {
    padding-left: 20px;
    padding-right: 20px;
  }

  .notice-toolbar {
    margin-left: 20px;
    margin-right: 20px;
  }

  .notice-editor-box {
    margin-left: 20px;
    margin-right: 20px;
  }
}


/* v62 safe notice nav */
.nav-links {
  gap: clamp(18px, 2.2vw, 30px) !important;
}
@media (max-width: 980px) {
  .nav-links {
    display: none !important;
  }
}


/* v63 restore session pages */


/* v67 normal admin login admin@admin.com */


/* v68 notice cleanup */
.notice-hero > p:empty {
  display: none !important;
}

.notice-editor-box img {
  display: block;
  max-width: 100%;
  height: auto;
  margin: 14px 0;
  border-radius: 16px;
  box-shadow: 0 14px 36px rgba(15,23,42,.10);
}

.nav-links a[href="purchase.php"],
.nav-actions a[href="purchase.php"],
.mobile-panel a[href="purchase.php"] {
  display: none !important;
}


/* v69 utility copy fixed */
.utility-hero h1,
.utility-hero-title,
.v9-utility-hero h1 {
  letter-spacing: -.085em !important;
}

.utility-hero p,
.utility-hero-sub,
.v9-utility-hero p {
  max-width: 720px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  word-break: keep-all !important;
}


/* v70 restore AI chat UI */
.ai-chat-stage {
  min-height: calc(100vh - 74px);
  padding: 42px 0 86px;
  background:
    radial-gradient(circle at 12% 12%, rgba(139,92,246,.12), transparent 30%),
    radial-gradient(circle at 88% 10%, rgba(37,99,235,.10), transparent 28%),
    linear-gradient(180deg, #fbfdff 0%, #f7faff 100%);
}

.ai-chat-shell {
  min-height: 760px;
  display: grid;
  grid-template-columns: 270px minmax(0, 1fr);
  border-radius: 30px;
  overflow: hidden;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(15,23,42,.08);
  box-shadow: 0 28px 90px rgba(15,23,42,.10);
}

.ai-chat-sidebar {
  padding: 28px 24px;
  background:
    radial-gradient(circle at 22% 16%, rgba(139,92,246,.20), transparent 36%),
    linear-gradient(180deg, #faf7ff 0%, #fff 100%);
  border-right: 1px solid rgba(15,23,42,.08);
  display: flex;
  flex-direction: column;
}

.ai-brand {
  display: flex;
  align-items: center;
  gap: 12px;
}

.ai-brand span,
.ai-avatar {
  width: 38px;
  height: 38px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  color: #fff;
  background: linear-gradient(135deg, #7c3aed, #2563eb);
  font-size: 14px;
  font-weight: 950;
}

.ai-brand strong {
  color: #111827;
  font-size: 20px;
  font-weight: 920;
  letter-spacing: -.055em;
}

.ai-side-note {
  margin-top: 22px;
  padding: 17px;
  border-radius: 17px;
  color: #64748b;
  background: rgba(255,255,255,.76);
  border: 1px solid #e2e8f0;
  font-size: 14px;
  line-height: 1.65;
  word-break: keep-all;
}

.ai-upload-card {
  margin-top: auto;
  padding: 22px;
  border-radius: 24px;
  background: #fff;
  border: 1px solid #e2e8f0;
  text-align: center;
}

.ai-upload-icon {
  width: 56px;
  height: 56px;
  margin: 0 auto 14px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  color: #7c3aed;
  background: #ede9fe;
  font-size: 26px;
}

.ai-upload-card strong {
  display: block;
  color: #111827;
  font-size: 17px;
  line-height: 1.45;
  letter-spacing: -.035em;
}

.ai-upload-card p,
.ai-upload-card small {
  display: block;
  margin: 10px 0 0;
  color: #64748b;
  font-size: 12px;
  line-height: 1.5;
}

.ai-upload-btn {
  height: 46px;
  margin-top: 18px;
  padding: 0 18px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  background: linear-gradient(135deg, #7c3aed, #2563eb);
  font-size: 14px;
  font-weight: 900;
  cursor: pointer;
}

.ai-chat-main {
  min-width: 0;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto auto;
  background: #fbfcff;
}

.ai-chat-head {
  padding: 26px 28px;
  border-bottom: 1px solid rgba(15,23,42,.08);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.ai-chat-head h1 {
  margin: 0;
  color: #111827;
  font-size: 30px;
  line-height: 1.12;
  letter-spacing: -.065em;
  font-weight: 950;
}

.ai-chat-head p {
  margin: 7px 0 0;
  color: #64748b;
  font-size: 14px;
}

.ai-chat-head select {
  width: 190px;
  height: 44px;
  border-radius: 14px;
  border: 1px solid #dbe4f0;
  background: #fff;
  color: #334155;
  padding: 0 13px;
  font-weight: 850;
}

.ai-messages {
  padding: 28px;
  overflow-y: auto;
}

.ai-row {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 22px;
}

.ai-row.user {
  justify-content: flex-end;
}

.ai-row.user .ai-avatar {
  background: #dff3ff;
  color: #0284c7;
}

.ai-bubble {
  max-width: min(680px, 78%);
  padding: 18px 20px;
  border-radius: 22px;
  background: #ede9fe;
  color: #334155;
  font-size: 15px;
  line-height: 1.72;
  white-space: pre-wrap;
  box-shadow: 0 18px 42px rgba(124,58,237,.08);
}

.ai-row.user .ai-bubble {
  background: #fff;
  border: 1px solid #e2e8f0;
  box-shadow: 0 18px 42px rgba(15,23,42,.06);
}

.ai-inputbar {
  margin: 0 28px 0;
  padding: 12px;
  border-radius: 22px;
  border: 1px solid #c4b5fd;
  background: #fff;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 56px;
  gap: 12px;
  box-shadow: 0 18px 52px rgba(124,58,237,.12);
}

.ai-inputbar textarea {
  min-height: 54px;
  max-height: 150px;
  border: 0;
  outline: 0;
  resize: vertical;
  padding: 12px 4px;
  color: #111827;
  font-size: 15px;
  line-height: 1.5;
  background: transparent;
}

.ai-inputbar button {
  width: 56px;
  height: 56px;
  border: 0;
  border-radius: 18px;
  color: #fff;
  background: linear-gradient(135deg, #7c3aed, #2563eb);
  font-size: 22px;
  font-weight: 950;
  cursor: pointer;
}

.ai-help {
  padding: 9px 30px 18px;
  color: #94a3b8;
  font-size: 12px;
}

@media (max-width: 960px) {
  .ai-chat-shell {
    grid-template-columns: 1fr;
  }
  .ai-chat-sidebar {
    display: none;
  }
}


/* v85 slice business card maker */
.slice-builder-stage{min-height:calc(100vh - 74px);padding:56px 0 90px;background:radial-gradient(circle at 10% 6%,rgba(37,99,235,.12),transparent 30%),radial-gradient(circle at 90% 12%,rgba(139,92,246,.12),transparent 28%),linear-gradient(180deg,#fbfdff 0%,#f7faff 100%)}
.slice-builder-head{text-align:center;margin-bottom:28px}
.slice-builder-head span{display:inline-flex;min-height:32px;align-items:center;padding:0 13px;border-radius:999px;background:#eef4ff;border:1px solid #dbeafe;color:#2563eb;font-size:12px;font-weight:900}
.slice-builder-head h1{margin:16px 0 0;color:#111827;font-size:clamp(42px,7vw,78px);line-height:.96;letter-spacing:-.09em;font-weight:950}
.slice-builder-head p{margin:16px auto 0;max-width:760px;color:#64748b;line-height:1.7;word-break:keep-all}
.slice-builder-grid{display:grid;grid-template-columns:390px minmax(0,1fr);gap:22px;align-items:start}
.slice-controls{display:grid;gap:16px}
.slice-control-card,.slice-save-card{padding:20px;border-radius:24px;background:rgba(255,255,255,.92);border:1px solid rgba(15,23,42,.08);box-shadow:0 22px 70px rgba(15,23,42,.08)}
.slice-control-card h2{margin:0 0 16px;color:#111827;font-size:22px;letter-spacing:-.055em;font-weight:920}
.slice-control-card label{display:grid;gap:7px;margin-top:12px;color:#334155;font-size:13px;font-weight:850}
.slice-control-card input,.slice-control-card select,.slice-control-card textarea{width:100%;min-height:44px;border:1px solid #dbe4f0;border-radius:14px;background:#f8fbff;color:#111827;padding:0 12px;outline:none}
.slice-control-card textarea{min-height:92px;padding:12px;resize:vertical}
.slice-save-card{display:grid;gap:10px}
.slice-save-card button,.slice-save-card a,.slice-public-empty a{min-height:46px;border:0;border-radius:15px;background:linear-gradient(135deg,#2563eb,#1677ff);color:#fff;font-size:14px;font-weight:900;display:flex;align-items:center;justify-content:center;text-decoration:none;cursor:pointer}
.slice-save-card button:nth-child(2),.slice-save-card a{background:#eef4ff;color:#2563eb;border:1px solid #dbeafe}
#scResult{padding:14px;border-radius:15px;background:#f8fbff;border:1px solid #dbe4f0;color:#64748b;word-break:break-all;font-size:13px}
#scResult a{color:#2563eb;font-weight:900}
.slice-preview-zone{position:sticky;top:92px;padding:22px;border-radius:30px;background:rgba(255,255,255,.94);border:1px solid rgba(15,23,42,.08);box-shadow:0 26px 90px rgba(15,23,42,.10)}
.slice-preview-tabs{display:flex;gap:8px;margin-bottom:18px}
.slice-preview-tabs button{min-height:40px;padding:0 14px;border-radius:14px;border:1px solid #dbe4f0;background:#f8fbff;color:#334155;font-weight:900;cursor:pointer}
.slice-preview-tabs button.active{background:#2563eb;color:#fff;border-color:#2563eb}
.slice-og-wrap{display:grid;place-items:center;overflow:auto}
.slice-og-card{width:1200px;height:630px;transform:scale(.56);transform-origin:center;background:#d9efff;border-radius:0;position:relative;overflow:hidden;color:var(--slice-text,#fff);font-family:inherit}
.slice-og-card::before{content:"";position:absolute;inset:56px 90px;border-radius:64px;background:linear-gradient(135deg,#cdeeff,#e7f4ff)}
.slice-og-card::after{content:"";position:absolute;left:210px;top:166px;width:780px;height:310px;border-radius:38px;background:var(--slice-bg,#071326);box-shadow:0 30px 80px rgba(0,0,0,.25)}
.slice-og-bubble{position:absolute;left:372px;top:78px;z-index:3;padding:14px 24px;border-radius:18px;background:#ffe45c;color:#111827;font-size:25px;font-weight:950}
.slice-og-main{position:absolute;left:270px;top:210px;z-index:4;display:flex;align-items:center;gap:34px}
.slice-og-photo{width:118px;height:118px;border-radius:28px;overflow:hidden;display:grid;place-items:center;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.25);font-size:48px;font-weight:950}
.slice-og-photo img{width:100%;height:100%;object-fit:cover}
.slice-og-name{display:block;font-size:38px;line-height:1;color:#fff;font-weight:950;letter-spacing:-.06em}
.slice-og-sub{margin:10px 0 0;font-size:21px;color:#e2e8f0;font-weight:850}
.slice-og-copy small{display:block;margin-top:8px;font-size:18px;color:#94a3b8}
.slice-og-tags{position:absolute;left:270px;top:365px;z-index:4;display:flex;gap:12px}
.slice-og-tags span{min-width:150px;min-height:42px;padding:0 18px;border-radius:10px;background:#1d2a46;color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:900}
.slice-og-bottom{position:absolute;left:210px;right:210px;bottom:72px;z-index:4}
.slice-og-bottom p{margin:0 0 12px;color:#111827;font-size:26px;font-weight:950}
.slice-og-bottom button{width:100%;height:46px;border:0;border-radius:10px;background:#f1f5f9;color:#111827;font-size:19px;font-weight:950}
.slice-og-card.clean-blue::after{background:linear-gradient(135deg,#2563eb,#38bdf8)}
.slice-og-card.glass-purple::after{background:linear-gradient(135deg,#7c3aed,#db2777)}
.slice-og-card.mono-pro::after{background:#111827}
.slice-og-card.orange-card::after{background:linear-gradient(135deg,#f97316,#ef4444)}
.slice-og-card.profile-left::after{background:linear-gradient(135deg,#0f172a,#2563eb)}
.slice-page-preview{display:none;grid-template-columns:360px minmax(0,1fr);overflow:hidden;border-radius:34px;background:#fff;border:1px solid #e2e8f0;box-shadow:0 24px 80px rgba(15,23,42,.12)}
.slice-page-visual{min-height:460px;padding:30px;background:var(--slice-bg,#071326);display:flex;align-items:flex-end}
.slice-page-photo{width:190px;height:190px;border-radius:42px;overflow:hidden;display:grid;place-items:center;background:rgba(255,255,255,.18);color:#fff;font-size:64px;font-weight:950}
.slice-page-photo img{width:100%;height:100%;object-fit:cover}
.slice-page-content{padding:42px}
.slice-page-content span{display:inline-flex;min-height:30px;align-items:center;padding:0 12px;border-radius:999px;background:#eef4ff;border:1px solid #dbeafe;font-size:12px;font-weight:900}
.slice-page-content h2{margin:18px 0 0;color:#111827;font-size:64px;letter-spacing:-.09em;line-height:.95;font-weight:950}
.slice-page-content h3{margin:14px 0 0;color:var(--slice-accent,#2563eb);font-size:18px;font-weight:900}
.slice-page-content p{margin:22px 0 0;color:#475569;line-height:1.75}
.slice-page-info{margin-top:24px;display:grid;gap:10px}
.slice-page-info div{min-height:44px;padding:0 14px;border-radius:14px;display:flex;align-items:center;background:#f8fbff;border:1px solid #e2e8f0;color:#334155;font-weight:800}
.slice-page-info b{margin-right:8px;color:#64748b}
.slice-public-stage{min-height:100vh;padding:42px 18px;display:grid;place-items:center;background:radial-gradient(circle at 12% 12%,rgba(37,99,235,.12),transparent 30%),radial-gradient(circle at 88% 18%,rgba(139,92,246,.10),transparent 28%),linear-gradient(180deg,#fbfdff 0%,#f7faff 100%)}
.slice-public-card{width:min(100%,980px);display:grid;grid-template-columns:360px minmax(0,1fr);overflow:hidden;border-radius:34px;background:#fff;border:1px solid rgba(15,23,42,.08);box-shadow:0 32px 110px rgba(15,23,42,.12)}
.slice-public-visual{min-height:520px;padding:30px;background:var(--slice-bg,#071326);display:flex;flex-direction:column;justify-content:space-between}
.slice-public-logo{width:58px;height:58px;border-radius:20px;display:grid;place-items:center;color:#fff;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.24);font-size:22px;font-weight:950}
.slice-public-photo{width:190px;height:190px;border-radius:42px;overflow:hidden;display:grid;place-items:center;color:#fff;background:rgba(255,255,255,.18);font-size:64px;font-weight:950}
.slice-public-photo img{width:100%;height:100%;object-fit:cover}
.slice-public-content{padding:44px}
.slice-public-content>span{display:inline-flex;min-height:30px;align-items:center;padding:0 12px;border-radius:999px;background:#eef4ff;border:1px solid #dbeafe;color:var(--slice-accent,#2563eb);font-size:12px;font-weight:900}
.slice-public-content h1{margin:20px 0 0;color:#111827;font-size:clamp(44px,6vw,72px);letter-spacing:-.09em;line-height:.95;font-weight:950}
.slice-public-content h2{margin:14px 0 0;color:var(--slice-accent,#2563eb);font-size:18px;font-weight:900}
.slice-public-content p{margin:24px 0 0;color:#475569;line-height:1.75}
.slice-public-info{margin-top:28px;display:grid;gap:10px}
.slice-public-info a,.slice-public-info div{min-height:44px;padding:0 14px;border-radius:14px;display:flex;align-items:center;color:#334155;background:#f8fbff;border:1px solid #e2e8f0;text-decoration:none;font-weight:800}
.slice-public-info b{margin-right:8px;color:#64748b}
.slice-public-buttons{margin-top:24px;display:flex;gap:10px;flex-wrap:wrap}
.slice-public-buttons a,.slice-public-empty a{min-height:44px;padding:0 16px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;font-weight:900;color:#2563eb;background:#eef4ff;border:1px solid #dbeafe}
.slice-public-buttons a.primary{color:#fff;background:linear-gradient(135deg,#2563eb,#1677ff);border:0}
.slice-public-empty{width:min(100%,520px);padding:40px;border-radius:28px;background:#fff;text-align:center;box-shadow:0 28px 90px rgba(15,23,42,.10)}
.card-stats-stage{min-height:calc(100vh - 74px);padding:62px 0 90px;background:linear-gradient(180deg,#fbfdff 0%,#f7faff 100%)}
.card-stats-shell{padding:28px;border-radius:30px;background:rgba(255,255,255,.92);border:1px solid rgba(15,23,42,.08);box-shadow:0 28px 90px rgba(15,23,42,.10)}
.card-stats-head span{display:inline-flex;min-height:30px;align-items:center;padding:0 12px;border-radius:999px;background:#eef4ff;border:1px solid #dbeafe;color:#2563eb;font-size:12px;font-weight:900}
.card-stats-head h1{margin:14px 0 0;color:#111827;font-size:34px;letter-spacing:-.07em;font-weight:950}
.card-stats-head p{margin:10px 0 0;color:#64748b}
.card-stats-search{margin-top:24px;display:grid;grid-template-columns:minmax(0,1fr) 120px;gap:10px}
.card-stats-search input{min-height:46px;border:1px solid #dbe4f0;border-radius:14px;padding:0 13px;background:#f8fbff}
.card-stats-search button{border:0;border-radius:14px;background:#2563eb;color:#fff;font-weight:900}
.card-stats-summary{margin-top:22px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.card-stats-summary>div{padding:18px;border-radius:18px;background:#f8fbff;border:1px solid #e2e8f0}
.card-stats-summary small{display:block;color:#94a3b8;font-size:12px;font-weight:900}
.card-stats-summary strong{display:block;margin-top:8px;color:#111827;font-size:20px;font-weight:950}
.card-stats-summary a{color:#2563eb;font-weight:900}
.card-stats-table{margin-top:18px;overflow:auto;border:1px solid #e2e8f0;border-radius:18px}
.card-stats-table table{width:100%;border-collapse:collapse;min-width:760px}
.card-stats-table th,.card-stats-table td{padding:13px 14px;border-bottom:1px solid #e2e8f0;text-align:left;color:#334155;font-size:14px}
.card-stats-table th{background:#f8fbff;color:#111827;font-weight:900}
.card-stats-empty{margin-top:20px;padding:18px;border-radius:18px;color:#dc2626;background:#fff5f5;border:1px solid #fecaca;font-weight:850}
@media(max-width:1060px){.slice-builder-grid{grid-template-columns:1fr}.slice-preview-zone{position:relative;top:auto}.slice-og-card{transform:scale(.45);margin:-80px 0}}
@media(max-width:760px){.slice-public-card,.slice-page-preview{grid-template-columns:1fr}.slice-public-visual,.slice-page-visual{min-height:260px}.slice-builder-head h1{font-size:46px}.card-stats-summary{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.slice-og-card{transform:scale(.32);margin:-150px 0}.card-stats-summary,.card-stats-search{grid-template-columns:1fr}}


/* v86 slice card clean rebuild */

/* remove v83 online residue if older page still existed */
#onlineCardPanel,
.online-card-panel {
  display: none !important;
}

/* utility card fix */
.utility-card[href*="slice-card"],
a[href="slice-card.php"].tool-open-btn {
  display: inline-flex;
}
.tool-card:has(a[href="slice-card.php"]),
.utility-card:has(a[href="slice-card.php"]) {
  background: rgba(255,255,255,.94) !important;
  color: inherit !important;
}
.tool-card:has(a[href="slice-card.php"]) h3,
.utility-card:has(a[href="slice-card.php"]) h3 {
  color: #111827 !important;
}
.tool-card:has(a[href="slice-card.php"]) p,
.utility-card:has(a[href="slice-card.php"]) p {
  color: #64748b !important;
}

.slice-v86-stage {
  min-height: calc(100vh - 74px);
  padding: 44px 0 80px;
  background:
    radial-gradient(circle at 12% 10%, rgba(37,99,235,.12), transparent 30%),
    radial-gradient(circle at 88% 12%, rgba(139,92,246,.10), transparent 28%),
    linear-gradient(180deg,#fbfdff 0%,#f7faff 100%);
}

.slice-v86-hero {
  text-align: center;
  margin-bottom: 26px;
}

.slice-v86-hero span {
  min-height: 32px;
  padding: 0 14px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  background: #eef4ff;
  border: 1px solid #dbeafe;
  color: #2563eb;
  font-size: 12px;
  font-weight: 950;
}

.slice-v86-hero h1 {
  margin: 16px 0 0;
  color: #111827;
  font-size: clamp(42px, 6vw, 72px);
  line-height: .98;
  letter-spacing: -.09em;
  font-weight: 950;
}

.slice-v86-hero p {
  margin: 14px auto 0;
  max-width: 740px;
  color: #64748b;
  line-height: 1.7;
  word-break: keep-all;
}

.slice-v86-app {
  display: grid;
  grid-template-columns: 380px minmax(0,1fr);
  gap: 22px;
  align-items: start;
}

.slice-v86-panel,
.slice-v86-preview {
  border-radius: 30px;
  background: rgba(255,255,255,.94);
  border: 1px solid rgba(15,23,42,.08);
  box-shadow: 0 26px 90px rgba(15,23,42,.10);
}

.slice-v86-panel {
  overflow: hidden;
}

.slice-v86-tabs {
  padding: 14px;
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 8px;
  border-bottom: 1px solid #e2e8f0;
  background: #fbfdff;
}

.slice-v86-tabs button,
.slice-v86-mode button {
  min-height: 40px;
  border: 1px solid #dbe4f0;
  border-radius: 14px;
  background: #fff;
  color: #334155;
  font-size: 13px;
  font-weight: 900;
  cursor: pointer;
}

.slice-v86-tabs button.active,
.slice-v86-mode button.active {
  background: #2563eb;
  color: #fff;
  border-color: #2563eb;
}

.slice-v86-section {
  display: none;
  padding: 22px;
}

.slice-v86-section.active {
  display: block;
}

.slice-v86-section h2 {
  margin: 0 0 16px;
  color: #111827;
  font-size: 22px;
  letter-spacing: -.055em;
  font-weight: 950;
}

.slice-v86-section label {
  margin-top: 12px;
  display: grid;
  gap: 7px;
  color: #334155;
  font-size: 13px;
  font-weight: 850;
}

.slice-v86-section input,
.slice-v86-section select,
.slice-v86-section textarea {
  width: 100%;
  min-height: 45px;
  border: 1px solid #dbe4f0;
  border-radius: 15px;
  padding: 0 13px;
  background: #f8fbff;
  color: #111827;
  outline: none;
}

.slice-v86-section textarea {
  min-height: 96px;
  padding: 12px 13px;
  resize: vertical;
}

.slice-v86-save {
  padding: 16px 22px 22px;
  display: grid;
  gap: 10px;
  border-top: 1px solid #e2e8f0;
}

.slice-v86-save button,
.slice-v86-save a {
  min-height: 46px;
  border: 0;
  border-radius: 15px;
  background: linear-gradient(135deg,#2563eb,#1677ff);
  color: #fff;
  font-size: 14px;
  font-weight: 950;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}

.slice-v86-save button:nth-child(2),
.slice-v86-save a {
  background: #eef4ff;
  color: #2563eb;
  border: 1px solid #dbeafe;
}

#scResult {
  padding: 13px 14px;
  border-radius: 15px;
  background: #f8fbff;
  border: 1px solid #dbe4f0;
  color: #64748b;
  font-size: 13px;
  word-break: break-all;
}

#scResult a {
  color: #2563eb;
  font-weight: 900;
}

.slice-v86-preview {
  position: sticky;
  top: 88px;
  overflow: hidden;
}

.slice-v86-preview-head {
  padding: 18px 20px;
  border-bottom: 1px solid #e2e8f0;
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: center;
}

.slice-v86-preview-head strong {
  color: #111827;
  font-size: 23px;
  letter-spacing: -.055em;
  font-weight: 950;
}

.slice-v86-preview-head p {
  margin: 4px 0 0;
  color: #64748b;
  font-size: 13px;
}

.slice-v86-mode {
  display: flex;
  gap: 8px;
}

.slice-v86-og-holder {
  min-height: 520px;
  padding: 26px;
  display: grid;
  place-items: center;
  overflow: auto;
  background: #fff;
}

.slice-og-v86 {
  width: 640px;
  height: 336px;
  position: relative;
  overflow: hidden;
  border-radius: 0;
  background: #d9efff;
  color: var(--slice-text,#fff);
  font-weight: var(--slice-weight,900);
  box-shadow: 0 20px 70px rgba(15,23,42,.10);
}

.slice-og-v86.capture {
  width: 1200px !important;
  height: 630px !important;
}

.slice-og-v86-phone {
  position: absolute;
  inset: 26px 48px;
  border-radius: 34px;
  background: linear-gradient(135deg,#cdeeff,#e8f6ff);
}

.slice-og-v86.capture .slice-og-v86-phone {
  inset: 50px 90px;
  border-radius: 64px;
}

.slice-og-v86-bubble {
  position: absolute;
  top: 28px;
  left: 190px;
  z-index: 3;
  padding: 7px 13px;
  border-radius: 10px;
  background: #ffe45c;
  color: #111827;
  font-size: 13px;
  font-weight: 950;
  white-space: nowrap;
}

.slice-og-v86.capture .slice-og-v86-bubble {
  top: 52px;
  left: 356px;
  padding: 14px 24px;
  border-radius: 18px;
  font-size: 25px;
}

.slice-og-v86-card {
  position: absolute;
  left: 118px;
  top: 78px;
  width: 408px;
  height: 142px;
  border-radius: var(--slice-radius,28px);
  background: var(--slice-bg,#071326);
  box-shadow: 0 18px 46px rgba(0,0,0,.24);
  padding: 26px 24px;
}

.slice-og-v86.capture .slice-og-v86-card {
  left: 220px;
  top: 146px;
  width: 765px;
  height: 266px;
  padding: 48px 44px;
}

.slice-og-v86-photo {
  position: absolute;
  left: 24px;
  top: 28px;
  width: 56px;
  height: 56px;
  overflow: hidden;
  display: grid;
  place-items: center;
  background: rgba(255,255,255,.18);
  border: 1px solid rgba(255,255,255,.24);
  color: #fff;
  font-size: 24px;
  font-weight: 950;
}

.slice-og-v86.capture .slice-og-v86-photo {
  left: 44px;
  top: 52px;
  width: 105px;
  height: 105px;
  font-size: 46px;
}

.slice-og-v86-photo.shape-circle,
.slice-page-v86-photo.shape-circle,
.slice-public-photo.shape-circle {
  border-radius: 999px;
}

.slice-og-v86-photo.shape-round,
.slice-page-v86-photo.shape-round,
.slice-public-photo.shape-round {
  border-radius: 26px;
}

.slice-og-v86-photo.shape-square,
.slice-page-v86-photo.shape-square,
.slice-public-photo.shape-square {
  border-radius: 6px;
}

.slice-og-v86-photo img,
.slice-page-v86-photo img,
.slice-public-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.slice-og-v86-main {
  margin-left: 78px;
}

.slice-og-v86.capture .slice-og-v86-main {
  margin-left: 145px;
}

.slice-og-v86-name {
  display: block;
  color: #fff;
  font-size: 22px;
  line-height: 1;
  letter-spacing: -.055em;
  font-weight: 950;
}

.slice-og-v86.capture .slice-og-v86-name {
  font-size: 42px;
}

.slice-og-v86-sub {
  margin: 6px 0 0;
  color: #e2e8f0;
  font-size: 11px;
  font-weight: 850;
}

.slice-og-v86.capture .slice-og-v86-sub {
  margin-top: 12px;
  font-size: 21px;
}

.slice-og-v86-small {
  display: block;
  margin-top: 5px;
  color: #94a3b8;
  font-size: 10px;
}

.slice-og-v86.capture .slice-og-v86-small {
  margin-top: 9px;
  font-size: 18px;
}

.slice-og-v86-tags {
  position: absolute;
  left: 24px;
  right: 24px;
  bottom: 24px;
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 7px;
}

.slice-og-v86.capture .slice-og-v86-tags {
  left: 44px;
  right: 44px;
  bottom: 45px;
  gap: 14px;
}

.slice-og-v86-tags span {
  min-height: 24px;
  border-radius: 7px;
  display: grid;
  place-items: center;
  background: rgba(255,255,255,.12);
  color: #fff;
  font-size: 10px;
  font-weight: 900;
}

.slice-og-v86.capture .slice-og-v86-tags span {
  min-height: 44px;
  border-radius: 12px;
  font-size: 18px;
}

.slice-og-v86-bottom {
  position: absolute;
  left: 118px;
  right: 118px;
  bottom: 32px;
  z-index: 5;
}

.slice-og-v86.capture .slice-og-v86-bottom {
  left: 220px;
  right: 220px;
  bottom: 60px;
}

.slice-og-v86-bottom p {
  margin: 0 0 7px;
  color: #111827;
  font-size: 13px;
  font-weight: 850;
}

.slice-og-v86.capture .slice-og-v86-bottom p {
  margin-bottom: 13px;
  font-size: 26px;
}

.slice-og-v86-bottom button {
  width: 100%;
  height: 26px;
  border: 0;
  border-radius: 7px;
  background: #f1f5f9;
  color: #111827;
  font-size: 11px;
  font-weight: 950;
}

.slice-og-v86.capture .slice-og-v86-bottom button {
  height: 50px;
  border-radius: 12px;
  font-size: 20px;
}

.slice-og-v86.clean-blue .slice-og-v86-card { background: linear-gradient(135deg,#2563eb,#38bdf8); }
.slice-og-v86.soft-white .slice-og-v86-card { background: #fff; color:#111827; }
.slice-og-v86.soft-white .slice-og-v86-name { color:#111827; }
.slice-og-v86.soft-white .slice-og-v86-sub { color:#475569; }
.slice-og-v86.soft-white .slice-og-v86-small { color:#64748b; }
.slice-og-v86.soft-white .slice-og-v86-tags span { background:#eef4ff;color:#2563eb; }
.slice-og-v86.glass-purple .slice-og-v86-card { background: linear-gradient(135deg,#7c3aed,#db2777); }
.slice-og-v86.mono-pro .slice-og-v86-card { background: #111827; }
.slice-og-v86.orange-card .slice-og-v86-card { background: linear-gradient(135deg,#f97316,#ef4444); }
.slice-og-v86.profile-left .slice-og-v86-card { background: linear-gradient(135deg,#0f172a,#2563eb); }
.slice-og-v86.luxury-gold .slice-og-v86-card { background: linear-gradient(135deg,#111827,#7c5c16); }

.slice-page-v86 {
  display: none;
  grid-template-columns: 330px minmax(0,1fr);
  margin: 26px;
  overflow: hidden;
  border-radius: 32px;
  border: 1px solid #e2e8f0;
  background: #fff;
  box-shadow: 0 24px 80px rgba(15,23,42,.10);
}

.slice-page-v86-visual {
  min-height: 470px;
  padding: 30px;
  background: var(--slice-bg,#071326);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.slice-page-v86-logo {
  width: 58px;
  height: 58px;
  border-radius: 20px;
  display: grid;
  place-items: center;
  color: #fff;
  background: rgba(255,255,255,.16);
  border: 1px solid rgba(255,255,255,.25);
  font-size: 22px;
  font-weight: 950;
}

.slice-page-v86-photo {
  width: 180px;
  height: 180px;
  overflow: hidden;
  display: grid;
  place-items: center;
  color: #fff;
  background: rgba(255,255,255,.16);
  font-size: 60px;
  font-weight: 950;
}

.slice-page-v86-content {
  padding: 42px;
}

.slice-page-v86-content > span {
  min-height: 30px;
  padding: 0 12px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  background: #eef4ff;
  border: 1px solid #dbeafe;
  color: #2563eb;
  font-size: 12px;
  font-weight: 900;
}

.slice-page-v86-content h2 {
  margin: 18px 0 0;
  color: #111827;
  font-size: 60px;
  line-height: .95;
  letter-spacing: -.09em;
  font-weight: 950;
}

.slice-page-v86-content h3 {
  margin: 13px 0 0;
  color: var(--slice-accent,#2563eb);
  font-size: 18px;
  font-weight: 950;
}

.slice-page-v86-content p {
  margin: 22px 0 0;
  color: #475569;
  line-height: 1.75;
}

.slice-page-v86-info {
  margin-top: 24px;
  display: grid;
  gap: 10px;
}

.slice-page-v86-info div {
  min-height: 44px;
  padding: 0 14px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  background: #f8fbff;
  border: 1px solid #e2e8f0;
  color: #334155;
  font-weight: 850;
}

.slice-page-v86-info b {
  margin-right: 8px;
  color: #64748b;
}

.slice-page-v86-buttons {
  margin-top: 22px;
  display: flex;
  gap: 10px;
}

.slice-page-v86-buttons a {
  min-height: 44px;
  padding: 0 16px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #eef4ff;
  border: 1px solid #dbeafe;
  color: #2563eb;
  font-weight: 950;
}

.slice-page-v86-buttons a.primary {
  color: #fff;
  background: linear-gradient(135deg,#2563eb,#1677ff);
  border: 0;
}

/* public page polish */
.slice-public-card {
  border-radius: 34px !important;
}
.slice-public-visual {
  background: var(--slice-bg,#071326) !important;
}
.slice-public-content h1 {
  font-weight: var(--slice-weight,950) !important;
}
.slice-public-photo {
  border-radius: var(--slice-radius,28px);
}

@media (max-width: 1080px) {
  .slice-v86-app {
    grid-template-columns: 1fr;
  }
  .slice-v86-preview {
    position: relative;
    top: auto;
  }
}

@media (max-width: 760px) {
  .slice-v86-og-holder {
    padding: 16px;
  }
  .slice-og-v86 {
    transform: scale(.72);
    transform-origin: center;
    margin: -44px 0;
  }
  .slice-page-v86 {
    grid-template-columns: 1fr;
  }
  .slice-page-v86-visual {
    min-height: 250px;
  }
}

@media (max-width: 540px) {
  .slice-og-v86 {
    transform: scale(.52);
    margin: -80px 0;
  }
  .slice-v86-tabs {
    grid-template-columns: repeat(2,1fr);
  }
}


/* v87 slice card: utility card + clean Kakao preview only */
.slice-tool-card {
  background: rgba(255,255,255,.94) !important;
  color: inherit !important;
}

.slice-tool-card .tool-icon {
  color: #2563eb !important;
  background: #eef4ff !important;
  border: 1px solid #dbeafe !important;
}

.slice-tool-card h3 {
  color: #111827 !important;
}

.slice-tool-card p {
  color: #64748b !important;
}

.slice-tool-card .tool-open-btn {
  min-height: 42px;
  padding: 0 18px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #2563eb;
  color: #fff !important;
  text-decoration: none;
  font-weight: 900;
}

/* preview area */
.slice-v86-og-holder {
  min-height: 440px !important;
  padding: 28px !important;
  display: grid !important;
  place-items: center !important;
  background: #fff !important;
  overflow: auto !important;
}

/* the captured/visible preview is the card itself only */
.slice-og-v86 {
  width: 640px !important;
  height: 336px !important;
  border-radius: 24px !important;
  background: transparent !important;
  box-shadow: 0 24px 80px rgba(15,23,42,.14) !important;
  overflow: visible !important;
  color: var(--slice-text,#fff);
  font-weight: var(--slice-weight,900);
}

.slice-og-v86.capture {
  width: 1200px !important;
  height: 630px !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  overflow: hidden !important;
}

.slice-og-v86::before,
.slice-og-v86::after,
.slice-og-v86-phone,
.slice-og-v86-bubble,
.slice-og-v86-bottom {
  display: none !important;
}

/* visible card fills the preview */
.slice-og-v86-card {
  position: absolute !important;
  inset: 0 !important;
  width: auto !important;
  height: auto !important;
  border-radius: var(--slice-radius,28px) !important;
  background: linear-gradient(135deg,#7c3aed,#db2777) !important;
  box-shadow: none !important;
  padding: 42px 44px !important;
  overflow: hidden !important;
}

.slice-og-v86.capture .slice-og-v86-card {
  inset: 0 !important;
  width: auto !important;
  height: auto !important;
  padding: 78px 82px !important;
  border-radius: 0 !important;
}

/* template colors */
.slice-og-v86.kakao-dark .slice-og-v86-card { background: var(--slice-bg,#071326) !important; }
.slice-og-v86.clean-blue .slice-og-v86-card { background: linear-gradient(135deg,#2563eb,#38bdf8) !important; }
.slice-og-v86.soft-white .slice-og-v86-card { background: #fff !important; color:#111827 !important; border: 1px solid #e2e8f0; }
.slice-og-v86.glass-purple .slice-og-v86-card { background: linear-gradient(135deg,#7c3aed,#db2777) !important; }
.slice-og-v86.mono-pro .slice-og-v86-card { background: #111827 !important; }
.slice-og-v86.orange-card .slice-og-v86-card { background: linear-gradient(135deg,#f97316,#ef4444) !important; }
.slice-og-v86.profile-left .slice-og-v86-card { background: linear-gradient(135deg,#0f172a,#2563eb) !important; }
.slice-og-v86.luxury-gold .slice-og-v86-card { background: linear-gradient(135deg,#111827,#7c5c16) !important; }

/* photo and text positions for single-card design */
.slice-og-v86-photo {
  position: absolute !important;
  left: 44px !important;
  top: 54px !important;
  width: 82px !important;
  height: 82px !important;
  overflow: hidden !important;
  display: grid !important;
  place-items: center !important;
  background: rgba(255,255,255,.18) !important;
  border: 1px solid rgba(255,255,255,.28) !important;
  color: #fff !important;
  font-size: 34px !important;
  font-weight: 950 !important;
}

.slice-og-v86.capture .slice-og-v86-photo {
  left: 82px !important;
  top: 100px !important;
  width: 154px !important;
  height: 154px !important;
  font-size: 64px !important;
}

.slice-og-v86-main {
  margin-left: 118px !important;
  padding-top: 4px !important;
}

.slice-og-v86.capture .slice-og-v86-main {
  margin-left: 220px !important;
  padding-top: 8px !important;
}

.slice-og-v86-name {
  display: block !important;
  color: #fff !important;
  font-size: 38px !important;
  line-height: 1 !important;
  letter-spacing: -.065em !important;
  font-weight: 950 !important;
}

.slice-og-v86.capture .slice-og-v86-name {
  font-size: 72px !important;
}

.slice-og-v86-sub {
  margin: 12px 0 0 !important;
  color: rgba(255,255,255,.92) !important;
  font-size: 17px !important;
  font-weight: 850 !important;
}

.slice-og-v86.capture .slice-og-v86-sub {
  margin-top: 22px !important;
  font-size: 32px !important;
}

.slice-og-v86-small {
  display: block !important;
  margin-top: 9px !important;
  color: rgba(255,255,255,.72) !important;
  font-size: 14px !important;
}

.slice-og-v86.capture .slice-og-v86-small {
  margin-top: 16px !important;
  font-size: 26px !important;
}

.slice-og-v86-tags {
  position: absolute !important;
  left: 44px !important;
  right: 44px !important;
  bottom: 42px !important;
  display: grid !important;
  grid-template-columns: repeat(3,1fr) !important;
  gap: 14px !important;
}

.slice-og-v86.capture .slice-og-v86-tags {
  left: 82px !important;
  right: 82px !important;
  bottom: 78px !important;
  gap: 26px !important;
}

.slice-og-v86-tags span {
  min-height: 44px !important;
  border-radius: 12px !important;
  display: grid !important;
  place-items: center !important;
  background: rgba(255,255,255,.16) !important;
  color: #fff !important;
  font-size: 16px !important;
  font-weight: 950 !important;
}

.slice-og-v86.capture .slice-og-v86-tags span {
  min-height: 82px !important;
  border-radius: 22px !important;
  font-size: 30px !important;
}

.slice-og-v86.soft-white .slice-og-v86-name { color:#111827 !important; }
.slice-og-v86.soft-white .slice-og-v86-sub { color:#334155 !important; }
.slice-og-v86.soft-white .slice-og-v86-small { color:#64748b !important; }
.slice-og-v86.soft-white .slice-og-v86-tags span { background:#eef4ff !important;color:#2563eb !important; }

@media (max-width: 760px) {
  .slice-og-v86 {
    transform: scale(.72);
    transform-origin: center;
    margin: -44px 0;
  }
}

@media (max-width: 540px) {
  .slice-og-v86 {
    transform: scale(.52);
    margin: -80px 0;
  }
}


/* v88 utility/excel/slice repair */
.utility-stage-v88{min-height:calc(100vh - 74px);padding:58px 0 90px;background:radial-gradient(circle at 10% 8%,rgba(37,99,235,.12),transparent 30%),radial-gradient(circle at 92% 12%,rgba(139,92,246,.10),transparent 28%),linear-gradient(180deg,#fbfdff 0%,#f7faff 100%)}
.utility-head-v88{text-align:center;margin-bottom:34px}.utility-head-v88 span{min-height:32px;padding:0 14px;border-radius:999px;display:inline-flex;align-items:center;background:#eef4ff;border:1px solid #dbeafe;color:#2563eb;font-size:12px;font-weight:950}.utility-head-v88 h1{margin:16px 0 0;color:#111827;font-size:clamp(42px,6vw,72px);line-height:.98;letter-spacing:-.09em;font-weight:950}.utility-head-v88 p{margin:14px auto 0;color:#64748b;line-height:1.7}
.utility-grid-v88{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:20px}.tool-card-v88{min-height:330px;padding:28px;border-radius:26px;background:rgba(255,255,255,.94);border:1px solid rgba(15,23,42,.08);box-shadow:0 26px 80px rgba(15,23,42,.08);display:flex;flex-direction:column;align-items:flex-start}.tool-icon-v88{width:56px;height:56px;border-radius:18px;display:grid;place-items:center;color:#2563eb;background:#eef4ff;border:1px solid #dbeafe;font-size:18px;font-weight:950}.tool-card-v88 h3{margin:26px 0 0;color:#111827;font-size:26px;line-height:1.16;letter-spacing:-.06em;font-weight:950}.tool-card-v88 p{margin:16px 0 0;color:#64748b;line-height:1.72;word-break:keep-all}.tool-card-v88 a,.tool-card-v88 button{margin-top:auto;min-height:44px;padding:0 18px;border:0;border-radius:13px;background:#2563eb;color:#fff;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;font-size:14px;font-weight:950}.tool-card-v88.disabled{opacity:.55}.tool-card-v88.disabled button{background:#fff;color:#334155;border:1px solid #dbe4f0}.slice-highlight-v88{background:radial-gradient(circle at 100% 0%,rgba(37,99,235,.16),transparent 34%),rgba(255,255,255,.96)}

.excel-v88-stage{min-height:calc(100vh - 74px);padding:38px 0 80px;background:radial-gradient(circle at 10% 8%,rgba(37,99,235,.10),transparent 28%),radial-gradient(circle at 92% 14%,rgba(139,92,246,.08),transparent 28%),linear-gradient(180deg,#fbfdff 0%,#f7faff 100%)}.excel-v88-shell{overflow:hidden;border-radius:30px;background:rgba(255,255,255,.94);border:1px solid rgba(15,23,42,.08);box-shadow:0 28px 90px rgba(15,23,42,.10)}.excel-v88-bar{height:54px;padding:0 18px;border-bottom:1px solid rgba(15,23,42,.08);display:flex;align-items:center;justify-content:space-between;background:#fbfdff}.window-dots-v88{display:flex;gap:8px}.window-dots-v88 span{width:9px;height:9px;border-radius:999px;background:#cbd5e1}.excel-v88-bar strong{min-height:30px;padding:0 12px;border-radius:999px;display:inline-flex;align-items:center;color:#3f9b14;background:#f0ffe8;border:1px solid #9be56a;font-size:12px;font-weight:950}.excel-v88-toolbar{padding:16px 22px;display:flex;gap:8px;flex-wrap:wrap;border-bottom:1px solid rgba(15,23,42,.08)}.excel-v88-toolbar button{min-height:40px;padding:0 13px;border:1px solid #dbe4f0;border-radius:13px;background:#f8fbff;color:#2563eb;font-size:14px;font-weight:900;cursor:pointer}.excel-v88-toolbar button.primary{color:#fff;background:#2563eb;border-color:#2563eb}.excel-v88-toolbar button.danger{color:#dc2626;background:#fff5f5;border-color:#fecaca}.excel-v88-status{margin:18px 22px 0;min-height:44px;padding:0 16px;border-radius:16px;display:flex;align-items:center;background:#f8fbff;border:1px solid #dbe4f0;color:#64748b;font-size:14px;font-weight:850}.excel-v88-sheet-wrap{margin:18px 22px 28px;height:640px;overflow:auto;border:1px solid #dbe4f0;border-radius:22px;background:#fff}.excel-v88-table{border-collapse:collapse;width:100%;table-layout:fixed;min-width:900px;font-size:14px;color:#172033}.excel-v88-table th,.excel-v88-table td{border:1px solid #e2e8f0;height:39px;padding:8px 10px;white-space:nowrap;background:#fff;outline:none;overflow:hidden;text-overflow:ellipsis}.excel-v88-table th{background:#f4f7fb;color:#334155;font-weight:900;text-align:center;cursor:pointer}.excel-v88-table .corner,.excel-v88-table tr>th:first-child{width:46px}.excel-v88-table tr.selected-row td,.excel-v88-table td.selected-col,.excel-v88-table th.selected-col{background:#eef4ff!important}.excel-v88-table td:focus{overflow:visible;white-space:normal;box-shadow:0 0 0 2px rgba(37,99,235,.22);position:relative;z-index:2}

#scLoad{background:#eef4ff!important;color:#2563eb!important;border:1px solid #dbeafe!important}
.slice-public-photo{border-radius:var(--slice-radius,28px)!important}.slice-public-photo.shape-circle{border-radius:999px!important}.slice-public-photo.shape-round{border-radius:28px!important}.slice-public-photo.shape-square{border-radius:6px!important}.slice-public-content h1{font-weight:var(--slice-weight,950)!important}
@media(max-width:1100px){.utility-grid-v88{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:640px){.utility-grid-v88{grid-template-columns:1fr}.tool-card-v88{min-height:280px}}


/* v89 slice editor like online business card */
.slice-editor-stage-v89{min-height:calc(100vh - 74px);padding:42px 0 90px;background:radial-gradient(circle at 10% 8%,rgba(37,99,235,.12),transparent 30%),radial-gradient(circle at 92% 12%,rgba(139,92,246,.10),transparent 28%),linear-gradient(180deg,#fbfdff 0%,#f7faff 100%)}
.slice-editor-head-v89{text-align:center;margin-bottom:26px}.slice-editor-head-v89 span{min-height:32px;padding:0 14px;border-radius:999px;display:inline-flex;align-items:center;background:#eef4ff;border:1px solid #dbeafe;color:#2563eb;font-size:12px;font-weight:950}.slice-editor-head-v89 h1{margin:16px 0 0;color:#111827;font-size:clamp(42px,6vw,72px);line-height:.98;letter-spacing:-.09em;font-weight:950}.slice-editor-head-v89 p{margin:14px auto 0;color:#64748b;line-height:1.7}
.slice-editor-grid-v89{display:grid;grid-template-columns:390px minmax(0,1fr);gap:22px;align-items:start}.slice-panel-v89,.slice-workspace-v89{border-radius:30px;background:rgba(255,255,255,.96);border:1px solid rgba(15,23,42,.08);box-shadow:0 26px 90px rgba(15,23,42,.10)}.slice-panel-v89{overflow:hidden}.slice-panel-title-v89{padding:24px}.slice-panel-title-v89 span{min-height:30px;padding:0 12px;border-radius:999px;display:inline-flex;align-items:center;background:#eef4ff;border:1px solid #dbeafe;color:#2563eb;font-size:12px;font-weight:900}.slice-panel-title-v89 h2{margin:16px 0 0;color:#111827;font-size:30px;letter-spacing:-.07em;font-weight:950}.slice-panel-title-v89 p{margin:10px 0 0;color:#64748b;line-height:1.65}
.slice-tabs-v89{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:0 14px 14px}.slice-tabs-v89 button,.preview-tabs-v89 button{min-height:42px;border:1px solid #dbe4f0;border-radius:14px;background:#f8fbff;color:#334155;font-weight:900;cursor:pointer}.slice-tabs-v89 button.active,.preview-tabs-v89 button.active{background:#2563eb;color:#fff;border-color:#2563eb}
.slice-tab-v89{display:none;padding:18px 18px 22px;border-top:1px solid #e2e8f0}.slice-tab-v89.active{display:block}.slice-tab-v89 label{display:grid;gap:7px;margin-top:12px;color:#334155;font-size:13px;font-weight:850}.slice-tab-v89 input,.slice-tab-v89 select,.slice-tab-v89 textarea{width:100%;min-height:45px;border:1px solid #dbe4f0;border-radius:15px;background:#f8fbff;color:#111827;padding:0 13px;outline:none}.slice-tab-v89 textarea{min-height:90px;padding:12px 13px;resize:vertical}.two-col-v89{display:grid;grid-template-columns:1fr 1fr;gap:10px}.check-grid-v89{display:grid;grid-template-columns:1fr 1fr;gap:9px}.check-grid-v89 label,.free-switch-v89{min-height:42px;padding:0 12px;border:1px solid #dbe4f0;border-radius:13px;background:#f8fbff;display:flex!important;align-items:center;gap:8px}.check-grid-v89 input{width:auto;min-height:auto}.palette-v89,.color-group-v89{margin-top:18px;padding:14px;border-radius:18px;background:#f8fbff;border:1px solid #dbe4f0}.palette-v89 h3,.color-group-v89 h3,.slice-tab-v89 h3{margin:0 0 10px;color:#111827;font-size:14px;font-weight:950}.palette-v89{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.palette-v89 h3{grid-column:1/-1}.palette-v89 label{margin:0}.font-edit-v89{margin-top:12px;padding:14px;border-radius:18px;background:#f8fbff;border:1px solid #dbe4f0}.font-head-v89{display:flex;justify-content:space-between;color:#111827;font-weight:950}.font-row-v89{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px}.font-edit-v89 input[type=range]{min-height:32px;padding:0}.color-group-v89 label{grid-template-columns:1fr 58px;align-items:center}.color-group-v89 input[type=color],.palette-v89 input[type=color]{height:42px;padding:4px}.image-actions-v89{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:14px}.image-actions-v89 button{min-height:42px;border:1px solid #dbe4f0;border-radius:14px;background:#f8fbff;color:#2563eb;font-weight:900}.image-actions-v89 button:last-child{grid-column:1/-1;color:#dc2626;background:#fff5f5;border-color:#fecaca}
.slice-actions-v89{padding:16px 18px 20px;border-top:1px solid #e2e8f0;display:grid;grid-template-columns:1fr 1fr;gap:10px}.slice-actions-v89 button,.slice-actions-v89 a{min-height:46px;border:0;border-radius:15px;background:#2563eb;color:#fff;font-weight:950;display:flex;align-items:center;justify-content:center;text-decoration:none}.slice-actions-v89 button:first-child,.slice-actions-v89 a{background:#eef4ff;color:#2563eb;border:1px solid #dbeafe}.slice-actions-v89 #scResult{grid-column:1/-1;padding:13px 14px;border-radius:15px;background:#f8fbff;border:1px solid #dbe4f0;color:#64748b;font-size:13px;word-break:break-all}.slice-actions-v89 #scResult a{color:#2563eb;font-weight:900}
.slice-workspace-v89{padding:22px;position:sticky;top:86px}.template-grid-v89{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;max-height:190px;overflow:auto;padding-right:4px}.template-chip-v89{min-height:76px;text-align:left;padding:12px;border-radius:15px;border:1px solid #dbe4f0;background:#fff;color:#111827;position:relative;overflow:hidden;cursor:pointer}.template-chip-v89.active{border-color:#2563eb;box-shadow:0 0 0 2px rgba(37,99,235,.12)}.template-chip-v89 strong{display:block;font-size:12px;font-weight:950}.template-chip-v89 small{display:block;margin-top:6px;color:#64748b;font-weight:800}.template-chip-v89 i{position:absolute;right:-18px;bottom:-18px;width:60px;height:60px;border-radius:999px;background:#c7d7ff}.template-dot-03 i,.template-dot-09 i,.template-dot-19 i{background:#d8c2f4}.template-dot-04 i{background:#c7c9cf}.template-dot-08 i{background:#c8efd5}.template-dot-18 i,.template-dot-20 i{background:#ffdfb7}
.preview-tabs-v89{margin-top:18px;display:flex;gap:8px}.preview-stage-v89{margin-top:14px;min-height:500px;padding:28px;border-radius:28px;background:#fff;display:grid;place-items:center;overflow:auto;border:1px solid #e2e8f0}
.slice-public-preview-v89{width:760px;height:430px;border-radius:var(--radius,28px);background:var(--bg,#fff);position:relative;overflow:hidden;box-shadow:0 26px 80px rgba(15,23,42,.12);border:1px solid rgba(15,23,42,.08);color:var(--text,#111827)}.slice-public-preview-v89::before{content:"";position:absolute;right:-70px;top:-80px;width:260px;height:260px;border-radius:999px;background:color-mix(in srgb,var(--accent,#2563eb) 25%,transparent)}.slice-public-preview-v89::after{content:"";position:absolute;left:-70px;bottom:-100px;width:230px;height:230px;border-radius:999px;background:color-mix(in srgb,var(--accent,#2563eb) 14%,transparent)}
.sp-logo{position:absolute;left:48px;top:40px;width:58px;height:58px;border-radius:18px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,#2563eb,#8b5cf6);font-weight:950;z-index:2}.sp-logo.logo-solid{background:var(--accent,#2563eb)}.sp-logo.logo-outline{background:#fff;color:var(--accent,#2563eb);border:1px solid var(--accent,#2563eb)}.sp-company{position:absolute;left:136px;top:58px;z-index:2}.sp-name{position:absolute;left:92px;top:150px;line-height:.95;letter-spacing:-.08em;z-index:2}.sp-job{position:absolute;left:94px;top:220px;z-index:2}.sp-intro{position:absolute;left:94px;bottom:78px;width:360px;line-height:1.65;z-index:2}.sp-contact{position:absolute;right:54px;top:168px;width:250px;display:grid;gap:13px;z-index:2}.sp-contact div{display:flex;gap:12px}.sp-contact b{min-width:52px;color:#94a3b8}.sp-contact span{flex:1}.sp-photo{position:absolute;right:56px;top:40px;width:96px;height:96px;display:grid;place-items:center;overflow:hidden;background:rgba(37,99,235,.12);color:var(--accent,#2563eb);font-size:36px;font-weight:950;z-index:2}.sp-photo img{width:100%;height:100%;object-fit:cover}.shape-circle{border-radius:999px}.shape-round{border-radius:26px}.shape-square{border-radius:8px}
.ratio-vertical{width:430px;height:760px}.ratio-square{width:560px;height:560px}.layout-center .sp-company,.layout-center .sp-name,.layout-center .sp-job,.layout-center .sp-intro{text-align:center;left:50%;transform:translateX(-50%)}.layout-center .sp-contact{left:50%;right:auto;transform:translateX(-50%);top:auto;bottom:44px}.layout-center .sp-photo{left:50%;right:auto;transform:translateX(-50%);top:52px}.layout-center .sp-logo{left:48px}.layout-right .sp-contact{left:54px;right:auto}.layout-right .sp-name,.layout-right .sp-job,.layout-right .sp-intro{left:auto;right:56px;text-align:right}.layout-split{display:block}
.bg-flat::before,.bg-flat::after{display:none}.bg-dark{background:#111827!important;color:#fff}.bg-pattern{background-image:linear-gradient(rgba(37,99,235,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(37,99,235,.05) 1px,transparent 1px);background-size:28px 28px}
.template-02 .sp-contact{top:130px}.template-03 .sp-name{text-align:center}.template-05,.template-17{background:#111827!important;color:#fff}.template-06 .sp-logo,.template-10 .sp-logo{width:80px}.template-08::before{background:#c8efd5}.template-09::before,.template-19::before{background:#d8c2f4}.template-18::before{background:#ffdfb7}
.slice-og-export-v89{width:1200px;height:630px;border-radius:0;background:linear-gradient(135deg,#071326,#0f172a);position:relative;overflow:hidden;color:#fff}.slice-og-export-v89 .og-photo{position:absolute;left:82px;top:100px;width:154px;height:154px;background:rgba(255,255,255,.16);display:grid;place-items:center;overflow:hidden;font-size:64px;font-weight:950}.slice-og-export-v89 .og-photo img{width:100%;height:100%;object-fit:cover}.slice-og-export-v89 .og-copy{position:absolute;left:280px;top:105px}.slice-og-export-v89 strong{display:block;font-size:72px;line-height:1;font-weight:950;letter-spacing:-.08em}.slice-og-export-v89 p{margin:22px 0 0;font-size:32px;font-weight:850}.slice-og-export-v89 small{display:block;margin-top:16px;color:#cbd5e1;font-size:26px}.slice-og-export-v89 .og-tags{position:absolute;left:82px;right:82px;bottom:78px;display:grid;grid-template-columns:repeat(3,1fr);gap:26px}.slice-og-export-v89 .og-tags span{min-height:82px;border-radius:22px;background:rgba(255,255,255,.16);display:grid;place-items:center;font-size:30px;font-weight:950}.slice-og-export-v89.template-03,.slice-og-export-v89.template-09,.slice-og-export-v89.template-19{background:linear-gradient(135deg,#7c3aed,#db2777)}.slice-og-export-v89.template-18,.slice-og-export-v89.template-20{background:linear-gradient(135deg,#f97316,#ef4444)}.slice-og-export-v89.template-02,.slice-og-export-v89.template-07,.slice-og-export-v89.template-10{background:linear-gradient(135deg,#2563eb,#38bdf8)}
.slice-homepage-v89{min-height:100vh;padding:50px 18px;display:grid;place-items:center;background:radial-gradient(circle at 12% 12%,rgba(37,99,235,.12),transparent 30%),linear-gradient(180deg,#fbfdff,#f7faff)}.slice-public-buttons-v89{margin-top:16px;display:flex;gap:10px;justify-content:center}.slice-public-buttons-v89 a{min-height:44px;padding:0 18px;border-radius:14px;background:#2563eb;color:#fff;text-decoration:none;font-weight:950}
@media(max-width:1120px){.slice-editor-grid-v89{grid-template-columns:1fr}.slice-workspace-v89{position:relative;top:auto}.template-grid-v89{grid-template-columns:repeat(3,1fr)}}@media(max-width:720px){.template-grid-v89{grid-template-columns:repeat(2,1fr)}.slice-public-preview-v89{transform:scale(.72);margin:-60px}.preview-stage-v89{min-height:420px}.slice-editor-head-v89 h1{font-size:42px}}


/* v90 hard repair: template buttons, mobile homepage, no broken OG overflow */
.slice90-stage{min-height:calc(100vh - 74px);padding:42px 0 90px;background:radial-gradient(circle at 10% 8%,rgba(37,99,235,.12),transparent 30%),radial-gradient(circle at 92% 12%,rgba(139,92,246,.10),transparent 28%),linear-gradient(180deg,#fbfdff 0%,#f7faff 100%)}
.slice90-head{text-align:center;margin-bottom:26px}.slice90-head span{min-height:32px;padding:0 14px;border-radius:999px;display:inline-flex;align-items:center;background:#eef4ff;border:1px solid #dbeafe;color:#2563eb;font-size:12px;font-weight:950}.slice90-head h1{margin:16px 0 0;color:#111827;font-size:clamp(42px,6vw,72px);line-height:.98;letter-spacing:-.09em;font-weight:950}.slice90-head p{margin:14px auto 0;color:#64748b;line-height:1.7}
.slice90-layout{display:grid;grid-template-columns:390px minmax(0,1fr);gap:22px;align-items:start}.slice90-panel,.slice90-workspace{border-radius:30px;background:rgba(255,255,255,.96);border:1px solid rgba(15,23,42,.08);box-shadow:0 26px 90px rgba(15,23,42,.10)}.slice90-panel{overflow:hidden}.slice90-title{padding:24px}.slice90-title span{min-height:30px;padding:0 12px;border-radius:999px;display:inline-flex;align-items:center;background:#eef4ff;border:1px solid #dbeafe;color:#2563eb;font-size:12px;font-weight:900}.slice90-title h2{margin:16px 0 0;color:#111827;font-size:30px;letter-spacing:-.07em;font-weight:950}.slice90-title p{margin:10px 0 0;color:#64748b;line-height:1.65}
.slice90-tabs{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:0 14px 14px}.slice90-tabs button,.slice90-preview-tabs button{min-height:42px;border:1px solid #dbe4f0;border-radius:14px;background:#f8fbff;color:#334155;font-weight:900;cursor:pointer}.slice90-tabs button.active,.slice90-preview-tabs button.active{background:#2563eb;color:#fff;border-color:#2563eb}
.slice90-pane{display:none;padding:18px 18px 22px;border-top:1px solid #e2e8f0}.slice90-pane.active{display:block}.slice90-pane label{display:grid;gap:7px;margin-top:12px;color:#334155;font-size:13px;font-weight:850}.slice90-pane input,.slice90-pane select,.slice90-pane textarea{width:100%;min-height:45px;border:1px solid #dbe4f0;border-radius:15px;background:#f8fbff;color:#111827;padding:0 13px;outline:none}.slice90-pane textarea{min-height:90px;padding:12px 13px;resize:vertical}.slice90-two{display:grid;grid-template-columns:1fr 1fr;gap:10px}.slice90-checks{display:grid;grid-template-columns:1fr 1fr;gap:9px}.slice90-checks label,.slice90-free{min-height:42px;padding:0 12px;border:1px solid #dbe4f0;border-radius:13px;background:#f8fbff;display:flex!important;align-items:center;gap:8px}.slice90-checks input{width:auto;min-height:auto}.slice90-colors,.slice90-color-box{margin-top:18px;padding:14px;border-radius:18px;background:#f8fbff;border:1px solid #dbe4f0}.slice90-colors{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.slice90-colors h3,.slice90-color-box h3,.slice90-pane h3{grid-column:1/-1;margin:0 0 10px;color:#111827;font-size:14px;font-weight:950}.slice90-colors label{margin:0}.slice90-color-box label{grid-template-columns:1fr 58px;align-items:center}.slice90-colors input[type=color],.slice90-color-box input[type=color]{height:42px;padding:4px}.font-edit-v90{margin-top:12px;padding:14px;border-radius:18px;background:#f8fbff;border:1px solid #dbe4f0}.font90-head{display:flex;justify-content:space-between;color:#111827;font-weight:950}.font90-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px}.font-edit-v90 input[type=range]{min-height:32px;padding:0}
.slice90-image-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:14px}.slice90-image-actions button{min-height:42px;border:1px solid #dbe4f0;border-radius:14px;background:#f8fbff;color:#2563eb;font-weight:900}.slice90-image-actions button:last-child{grid-column:1/-1;color:#dc2626;background:#fff5f5;border-color:#fecaca}
.slice90-actions{padding:16px 18px 20px;border-top:1px solid #e2e8f0;display:grid;grid-template-columns:1fr 1fr;gap:10px}.slice90-actions button,.slice90-actions a{min-height:46px;border:0;border-radius:15px;background:#2563eb;color:#fff;font-weight:950;display:flex;align-items:center;justify-content:center;text-decoration:none}.slice90-actions button:first-child,.slice90-actions a{background:#eef4ff;color:#2563eb;border:1px solid #dbeafe}.slice90-actions #scResult{grid-column:1/-1;padding:13px 14px;border-radius:15px;background:#f8fbff;border:1px solid #dbe4f0;color:#64748b;font-size:13px;word-break:break-all}
.slice90-workspace{padding:22px;position:sticky;top:86px}.slice90-template-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;max-height:190px;overflow:auto;padding-right:4px}.slice90-template-btn{min-height:76px;text-align:left;padding:12px;border-radius:15px;border:1px solid #dbe4f0;background:#fff;color:#111827;position:relative;overflow:hidden;cursor:pointer}.slice90-template-btn.active{border-color:#2563eb;box-shadow:0 0 0 2px rgba(37,99,235,.12)}.slice90-template-btn strong{display:block;font-size:12px;font-weight:950}.slice90-template-btn small{display:block;margin-top:6px;color:#64748b;font-weight:800}.slice90-template-btn i{position:absolute;right:-18px;bottom:-18px;width:60px;height:60px;border-radius:999px;background:#c7d7ff}.slice90-template-btn.dot-03 i,.slice90-template-btn.dot-09 i,.slice90-template-btn.dot-19 i{background:#d8c2f4}.slice90-template-btn.dot-08 i{background:#c8efd5}.slice90-template-btn.dot-18 i,.slice90-template-btn.dot-20 i{background:#ffdfb7}
.slice90-preview-tabs{margin-top:18px;display:flex;gap:8px}.slice90-preview-stage{margin-top:14px;min-height:720px;padding:28px;border-radius:28px;background:#fff;display:grid;place-items:center;overflow:auto;border:1px solid #e2e8f0}

/* mobile homepage preview */
.slice90-mobile-page,.slice90-public-phone{width:360px;min-height:720px;border-radius:24px;background:#151515;color:#fff;position:relative;overflow:hidden;box-shadow:0 26px 80px rgba(15,23,42,.22);font-family:Pretendard,system-ui,sans-serif}
.phone-photo{height:var(--profile-h,310px);background:#333;display:grid;place-items:center;font-size:58px;font-weight:950;color:#fff;overflow:hidden}.phone-photo img{width:100%;height:100%;object-fit:cover}.phone-panel{position:relative;margin:-86px 18px 0;padding:16px 16px 14px;border-radius:12px;background:rgba(0,0,0,var(--panel-alpha,.86));backdrop-filter:blur(8px);min-height:138px}.phone-logo{width:42px;height:42px;border-radius:999px;background:rgba(255,255,255,.16);display:grid;place-items:center;font-weight:950;position:absolute;left:16px;top:16px}.phone-logo.logo-gradient{background:linear-gradient(135deg,#2563eb,#8b5cf6)}.phone-logo.logo-outline{background:transparent;border:1px solid rgba(255,255,255,.35)}.phone-name{margin-left:56px;font-size:18px;font-weight:900;color:#fff}.phone-job{margin:5px 0 0 56px;font-size:12px;color:#cbd5e1}.phone-tags{margin-top:22px;display:grid;grid-template-columns:repeat(3,1fr);gap:7px}.phone-tags span{min-height:28px;border-radius:6px;background:rgba(255,255,255,.14);display:grid;place-items:center;font-size:11px;font-weight:850}.phone-info{margin-top:18px;background:#151515;border-top:1px solid rgba(255,255,255,.08)}.phone-row{min-height:56px;padding:0 18px;display:grid;grid-template-columns:86px minmax(0,1fr) 16px;align-items:center;border-bottom:1px solid rgba(255,255,255,.08);font-size:12px;color:#fff}.phone-row b{color:#9ca3af;font-size:11px}.phone-row span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:right}.phone-row i{color:#9ca3af;text-align:right}.phone-kakao{margin-top:10px;min-height:48px;padding:0 18px;display:flex;align-items:center;justify-content:space-between;background:#1a1a1a;color:#facc15;text-decoration:none;font-size:13px;font-weight:900}.shape-circle{border-radius:999px}.shape-round{border-radius:18px}.shape-square{border-radius:4px}
.style-glass{background:#f8fbff;color:#111827}.style-glass .phone-info{background:#fff}.style-glass .phone-row{color:#111827;border-color:#e2e8f0}.style-glass .phone-kakao{background:#fff7d6;color:#111827}.style-flat .phone-panel{background:var(--bg,#111)}.style-luxury .phone-panel{background:rgba(20,14,5,.88)}.template-02 .phone-panel,.template-17 .phone-panel,.template-20 .phone-panel{background:rgba(0,0,0,.82)}.template-03 .phone-kakao,.template-07 .phone-kakao{color:#60a5fa}.template-18 .phone-kakao{color:#fb923c}

/* OG card preview scaled correctly */
.slice90-og-card{width:640px;height:336px;border-radius:24px;background:linear-gradient(135deg,#071326,#0f172a);position:relative;overflow:hidden;color:#fff;box-shadow:0 24px 80px rgba(15,23,42,.18)}.slice90-og-card.capture{width:1200px;height:630px;border-radius:0;box-shadow:none}.ogp-photo{position:absolute;left:44px;top:54px;width:82px;height:82px;background:rgba(255,255,255,.16);display:grid;place-items:center;overflow:hidden;font-size:34px;font-weight:950}.capture .ogp-photo{left:82px;top:100px;width:154px;height:154px;font-size:64px}.ogp-photo img{width:100%;height:100%;object-fit:cover}.ogp-name{position:absolute;left:150px;top:64px;font-size:38px;font-weight:950;letter-spacing:-.07em}.capture .ogp-name{left:280px;top:120px;font-size:72px}.ogp-sub{position:absolute;left:150px;top:115px;font-size:17px;font-weight:850}.capture .ogp-sub{left:280px;top:216px;font-size:32px}.ogp-small{position:absolute;left:150px;top:145px;color:#cbd5e1;font-size:14px}.capture .ogp-small{left:280px;top:272px;font-size:26px}.ogp-tags{position:absolute;left:44px;right:44px;bottom:42px;display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.capture .ogp-tags{left:82px;right:82px;bottom:78px;gap:26px}.ogp-tags span{min-height:44px;border-radius:12px;background:rgba(255,255,255,.16);display:grid;place-items:center;font-size:16px;font-weight:950}.capture .ogp-tags span{min-height:82px;border-radius:22px;font-size:30px}.slice90-og-card.template-03,.slice90-og-card.template-09,.slice90-og-card.template-19{background:linear-gradient(135deg,#7c3aed,#db2777)}.slice90-og-card.template-18,.slice90-og-card.template-20{background:linear-gradient(135deg,#f97316,#ef4444)}.slice90-og-card.template-02,.slice90-og-card.template-07,.slice90-og-card.template-10{background:linear-gradient(135deg,#2563eb,#38bdf8)}

.free-draggable{cursor:move;touch-action:none;outline:1px dashed rgba(37,99,235,.45)}
.slice90-public-stage{min-height:100vh;padding:18px;display:grid;place-items:center;background:#0f0f0f}
@media(max-width:1120px){.slice90-layout{grid-template-columns:1fr}.slice90-workspace{position:relative;top:auto}.slice90-template-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:720px){.slice90-template-grid{grid-template-columns:repeat(2,1fr)}.slice90-preview-stage{min-height:640px}.slice90-head h1{font-size:42px}.slice90-mobile-page{transform:scale(.92);margin:-20px 0}.slice90-og-card{transform:scale(.78);margin:-42px 0}}


/* v91 interaction repairs */
.phone-row{
  text-decoration:none;
  color:inherit;
}
.phone-row:visited{color:inherit}
.phone-kakao{
  text-decoration:none;
}
.selected-drag{
  outline:2px solid rgba(37,99,235,.75)!important;
  outline-offset:2px;
}
.slice90-og-card [data-drag]{
  pointer-events:auto;
}
.slice90-preview-stage .slice90-og-card:not(.capture){
  transform-origin:center center;
}
.slice90-og-card.capture [data-drag],
.slice90-mobile-page [data-drag]{
  position:absolute;
}
.slice90-mobile-page .phone-panel[data-drag]{
  position:relative;
}
.slice90-mobile-page .phone-info[data-drag],
.slice90-mobile-page .phone-kakao[data-drag]{
  position:relative;
}
.phone-info{
  position:relative;
}
.phone-kakao{
  position:relative;
}
.slice90-og-card .ogp-photo img{
  display:block;
}


/* v92 anti-mangle layout guard */
.slice90-reset-layout{
  width:100%;
  min-height:42px;
  margin-top:10px;
  border:1px solid #dbe4f0;
  border-radius:14px;
  background:#fff;
  color:#2563eb;
  font-weight:900;
  cursor:pointer;
}

.slice90-mobile-page,
.slice90-public-phone{
  display:block;
}

.slice90-mobile-page .phone-photo,
.slice90-public-phone .phone-photo{
  width:100%;
  border-radius:0!important;
}

.slice90-mobile-page .phone-panel,
.slice90-public-phone .phone-panel{
  position:relative;
  margin:-86px 18px 0;
  min-height:138px;
  box-sizing:border-box;
}

.slice90-mobile-page .phone-info,
.slice90-public-phone .phone-info{
  position:relative;
  margin-top:18px;
  display:block;
}

.slice90-mobile-page .phone-kakao,
.slice90-public-phone .phone-kakao{
  position:relative;
  margin-top:10px;
}

.slice90-mobile-page [data-drag],
.slice90-og-card [data-drag]{
  transition:outline .12s ease;
}

.slice90-mobile-page:not(:has(.free-draggable)) [data-drag],
.slice90-og-card:not(:has(.free-draggable)) [data-drag]{
  outline:none!important;
}

/* When free layout is enabled, allow movement but keep blocks from destroying the page flow */
.free-draggable{
  cursor:move;
  touch-action:none;
  outline:1px dashed rgba(37,99,235,.55);
  outline-offset:2px;
}

.selected-drag{
  outline:2px solid rgba(37,99,235,.8)!important;
  outline-offset:3px;
}

/* keep public link rows stable */
.slice90-public-phone .phone-row{
  display:grid;
  grid-template-columns:86px minmax(0,1fr) 16px;
  align-items:center;
  text-decoration:none;
  color:inherit;
}
.slice90-public-phone .phone-row:visited{
  color:inherit;
}

/* prevent old saved transform from creating giant blank zones when free mode is off */
.slice90-public-phone .phone-panel[style=""],
.slice90-public-phone .phone-info[style=""],
.slice90-public-phone .phone-kakao[style=""]{
  transform:none!important;
}


/* v93 emergency fix: prevent mobile homepage preview from collapsing */
.slice90-mobile-page [data-drag] {
  position: relative !important;
}

.slice90-mobile-page .phone-photo[data-drag] {
  position: relative !important;
  transform: none;
  z-index: auto;
}

.slice90-mobile-page .phone-panel[data-drag] {
  position: relative !important;
  margin: -86px 18px 0 !important;
  transform: none;
  z-index: auto;
}

.slice90-mobile-page .phone-logo[data-drag] {
  position: absolute !important;
  left: 16px !important;
  top: 16px !important;
}

.slice90-mobile-page .phone-name[data-drag],
.slice90-mobile-page .phone-job[data-drag],
.slice90-mobile-page .phone-tags[data-drag] {
  position: relative !important;
}

.slice90-mobile-page .phone-info[data-drag] {
  position: relative !important;
  margin-top: 18px !important;
  transform: none;
  z-index: auto;
}

.slice90-mobile-page .phone-kakao[data-drag] {
  position: relative !important;
  margin-top: 10px !important;
  transform: none;
  z-index: auto;
}

/* Only show draggable outline when free mode class is actually active */
.slice90-mobile-page [data-drag]:not(.free-draggable) {
  outline: none !important;
}

/* When free layout is enabled, use transform only, not absolute layout destruction */
.slice90-mobile-page .free-draggable {
  position: relative !important;
}

.slice90-mobile-page .phone-logo.free-draggable {
  position: absolute !important;
}

/* Keep the default phone layout stable */
.slice90-mobile-page .phone-photo {
  display: grid !important;
  place-items: center !important;
  height: var(--profile-h, 310px) !important;
  overflow: hidden !important;
}

.slice90-mobile-page .phone-photo img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}

.slice90-mobile-page .phone-panel {
  box-sizing: border-box !important;
  min-height: 138px !important;
}

.slice90-mobile-page .phone-info {
  display: block !important;
}

.slice90-mobile-page .phone-row {
  display: grid !important;
  grid-template-columns: 86px minmax(0,1fr) 16px !important;
  align-items: center !important;
}

.slice90-mobile-page .phone-kakao {
  display: flex !important;
}


/* v94 fixes: uploaded logo image, OG font controls, clickable Kakao polish */
.phone-logo {
  overflow: hidden;
}

.phone-logo img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block;
}

.slice90-og-card .ogp-name,
.slice90-og-card .ogp-sub,
.slice90-og-card .ogp-small,
.slice90-og-card .ogp-tags span {
  line-height: 1.15;
}

.slice90-og-card .ogp-tags span {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.phone-kakao[href="#"] {
  cursor: default;
}

.phone-kakao[href^="http"] {
  cursor: pointer;
}


/* v95: separate homepage editor and Kakao preview editor */
.slice90-og-controls{
  margin-top:18px;
  padding:14px;
  border-radius:18px;
  background:#f8fbff;
  border:1px solid #dbe4f0;
}
.slice90-og-controls h3{
  margin:0 0 10px;
  color:#111827;
  font-size:14px;
  font-weight:950;
}
.slice90-og-controls input[type=range]{
  min-height:32px;
  padding:0;
}
.slice90-og-colors{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:10px;
  margin-top:12px;
}
.slice90-og-colors label{
  margin:0;
}
.slice90-og-colors input[type=color]{
  height:42px;
  padding:4px;
}

/* Make Kakao preview readable, not tiny */
.slice90-og-card:not(.capture){
  width:760px !important;
  height:399px !important;
  border-radius:26px !important;
}
.slice90-og-card:not(.capture) .ogp-photo{
  left:52px !important;
  top:62px !important;
}
.slice90-og-card:not(.capture) .ogp-name{
  left:250px !important;
  top:70px !important;
}
.slice90-og-card:not(.capture) .ogp-sub{
  left:250px !important;
  top:150px !important;
}
.slice90-og-card:not(.capture) .ogp-small{
  left:250px !important;
  top:198px !important;
}
.slice90-og-card:not(.capture) .ogp-tags{
  left:52px !important;
  right:52px !important;
  bottom:50px !important;
}

/* Capture mode uses 1200x630 with same proportions */
.slice90-og-card.capture{
  width:1200px !important;
  height:630px !important;
}
.slice90-og-card.capture .ogp-photo{
  left:82px !important;
  top:98px !important;
}
.slice90-og-card.capture .ogp-name{
  left:395px !important;
  top:110px !important;
}
.slice90-og-card.capture .ogp-sub{
  left:395px !important;
  top:237px !important;
}
.slice90-og-card.capture .ogp-small{
  left:395px !important;
  top:313px !important;
}
.slice90-og-card.capture .ogp-tags{
  left:82px !important;
  right:82px !important;
  bottom:78px !important;
}

/* Homepage drag and OG drag are separate */
.slice90-mobile-page [data-drag^="page_"]:not(.free-draggable){
  outline:none !important;
}
.slice90-og-card [data-drag^="og_"]:not(.free-draggable){
  outline:none !important;
}
.slice90-og-card .free-draggable{
  cursor:move;
  touch-action:none;
  outline:1px dashed rgba(255,255,255,.75);
  outline-offset:3px;
}
.slice90-og-card .selected-drag{
  outline:2px solid rgba(255,255,255,.95)!important;
  outline-offset:4px;
}

/* Prevent older v90 fixed font sizes from overriding controls */
.slice90-og-card .ogp-name,
.slice90-og-card .ogp-sub,
.slice90-og-card .ogp-small,
.slice90-og-card .ogp-tags span{
  line-height:1.12 !important;
}
.slice90-og-card .ogp-tags span{
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

/* Mobile responsiveness for bigger OG preview */
@media(max-width:900px){
  .slice90-og-card:not(.capture){
    transform:scale(.72);
    margin:-54px 0;
  }
}


/* v96: Kakao preview must fit without horizontal scroll */
.slice90-preview-stage {
  overflow: hidden !important;
}

/* Visible editor preview: compact 1200:630 ratio so the whole card is visible */
.slice90-og-card:not(.capture) {
  width: 620px !important;
  height: 326px !important;
  max-width: calc(100vw - 560px);
  border-radius: 24px !important;
  overflow: hidden !important;
}

/* Keep the saved image capture full size */
.slice90-og-card.capture {
  width: 1200px !important;
  height: 630px !important;
  transform: none !important;
  margin: 0 !important;
}

/* Bigger, clearer image in visible preview */
.slice90-og-card:not(.capture) .ogp-photo {
  left: 34px !important;
  top: 34px !important;
  width: 150px !important;
  height: 150px !important;
}

/* If user controls set a bigger inline size, don't allow it to break the visible card */
.slice90-og-card:not(.capture) .ogp-photo[style] {
  max-width: 190px !important;
  max-height: 190px !important;
}

/* Text positions fitted for the smaller visible card */
.slice90-og-card:not(.capture) .ogp-name {
  left: 210px !important;
  top: 42px !important;
  max-width: 370px !important;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.slice90-og-card:not(.capture) .ogp-sub {
  left: 210px !important;
  top: 122px !important;
  max-width: 370px !important;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.slice90-og-card:not(.capture) .ogp-small {
  left: 210px !important;
  top: 168px !important;
  max-width: 370px !important;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.slice90-og-card:not(.capture) .ogp-tags {
  left: 34px !important;
  right: 34px !important;
  bottom: 34px !important;
  gap: 12px !important;
}

.slice90-og-card:not(.capture) .ogp-tags span {
  min-height: 46px !important;
  border-radius: 12px !important;
  white-space: nowrap !important;
}

/* Capture mode remains high-res and uses full layout */
.slice90-og-card.capture .ogp-photo {
  left: 82px !important;
  top: 98px !important;
}

.slice90-og-card.capture .ogp-name {
  left: 395px !important;
  top: 110px !important;
}

.slice90-og-card.capture .ogp-sub {
  left: 395px !important;
  top: 237px !important;
}

.slice90-og-card.capture .ogp-small {
  left: 395px !important;
  top: 313px !important;
}

.slice90-og-card.capture .ogp-tags {
  left: 82px !important;
  right: 82px !important;
  bottom: 78px !important;
}

/* Make preview stage visually centered and no horizontal scrollbar */
.slice90-preview-stage:has(.slice90-og-card:not([style*="display: none"])) {
  justify-items: center !important;
}

/* smaller screens */
@media (max-width: 1250px) {
  .slice90-og-card:not(.capture) {
    width: 560px !important;
    height: 294px !important;
  }

  .slice90-og-card:not(.capture) .ogp-photo {
    width: 132px !important;
    height: 132px !important;
  }

  .slice90-og-card:not(.capture) .ogp-name,
  .slice90-og-card:not(.capture) .ogp-sub,
  .slice90-og-card:not(.capture) .ogp-small {
    left: 186px !important;
    max-width: 330px !important;
  }

  .slice90-og-card:not(.capture) .ogp-tags {
    left: 30px !important;
    right: 30px !important;
    bottom: 30px !important;
  }
}

@media (max-width: 900px) {
  .slice90-og-card:not(.capture) {
    width: 520px !important;
    height: 273px !important;
    transform-origin: center center;
  }
}


/* v97: Kakao thumbnail export must look large after Kakao shrinks it */
.slice90-og-card.export-zoom.capture {
  overflow: hidden !important;
}

/* Export mode scales the inside content up around the top-left card area.
   The editor preview remains unchanged. */
.slice90-og-card.export-zoom.capture .ogp-photo,
.slice90-og-card.export-zoom.capture .ogp-name,
.slice90-og-card.export-zoom.capture .ogp-sub,
.slice90-og-card.export-zoom.capture .ogp-small,
.slice90-og-card.export-zoom.capture .ogp-tags {
  transform-origin: left top !important;
}

/* Bigger default export layout for Kakao thumbnail readability */
.slice90-og-card.export-zoom.capture .ogp-photo {
  left: 54px !important;
  top: 54px !important;
  width: calc(210px * var(--og-export-zoom, 1.5)) !important;
  height: calc(210px * var(--og-export-zoom, 1.5)) !important;
  max-width: 330px !important;
  max-height: 330px !important;
}

.slice90-og-card.export-zoom.capture .ogp-name {
  left: calc(300px * var(--og-export-zoom, 1.5) / 1.5) !important;
  top: 58px !important;
  font-size: calc(var(--og-name-size, 88px) * var(--og-export-zoom, 1.5)) !important;
  max-width: 840px !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.slice90-og-card.export-zoom.capture .ogp-sub {
  left: calc(300px * var(--og-export-zoom, 1.5) / 1.5) !important;
  top: calc(160px * var(--og-export-zoom, 1.5) / 1.5) !important;
  font-size: calc(var(--og-sub-size, 34px) * var(--og-export-zoom, 1.5)) !important;
  max-width: 840px !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.slice90-og-card.export-zoom.capture .ogp-small {
  left: calc(300px * var(--og-export-zoom, 1.5) / 1.5) !important;
  top: calc(218px * var(--og-export-zoom, 1.5) / 1.5) !important;
  font-size: calc(var(--og-small-size, 28px) * var(--og-export-zoom, 1.5)) !important;
  max-width: 840px !important;
}

.slice90-og-card.export-zoom.capture .ogp-tags {
  left: 54px !important;
  right: 54px !important;
  bottom: 54px !important;
  gap: 22px !important;
}

.slice90-og-card.export-zoom.capture .ogp-tags span {
  min-height: calc(72px * var(--og-export-zoom, 1.5)) !important;
  max-height: 118px !important;
  font-size: calc(var(--og-tag-size, 32px) * var(--og-export-zoom, 1.5)) !important;
  border-radius: 18px !important;
}

/* Make JS-set sizes available to CSS export calc */
.slice90-og-card {
  --og-name-size: 88px;
  --og-sub-size: 34px;
  --og-small-size: 28px;
  --og-tag-size: 32px;
}


/* v102 CODEF coverage integration */
.coverage-primary-btn{width:100%;min-height:46px;border:0;border-radius:15px;background:#2563eb;color:#fff;font-weight:950;cursor:pointer}
.coverage-consent-v102{display:flex!important;align-items:center;gap:10px;padding:12px;border:1px solid #dbe4f0;border-radius:15px;background:#f8fbff}
.coverage-consent-v102 input{width:auto!important;min-height:auto!important}


/* v103 utility page hard reset */
.utility-stage-v103{
  min-height:calc(100vh - 74px);
  padding:64px 0 96px;
  background:
    radial-gradient(circle at 8% 10%, rgba(37,99,235,.10), transparent 30%),
    radial-gradient(circle at 92% 12%, rgba(139,92,246,.10), transparent 28%),
    linear-gradient(180deg,#fbfdff 0%,#f7faff 100%);
}

.utility-head-v103{
  text-align:center;
  margin-bottom:34px;
}

.utility-head-v103 span{
  min-height:32px;
  padding:0 14px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  background:#eef4ff;
  border:1px solid #dbeafe;
  color:#2563eb;
  font-size:12px;
  font-weight:950;
}

.utility-head-v103 h1{
  margin:16px 0 0;
  color:#111827;
  font-size:clamp(42px,6vw,72px);
  line-height:.98;
  letter-spacing:-.09em;
  font-weight:950;
}

.utility-head-v103 p{
  margin:14px auto 0;
  color:#64748b;
  line-height:1.7;
  word-break:keep-all;
}

.utility-grid-v103{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:20px;
  max-width:1080px;
  margin:0 auto;
}

.tool-card-v103{
  min-height:300px;
  padding:28px;
  border-radius:28px;
  background:rgba(255,255,255,.96);
  border:1px solid rgba(15,23,42,.08);
  box-shadow:0 26px 90px rgba(15,23,42,.08);
  display:flex;
  flex-direction:column;
  align-items:flex-start;
}

.tool-card-v103.coverage{
  background:
    radial-gradient(circle at 100% 0%, rgba(22,163,74,.16), transparent 36%),
    rgba(255,255,255,.96);
}

.tool-card-v103.slice{
  background:
    radial-gradient(circle at 100% 0%, rgba(139,92,246,.16), transparent 36%),
    rgba(255,255,255,.96);
}

.tool-card-v103.disabled{
  opacity:.58;
}

.tool-icon-v103{
  width:54px;
  height:54px;
  border-radius:18px;
  display:grid;
  place-items:center;
  background:#eef4ff;
  border:1px solid #dbeafe;
  color:#2563eb;
  font-size:18px;
  font-weight:950;
}

.tool-card-v103.coverage .tool-icon-v103{
  background:#ecfdf5;
  border-color:#bbf7d0;
  color:#16a34a;
}

.tool-card-v103.slice .tool-icon-v103{
  background:#f3e8ff;
  border-color:#e9d5ff;
  color:#7c3aed;
}

.tool-card-v103 h3{
  margin:28px 0 0;
  color:#111827;
  font-size:28px;
  line-height:1.15;
  letter-spacing:-.07em;
  font-weight:950;
}

.tool-card-v103 p{
  margin:16px 0 0;
  color:#64748b;
  font-size:15px;
  line-height:1.75;
  word-break:keep-all;
}

.tool-card-v103 a,
.tool-card-v103 button{
  margin-top:auto;
  min-height:46px;
  padding:0 18px;
  border:0;
  border-radius:14px;
  background:#2563eb;
  color:#fff;
  font-size:14px;
  font-weight:950;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  cursor:pointer;
}

.tool-card-v103.coverage a{
  background:#16a34a;
}

.tool-card-v103.slice a{
  background:#7c3aed;
}

.tool-card-v103 button{
  background:#fff;
  color:#64748b;
  border:1px solid #dbe4f0;
}

@media(max-width:1000px){
  .utility-grid-v103{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

@media(max-width:640px){
  .utility-stage-v103{
    padding:42px 0 70px;
  }
  .utility-grid-v103{
    grid-template-columns:1fr;
  }
  .tool-card-v103{
    min-height:260px;
  }
}


/* v104 coverage analysis UI hard reset */
.coverage-stage-v104{
  min-height:calc(100vh - 74px);
  padding:52px 0 96px;
  background:
    radial-gradient(circle at 7% 8%, rgba(37,99,235,.10), transparent 31%),
    radial-gradient(circle at 92% 12%, rgba(139,92,246,.10), transparent 30%),
    linear-gradient(180deg,#fbfdff 0%,#f7faff 100%);
}

.coverage-hero-v104{
  text-align:center;
  margin-bottom:30px;
}

.coverage-hero-v104 span{
  min-height:32px;
  padding:0 14px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  background:#eef4ff;
  border:1px solid #dbeafe;
  color:#2563eb;
  font-size:12px;
  font-weight:950;
}

.coverage-hero-v104 h1{
  margin:16px 0 0;
  color:#111827;
  font-size:clamp(42px,6vw,72px);
  line-height:.98;
  letter-spacing:-.09em;
  font-weight:950;
}

.coverage-hero-v104 p{
  margin:14px auto 0;
  max-width:860px;
  color:#64748b;
  line-height:1.7;
  word-break:keep-all;
}

.coverage-shell-v104{
  display:grid;
  grid-template-columns:390px minmax(0,1fr);
  gap:22px;
  align-items:start;
}

.coverage-side-v104{
  display:grid;
  gap:16px;
}

.coverage-card-v104,
.coverage-main-v104{
  border-radius:28px;
  background:rgba(255,255,255,.96);
  border:1px solid rgba(15,23,42,.08);
  box-shadow:0 26px 90px rgba(15,23,42,.08);
}

.coverage-card-v104{
  padding:22px;
}

.coverage-card-title-v104{
  display:flex;
  align-items:flex-start;
  gap:12px;
  margin-bottom:16px;
}

.coverage-card-title-v104>span{
  width:34px;
  height:34px;
  border-radius:12px;
  display:grid;
  place-items:center;
  flex:none;
  background:#eef4ff;
  color:#2563eb;
  font-size:13px;
  font-weight:950;
}

.coverage-card-title-v104 h2{
  margin:0;
  color:#111827;
  font-size:23px;
  line-height:1.2;
  letter-spacing:-.06em;
  font-weight:950;
}

.coverage-card-title-v104 p{
  margin:6px 0 0;
  color:#64748b;
  font-size:13px;
  line-height:1.55;
}

.coverage-form-grid-v104{
  display:grid;
  gap:10px;
}

.coverage-form-grid-v104 label,
.coverage-full-label-v104{
  display:grid;
  gap:7px;
  margin-top:10px;
  color:#334155;
  font-size:13px;
  font-weight:850;
}

.coverage-form-grid-v104 input,
.coverage-form-grid-v104 select,
.coverage-full-label-v104 input,
.coverage-add-box-v104 input,
.coverage-add-box-v104 select{
  width:100%;
  min-height:45px;
  border:1px solid #dbe4f0;
  border-radius:15px;
  background:#f8fbff;
  color:#111827;
  padding:0 13px;
  outline:none;
  font-size:14px;
  box-sizing:border-box;
}

.coverage-consent-v104{
  min-height:46px;
  margin:14px 0 0;
  padding:0 13px;
  border:1px solid #dbe4f0;
  border-radius:15px;
  background:#f8fbff;
  display:flex;
  align-items:center;
  gap:10px;
  color:#334155;
  font-size:13px;
  font-weight:850;
}

.coverage-consent-v104 input{
  width:16px;
  height:16px;
  flex:none;
}

.coverage-btn-v104,
.coverage-add-box-v104 button,
.coverage-action-grid-v104 button{
  min-height:46px;
  border:0;
  border-radius:15px;
  font-size:14px;
  font-weight:950;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
}

.coverage-btn-v104.primary,
.coverage-add-box-v104 button{
  background:#2563eb;
  color:#fff;
}

.coverage-btn-v104.soft,
.coverage-action-grid-v104 button{
  background:#eef4ff;
  color:#2563eb;
  border:1px solid #dbeafe;
}

.coverage-two-buttons-v104{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin-top:12px;
}

.coverage-two-buttons-v104.raw{
  margin-top:14px;
}

.coverage-add-box-v104{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:9px;
  margin-top:12px;
}

.coverage-add-box-v104 input:nth-child(3),
.coverage-add-box-v104 button{
  grid-column:1/-1;
}

.coverage-action-grid-v104{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:9px;
  margin-top:12px;
}

.coverage-status-v104{
  margin-top:12px;
  padding:13px 14px;
  border-radius:15px;
  background:#f8fbff;
  border:1px solid #dbe4f0;
  color:#64748b;
  font-size:13px;
  line-height:1.5;
  word-break:break-all;
}

.coverage-main-v104{
  overflow:hidden;
  min-height:780px;
}

.coverage-tabs-v104{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  padding:16px;
  background:#fbfdff;
  border-bottom:1px solid #e2e8f0;
}

.coverage-tabs-v104 button{
  min-height:42px;
  padding:0 16px;
  border:1px solid #dbe4f0;
  border-radius:14px;
  background:#fff;
  color:#334155;
  font-size:14px;
  font-weight:950;
  cursor:pointer;
}

.coverage-tabs-v104 button.active{
  background:#2563eb;
  color:#fff;
  border-color:#2563eb;
}

.coverage-pane-v104{
  display:none;
  padding:22px;
}

.coverage-pane-v104.active{
  display:block;
}

.coverage-score-v104{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
  margin-bottom:18px;
}

.coverage-score-v104 article{
  padding:18px;
  border-radius:20px;
  background:#f8fbff;
  border:1px solid #e2e8f0;
}

.coverage-score-v104 small{
  display:block;
  color:#94a3b8;
  font-size:12px;
  font-weight:950;
}

.coverage-score-v104 strong{
  display:block;
  margin-top:8px;
  color:#111827;
  font-size:25px;
  line-height:1;
  font-weight:950;
}

.coverage-summary-grid-v104{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}

.coverage-summary-card-v104{
  padding:18px;
  border-radius:20px;
  border:1px solid #e2e8f0;
  background:#fff;
}

.coverage-summary-card-v104>div{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}

.coverage-summary-card-v104 span{
  color:#111827;
  font-size:15px;
  font-weight:950;
}

.coverage-summary-card-v104 strong{
  min-height:28px;
  padding:0 10px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  font-size:12px;
  font-weight:950;
}

.coverage-summary-card-v104.ok strong{background:#ecfdf5;color:#16a34a}
.coverage-summary-card-v104.lack strong{background:#fff5f5;color:#dc2626}
.coverage-summary-card-v104.check strong{background:#fff7ed;color:#ea580c}

.coverage-summary-card-v104 p{
  margin:14px 0 0;
  color:#111827;
  font-size:24px;
  font-weight:950;
}

.coverage-summary-card-v104 small{
  display:block;
  margin-top:8px;
  color:#64748b;
  line-height:1.5;
}

.coverage-table-wrap-v104{
  overflow:auto;
  border:1px solid #e2e8f0;
  border-radius:22px;
  background:#fff;
}

.coverage-table-v104{
  width:100%;
  min-width:860px;
  border-collapse:collapse;
  background:#fff;
}

.coverage-table-v104 th,
.coverage-table-v104 td{
  padding:13px 14px;
  border-bottom:1px solid #e2e8f0;
  text-align:left;
  color:#334155;
  font-size:14px;
  vertical-align:middle;
}

.coverage-table-v104 th{
  background:#f8fbff;
  color:#111827;
  font-weight:950;
}

.coverage-table-v104 .cat{
  min-height:28px;
  padding:0 10px;
  border-radius:999px;
  background:#eef4ff;
  color:#2563eb;
  display:inline-flex;
  align-items:center;
  font-size:12px;
  font-weight:950;
}

.coverage-table-v104 button{
  min-height:34px;
  padding:0 10px;
  border:1px solid #fecaca;
  border-radius:10px;
  background:#fff5f5;
  color:#dc2626;
  font-weight:850;
  cursor:pointer;
}

.coverage-report-v104{
  color:#334155;
}

.report-title-v104 span{
  min-height:30px;
  padding:0 12px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  background:#eef4ff;
  color:#2563eb;
  font-size:12px;
  font-weight:950;
}

.report-title-v104 h2{
  margin:14px 0 0;
  color:#111827;
  font-size:34px;
  letter-spacing:-.07em;
  font-weight:950;
}

.report-title-v104 p{
  color:#64748b;
  line-height:1.7;
}

.report-block-v104{
  margin-top:18px;
  padding:20px;
  border-radius:20px;
  background:#f8fbff;
  border:1px solid #e2e8f0;
}

.report-block-v104 h3{
  margin:0 0 12px;
  color:#111827;
  font-size:20px;
  font-weight:950;
}

.report-block-v104 ul{
  margin:0;
  padding-left:20px;
  line-height:1.8;
}

.report-block-v104 table{
  width:100%;
  border-collapse:collapse;
  background:#fff;
  border-radius:14px;
  overflow:hidden;
}

.report-block-v104 th,
.report-block-v104 td{
  padding:12px;
  border-bottom:1px solid #e2e8f0;
  text-align:left;
}

.coverage-raw-v104{
  width:100%;
  min-height:560px;
  padding:16px;
  border:1px solid #dbe4f0;
  border-radius:20px;
  background:#f8fbff;
  color:#111827;
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace;
  font-size:13px;
  line-height:1.55;
  box-sizing:border-box;
  outline:none;
  resize:vertical;
}

@media(max-width:1120px){
  .coverage-shell-v104{
    grid-template-columns:1fr;
  }
  .coverage-score-v104,
  .coverage-summary-grid-v104{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

@media(max-width:680px){
  .coverage-stage-v104{
    padding:38px 0 70px;
  }
  .coverage-hero-v104 h1{
    font-size:42px;
  }
  .coverage-score-v104,
  .coverage-summary-grid-v104,
  .coverage-two-buttons-v104,
  .coverage-add-box-v104,
  .coverage-action-grid-v104{
    grid-template-columns:1fr;
  }
  .coverage-add-box-v104 input:nth-child(3),
  .coverage-add-box-v104 button{
    grid-column:auto;
  }
}


/* v105 credit4u register flow */
.coverage-action-stack-v105{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin-top:12px;
}

.coverage-btn-v104.green{
  background:#ecfdf5;
  color:#16a34a;
  border-color:#bbf7d0;
}

.coverage-raw-request-v105{
  margin-top:12px;
  border:1px solid #dbe4f0;
  border-radius:16px;
  background:#f8fbff;
  overflow:hidden;
}

.coverage-raw-request-v105 summary{
  cursor:pointer;
  min-height:44px;
  display:flex;
  align-items:center;
  padding:0 14px;
  color:#334155;
  font-size:13px;
  font-weight:950;
}

.coverage-raw-request-v105 textarea{
  width:100%;
  min-height:150px;
  border:0;
  border-top:1px solid #dbe4f0;
  background:#fff;
  color:#111827;
  padding:13px;
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace;
  font-size:12px;
  line-height:1.5;
  box-sizing:border-box;
  outline:none;
  resize:vertical;
}

@media(max-width:680px){
  .coverage-action-stack-v105{
    grid-template-columns:1fr;
  }
}


/* v106 CODEF raw error debug */
.coverage-raw-request-tools-v106{
  display:grid;
  grid-template-columns:1fr 1fr 90px;
  gap:8px;
  padding:10px;
  border-top:1px solid #dbe4f0;
  background:#fff;
}

.coverage-raw-request-tools-v106 button{
  min-height:36px;
  border-radius:10px;
  border:1px solid #dbeafe;
  background:#eef4ff;
  color:#2563eb;
  font-size:12px;
  font-weight:900;
  cursor:pointer;
}

.coverage-raw-request-tools-v106 button:last-child{
  border-color:#fecaca;
  background:#fff5f5;
  color:#dc2626;
}

@media(max-width:680px){
  .coverage-raw-request-tools-v106{
    grid-template-columns:1fr;
  }
}


/* v107 identity field */
#customerIdentity{
  letter-spacing:.18em;
}


/* v108 birthDate CODEF format helper */
#customerBirth{
  letter-spacing:.08em;
}


/* v109 telecom field */
#customerTelecom{
  cursor:pointer;
}


/* v112 register-status optional notice */
.coverage-note-v112{
  margin:10px 0 0;
  padding:10px 12px;
  border-radius:13px;
  background:#fff7ed;
  border:1px solid #fed7aa;
  color:#9a3412;
  font-size:12px;
  font-weight:800;
  line-height:1.55;
}


/* v113 Connected ID minimal account/create */
.coverage-raw-request-v105 textarea#connectedRawJson{
  min-height:135px;
}


/* v114 restored SMS 2WAY UI */
.coverage-sms2way-v110{
  margin-top:12px;
  padding:14px;
  border-radius:18px;
  border:1px solid #93c5fd;
  background:linear-gradient(180deg,#eff6ff,#f8fbff);
  gap:10px;
}
.coverage-sms2way-v110 strong{display:block;color:#111827;font-size:15px;font-weight:950}
.coverage-sms2way-v110 p{margin:5px 0 0;color:#64748b;font-size:13px;line-height:1.55}
.coverage-sms2way-v110 input{
  width:100%;
  min-height:46px;
  border:1px solid #bfdbfe;
  border-radius:14px;
  background:#fff;
  padding:0 13px;
  font-size:18px;
  font-weight:900;
  letter-spacing:.12em;
  box-sizing:border-box;
}


/* v115 direct contract info query */
.coverage-btn-v104.green-main{
  background:#16a34a!important;
  color:#fff!important;
  border-color:#16a34a!important;
}
.coverage-raw-request-v105 textarea#directContractRawJson{
  min-height:150px;
}


/* v116 find ID */
.coverage-btn-v104.orange{
  background:#fff7ed;
  color:#ea580c;
  border-color:#fed7aa;
}
.coverage-raw-request-v105 textarea#findIdRawJson{
  min-height:130px;
}


/* v117 clean CODEF coverage flow */
.coverage-stage-v117{
  min-height:calc(100vh - 74px);
  padding:52px 0 96px;
  background:
    radial-gradient(circle at 7% 8%, rgba(37,99,235,.10), transparent 31%),
    radial-gradient(circle at 92% 12%, rgba(22,163,74,.10), transparent 30%),
    linear-gradient(180deg,#fbfdff 0%,#f7faff 100%);
}
.coverage-hero-v117{text-align:center;margin-bottom:30px}
.coverage-hero-v117 span{
  min-height:32px;padding:0 14px;border-radius:999px;display:inline-flex;align-items:center;
  background:#eef4ff;border:1px solid #dbeafe;color:#2563eb;font-size:12px;font-weight:950
}
.coverage-hero-v117 h1{
  margin:16px 0 0;color:#111827;font-size:clamp(42px,6vw,72px);
  line-height:.98;letter-spacing:-.09em;font-weight:950
}
.coverage-hero-v117 p{
  margin:14px auto 0;max-width:900px;color:#64748b;line-height:1.7;word-break:keep-all
}
.coverage-shell-v117{
  display:grid;grid-template-columns:410px minmax(0,1fr);gap:22px;align-items:start
}
.coverage-side-v117{display:grid;gap:16px}
.coverage-card-v117,.coverage-main-v117{
  border-radius:28px;background:rgba(255,255,255,.96);border:1px solid rgba(15,23,42,.08);
  box-shadow:0 26px 90px rgba(15,23,42,.08)
}
.coverage-card-v117{padding:22px}
.coverage-card-v117.main{
  background:radial-gradient(circle at 100% 0%,rgba(37,99,235,.12),transparent 34%),rgba(255,255,255,.96)
}
.coverage-card-title-v117{display:flex;align-items:flex-start;gap:12px;margin-bottom:16px}
.coverage-card-title-v117>span{
  width:34px;height:34px;border-radius:12px;display:grid;place-items:center;flex:none;
  background:#eef4ff;color:#2563eb;font-size:13px;font-weight:950
}
.coverage-card-title-v117 h2{
  margin:0;color:#111827;font-size:23px;line-height:1.2;letter-spacing:-.06em;font-weight:950
}
.coverage-card-title-v117 p{margin:6px 0 0;color:#64748b;font-size:13px;line-height:1.55}
.coverage-form-grid-v117{display:grid;gap:10px}
.coverage-form-grid-v117 label,.coverage-card-v117 label{
  display:grid;gap:7px;color:#334155;font-size:13px;font-weight:850
}
.coverage-form-grid-v117 input,.coverage-form-grid-v117 select,
.coverage-add-box-v117 input{
  width:100%;min-height:45px;border:1px solid #dbe4f0;border-radius:15px;
  background:#f8fbff;color:#111827;padding:0 13px;outline:none;font-size:14px;box-sizing:border-box
}
.coverage-consent-v117{
  min-height:46px;margin:14px 0 0;padding:0 13px;border:1px solid #dbe4f0;border-radius:15px;
  background:#f8fbff;display:flex!important;align-items:center;gap:10px;color:#334155;font-size:13px;font-weight:850
}
.coverage-consent-v117 input{width:16px;height:16px;flex:none}
.coverage-main-btn-v117{
  width:100%;min-height:50px;margin-top:13px;border:0;border-radius:16px;background:#2563eb;color:#fff;
  font-size:15px;font-weight:950;cursor:pointer;box-shadow:0 14px 30px rgba(37,99,235,.18)
}
.coverage-status-v117{
  margin-top:12px;padding:13px 14px;border-radius:15px;background:#f8fbff;border:1px solid #dbe4f0;
  color:#64748b;font-size:13px;line-height:1.55;word-break:break-word;white-space:pre-wrap
}
.coverage-raw-request-v117{
  margin-top:12px;border:1px solid #dbe4f0;border-radius:16px;background:#f8fbff;overflow:hidden
}
.coverage-raw-request-v117 summary{
  cursor:pointer;min-height:44px;display:flex;align-items:center;padding:0 14px;
  color:#334155;font-size:13px;font-weight:950
}
.coverage-raw-tools-v117{
  display:grid;grid-template-columns:1fr 90px;gap:8px;padding:10px;border-top:1px solid #dbe4f0;background:#fff
}
.coverage-raw-tools-v117 button{
  min-height:36px;border-radius:10px;border:1px solid #dbeafe;background:#eef4ff;color:#2563eb;
  font-size:12px;font-weight:900;cursor:pointer
}
.coverage-raw-tools-v117 button:last-child{
  border-color:#fecaca;background:#fff5f5;color:#dc2626
}
.coverage-raw-request-v117 textarea{
  width:100%;min-height:135px;border:0;border-top:1px solid #dbe4f0;background:#fff;color:#111827;
  padding:13px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;line-height:1.5;
  box-sizing:border-box;outline:none;resize:vertical
}
.coverage-sub-actions-v117{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:4px
}
.coverage-sub-actions-v117 button,.coverage-action-grid-v117 button,.coverage-add-box-v117 button,.coverage-two-buttons-v117 button{
  min-height:44px;border:1px solid #dbeafe;border-radius:14px;background:#eef4ff;color:#2563eb;
  font-size:13px;font-weight:950;cursor:pointer
}
.coverage-sub-actions-v117 button:nth-child(2){
  border-color:#fed7aa;background:#fff7ed;color:#ea580c
}
.coverage-sms2way-v117{
  margin-top:12px;padding:14px;border-radius:18px;border:1px solid #93c5fd;
  background:linear-gradient(180deg,#eff6ff,#f8fbff);gap:10px
}
.coverage-sms2way-v117 strong{display:block;color:#111827;font-size:15px;font-weight:950}
.coverage-sms2way-v117 p{margin:5px 0 0;color:#64748b;font-size:13px;line-height:1.55}
.coverage-sms2way-v117 input{
  width:100%;min-height:46px;border:1px solid #bfdbfe;border-radius:14px;background:#fff;
  padding:0 13px;font-size:18px;font-weight:900;letter-spacing:.12em;box-sizing:border-box
}
.coverage-sms2way-v117 button{
  min-height:44px;border:0;border-radius:14px;background:#2563eb;color:#fff;font-size:13px;font-weight:950;cursor:pointer
}
.coverage-warning-v117{
  margin-top:12px;padding:13px;border-radius:16px;background:#fff7ed;border:1px solid #fed7aa;color:#9a3412
}
.coverage-warning-v117 strong{display:block;font-size:13px;font-weight:950;margin-bottom:6px}
.coverage-warning-v117 p{margin:4px 0 0;font-size:12px;line-height:1.55}
.coverage-add-box-v117{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-top:12px}
.coverage-add-box-v117 input:nth-child(3),.coverage-add-box-v117 button{grid-column:1/-1}
.coverage-add-box-v117 button{background:#2563eb;color:#fff;border-color:#2563eb}
.coverage-action-grid-v117{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-top:12px}
.coverage-main-v117{overflow:hidden;min-height:780px}
.coverage-tabs-v117{
  display:flex;flex-wrap:wrap;gap:8px;padding:16px;background:#fbfdff;border-bottom:1px solid #e2e8f0
}
.coverage-tabs-v117 button{
  min-height:42px;padding:0 16px;border:1px solid #dbe4f0;border-radius:14px;background:#fff;color:#334155;
  font-size:14px;font-weight:950;cursor:pointer
}
.coverage-tabs-v117 button.active{background:#2563eb;color:#fff;border-color:#2563eb}
.coverage-pane-v117{display:none;padding:22px}
.coverage-pane-v117.active{display:block}
.coverage-score-v117{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:18px}
.coverage-score-v117 article{padding:18px;border-radius:20px;background:#f8fbff;border:1px solid #e2e8f0}
.coverage-score-v117 small{display:block;color:#94a3b8;font-size:12px;font-weight:950}
.coverage-score-v117 strong{display:block;margin-top:8px;color:#111827;font-size:25px;line-height:1;font-weight:950}
.coverage-summary-grid-v117{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.coverage-summary-card-v117{padding:18px;border-radius:20px;border:1px solid #e2e8f0;background:#fff}
.coverage-summary-card-v117>div{display:flex;align-items:center;justify-content:space-between;gap:10px}
.coverage-summary-card-v117 span{color:#111827;font-size:15px;font-weight:950}
.coverage-summary-card-v117 strong{min-height:28px;padding:0 10px;border-radius:999px;display:inline-flex;align-items:center;font-size:12px;font-weight:950}
.coverage-summary-card-v117.ok strong{background:#ecfdf5;color:#16a34a}
.coverage-summary-card-v117.lack strong{background:#fff5f5;color:#dc2626}
.coverage-summary-card-v117.check strong{background:#fff7ed;color:#ea580c}
.coverage-summary-card-v117 p{margin:14px 0 0;color:#111827;font-size:24px;font-weight:950}
.coverage-summary-card-v117 small{display:block;margin-top:8px;color:#64748b;line-height:1.5}
.coverage-table-wrap-v117{overflow:auto;border:1px solid #e2e8f0;border-radius:22px;background:#fff}
.coverage-table-v117{width:100%;min-width:860px;border-collapse:collapse;background:#fff}
.coverage-table-v117 th,.coverage-table-v117 td{padding:13px 14px;border-bottom:1px solid #e2e8f0;text-align:left;color:#334155;font-size:14px;vertical-align:middle}
.coverage-table-v117 th{background:#f8fbff;color:#111827;font-weight:950}
.coverage-table-v117 .cat{min-height:28px;padding:0 10px;border-radius:999px;background:#eef4ff;color:#2563eb;display:inline-flex;align-items:center;font-size:12px;font-weight:950}
.coverage-table-v117 button{min-height:34px;padding:0 10px;border:1px solid #fecaca;border-radius:10px;background:#fff5f5;color:#dc2626;font-weight:850;cursor:pointer}
.report-title-v117 span{min-height:30px;padding:0 12px;border-radius:999px;display:inline-flex;align-items:center;background:#eef4ff;color:#2563eb;font-size:12px;font-weight:950}
.report-title-v117 h2{margin:14px 0 0;color:#111827;font-size:34px;letter-spacing:-.07em;font-weight:950}
.report-title-v117 p{color:#64748b;line-height:1.7}
.report-block-v117{margin-top:18px;padding:20px;border-radius:20px;background:#f8fbff;border:1px solid #e2e8f0}
.report-block-v117 h3{margin:0 0 12px;color:#111827;font-size:20px;font-weight:950}
.report-block-v117 ul{margin:0;padding-left:20px;line-height:1.8}
.report-block-v117 table{width:100%;border-collapse:collapse;background:#fff;border-radius:14px;overflow:hidden}
.report-block-v117 th,.report-block-v117 td{padding:12px;border-bottom:1px solid #e2e8f0;text-align:left}
.coverage-raw-v117{
  width:100%;min-height:560px;padding:16px;border:1px solid #dbe4f0;border-radius:20px;background:#f8fbff;color:#111827;
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px;line-height:1.55;box-sizing:border-box;outline:none;resize:vertical
}
.coverage-two-buttons-v117{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}
@media(max-width:1120px){
  .coverage-shell-v117{grid-template-columns:1fr}
  .coverage-score-v117,.coverage-summary-grid-v117{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:680px){
  .coverage-stage-v117{padding:38px 0 70px}
  .coverage-hero-v117 h1{font-size:42px}
  .coverage-score-v117,.coverage-summary-grid-v117,.coverage-sub-actions-v117,.coverage-add-box-v117,.coverage-action-grid-v117,.coverage-two-buttons-v117,.coverage-raw-tools-v117{grid-template-columns:1fr}
  .coverage-add-box-v117 input:nth-child(3),.coverage-add-box-v117 button{grid-column:auto}
}


/* v118 email field restored */
#customerEmail{
  text-transform:none;
}


/* v119 account recovery buttons */
.coverage-sub-actions-v117{
  grid-template-columns:1fr 1fr;
}
.coverage-sub-actions-v117 button:nth-child(3){
  border-color:#bbf7d0;
  background:#ecfdf5;
  color:#16a34a;
}
.coverage-sub-actions-v117 button:nth-child(4){
  border-color:#bfdbfe;
  background:#eff6ff;
  color:#2563eb;
}
.coverage-sub-actions-v117 button:nth-child(5){
  grid-column:1/-1;
  border-color:#fecaca;
  background:#fff5f5;
  color:#dc2626;
}
#credit4uNewPw{
  border-color:#bfdbfe;
}
@media(max-width:680px){
  .coverage-sub-actions-v117 button:nth-child(5){grid-column:auto}
}


/* v120 account parameter compatibility */
#accountToolRawJson{
  min-height:190px;
}


/* v121 password alias buttons */
.coverage-raw-tools-v117{
  grid-template-columns:1fr 1fr 90px;
}
@media(max-width:680px){
  .coverage-raw-tools-v117{grid-template-columns:1fr}
}


/* v122 raw CODEF tester */
.raw-tester-v122{
  border-color:#c4b5fd;
  background:#faf5ff;
}
.coverage-raw-call-v122{
  padding:10px;
  border-top:1px solid #ddd6fe;
  background:#fff;
}
.coverage-raw-call-v122 label{
  display:grid;
  gap:7px;
  color:#334155;
  font-size:13px;
  font-weight:900;
  margin-bottom:10px;
}
.coverage-raw-call-v122 select{
  min-height:42px;
  border:1px solid #ddd6fe;
  border-radius:12px;
  padding:0 12px;
  background:#fff;
  color:#111827;
  font-weight:800;
}
#rawTesterJson{
  min-height:220px;
}
.raw-tester-v122 .coverage-raw-tools-v117{
  grid-template-columns:1fr 1fr 1fr;
}
@media(max-width:680px){
  .raw-tester-v122 .coverage-raw-tools-v117{grid-template-columns:1fr}
}


/* v123 coverage converter + readable analysis UI */
.coverage-main-v117{min-height:760px;background:#fff;}
.coverage-score-v117 article{background:linear-gradient(180deg,#f8fbff,#fff);border-color:#dbeafe;box-shadow:0 10px 26px rgba(15,23,42,.04)}
.coverage-summary-grid-v117{grid-template-columns:repeat(3,minmax(0,1fr));align-items:stretch}
.coverage-summary-card-v117{min-height:118px;box-shadow:0 12px 28px rgba(15,23,42,.055)}
.coverage-summary-card-v117.ok{border-color:#bbf7d0;background:linear-gradient(180deg,#f0fdf4,#fff)}
.coverage-summary-card-v117.lack{border-color:#fecaca;background:linear-gradient(180deg,#fff5f5,#fff)}
.coverage-summary-card-v117.check{border-color:#fed7aa;background:linear-gradient(180deg,#fff7ed,#fff)}
.coverage-summary-card-v117.ok strong{background:#dcfce7;color:#15803d}
.coverage-summary-card-v117.lack strong{background:#fee2e2;color:#dc2626}
.coverage-summary-card-v117.check strong{background:#ffedd5;color:#ea580c}
.coverage-table-wrap-v117{max-height:620px;overflow:auto;box-shadow:inset 0 1px 0 rgba(255,255,255,.8)}
.coverage-table-v117{min-width:1050px}
.coverage-table-v117 th{position:sticky;top:0;z-index:1;background:#eef4ff}
.coverage-table-v117 td:nth-child(3){min-width:360px;line-height:1.45}
.coverage-table-v117 td:nth-child(5){font-weight:900;color:#111827;white-space:nowrap}
.report-block-v117{box-shadow:0 12px 30px rgba(15,23,42,.045)}
@media(max-width:920px){.coverage-summary-grid-v117{grid-template-columns:repeat(2,minmax(0,1fr));}}
@media(max-width:640px){.coverage-summary-grid-v117{grid-template-columns:1fr}.coverage-table-v117{min-width:900px}}


/* v124 focused insured person analysis + wider layout */
.coverage-stage-v117 .container{
  width:min(1560px, calc(100% - 32px));
  max-width:1560px;
}
.coverage-shell-v117{
  grid-template-columns:390px minmax(0, 1fr);
  gap:20px;
}
.coverage-main-v117{min-height:720px}
.coverage-card-v117{padding:18px}
.coverage-form-grid-v117 input,.coverage-form-grid-v117 select{min-height:41px}
.coverage-pane-v117{padding:18px 20px 24px}
.coverage-table-wrap-v117{max-height:none;overflow:auto}
.coverage-table-v117{min-width:1100px}
.coverage-table-v117 th,.coverage-table-v117 td{padding:10px 12px;font-size:13px}
.coverage-table-v117 td:nth-child(4),.coverage-table-v117 th:nth-child(4){min-width:360px}
.coverage-table-v117 td:nth-child(3),.coverage-table-v117 th:nth-child(3){min-width:280px}
.coverage-score-v117{grid-template-columns:repeat(4,minmax(0,1fr))}
.coverage-summary-grid-v117{grid-template-columns:repeat(4,minmax(0,1fr))}
.coverage-meta-grid-v124{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:10px;margin:0 0 16px}
.coverage-meta-grid-v124 article{padding:14px;border-radius:18px;border:1px solid #e2e8f0;background:#fff}
.coverage-meta-grid-v124 small{display:block;color:#94a3b8;font-size:11px;font-weight:950}
.coverage-meta-grid-v124 strong{display:block;margin-top:6px;color:#111827;font-size:18px;font-weight:950}
.coverage-bar-v124{height:7px;border-radius:999px;background:#e8eef8;overflow:hidden;margin-top:12px}
.coverage-bar-v124 i{display:block;height:100%;border-radius:999px;background:#2563eb}
.coverage-summary-card-v117{padding:16px}
.coverage-summary-card-v117 p{font-size:21px}
.coverage-export-btn-v124{margin-left:auto;min-height:42px;padding:0 14px;border:1px solid #bfdbfe!important;border-radius:14px!important;background:#eff6ff!important;color:#2563eb!important;font-weight:950!important}
.coverage-export-btn-v124 + .coverage-export-btn-v124{margin-left:0}
.renewal{display:inline-flex;align-items:center;min-height:26px;padding:0 9px;border-radius:999px;background:#fff7ed;color:#ea580c;font-size:12px;font-weight:950}
.report-kpi-v124{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin:18px 0}
.report-kpi-v124 article{padding:18px;border-radius:20px;background:#f8fbff;border:1px solid #e2e8f0}
.report-kpi-v124 b{display:block;color:#111827;font-size:26px;font-weight:950}
.report-kpi-v124 span{display:block;margin-top:6px;color:#64748b;font-size:13px;font-weight:850}
@media(max-width:1280px){
  .coverage-shell-v117{grid-template-columns:1fr}
  .coverage-summary-grid-v117{grid-template-columns:repeat(3,minmax(0,1fr))}
  .coverage-meta-grid-v124{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media(max-width:780px){
  .coverage-stage-v117 .container{width:min(100% - 20px, 1560px)}
  .coverage-summary-grid-v117,.coverage-score-v117,.coverage-meta-grid-v124,.report-kpi-v124{grid-template-columns:1fr 1fr}
}
@media print{
  body *{visibility:hidden!important}
  #reportBox, #reportBox *{visibility:visible!important}
  #reportBox{position:absolute;left:0;top:0;width:100%;padding:20px;background:white}
  .header,.coverage-side-v117,.coverage-tabs-v117{display:none!important}
  .coverage-main-v117{box-shadow:none!important;border:none!important}
}


/* v125 full report export */
.coverage-export-btn-v124{
  white-space:nowrap;
}
@media(max-width:900px){
  .coverage-tabs-v117{
    overflow-x:auto;
    flex-wrap:nowrap;
  }
  .coverage-export-btn-v124{
    flex:0 0 auto;
  }
}


/* v126 export buttons must not act like tabs */
.coverage-export-btn-v124.active{
  background:#eff6ff!important;
  color:#2563eb!important;
}
.coverage-tabs-v117 button[data-tab].active{
  background:#2563eb;
  color:#fff;
}


/* v127 exported files intentionally exclude CODEF raw data */


/* v130 stable report/export + less empty dashboard */
.coverage-hero-desc-v117:empty{display:none!important}
.coverage-main-v117{min-height:620px!important}
.coverage-pane-v117{padding:16px 18px 22px!important}
.coverage-score-v117{max-width:1120px;grid-template-columns:repeat(4,minmax(180px,1fr))!important}
.coverage-meta-grid-v124{max-width:1120px;grid-template-columns:repeat(6,minmax(140px,1fr))!important}
.coverage-summary-grid-v117{max-width:1120px;grid-template-columns:repeat(4,minmax(210px,1fr))!important;gap:12px!important}
.coverage-summary-card-v117{min-height:150px!important}
.report-block-v117 table td,.report-block-v117 table th{vertical-align:top}
.report-block-v117 li{margin-bottom:7px;line-height:1.75}
.report-title-v117 p{line-height:1.75}
@media(max-width:1100px){
  .coverage-score-v117,.coverage-summary-grid-v117{grid-template-columns:repeat(2,minmax(0,1fr))!important}
  .coverage-meta-grid-v124{grid-template-columns:repeat(3,minmax(0,1fr))!important}
}

/* v131 hotfix: monthlyMoney + guarded render/export */


/* v132 simplified CODEF lookup UI */
.coverage-hero-desc-v117:empty{display:none!important}

/* hide fields not needed for regular contract lookup */
label[for="customerBirth"],
label[for="identity"],
label[for="customerIdentity"],
label[for="customerPhone"],
label[for="telecom"],
label[for="customerEmail"],
label[for="newPassword"],
label[for="newPwd"],
#customerBirth,
#identity,
#customerIdentity,
#customerPhone,
#telecom,
#customerEmail,
#newPassword,
#newPwd,
#birthDate,
#phoneNo,
#email,
#telecomCode{
  display:none!important;
}

/* hide legacy CODEF test/registration buttons by text-ish layout classes and IDs */
#checkRegisterStatus,
#registerCredit4u,
#issueConnectedId,
#findCredit4uId,
#changeCredit4uPwd,
#renewalCredit4uPwd,
#connectedId,
label[for="connectedId"],
.sf-codef-test-v117,
.sf-connected-box-v117{
  display:none!important;
}

/* hide small raw request/manual boxes if old UI has them */
textarea[id*="manual"],
textarea[id*="json"],
input[id*="connected"],
button[data-action*="register"],
button[data-action*="status"],
button[data-action*="connected"],
button[data-action*="find"],
button[data-action*="pwd"]{
  display:none!important;
}

.sf-simple-notice-v132{
  margin:16px 0 18px;
  padding:14px;
  border:1px solid #bfdbfe;
  background:linear-gradient(135deg,#eff6ff,#f8fbff);
  border-radius:18px;
  display:flex;
  flex-direction:column;
  gap:6px;
  color:#334155;
  line-height:1.5;
}
.sf-simple-notice-v132 strong{
  color:#0f172a;
  font-size:14px;
}
.sf-simple-notice-v132 span{
  font-size:13px;
  color:#64748b;
}
.sf-simple-notice-v132 a{
  display:inline-flex;
  width:fit-content;
  margin-top:4px;
  padding:9px 12px;
  border-radius:12px;
  background:#2563eb;
  color:#fff!important;
  text-decoration:none!important;
  font-size:13px;
  font-weight:900;
}

/* make left lookup box cleaner */
.coverage-side-v117 input,
.coverage-side-v117 select{
  margin-bottom:14px;
}
.coverage-side-v117 button{
  border-radius:16px;
  font-weight:950;
}

/* central loading overlay */
.sf-loading-overlay-v132{
  position:fixed;
  inset:0;
  z-index:999999;
  background:rgba(15,23,42,.42);
  backdrop-filter:blur(9px);
  display:none;
  align-items:center;
  justify-content:center;
  padding:24px;
}
.sf-loading-overlay-v132.active{
  display:flex;
}
.sf-loading-lock-v132{
  overflow:hidden!important;
}
.sf-loading-card-v132{
  width:min(430px,92vw);
  border-radius:30px;
  border:1px solid rgba(255,255,255,.55);
  background:linear-gradient(145deg,rgba(255,255,255,.96),rgba(239,246,255,.94));
  box-shadow:0 34px 100px rgba(15,23,42,.28);
  padding:32px;
  text-align:center;
  color:#0f172a;
}
.sf-loading-logo-v132{
  width:62px;
  height:62px;
  margin:0 auto 16px;
  border-radius:22px;
  display:grid;
  place-items:center;
  color:#fff;
  font-weight:1000;
  letter-spacing:-.05em;
  background:linear-gradient(135deg,#2563eb,#0ea5e9);
  box-shadow:0 18px 34px rgba(37,99,235,.3);
}
.sf-loading-card-v132 h3{
  margin:0;
  font-size:24px;
  letter-spacing:-.05em;
}
.sf-loading-card-v132 p{
  margin:10px 0 20px;
  color:#64748b;
  line-height:1.6;
  font-size:14px;
}
.sf-loading-card-v132 small{
  display:block;
  margin-top:12px;
  color:#94a3b8;
  font-weight:800;
}
.sf-loading-bar-v132{
  height:12px;
  border-radius:999px;
  background:#dbeafe;
  overflow:hidden;
  position:relative;
}
.sf-loading-bar-v132 span{
  position:absolute;
  inset:0 auto 0 0;
  width:42%;
  border-radius:999px;
  background:linear-gradient(90deg,#2563eb,#60a5fa,#22c55e);
  animation:sf132LoadingMove 1.05s infinite ease-in-out;
}
@keyframes sf132LoadingMove{
  0%{transform:translateX(-110%)}
  100%{transform:translateX(260%)}
}


/* v134 safe cleanup - never hide big containers */
.coverage-hero-desc-v117{display:none!important}

/* hide exact known controls only */
#customerBirth,#birthDate,
#identity,#customerIdentity,#identityBack,
#customerPhone,#phoneNo,
#telecom,#telecomCode,
#customerEmail,#email,
#newPassword,#newPwd,
label[for="customerBirth"],label[for="birthDate"],
label[for="identity"],label[for="customerIdentity"],label[for="identityBack"],
label[for="customerPhone"],label[for="phoneNo"],
label[for="telecom"],label[for="telecomCode"],
label[for="customerEmail"],label[for="email"],
label[for="newPassword"],label[for="newPwd"]{
  display:none!important;
}

/* keep main page visible */
.coverage-shell-v117,
.coverage-side-v117,
.coverage-main-v117{
  display:revert-layer;
}


/* v135 restore original two-column coverage analyzer layout */
body.sf135-layout-restore .coverage-shell-v117{
  width:min(1480px, calc(100vw - 64px))!important;
  margin:36px auto!important;
  display:grid!important;
  grid-template-columns:380px minmax(0,1fr)!important;
  gap:22px!important;
  align-items:start!important;
}

body.sf135-layout-restore .coverage-side-v117{
  width:380px!important;
  max-width:380px!important;
  display:block!important;
  padding:22px!important;
  border-radius:24px!important;
  align-self:start!important;
}

body.sf135-layout-restore .coverage-main-v117{
  min-width:0!important;
  width:100%!important;
  display:block!important;
  border-radius:24px!important;
  overflow:hidden!important;
}

body.sf135-layout-restore .coverage-side-v117 input,
body.sf135-layout-restore .coverage-side-v117 select,
body.sf135-layout-restore .coverage-side-v117 textarea,
body.sf135-layout-restore .coverage-side-v117 button{
  width:100%!important;
  max-width:100%!important;
  box-sizing:border-box!important;
}

body.sf135-layout-restore .coverage-side-v117 label,
body.sf135-layout-restore .coverage-side-v117 .field-label,
body.sf135-layout-restore .coverage-side-v117 .coverage-label{
  display:block;
  margin:14px 0 7px!important;
}

body.sf135-layout-restore .sf-simple-notice-v132{
  width:100%!important;
  max-width:100%!important;
  margin:16px 0 20px!important;
}

body.sf135-layout-restore #telecom,
body.sf135-layout-restore #telecomCode,
body.sf135-layout-restore label[for="telecom"],
body.sf135-layout-restore label[for="telecomCode"]{
  display:none!important;
}

/* If old CSS made side card stretch, force it back */
body.sf135-layout-restore .coverage-side-v117 .sf-simple-notice-v132 a{
  width:fit-content!important;
}

/* Keep form compact */
body.sf135-layout-restore .coverage-side-v117 input{
  height:44px!important;
}
body.sf135-layout-restore .coverage-side-v117 button{
  min-height:48px!important;
}

/* responsive fallback */
@media(max-width:980px){
  body.sf135-layout-restore .coverage-shell-v117{
    width:min(94vw, 720px)!important;
    grid-template-columns:1fr!important;
  }
  body.sf135-layout-restore .coverage-side-v117{
    width:100%!important;
    max-width:none!important;
  }
}


/* v136: clean consent checkbox and remove helper boxes */
body.sf136-checkbox-clean .sf-simple-notice-v132,
body.sf136-checkbox-clean .sf-codef-helper,
body.sf136-checkbox-clean .sf-codef-test-v117,
body.sf136-checkbox-clean .sf-connected-box-v117{
  display:none!important;
}

body.sf136-checkbox-clean .coverage-side-v117 input[type="checkbox"],
body.sf136-checkbox-clean input.sf136-normal-checkbox{
  width:18px!important;
  min-width:18px!important;
  max-width:18px!important;
  height:18px!important;
  min-height:18px!important;
  max-height:18px!important;
  padding:0!important;
  margin:0 10px 0 0!important;
  display:inline-block!important;
  vertical-align:middle!important;
  flex:0 0 18px!important;
  box-sizing:border-box!important;
  appearance:auto!important;
  -webkit-appearance:checkbox!important;
}

body.sf136-checkbox-clean .sf136-consent-row{
  display:flex!important;
  align-items:center!important;
  gap:26px!important;
  min-height:48px!important;
  height:auto!important;
  padding:12px 14px!important;
  margin:16px 0 12px!important;
  border:1px solid #dbe7f6!important;
  border-radius:14px!important;
  background:#f8fbff!important;
  font-size:13px!important;
  font-weight:800!important;
  line-height:1.45!important;
  color:#26364d!important;
  white-space:normal!important;
}

body.sf136-checkbox-clean .sf136-consent-row input[type="checkbox"]{
  position:static!important;
}

body.sf136-checkbox-clean .coverage-side-v117 .sf136-consent-row{
  width:100%!important;
  max-width:100%!important;
  box-sizing:border-box!important;
}

/* prevent checkbox row text from overflowing outside left card */
body.sf136-checkbox-clean .sf136-consent-row *{
  max-width:100%!important;
}


/* v137 remove auxiliary panel and constrain result height */
[data-sf137-hidden],
[data-sf137-hidden="aux"],
[data-sf137-hidden="aux-item"],
[data-sf137-hidden="aux-control"]{
  display:none!important;
}

/* hard-hide common auxiliary/test classes if they exist */
.sf-codef-helper,
.sf-codef-test-v117,
.sf-connected-box-v117,
.coverage-helper-v117,
.coverage-extra-v117,
.codef-raw-call-v117{
  display:none!important;
}

/* right-side analysis should scroll inside, not stretch page endlessly */
body.sf137-aux-scroll .coverage-main-v117{
  height:calc(100vh - 150px)!important;
  min-height:640px!important;
  max-height:900px!important;
  display:flex!important;
  flex-direction:column!important;
  overflow:hidden!important;
}

body.sf137-aux-scroll .coverage-tabs-v117{
  flex:0 0 auto!important;
}

body.sf137-aux-scroll .coverage-pane-v117.sf137-scroll-pane{
  flex:1 1 auto!important;
  min-height:0!important;
  max-height:calc(100vh - 250px)!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  padding-right:18px!important;
  scrollbar-width:thin;
}

body.sf137-aux-scroll .coverage-pane-v117.sf137-scroll-pane::-webkit-scrollbar{
  width:10px;
}
body.sf137-aux-scroll .coverage-pane-v117.sf137-scroll-pane::-webkit-scrollbar-track{
  background:#eef4fb;
  border-radius:999px;
}
body.sf137-aux-scroll .coverage-pane-v117.sf137-scroll-pane::-webkit-scrollbar-thumb{
  background:#b7c7dc;
  border-radius:999px;
  border:2px solid #eef4fb;
}

/* compact loading copy */
.sf-loading-card-v132{
  padding:28px!important;
}
.sf-loading-card-v132 p{
  margin:8px 0 18px!important;
}
.sf-loading-card-v132 small{
  margin-top:10px!important;
}


/* v138 final cleanup */
[data-sf138-hidden]{
  display:none!important;
}

/* remove telecom/select residue in left lookup area */
body.sf138-final-clean .coverage-side-v117 select,
body.sf138-final-clean #telecom,
body.sf138-final-clean #telecomCode,
body.sf138-final-clean label[for="telecom"],
body.sf138-final-clean label[for="telecomCode"]{
  display:none!important;
}

/* clean signup button */
.sf138-signup-btn{
  display:flex!important;
  width:100%!important;
  min-height:46px!important;
  align-items:center!important;
  justify-content:center!important;
  margin:14px 0 18px!important;
  border-radius:15px!important;
  background:linear-gradient(135deg,#2563eb,#1d4ed8)!important;
  color:#fff!important;
  text-decoration:none!important;
  font-weight:950!important;
  font-size:14px!important;
  box-shadow:0 14px 30px rgba(37,99,235,.22)!important;
}

/* make the right result panel a little taller so bottom cards do not cut off */
body.sf138-final-clean .coverage-main-v117{
  height:calc(100vh - 105px)!important;
  min-height:720px!important;
  max-height:980px!important;
}

body.sf138-final-clean .coverage-pane-v117.sf137-scroll-pane,
body.sf138-final-clean .coverage-pane-v117.sf138-tall-pane{
  max-height:calc(100vh - 190px)!important;
  padding-bottom:34px!important;
}

/* more bottom room for the last row cards */
body.sf138-final-clean .coverage-summary-grid-v117{
  padding-bottom:34px!important;
}


/* v139 final residue cleanup */
[data-sf139-hidden]{
  display:none!important;
}

body.sf139-residue-clean .coverage-side-v117 select,
body.sf139-residue-clean #telecom,
body.sf139-residue-clean #telecomCode,
body.sf139-residue-clean label[for="telecom"],
body.sf139-residue-clean label[for="telecomCode"]{
  display:none!important;
}

/* direct text/json helper structures */
body.sf139-residue-clean details,
body.sf139-residue-clean textarea[id*="json"],
body.sf139-residue-clean textarea[name*="json"],
body.sf139-residue-clean textarea[placeholder*="ENCRYPTED"],
body.sf139-residue-clean textarea[placeholder*="비워두면"]{
  display:none!important;
}


/* v141 index additions - keep current v7 design */
.v7-tag.codef{
  color:#2563eb;
  background:#eff6ff;
  border-color:#bfdbfe;
}

/* Salesflo header logo final fix */
.header .logo,
.site-header .logo,
.logo {
  width: 176px !important;
  height: 44px !important;
  min-width: 176px !important;

  display: block !important;
  padding: 0 !important;
  margin: 0 !important;
  gap: 0 !important;

  background: transparent url('../img/salesflo-logo-header.png?v=10') left center / contain no-repeat !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  outline: 0 !important;
  overflow: visible !important;

  font-size: 0 !important;
  line-height: 0 !important;
}

/* 기존 SF / Sales utility 완전 제거 */
.header .logo .logo-mark,
.header .logo .logo-name,
.header .logo .logo-sub,
.site-header .logo .logo-mark,
.site-header .logo .logo-name,
.site-header .logo .logo-sub,
.logo .logo-mark,
.logo .logo-name,
.logo .logo-sub,
.logo > span,
.logo-mark,
.logo-mark::before {
  display: none !important;
  content: none !important;
}

/* hover 때 기존 튀는 효과 제거 */
.logo:hover {
  transform: none !important;
  box-shadow: none !important;
}

/* 모바일 */
@media (max-width: 760px) {
  .header .logo,
  .site-header .logo,
  .logo {
    width: 148px !important;
    height: 38px !important;
    min-width: 148px !important;
  }
}

/* login/signup email field restore */
.auth-card label[for="email"],
.auth-card input#email {
  display: block !important;
}

/* login/signup left 안내문 제거 */
.auth-copy > p {
  display: none !important;
}


body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 999998;
  background:
    radial-gradient(circle at 50% 38%, rgba(37, 99, 235, .20), transparent 30%),
    radial-gradient(circle at 58% 58%, rgba(14, 165, 233, .18), transparent 26%),
    radial-gradient(circle at 42% 68%, rgba(124, 58, 237, .12), transparent 28%),
    linear-gradient(135deg, rgba(248, 251, 255, .98) 0%, rgba(237, 244, 255, .98) 48%, rgba(255, 255, 255, .98) 100%);
  backdrop-filter: blur(14px) saturate(135%);
  -webkit-backdrop-filter: blur(14px) saturate(135%);
  animation:
    sfIntroBgMove 3s ease-in-out forwards,
    sfIntroFadeOut 3.35s ease forwards;
}

body::after {
  content: "영업 업무를 더 가볍고 유연하게";
  position: fixed;
  left: 50%;
  top: 50%;
  z-index: 999999;
  width: min(440px, calc(100vw - 44px));
  height: 238px;
  box-sizing: border-box;
  padding: 162px 22px 0;
  transform: translate(-50%, -50%);
  border: 1px solid rgba(180, 208, 255, .72);
  border-radius: 34px;
  background:
    url('../img/salesflo-logo-full-transparent.png?v=loader1') center 46px / min(310px, calc(100vw - 120px)) auto no-repeat,
    linear-gradient(90deg, #2563ff 0%, #00d5ff 45%, #7c3aed 100%) left 197px / 0% 8px no-repeat,
    linear-gradient(90deg, rgba(215, 227, 248, .95), rgba(232, 240, 252, .95)) left 197px / 100% 8px no-repeat,
    linear-gradient(145deg, rgba(255,255,255,.78), rgba(244,249,255,.60));
  box-shadow:
    0 34px 90px rgba(15, 23, 42, .16),
    0 0 80px rgba(37, 99, 235, .16),
    inset 0 1px 0 rgba(255, 255, 255, .88);
  color: #10213f;
  font-family: Pretendard, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: 17px;
  font-weight: 800;
  letter-spacing: -0.03em;
  text-align: center;
  text-shadow: 0 1px 0 rgba(255,255,255,.8);
  overflow: hidden;
  animation:
    sfIntroCardIn 3.35s ease forwards,
    sfIntroProgress 2.8s cubic-bezier(.22, .8, .22, 1) forwards;
}

@keyframes sfIntroBgMove {
  0% { filter: hue-rotate(0deg) brightness(1); }
  45% { filter: hue-rotate(8deg) brightness(1.03); }
  100% { filter: hue-rotate(0deg) brightness(1); }
}

@keyframes sfIntroProgress {
  0% {
    background-size:
      min(310px, calc(100vw - 120px)) auto,
      0% 8px,
      100% 8px,
      100% 100%;
  }
  78% {
    background-size:
      min(310px, calc(100vw - 120px)) auto,
      88% 8px,
      100% 8px,
      100% 100%;
  }
  100% {
    background-size:
      min(310px, calc(100vw - 120px)) auto,
      100% 8px,
      100% 8px,
      100% 100%;
  }


/* v142 open-ready additions */
.footer a { color: inherit; text-decoration: none; font-weight: 760; }
.footer a:hover { color: var(--blue, #2563eb); }
body.modal-open { overflow: hidden; }
.status-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 74px;
  padding: 6px 10px;
  border-radius: 999px;
  background: #eef4ff;
  color: #1d4ed8;
  font-size: 12px;
  font-weight: 850;
  white-space: nowrap;
}
.status-reviewing { background: #fff7ed; color: #c2410c; }
.status-contacted { background: #f0fdf4; color: #15803d; }
.status-payment_pending { background: #fefce8; color: #a16207; }
.status-active { background: #ecfdf5; color: #047857; }
.status-closed { background: #f2f4f7; color: #475467; }
.status-select {
  min-width: 120px;
  padding: 9px 10px;
  border: 1px solid #d0d5dd;
  border-radius: 12px;
  background: #fff;
  color: #344054;
  font-weight: 720;
}
.inline-status-form {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}
.inline-status-form .btn { min-height: 38px; padding: 8px 12px; font-size: 13px; }
.mypage-hero, .faq-hero, .legal-shell {
  padding: 76px 0 34px;
}
.mypage-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(280px, .85fr);
  gap: 28px;
  align-items: stretch;
}
.mypage-hero h1 {
  margin: 18px 0 12px;
  font-size: clamp(34px, 5vw, 62px);
  letter-spacing: -.07em;
  line-height: .98;
  color: var(--ink, #101828);
}
.mypage-hero p { max-width: 620px; color: var(--muted, #667085); font-size: 18px; line-height: 1.75; }
.mypage-summary-card, .mypage-panel, .faq-card, .faq-cta, .legal-card {
  border: 1px solid rgba(16,24,40,.08);
  border-radius: 28px;
  background: rgba(255,255,255,.86);
  box-shadow: 0 24px 70px rgba(16,24,40,.08);
}
.mypage-summary-card {
  padding: 30px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.mypage-summary-card span { color: #667085; font-weight: 760; }
.mypage-summary-card strong { margin-top: 10px; color: var(--blue, #2563eb); font-size: 34px; letter-spacing: -.06em; }
.mypage-summary-card p { font-size: 15px; }
.mypage-shell, .faq-shell { padding: 24px 0 72px; }
.mypage-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 22px;
  margin-bottom: 22px;
}
.mypage-panel { padding: 26px; }
.mypage-panel.full { margin-top: 22px; }
.mypage-panel h2, .faq-card h3, .faq-cta h3, .legal-card h1, .legal-card h2 {
  margin-top: 0;
  letter-spacing: -.045em;
  color: var(--ink, #101828);
}
.info-list { margin: 0; display: grid; gap: 12px; }
.info-list div {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  padding: 14px 0;
  border-bottom: 1px solid #eef2f6;
}
.info-list div:last-child { border-bottom: 0; }
.info-list dt { color: #667085; font-weight: 760; }
.info-list dd { margin: 0; color: #101828; font-weight: 820; text-align: right; }
.panel-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
}
.panel-title-row p { margin: 4px 0 0; color: #667085; }
.faq-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}
.faq-card { padding: 24px; }
.faq-card p, .faq-cta p, .legal-card p { color: #667085; line-height: 1.8; }
.faq-cta { margin-top: 22px; padding: 28px; text-align: center; }
.legal-card { padding: 34px; max-width: 920px; }
.legal-card h1 { font-size: clamp(32px, 5vw, 54px); }
.legal-card h2 { margin-top: 28px; }
.legal-note {
  padding: 16px;
  border-radius: 18px;
  background: #f7faff;
  border: 1px solid #e0eaff;
}
@media (max-width: 920px) {
  .mypage-hero-grid, .mypage-grid, .faq-grid { grid-template-columns: 1fr; }
  .panel-title-row { align-items: flex-start; flex-direction: column; }
}


/* v143 open cleanup: remove distracting homepage residue/glow and route download into utility card */
body.home-v7,
.home-v7 {
  background:#ffffff !important;
}
.home-v7 #snowCanvas,
.home-v7 .v7-main::before,
.home-v7 .v7-hero::before,
.home-v7 .v7-hero::after,
.home-v7 body::before,
.home-v7 body::after {
  display:none !important;
  content:none !important;
  animation:none !important;
}
body.home-v7::before,
body.home-v7::after {
  display:none !important;
  content:none !important;
  animation:none !important;
}
.home-v7 .v7-main {
  background:#ffffff !important;
  overflow:hidden;
}
.home-v7 .v7-hero,
.home-v7 .v7-section.soft {
  background:#ffffff !important;
}
.home-v7 .v7-section {
  background:#ffffff !important;
}
.home-v7 .v7-copy h1 {
  text-shadow:none !important;
}
#snowCanvas {
  display:none !important;
}
.tool-card-v103.kakao-send {
  background:linear-gradient(180deg,#fff7cc 0%,#ffffff 62%) !important;
  border-color:rgba(250,204,21,.45) !important;
  box-shadow:0 28px 90px rgba(202,138,4,.12) !important;
}
.tool-card-v103.kakao-send .tool-icon-v103 {
  background:#fee500 !important;
  border-color:#facc15 !important;
  color:#111827 !important;
}
.tool-card-v103.kakao-send a {
  background:#111827 !important;
  color:#fee500 !important;
}


/* v144 clean visual pass: remove lingering background residue and highlight kakao utility */
body::before,
body::after {
  content: none !important;
  display: none !important;
}

#snowCanvas {
  display: none !important;
}

.home-v7 {
  background: linear-gradient(180deg, #ffffff 0%, #f7f8fb 100%) !important;
}

.home-v7::before,
.home-v7::after,
.home-v7 .v7-main::before,
.home-v7 .v7-hero::before,
.home-v7 .v7-hero::after {
  content: none !important;
  display: none !important;
  background: none !important;
}

.tool-card-v103.kakao-send {
  border-color: rgba(37, 99, 235, .24) !important;
  box-shadow: 0 24px 70px rgba(37, 99, 235, .12) !important;
}

.tool-card-v103.kakao-send .tool-icon-v103 {
  background: linear-gradient(135deg, #2563eb, #60a5fa) !important;
  color: #fff !important;
}

.tool-card-v103.kakao-send a {
  background: linear-gradient(135deg, #2563eb, #1677ff) !important;
  color: #fff !important;
  border-color: transparent !important;
}


/* v145 header cleanup + home residue fix */
body.home-v7,
.home-v7,
body.home-v7 .page,
body.home-v7 .v7-main,
body.home-v7 .v7-hero,
body.home-v7 .v7-section,
body.home-v7 .v7-section.soft {
  background: #ffffff !important;
  background-image: none !important;
}

body.home-v7 *::before,
body.home-v7 *::after {
  box-shadow: none;
}

body.home-v7 .v7-main::before,
body.home-v7 .v7-main::after,
body.home-v7 .v7-hero::before,
body.home-v7 .v7-hero::after,
body.home-v7 .v7-section.soft::before,
body.home-v7 .v7-section.soft::after {
  content: none !important;
  display: none !important;
  background: none !important;
}

.nav-actions > a:not(.btn) {
  display: none !important;
}


/* v146 final cleanup: remove all homepage residue/glow and duplicate right header buttons */
html,
body,
.page {
  background: #ffffff !important;
  background-image: none !important;
}

#snowCanvas,
canvas#snowCanvas {
  display: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
}

body::before,
body::after,
.page::before,
.page::after,
.v7-main::before,
.v7-main::after,
.v7-hero::before,
.v7-hero::after,
.v7-section::before,
.v7-section::after,
.v7-section.soft::before,
.v7-section.soft::after,
.v9-page::before,
.v9-page::after,
.notice-stage::before,
.notice-stage::after,
.utility-stage-v103::before,
.utility-stage-v103::after {
  content: none !important;
  display: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
  background: none !important;
  background-image: none !important;
  box-shadow: none !important;
  filter: none !important;
  animation: none !important;
}

body.home-v7,
.home-v7,
.home-v7 .page,
.home-v7 .v7-main,
.home-v7 .v7-hero,
.home-v7 .v7-section,
.home-v7 .v7-section.soft,
.v7-section.soft {
  background: #ffffff !important;
  background-image: none !important;
}

.home-v7 .v7-section-title,
.home-v7 .v7-section-title h2,
.home-v7 .v7-section-title p {
  text-shadow: none !important;
  filter: none !important;
}

.header .nav-actions {
  display: none !important;
}

.tool-card-v103.kakao-send {
  position: relative;
  border-color: rgba(37, 99, 235, .24) !important;
  box-shadow: 0 24px 70px rgba(37, 99, 235, .10) !important;
}

.tool-card-v103.kakao-send .tool-icon-v103 {
  background: linear-gradient(135deg, #2563eb, #60a5fa) !important;
  color: #fff !important;
}

.tool-card-v103.kakao-send a {
  background: linear-gradient(135deg, #2563eb, #1677ff) !important;
  color: #fff !important;
  border-color: transparent !important;
}

.tool-paid-v103 {
  position: absolute;
  top: 22px;
  right: 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 46px;
  height: 28px;
  padding: 0 12px;
  border-radius: 999px;
  background: #eff6ff;
  color: #2563eb;
  border: 1px solid #bfdbfe;
  font-size: 13px;
  font-weight: 900;
}

/* v151 insurance calculators + portal */
.sf-clean-page,
.sf-clean-page body {
  background: #f7f9fd !important;
}

.sf-clean-page::before,
.sf-clean-page::after,
.sf-tool-page::before,
.sf-tool-page::after {
  content: none !important;
  display: none !important;
}

.sf-simple-header .nav-actions,
.utility-stage-v103 ~ .nav-actions {
  display: none !important;
}

.utility-grid-v103 {
  align-items: stretch;
}

.tool-card-v103 {
  position: relative;
  overflow: hidden;
}

.tool-paid-v103 {
  position: absolute;
  top: 20px;
  right: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 46px;
  height: 28px;
  padding: 0 12px;
  border-radius: 999px;
  background: #111827;
  color: #fee500;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: -.02em;
}

.tool-card-v103.portal-tool,
.tool-card-v103.calc-tool {
  background: rgba(255,255,255,.94) !important;
}

.tool-card-v103.portal-tool {
  border-color: rgba(124,58,237,.22) !important;
  box-shadow: 0 24px 70px rgba(124,58,237,.10) !important;
}

.tool-card-v103.portal-tool .tool-icon-v103 {
  background: linear-gradient(135deg, #7c3aed, #60a5fa) !important;
  color: #fff !important;
}

.tool-card-v103.silbi-tool .tool-icon-v103 {
  background: linear-gradient(135deg, #0ea5e9, #2563eb) !important;
  color: #fff !important;
}

.tool-card-v103.age-tool .tool-icon-v103 {
  background: linear-gradient(135deg, #10b981, #2563eb) !important;
  color: #fff !important;
}

.tool-card-v103.bmi-tool .tool-icon-v103 {
  background: linear-gradient(135deg, #f59e0b, #ef4444) !important;
  color: #fff !important;
}

.sf-tool-page {
  min-height: calc(100vh - 74px);
  background:
    radial-gradient(circle at 12% 0%, rgba(37,99,235,.08), transparent 30%),
    radial-gradient(circle at 88% 6%, rgba(124,58,237,.07), transparent 28%),
    linear-gradient(180deg, #fbfdff 0%, #f7f9fd 100%);
  padding-bottom: 70px;
}

.sf-tool-hero {
  padding: 70px 0 36px;
}

.sf-tool-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 330px;
  gap: 28px;
  align-items: end;
}

.sf-tool-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 34px;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(37,99,235,.08);
  color: #2563eb;
  font-weight: 900;
  font-size: 13px;
  margin-bottom: 18px;
}

.sf-tool-kicker::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: #2563eb;
  box-shadow: 0 0 0 5px rgba(37,99,235,.12);
}

.sf-tool-hero h1 {
  margin: 0;
  font-size: clamp(38px, 5vw, 64px);
  line-height: 1.02;
  letter-spacing: -.06em;
  color: #101828;
}

.sf-tool-hero p {
  margin: 18px 0 0;
  max-width: 680px;
  color: #667085;
  font-size: 18px;
  line-height: 1.75;
}

.sf-tool-summary-card,
.sf-panel {
  border: 1px solid rgba(15,23,42,.08);
  background: rgba(255,255,255,.88);
  box-shadow: 0 22px 70px rgba(15,23,42,.08);
  backdrop-filter: blur(16px);
}

.sf-tool-summary-card {
  border-radius: 28px;
  padding: 28px;
}

.sf-tool-summary-card span {
  display: block;
  color: #667085;
  font-size: 14px;
  font-weight: 900;
  margin-bottom: 10px;
}

.sf-tool-summary-card strong {
  display: block;
  color: #2563eb;
  font-size: 34px;
  letter-spacing: -.05em;
  line-height: 1.1;
}

.sf-tool-summary-card p {
  margin: 12px 0 0;
  font-size: 14px;
  line-height: 1.6;
}

.sf-tool-body {
  padding: 8px 0 0;
}

.sf-calc-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 380px;
  gap: 24px;
  align-items: start;
}

.sf-panel {
  border-radius: 30px;
  padding: 28px;
}

.sf-panel-head {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 24px;
}

.sf-panel-head > span {
  width: 44px;
  height: 44px;
  border-radius: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #edf4ff;
  color: #2563eb;
  font-weight: 900;
}

.sf-panel-head.compact > span {
  width: auto;
  padding: 0 14px;
  height: 34px;
  border-radius: 999px;
  font-size: 13px;
}

.sf-panel-head h2 {
  margin: 0;
  color: #101828;
  font-size: 24px;
  letter-spacing: -.04em;
}

.sf-panel-head p {
  margin: 5px 0 0;
  color: #667085;
  line-height: 1.5;
}

.sf-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.sf-form-grid.two {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.sf-field {
  display: block;
  position: relative;
}

.sf-field span {
  display: block;
  margin-bottom: 8px;
  color: #344054;
  font-size: 14px;
  font-weight: 900;
}

.sf-field input,
.sf-field select {
  width: 100%;
  height: 58px;
  border: 1px solid #d6e0ef;
  border-radius: 18px;
  background: #fff;
  color: #101828;
  font-size: 17px;
  font-weight: 800;
  padding: 0 54px 0 18px;
  outline: none;
}

.sf-field select {
  padding-right: 18px;
}

.sf-field em {
  position: absolute;
  right: 18px;
  bottom: 18px;
  color: #98a2b3;
  font-size: 14px;
  font-style: normal;
  font-weight: 800;
}

.sf-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

.sf-chip-row button {
  height: 40px;
  padding: 0 16px;
  border: 1px solid #dbe7f7;
  border-radius: 999px;
  background: #f6f9ff;
  color: #2563eb;
  font-weight: 900;
  cursor: pointer;
}

.sf-result-list {
  display: grid;
  gap: 12px;
}

.sf-result-list > div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 16px 0;
  border-bottom: 1px solid #edf1f7;
}

.sf-result-list > div:last-child {
  border-bottom: 0;
}

.sf-result-list span {
  color: #667085;
  font-weight: 800;
}

.sf-result-list strong {
  color: #101828;
  font-size: 20px;
  letter-spacing: -.04em;
  text-align: right;
}

.sf-result-list .focus {
  margin: 4px 0;
  padding: 18px;
  border: 0;
  border-radius: 22px;
  background: linear-gradient(135deg, #2563eb, #1677ff);
}

.sf-result-list .focus span,
.sf-result-list .focus strong {
  color: #fff;
}

.sf-result-list .focus strong {
  font-size: 26px;
}

.sf-note {
  margin: 18px 0 0;
  padding: 14px 16px;
  border-radius: 16px;
  background: #f8fafc;
  color: #667085;
  font-size: 13px;
  line-height: 1.55;
}

.sf-bmi-meter {
  position: relative;
  height: 12px;
  border-radius: 999px;
  margin: 8px 0 24px;
  background: linear-gradient(90deg, #60a5fa 0%, #22c55e 38%, #f59e0b 62%, #ef4444 100%);
}

.sf-bmi-meter div {
  position: absolute;
  top: 50%;
  width: 20px;
  height: 20px;
  border: 4px solid #fff;
  border-radius: 999px;
  background: #111827;
  box-shadow: 0 8px 22px rgba(15,23,42,.20);
  transform: translate(-50%, -50%);
}

.sf-portal-search {
  position: relative;
  max-width: 620px;
  margin-bottom: 24px;
}

.sf-portal-search input {
  width: 100%;
  height: 62px;
  border: 1px solid #d6e0ef;
  border-radius: 22px;
  background: #fff;
  padding: 0 58px 0 22px;
  font-size: 17px;
  font-weight: 800;
  outline: none;
  box-shadow: 0 16px 46px rgba(15,23,42,.06);
}

.sf-portal-search span {
  position: absolute;
  right: 22px;
  top: 50%;
  transform: translateY(-50%);
  color: #2563eb;
  font-size: 22px;
  font-weight: 900;
}

.sf-portal-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.sf-portal-card {
  min-height: 190px;
  padding: 26px;
  border: 1px solid rgba(15,23,42,.08);
  border-radius: 28px;
  background: rgba(255,255,255,.90);
  box-shadow: 0 18px 56px rgba(15,23,42,.07);
  transition: transform .18s ease, box-shadow .18s ease;
}

.sf-portal-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 26px 80px rgba(15,23,42,.11);
}

.sf-portal-card b {
  display: block;
  color: #101828;
  font-size: 22px;
  letter-spacing: -.04em;
}

.sf-portal-card p {
  margin: 12px 0 24px;
  color: #667085;
  line-height: 1.65;
}

.sf-portal-card em {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 38px;
  padding: 0 16px;
  border-radius: 999px;
  background: #edf4ff;
  color: #2563eb;
  font-style: normal;
  font-weight: 900;
}

@media (max-width: 980px) {
  .sf-tool-hero-grid,
  .sf-calc-layout,
  .sf-portal-grid {
    grid-template-columns: 1fr;
  }

  .sf-tool-summary-card {
    align-self: stretch;
  }
}

@media (max-width: 640px) {
  .sf-tool-hero {
    padding: 44px 0 26px;
  }

  .sf-form-grid,
  .sf-form-grid.two {
    grid-template-columns: 1fr;
  }

  .sf-panel,
  .sf-tool-summary-card,
  .sf-portal-card {
    border-radius: 22px;
    padding: 22px;
  }
}

/* v152 insurance portal redesign */
.sf-portal-clean,
.sf-portal-clean body {
  background: #f7f9fd !important;
}

.sf-insurance-portal {
  min-height: calc(100vh - 72px);
  background:
    radial-gradient(circle at 8% 0%, rgba(37, 99, 235, .09), transparent 30%),
    radial-gradient(circle at 92% 8%, rgba(124, 58, 237, .08), transparent 28%),
    linear-gradient(180deg, #ffffff 0%, #f7f9fd 44%, #ffffff 100%);
}

.portal-hero-v152 {
  padding: 54px 0 24px;
}

.portal-hero-inner-v152 {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 280px;
  gap: 24px;
  align-items: stretch;
}

.portal-hero-copy-v152,
.portal-quick-v152 {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(37, 99, 235, .12);
  border-radius: 34px;
  background: rgba(255, 255, 255, .88);
  box-shadow: 0 26px 80px rgba(15, 23, 42, .08);
}

.portal-hero-copy-v152 {
  padding: 34px;
}

.portal-hero-copy-v152::after {
  content: "";
  position: absolute;
  right: -90px;
  bottom: -120px;
  width: 300px;
  height: 300px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(37, 99, 235, .13), transparent 68%);
  pointer-events: none;
}

.portal-back-v152 {
  display: inline-flex;
  align-items: center;
  height: 36px;
  padding: 0 14px;
  border: 1px solid #dbe7f7;
  border-radius: 999px;
  background: #f8fbff;
  color: #2563eb;
  font-size: 13px;
  font-weight: 900;
}

.portal-kicker-v152 {
  display: block;
  margin-top: 22px;
  color: #2563eb;
  font-size: 13px;
  font-weight: 950;
  letter-spacing: .02em;
}

.portal-hero-copy-v152 h1 {
  margin: 10px 0 12px;
  color: #101828;
  font-size: clamp(34px, 5vw, 58px);
  line-height: 1.03;
  letter-spacing: -.065em;
}

.portal-hero-copy-v152 p {
  max-width: 740px;
  margin: 0;
  color: #667085;
  font-size: 17px;
  line-height: 1.75;
  font-weight: 700;
}

.portal-quick-v152 {
  padding: 30px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  background: linear-gradient(135deg, #2563eb, #1677ff);
  color: #fff;
}

.portal-quick-v152 strong {
  font-size: 58px;
  line-height: 1;
  letter-spacing: -.06em;
}

.portal-quick-v152 span {
  margin-top: 6px;
  font-weight: 950;
}

.portal-quick-v152 p {
  margin: 14px 0 0;
  color: rgba(255, 255, 255, .78);
  line-height: 1.55;
  font-size: 14px;
  font-weight: 700;
}

.portal-body-v152 {
  padding: 18px 0 80px;
}

.portal-toolbar-v152 {
  position: sticky;
  top: 72px;
  z-index: 20;
  display: grid;
  grid-template-columns: minmax(280px, 420px) 1fr;
  gap: 16px;
  align-items: center;
  padding: 14px;
  border: 1px solid rgba(15, 23, 42, .07);
  border-radius: 28px;
  background: rgba(255, 255, 255, .82);
  box-shadow: 0 18px 60px rgba(15, 23, 42, .06);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.portal-search-v152 {
  position: relative;
}

.portal-search-v152 span {
  position: absolute;
  left: 18px;
  top: 50%;
  transform: translateY(-50%);
  color: #2563eb;
  font-size: 20px;
  font-weight: 950;
}

.portal-search-v152 input {
  width: 100%;
  height: 52px;
  padding: 0 18px 0 48px;
  border: 1px solid #dbe7f7;
  border-radius: 18px;
  background: #f8fbff;
  color: #101828;
  font-size: 15px;
  font-weight: 800;
  outline: none;
}

.portal-search-v152 input:focus {
  border-color: #93c5fd !important;
  background: #fff;
  box-shadow: 0 0 0 4px rgba(37, 99, 235, .10) !important;
}

.portal-tabs-v152 {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}

.portal-tabs-v152 button {
  height: 44px;
  padding: 0 16px;
  border: 1px solid #dbe7f7;
  border-radius: 999px;
  background: #fff;
  color: #475467;
  font-size: 14px;
  font-weight: 950;
  cursor: pointer;
  transition: transform .16s ease, box-shadow .16s ease, background .16s ease, color .16s ease;
}

.portal-tabs-v152 button:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 26px rgba(15, 23, 42, .08);
}

.portal-tabs-v152 button.is-active {
  border-color: transparent;
  background: linear-gradient(135deg, #2563eb, #1677ff);
  color: #fff;
  box-shadow: 0 14px 30px rgba(37, 99, 235, .22);
}

.portal-layout-v152 {
  display: grid;
  grid-template-columns: 250px minmax(0, 1fr);
  gap: 22px;
  margin-top: 22px;
  align-items: start;
}

.portal-side-v152 {
  position: sticky;
  top: 168px;
  display: grid;
  gap: 14px;
}

.portal-side-card-v152 {
  padding: 22px;
  border: 1px solid rgba(15, 23, 42, .08);
  border-radius: 26px;
  background: rgba(255,255,255,.92);
  box-shadow: 0 18px 54px rgba(15,23,42,.06);
}

.portal-side-card-v152 b {
  display: block;
  margin-bottom: 14px;
  color: #101828;
  font-size: 18px;
  letter-spacing: -.04em;
}

.portal-side-card-v152 a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 42px;
  padding: 0 12px;
  border-radius: 14px;
  color: #344054;
  font-size: 14px;
  font-weight: 900;
}

.portal-side-card-v152 a::after {
  content: "→";
  color: #2563eb;
}

.portal-side-card-v152 a:hover {
  background: #edf4ff;
  color: #2563eb;
}

.portal-side-card-v152.muted {
  background: #111827;
  color: #fff;
}

.portal-side-card-v152.muted b {
  color: #fff;
}

.portal-side-card-v152.muted p {
  margin: 0;
  color: rgba(255,255,255,.72);
  line-height: 1.65;
  font-size: 13px;
  font-weight: 700;
}

.portal-section-title-v152 {
  display: flex;
  align-items: end;
  justify-content: space-between;
  margin: 4px 0 16px;
}

.portal-section-title-v152 span {
  color: #2563eb;
  font-size: 13px;
  font-weight: 950;
}

.portal-section-title-v152 h2 {
  margin: 0;
  color: #101828;
  font-size: 28px;
  letter-spacing: -.05em;
}

.portal-company-grid-v152 {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.portal-company-card-v152 {
  position: relative;
  overflow: hidden;
  padding: 20px;
  border: 1px solid rgba(15, 23, 42, .08);
  border-radius: 28px;
  background: rgba(255,255,255,.94);
  box-shadow: 0 18px 56px rgba(15,23,42,.07);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.portal-company-card-v152::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 7px;
  background: var(--portal-tone, #2563eb);
}

.portal-company-card-v152:hover {
  transform: translateY(-5px);
  border-color: rgba(37, 99, 235, .20);
  box-shadow: 0 28px 84px rgba(15, 23, 42, .12);
}

.portal-company-top-v152 {
  display: flex;
  align-items: center;
  gap: 14px;
  min-height: 64px;
}

.portal-logo-v152 {
  width: 54px;
  height: 54px;
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 18px;
  background: linear-gradient(180deg, #ffffff, #f3f7ff);
  border: 1px solid #e3ebf7;
  color: #101828;
  font-size: 14px;
  font-weight: 950;
  letter-spacing: -.04em;
}

.portal-company-top-v152 h3 {
  margin: 0;
  color: #101828;
  font-size: 20px;
  letter-spacing: -.045em;
}

.portal-company-top-v152 span {
  display: inline-flex;
  margin-top: 5px;
  height: 26px;
  align-items: center;
  padding: 0 10px;
  border-radius: 999px;
  background: #f2f6ff;
  color: #2563eb;
  font-size: 12px;
  font-weight: 950;
}

.portal-company-actions-v152 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 9px;
  margin: 20px 0 16px;
}

.portal-company-actions-v152 a {
  height: 42px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #dbe7f7;
  border-radius: 15px;
  background: #f8fbff;
  color: #344054;
  font-size: 13px;
  font-weight: 950;
}

.portal-company-actions-v152 a.primary {
  grid-column: 1 / -1;
  border-color: transparent;
  background: var(--portal-tone, #2563eb);
  color: #fff;
  box-shadow: 0 14px 30px rgba(37, 99, 235, .18);
}

.portal-company-actions-v152 a:hover {
  transform: translateY(-1px);
}

.portal-company-info-v152 {
  display: grid;
  gap: 8px;
  margin: 0;
  padding-top: 16px;
  border-top: 1px solid #eef2f7;
}

.portal-company-info-v152 div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.portal-company-info-v152 dt,
.portal-company-info-v152 dd {
  margin: 0;
  font-size: 13px;
  font-weight: 850;
}

.portal-company-info-v152 dt {
  color: #667085;
}

.portal-company-info-v152 dd {
  color: #2563eb;
  text-align: right;
}

.portal-company-card-v152.tone-blue { --portal-tone: #2563eb; }
.portal-company-card-v152.tone-orange { --portal-tone: #f97316; }
.portal-company-card-v152.tone-green { --portal-tone: #16a34a; }
.portal-company-card-v152.tone-gold { --portal-tone: #d97706; }
.portal-company-card-v152.tone-navy { --portal-tone: #1e3a8a; }
.portal-company-card-v152.tone-red { --portal-tone: #dc2626; }
.portal-company-card-v152.tone-mint { --portal-tone: #0d9488; }
.portal-company-card-v152.tone-purple { --portal-tone: #7c3aed; }

.portal-empty-v152 {
  padding: 54px;
  border: 1px dashed #cbd5e1;
  border-radius: 28px;
  background: #fff;
  color: #667085;
  text-align: center;
  font-weight: 950;
}

@media (max-width: 1120px) {
  .portal-company-grid-v152 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 920px) {
  .portal-hero-inner-v152,
  .portal-toolbar-v152,
  .portal-layout-v152 {
    grid-template-columns: 1fr;
  }

  .portal-toolbar-v152,
  .portal-side-v152 {
    position: static;
  }

  .portal-tabs-v152 {
    justify-content: flex-start;
  }
}

@media (max-width: 640px) {
  .portal-hero-v152 {
    padding: 34px 0 16px;
  }

  .portal-hero-copy-v152,
  .portal-quick-v152,
  .portal-toolbar-v152,
  .portal-side-card-v152,
  .portal-company-card-v152 {
    border-radius: 22px;
  }

  .portal-hero-copy-v152,
  .portal-quick-v152 {
    padding: 24px;
  }

  .portal-company-grid-v152 {
    grid-template-columns: 1fr;
  }

  .portal-tabs-v152 button {
    flex: 1 1 auto;
  }
}


/* v158 header alignment lock: keep every page consistent */
@media (min-width: 761px) {
  .header .container {
    width: min(1120px, calc(100% - 44px)) !important;
  }

  .header .nav {
    height: 72px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 22px !important;
  }

  .header .logo {
    margin-right: auto !important;
    flex: 0 0 auto !important;
  }

  .header .nav-links {
    margin-left: auto !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 14px !important;
    flex: 0 1 auto !important;
  }

  .header .nav-actions {
    display: none !important;
  }
}

@media (max-width: 760px) {
  .header .nav-actions,
  .header .nav-links {
    display: none !important;
  }

  .header .menu-button {
    margin-left: auto !important;
  }
}


/* v159 absolute header lock: keep logo left and menu right on every page */
@media (min-width: 761px) {
  .header .container,
  .sf-header .sf-container,
  .sf-v155 .sf-header .sf-container {
    width: min(1180px, calc(100% - 72px)) !important;
    max-width: 1180px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .header .nav,
  .sf-header .sf-nav,
  .sf-v155 .sf-nav {
    position: relative !important;
    height: 72px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 0 !important;
    width: 100% !important;
  }

  .header .logo,
  .sf-header .sf-brand,
  .sf-v155 .sf-brand {
    position: relative !important;
    margin: 0 !important;
    flex: 0 0 auto !important;
    min-width: 0 !important;
    z-index: 2 !important;
  }

  .header .nav-links,
  .sf-header .sf-menu,
  .sf-v155 .sf-menu {
    position: absolute !important;
    right: 0 !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    margin: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 8px !important;
    flex: none !important;
    width: auto !important;
    white-space: nowrap !important;
    z-index: 3 !important;
  }

  .header .nav-actions {
    display: none !important;
  }

  .header .menu-button,
  .sf-header .sf-menu-btn,
  .sf-v155 .sf-menu-btn {
    display: none !important;
  }
}

@media (max-width: 760px) {
  .header .nav-links,
  .header .nav-actions,
  .sf-header .sf-menu,
  .sf-v155 .sf-menu {
    display: none !important;
  }

  .header .menu-button,
  .sf-header .sf-menu-btn,
  .sf-v155 .sf-menu-btn {
    display: block !important;
    margin-left: auto !important;
  }
}


/* v160 nav spacing correction: keep every desktop menu spaced like utility page */
@media (min-width: 761px) {
  .header .nav-links,
  .sf-header .sf-menu,
  .sf-v155 .sf-menu {
    gap: 26px !important;
    column-gap: 26px !important;
    align-items: center !important;
  }

  .header .nav-links a,
  .sf-header .sf-menu a,
  .sf-v155 .sf-menu a {
    margin: 0 !important;
    white-space: nowrap !important;
  }
}
