/* SAVE-INSU v9 — clean, white, professional */

/* ============================================================
   Fonts (self-hosted, FOUT-safe)
   ============================================================ */
@font-face{font-family:'Pretendard';font-weight:400;font-display:swap;src:url('../_ext/cdn.jsdelivr.net/gh/orioncactus/pretendard/packages/pretendard/dist/web/static/woff2/Pretendard-Regular.woff2') format('woff2');}
@font-face{font-family:'Pretendard';font-weight:500;font-display:swap;src:url('../_ext/cdn.jsdelivr.net/gh/orioncactus/pretendard/packages/pretendard/dist/web/static/woff2/Pretendard-Medium.woff2') format('woff2');}
@font-face{font-family:'Pretendard';font-weight:600;font-display:swap;src:url('../_ext/cdn.jsdelivr.net/gh/orioncactus/pretendard/packages/pretendard/dist/web/static/woff2/Pretendard-SemiBold.woff2') format('woff2');}
@font-face{font-family:'Pretendard';font-weight:700;font-display:swap;src:url('../_ext/cdn.jsdelivr.net/gh/orioncactus/pretendard/packages/pretendard/dist/web/static/woff2/Pretendard-Bold.woff2') format('woff2');}
@font-face{font-family:'Pretendard';font-weight:800;font-display:swap;src:url('../_ext/cdn.jsdelivr.net/gh/orioncactus/pretendard/packages/pretendard/dist/web/static/woff2/Pretendard-ExtraBold.woff2') format('woff2');}

/* ============================================================
   Tokens
   ============================================================ */
:root{
  --bg:#ffffff;
  --bg-alt:#fafafa;
  --bg-card:#ffffff;

  --ink:#111111;
  --text:#2a2a2a;
  --text-2:#4a4a4a;
  --muted:#6b6b6b;
  --muted-2:#8e8e93;

  --line:#e6e6e8;
  --line-2:#d4d4d6;
  --line-hover:#b4b4b6;

  --brand:#0f172a;           /* deep slate */
  --accent:#1e40af;           /* trustworthy blue — used rarely */

  --shadow-sm: 0 1px 2px rgba(17,17,17,.04);
  --shadow-md: 0 2px 8px -2px rgba(17,17,17,.06), 0 1px 3px rgba(17,17,17,.04);
  --shadow-lg: 0 12px 32px -12px rgba(17,17,17,.12), 0 4px 12px -4px rgba(17,17,17,.06);

  --r-sm:8px; --r-md:10px; --r-lg:14px; --r-xl:18px;

  --container:1120px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ============================================================
   Reset
   ============================================================ */
*,*::before,*::after{ box-sizing:border-box; }
*:focus-visible{ outline:2px solid var(--ink); outline-offset:3px; border-radius:4px; }
.serviceCard:focus-visible, .processStep:focus-visible{ outline:2px solid var(--ink); outline-offset:4px; }
.faq summary:focus-visible{ outline:2px solid var(--ink); outline-offset:4px; border-radius:2px; }
.btn:focus-visible{ outline:2px solid var(--accent); outline-offset:3px; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
html,body{ height:100%; }
body{
  margin:0;
  font-family:'Pretendard',-apple-system,BlinkMacSystemFont,'Apple SD Gothic Neo','Malgun Gothic',system-ui,sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.7;
  font-feature-settings:"ss01","ss02","tnum";
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  font-variant-numeric:tabular-nums;
}
img,svg{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
p{ margin:0; color:var(--text); }
h1,h2,h3,h4{ color:var(--ink); margin:0; font-weight:700; letter-spacing:-.02em; }
h1{ font-weight:800; letter-spacing:-.025em; line-height:1.2; }
::selection{ background:#e7f0ff; color:var(--ink); }

/* ============================================================
   Layout primitives
   ============================================================ */
.container{ width:min(var(--container), calc(100% - 40px)); margin-inline:auto; }

.skip{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.skip:focus{
  position:fixed; left:16px; top:16px; width:auto; height:auto;
  padding:10px 14px; background:#fff;
  border:1px solid var(--line-2); border-radius:var(--r-sm);
  box-shadow:var(--shadow-md); z-index:9999;
}

/* ============================================================
   Header
   ============================================================ */
.header{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .2s var(--ease), box-shadow .2s var(--ease);
}
.header.is-scrolled{
  border-bottom-color:var(--line);
  box-shadow:0 1px 0 rgba(17,17,17,.02), 0 4px 12px -6px rgba(17,17,17,.06);
}
.header__inner{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  padding:16px 0; gap:20px;
}
.nav{ justify-self:center; }
.brand{ display:inline-flex; align-items:center; flex-shrink:0; }
.brand__logo{ height:34px; width:auto; }
@media (min-width:768px){ .brand__logo{ height:38px; } }

.nav{ display:flex; align-items:center; gap:4px; }
.nav a{
  font-weight:500; font-size:15px;
  color:var(--text-2);
  padding:9px 14px;
  border-radius:8px;
  transition:color .16s var(--ease), background .16s var(--ease);
  position:relative;
}
.nav a:hover{ color:var(--ink); background:var(--bg-alt); }
.nav a.is-active{ color:var(--ink); font-weight:700; }
.nav a.is-active::after{
  content:"";
  position:absolute;
  left:14px; right:14px; bottom:0;
  height:2px;
  background:var(--ink);
  border-radius:2px;
}

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

/* ============================================================
   Buttons
   ============================================================ */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:8px;
  padding:11px 18px;
  border:1px solid var(--line-2);
  border-radius:var(--r-sm);
  background:#fff;
  color:var(--ink);
  font-family:inherit; font-weight:600; font-size:14.5px;
  letter-spacing:-.005em; line-height:1;
  cursor:pointer; user-select:none; white-space:nowrap;
  min-height:42px;
  transition:transform .15s var(--ease), background .18s var(--ease), border-color .18s var(--ease), box-shadow .22s var(--ease);
}
.btn:hover{ border-color:var(--line-hover); box-shadow:var(--shadow-sm); }
.btn:active{ transform:translateY(1px); }

.btn--primary{
  background:var(--ink); color:#fff; border-color:var(--ink);
  font-weight:700;
}
.btn--primary:hover{ background:#000; box-shadow:var(--shadow-md); }

.btn--lg{ padding:14px 24px; min-height:50px; font-size:15px; }

.btn__arrow{ width:14px; height:14px; transition:transform .22s var(--ease); }
.btn:hover .btn__arrow{ transform:translateX(3px); }

/* ============================================================
   Mobile menu
   ============================================================ */
.burger{
  display:none;
  width:40px; height:40px;
  border:1px solid var(--line-2);
  border-radius:var(--r-sm);
  background:#fff;
  cursor:pointer;
  align-items:center; justify-content:center;
  transition:background .16s var(--ease);
}
.burger:hover{ background:var(--bg-alt); }
.burger svg{ width:18px; height:18px; color:var(--ink); }
.mobilePanel{ display:none; padding:8px 0 16px; border-top:1px solid var(--line); }
.mobilePanel a{
  display:block;
  padding:12px 4px;
  font-weight:500; font-size:16px;
  color:var(--text);
  border-bottom:1px solid var(--line);
}
.mobilePanel a.is-active{ color:var(--ink); font-weight:700; }
body.is-menu-open .mobilePanel{ display:block; }
@media (max-width:860px){
  .nav{ display:none; }
  .burger{ display:inline-flex; }
}

/* ============================================================
   Section rhythm
   ============================================================ */
.section{ padding:clamp(64px, 7vw, 112px) 0; }
.section--tight{ padding:clamp(44px, 5vw, 72px) 0; }
.section--alt{ background:var(--bg-alt); }

.sectionHeader{
  max-width:720px;
  margin-bottom:clamp(40px, 4.4vw, 64px);
}
.sectionHeader--center{ margin-inline:auto; text-align:center; }
.sectionHeader__label{
  display:inline-block;
  font-size:12.5px; font-weight:700;
  color:var(--ink);
  letter-spacing:.08em;
  text-transform:uppercase;
  margin-bottom:14px;
  padding-bottom:8px;
  border-bottom:2px solid var(--ink);
}
.sectionHeader h2{
  font-size:clamp(26px, 3.2vw, 40px);
  line-height:1.25;
  letter-spacing:-.025em;
  margin:0 0 14px;
}
.sectionHeader p{
  color:var(--muted);
  font-size:clamp(15px, 1.15vw, 17px);
  line-height:1.65;
  max-width:640px;
}

/* ============================================================
   Hero
   ============================================================ */
.hero{
  padding:clamp(72px, 9vw, 136px) 0 clamp(60px, 7vw, 104px);
}
.hero__grid{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:clamp(32px, 5vw, 80px);
  align-items:center;
}
.hero__label{
  display:inline-block;
  font-size:13px; font-weight:600;
  color:var(--accent);
  margin-bottom:18px;
}
.hero__title{
  font-size:clamp(34px, 5.4vw, 62px);
  line-height:1.14;
  letter-spacing:-.034em;
  font-weight:800;
  margin:0 0 22px;
  color:var(--ink);
}
.hero__title mark{
  background:transparent;
  color:inherit;
  box-shadow:inset 0 -10px 0 rgba(200,154,74,.38);
  padding:0 2px;
}
.hero__lead{
  font-size:clamp(16px, 1.3vw, 18px);
  line-height:1.7;
  color:var(--text);
  max-width:54ch;
  margin:0 0 32px;
}
.hero__actions{ display:flex; gap:12px; flex-wrap:wrap; }
.hero__trust{
  margin-top:40px;
  padding-top:28px;
  border-top:1px solid var(--line);
  display:flex; flex-wrap:wrap; gap:28px;
  color:var(--text-2); font-size:14px;
}
.hero__trust span{
  display:inline-flex; align-items:center; gap:10px;
  font-weight:500;
}
.hero__trust svg{
  width:16px; height:16px;
  color:#fff;
  background:var(--ink);
  border-radius:999px;
  padding:3px;
  box-sizing:content-box;
  flex-shrink:0;
}

.heroPanel{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--r-xl);
  padding:30px;
  box-shadow:var(--shadow-md);
  position:relative;
  overflow:hidden;
}
.heroPanel::before{
  content:"";
  position:absolute; left:0; right:0; top:0; height:3px;
  background:var(--ink);
}
.heroPanel__head{
  display:flex; justify-content:space-between; align-items:center;
  padding-bottom:18px;
  border-bottom:1px solid var(--line);
  margin-bottom:4px;
}
.heroPanel__title{
  font-weight:700;
  font-size:15px;
  color:var(--ink);
  letter-spacing:-.01em;
}
.heroPanel__tag{
  display:inline-flex; align-items:center; gap:6px;
  font-size:11.5px; font-weight:600;
  color:var(--muted);
  letter-spacing:.05em;
  text-transform:uppercase;
}
.heroPanel__tag::before{
  content:"";
  width:6px; height:6px; border-radius:999px;
  background:var(--ink);
}
.heroPanel__row{
  display:flex; justify-content:space-between; align-items:baseline;
  padding:14px 0;
  border-bottom:1px solid var(--line);
}
.heroPanel__row:last-child{ border-bottom:none; }
.heroPanel__key{ color:var(--muted); font-size:13.5px; font-weight:500; }
.heroPanel__val{ color:var(--ink); font-weight:700; font-size:15px; letter-spacing:-.01em; }

.heroPanel__figure{
  padding:18px 0 20px;
  border-bottom:1px solid var(--line);
  margin-bottom:6px;
}
.heroPanel__figureNum{
  display:block;
  font-size:40px; font-weight:900;
  color:var(--ink);
  letter-spacing:-.035em;
  line-height:1;
  margin-bottom:6px;
}
.heroPanel__figureLabel{
  display:block;
  font-size:13px;
  color:var(--muted);
  font-weight:500;
}

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

/* ============================================================
   Services — 3 clean cards
   ============================================================ */
.services{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
  gap:20px;
}
.services--4{
  grid-template-columns:repeat(4, minmax(0, 1fr));
}
@media (max-width:1100px){ .services--4{ grid-template-columns:repeat(2, 1fr); } }
@media (max-width:560px){ .services--4{ grid-template-columns:1fr; } }

.serviceCard{
  display:flex; flex-direction:column;
  padding:32px 30px 30px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  transition:transform .22s var(--ease), box-shadow .22s var(--ease), border-color .22s var(--ease);
  color:inherit;
  cursor:pointer;
  min-height:300px;
}
.serviceCard:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow-lg);
  border-color:var(--line-2);
}
.serviceCard__icon{
  width:46px; height:46px;
  display:inline-flex; align-items:center; justify-content:center;
  border:1px solid var(--line-2);
  border-radius:12px;
  color:var(--ink);
  margin-bottom:22px;
  transition:background .22s var(--ease), color .22s var(--ease), border-color .22s var(--ease), transform .22s var(--ease);
}
.serviceCard:hover .serviceCard__icon{
  background:var(--ink);
  color:#fff;
  border-color:var(--ink);
  transform:rotate(-4deg) scale(1.04);
}
.serviceCard__icon svg{ width:20px; height:20px; }
.serviceCard__num{
  font-size:11.5px; font-weight:700;
  color:var(--muted);
  margin-bottom:10px;
  letter-spacing:.14em;
  text-transform:uppercase;
}
.serviceCard h3{
  font-size:20px;
  line-height:1.3;
  letter-spacing:-.018em;
  margin:0 0 12px;
}
.serviceCard p{
  color:var(--muted);
  font-size:14.5px;
  line-height:1.7;
  flex-grow:1;
  margin:0 0 22px;
}
.serviceCard__link{
  display:inline-flex; align-items:center; gap:6px;
  color:var(--ink);
  font-weight:600;
  font-size:14px;
  padding-top:16px;
  border-top:1px solid var(--line);
  transition:gap .22s var(--ease);
}
.serviceCard__link svg{ width:14px; height:14px; transition:transform .22s var(--ease); }
.serviceCard:hover .serviceCard__link{ gap:10px; }
.serviceCard:hover .serviceCard__link svg{ transform:translateX(3px); }

/* ============================================================
   Process — 4 steps, horizontal on desktop
   ============================================================ */
.process{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:18px;
}
.process--3{ grid-template-columns:repeat(3, 1fr); }
@media (max-width:880px){
  .process, .process--3{ grid-template-columns:1fr 1fr; gap:14px; }
}
@media (max-width:520px){
  .process, .process--3{ grid-template-columns:1fr; }
}

.processStep{
  padding:28px 24px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--r-md);
  transition:border-color .22s var(--ease), box-shadow .22s var(--ease), transform .22s var(--ease);
}
.processStep:hover{
  border-color:var(--ink);
  box-shadow:var(--shadow-md);
  transform:translateY(-2px);
}
.processStep__num{
  width:42px; height:42px;
  display:inline-flex; align-items:center; justify-content:center;
  border-radius:999px;
  background:#fff;
  border:1.5px solid var(--ink);
  color:var(--ink);
  font-weight:800; font-size:15px;
  margin-bottom:20px;
  letter-spacing:-.01em;
  transition:background .22s var(--ease), color .22s var(--ease);
}
.processStep:hover .processStep__num{
  background:var(--ink);
  color:#fff;
}
.processStep h4{
  font-size:18px;
  line-height:1.35;
  margin:0 0 8px;
  color:var(--ink);
  letter-spacing:-.015em;
  font-weight:700;
}
.processStep p{
  color:var(--muted);
  font-size:14px;
  line-height:1.65;
  margin:0;
}

/* ============================================================
   Split — content + image
   ============================================================ */
.split{
  display:grid;
  grid-template-columns:1fr 1.1fr;
  gap:clamp(32px, 5vw, 80px);
  align-items:center;
}
.split--flip .split__media{ order:-1; }
@media (max-width:860px){
  .split, .split--flip{ grid-template-columns:1fr; gap:28px; }
  .split--flip .split__media{ order:initial; }
}
.split__content h3{
  font-size:clamp(22px, 2.4vw, 30px);
  line-height:1.25;
  letter-spacing:-.02em;
  margin:0 0 16px;
}
.split__content p{
  color:var(--text);
  font-size:16px;
  line-height:1.75;
  margin:0 0 16px;
  max-width:54ch;
}
.split__list{
  list-style:none; padding:0; margin:20px 0 0;
  display:grid; gap:10px;
}
.split__list li{
  position:relative;
  padding-left:26px;
  font-size:15px;
  color:var(--text);
  line-height:1.65;
}
.split__list li::before{
  content:"";
  position:absolute; left:0; top:10px;
  width:14px; height:14px;
  background:var(--bg-alt);
  border:1px solid var(--line-2);
  border-radius:999px;
}
.split__list li::after{
  content:"";
  position:absolute; left:5px; top:14px;
  width:4px; height:4px;
  background:var(--ink);
  border-radius:999px;
}
.split__media{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--r-xl);
  aspect-ratio:4/3;
  position:relative;
  overflow:hidden;
  box-shadow:var(--shadow-md);
}
.split__media img{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:contain;
  padding:20px;
}

/* ============================================================
   FAQ
   ============================================================ */
.faq{
  max-width:840px;
  margin:0 auto;
}
.faq details{
  border-bottom:1px solid var(--line);
  padding:24px 0;
  transition:padding .2s var(--ease);
}
.faq details:first-child{ border-top:1px solid var(--line); }
.faq details[open]{ padding-bottom:28px; }
.faq summary{
  cursor:pointer;
  font-weight:600;
  color:var(--ink);
  list-style:none;
  position:relative;
  padding-right:44px;
  padding-left:0;
  font-size:18px;
  line-height:1.4;
  letter-spacing:-.015em;
  transition:color .18s var(--ease), padding-left .2s var(--ease);
}
.faq summary:hover{ color:var(--ink); padding-left:6px; }
.faq details[open] summary{ color:var(--ink); }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{
  content:"";
  position:absolute; right:0; top:50%;
  transform:translateY(-50%);
  width:24px; height:24px;
  background:
    linear-gradient(currentColor,currentColor) center / 12px 1.5px no-repeat,
    linear-gradient(currentColor,currentColor) center / 1.5px 12px no-repeat;
  color:var(--muted);
  transition:transform .25s var(--ease), color .25s var(--ease);
}
.faq details[open] summary::after{
  transform:translateY(-50%) rotate(45deg);
  color:var(--ink);
  background:linear-gradient(currentColor,currentColor) center / 12px 1.5px no-repeat;
}
.faq p{
  margin:14px 0 0;
  color:var(--muted);
  font-size:15px;
  line-height:1.75;
  max-width:62ch;
}

/* ============================================================
   Contact — form + info
   ============================================================ */
.contactGrid{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:clamp(28px, 3.5vw, 48px);
  align-items:start;
}
@media (max-width:860px){ .contactGrid{ grid-template-columns:1fr; } }

.contactInfo{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--r-xl);
  padding:clamp(24px, 2.8vw, 36px);
}
.contactInfo__row{
  padding:18px 0;
  border-bottom:1px solid var(--line);
}
.contactInfo__row:first-child{ padding-top:0; }
.contactInfo__row:last-child{ padding-bottom:0; border-bottom:none; }
.contactInfo dt{
  font-size:11.5px; font-weight:700;
  color:var(--muted);
  letter-spacing:.12em;
  text-transform:uppercase;
  margin-bottom:8px;
}
.contactInfo dd{
  margin:0;
  color:var(--ink);
  font-weight:700;
  font-size:16.5px;
  line-height:1.5;
  letter-spacing:-.012em;
}
.contactInfo dd small{
  display:block;
  font-weight:500;
  color:var(--muted);
  font-size:13.5px;
  margin-top:6px;
  line-height:1.55;
}

.formCard{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--r-xl);
  padding:clamp(24px, 2.8vw, 36px);
  box-shadow:var(--shadow-md);
}
.formGrid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}
@media (max-width:640px){ .formGrid{ grid-template-columns:1fr; } }
.field{ display:block; }
.field label{
  display:block;
  font-weight:600;
  font-size:13.5px;
  color:var(--ink);
  margin:0 0 8px;
}
.field label .req{
  color:#dc2626;
  font-weight:700;
  margin-left:3px;
  font-size:13.5px;
}
.field label small{
  color:var(--muted);
  font-weight:500;
  margin-left:6px;
  font-size:12.5px;
}
.field input,.field select,.field textarea{
  width:100%;
  border:1px solid var(--line-2);
  border-radius:var(--r-sm);
  padding:11px 14px;
  font:inherit; font-size:15px;
  background:#fff;
  color:var(--ink);
  min-height:44px;
  transition:border-color .16s var(--ease), box-shadow .16s var(--ease);
}
.field textarea{ min-height:140px; resize:vertical; line-height:1.6; padding:12px 14px; }
.field input::placeholder,.field textarea::placeholder{ color:var(--muted-2); }
.field input:hover,.field select:hover,.field textarea:hover{ border-color:var(--line-hover); }
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;
  border-color:var(--ink);
  box-shadow:0 0 0 3px rgba(17,17,17,.08);
}
.formActions{
  margin-top:20px;
  display:flex;
  justify-content:flex-end;
  gap:10px;
  flex-wrap:wrap;
}
.formActions .btn[disabled]{ opacity:.55; cursor:wait; }
.formStatus{
  margin-top:14px;
  padding:12px 14px;
  border:1px solid #c7e6d5;
  border-radius:var(--r-sm);
  background:#f0faf5;
  color:#0f7b51;
  font-weight:600;
  font-size:14px;
}
.formStatus[data-tone="error"]{
  border-color:#f0c9c1;
  background:#fdf3f0;
  color:#a5350e;
}

/* ============================================================
   CTA section — simple
   ============================================================ */
.ctaSection{
  background:var(--ink);
  color:#fff;
  padding:clamp(64px, 7vw, 112px) 0;
}
.ctaSection__inner{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:40px;
  flex-wrap:wrap;
}
@media (max-width:720px){
  .ctaSection__inner{ align-items:flex-start; }
}
.ctaSection__label{
  display:inline-block;
  font-size:12px; font-weight:700;
  letter-spacing:.12em; text-transform:uppercase;
  color:rgba(255,255,255,.55);
  margin-bottom:14px;
}
.ctaSection h2{
  color:#fff;
  font-size:clamp(24px, 2.8vw, 34px);
  line-height:1.2;
  letter-spacing:-.025em;
  margin:0 0 10px;
  max-width:22ch;
}
.ctaSection p{
  color:rgba(255,255,255,.65);
  font-size:16px;
  line-height:1.6;
  margin:0;
  max-width:52ch;
}
.ctaSection__actions{
  display:flex; gap:10px; flex-wrap:wrap;
}
.ctaSection .btn{
  background:#fff;
  color:var(--ink);
  border-color:#fff;
}
.ctaSection .btn:hover{ background:#f0f0f0; border-color:#f0f0f0; }
.ctaSection .btn--ghost-inv{
  background:transparent;
  color:#fff;
  border-color:rgba(255,255,255,.3);
}
.ctaSection .btn--ghost-inv:hover{
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.6);
  color:#fff;
}

/* ============================================================
   Page hero (inner pages)
   ============================================================ */
.pageHero{
  padding:clamp(68px, 8vw, 120px) 0 clamp(44px, 5.4vw, 80px);
  border-bottom:1px solid var(--line);
  background:var(--bg-alt);
}
.pageHero__label{
  display:inline-flex; align-items:center; gap:10px;
  font-size:12.5px; font-weight:700;
  color:var(--ink);
  letter-spacing:.1em;
  text-transform:uppercase;
  margin-bottom:18px;
  padding-bottom:8px;
  border-bottom:2px solid var(--ink);
}
.pageHero h1{
  font-size:clamp(30px, 4.4vw, 52px);
  line-height:1.15;
  letter-spacing:-.034em;
  margin:0 0 20px;
  max-width:20ch;
}
.pageHero p{
  color:var(--text);
  font-size:clamp(16px, 1.25vw, 18px);
  line-height:1.7;
  max-width:56ch;
  margin:0;
}
.pageHero__actions{
  margin-top:32px;
  display:flex; gap:12px; flex-wrap:wrap;
}

/* ============================================================
   Footer
   ============================================================ */
.footer{
  background:#fff;
  padding:clamp(56px, 6vw, 80px) 0 32px;
  position:relative;
  border-top:1px solid var(--line);
}
.footer__grid{
  display:grid;
  grid-template-columns:1.5fr 1fr 1fr;
  gap:clamp(24px, 3vw, 48px);
  padding-bottom:32px;
  border-bottom:1px solid var(--line);
  margin-bottom:24px;
}
.footer__brand{
  font-size:18px; font-weight:800;
  color:var(--ink);
  letter-spacing:-.015em;
  margin:0 0 12px;
}
.footer__tag{
  color:var(--muted);
  font-size:14px;
  line-height:1.7;
  max-width:38ch;
  margin:0 0 16px;
}
.footer__addr{
  color:var(--muted);
  font-size:13.5px;
  line-height:1.6;
}
.footer h4{
  font-size:14px; font-weight:700;
  color:var(--ink);
  margin:0 0 14px;
  letter-spacing:-.01em;
}
.footer ul{ list-style:none; padding:0; margin:0; display:grid; gap:8px; }
.footer ul a{
  color:var(--muted);
  font-size:14px;
  transition:color .16s var(--ease);
}
.footer ul a:hover{ color:var(--ink); }
.footer__bizInfo ul{ list-style:none; padding:0; margin:0; display:grid; gap:10px; }
.footer__bizInfo li{
  display:grid;
  grid-template-columns:78px 1fr;
  gap:10px;
  font-size:13.5px;
  line-height:1.5;
}
.footer__bizInfo li span:first-child{
  color:var(--muted-2);
  font-weight:500;
  font-size:12.5px;
  letter-spacing:.02em;
}
.footer__bizInfo li span:last-child{
  color:var(--text-2);
  font-weight:600;
}
.footer__bottom{
  display:flex; justify-content:space-between;
  gap:16px; flex-wrap:wrap;
  font-size:13px;
  color:var(--muted-2);
}
@media (max-width:760px){
  .footer__grid{ grid-template-columns:1fr; gap:32px; }
}

/* ============================================================
   Toast
   ============================================================ */
.toast{
  position:fixed; left:50%; bottom:24px;
  transform:translateX(-50%) translateY(16px);
  opacity:0; pointer-events:none;
  background:var(--ink); color:#fff;
  padding:12px 20px;
  border-radius:var(--r-sm);
  font-weight:600; font-size:14.5px;
  box-shadow:var(--shadow-lg);
  transition:opacity .22s var(--ease), transform .22s var(--ease);
  max-width:calc(100% - 32px); text-align:center;
  z-index:100;
}
.toast.is-on{ opacity:1; transform:translateX(-50%) translateY(0); }

/* ============================================================
   Manifesto (intro block, left-aligned)
   ============================================================ */
.manifesto{
  display:grid;
  grid-template-columns:.4fr 1fr;
  gap:clamp(32px, 5vw, 80px);
  align-items:start;
}
.manifesto__aside{
  padding-top:8px;
}
.manifesto__body h2{
  font-size:clamp(28px, 3.6vw, 44px);
  line-height:1.2;
  letter-spacing:-.028em;
  margin:0 0 24px;
}
.manifesto__body p{
  color:var(--text);
  font-size:clamp(15.5px, 1.2vw, 17.5px);
  line-height:1.75;
  margin:0 0 16px;
  max-width:56ch;
}
@media (max-width:860px){
  .manifesto{ grid-template-columns:1fr; gap:16px; }
}

/* Page load fade-up stagger (pure CSS, reliable) */
@keyframes fadeUp{
  from{ opacity:0; transform:translateY(14px); }
  to  { opacity:1; transform:translateY(0); }
}
.hero__label,
.hero__title,
.hero__lead,
.hero__actions,
.hero__trust,
.heroPanel{
  animation: fadeUp .7s var(--ease-spring) both;
}
.hero__label{ animation-delay: 0s; }
.hero__title{ animation-delay: .05s; }
.hero__lead{ animation-delay: .15s; }
.hero__actions{ animation-delay: .22s; }
.hero__trust{ animation-delay: .3s; }
.heroPanel{ animation-delay: .3s; }

.pageHero__label,
.pageHero h1,
.pageHero p,
.pageHero__actions{
  animation: fadeUp .6s var(--ease-spring) both;
}
.pageHero__label{ animation-delay: 0s; }
.pageHero h1{ animation-delay: .06s; }
.pageHero p{ animation-delay: .16s; }
.pageHero__actions{ animation-delay: .24s; }

/* ============================================================
   Responsive tweaks
   ============================================================ */
@media (max-width:480px){
  .container{ width:calc(100% - 32px); }
}
@media (min-width:1280px){ :root{ --container:1160px; } }

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.001ms !important;
    transition-duration:.001ms !important;
  }
  html{ scroll-behavior:auto; }
  .reveal{ opacity:1; transform:none; }
}
@media print{
  .header,.footer,.toast,.burger,.mobilePanel,.ctaSection{ display:none !important; }
}
