:root {
  --ink: #18263d;
  --muted: #647083;
  --cream: #fcf8f2;
  --paper: #ffffff;
  --aqua: #dff1f1;
  --teal: #147d87;
  --teal-dark: #0d626b;
  --coral: #ed625d;
  --peach: #f8ddd4;
  --gold: #eeb84f;
  --line: #e7e4df;
  --shadow-sm: 0 10px 30px rgba(24, 38, 61, .08);
  --shadow-lg: 0 28px 70px rgba(24, 38, 61, .14);
  --radius-sm: 14px;
  --radius-md: 24px;
  --radius-lg: 36px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--cream); font-family: "DM Sans", sans-serif; font-size: 16px; line-height: 1.65; -webkit-font-smoothing: antialiased; }
img { display: block; max-width: 100%; }
a { color: inherit; }
.wrap { width: min(1120px, calc(100% - 48px)); margin-inline: auto; }

h1, h2, h3 { margin: 0; font-family: "Playfair Display", serif; font-weight: 700; text-wrap: balance; }
h1 { max-width: 700px; font-size: clamp(3rem, 5.6vw, 5rem); line-height: .98; letter-spacing: -.045em; }
h2 { font-size: clamp(2.15rem, 4vw, 3.35rem); line-height: 1.05; letter-spacing: -.03em; }
h3 { font-size: 1.55rem; line-height: 1.2; letter-spacing: -.015em; }
p { margin: 0; }
.eyebrow { margin-bottom: 16px; color: var(--teal-dark); font-size: .75rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; }
.lead { max-width: 590px; margin-top: 24px; color: var(--muted); font-size: 1.125rem; line-height: 1.7; }

.btn { min-height: 52px; display: inline-flex; align-items: center; justify-content: center; gap: 12px; padding: 13px 24px; border-radius: 999px; background: var(--teal); color: #fff; font-size: .94rem; font-weight: 700; text-decoration: none; box-shadow: 0 8px 20px rgba(20, 125, 135, .2); transition: background .2s ease, transform .2s ease, box-shadow .2s ease; }
.btn:hover { background: var(--teal-dark); transform: translateY(-2px); box-shadow: 0 12px 25px rgba(20, 125, 135, .25); }
.btn:focus-visible, a:focus-visible, summary:focus-visible { outline: 3px solid var(--gold); outline-offset: 4px; }
.btn.small { min-height: 42px; padding: 9px 18px; font-size: .875rem; }
.btn.full { width: 100%; }
.text-link { color: var(--teal-dark); font-weight: 700; text-decoration-thickness: 1px; text-underline-offset: 5px; }

.announcement { padding: 8px 20px; background: var(--ink); color: #fff; text-align: center; font-size: .78rem; font-weight: 600; letter-spacing: .02em; }
header { position: sticky; top: 0; z-index: 20; border-bottom: 1px solid rgba(24, 38, 61, .08); background: rgba(252, 248, 242, .94); backdrop-filter: blur(14px); }
nav { min-height: 72px; display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.brand { display: flex; align-items: center; gap: 11px; font-family: "Playfair Display", serif; font-size: 1.2rem; font-weight: 700; text-decoration: none; }
.brand-mark { width: 42px; height: 42px; display: grid; place-items: center; border-radius: 50%; background: var(--coral); color: #fff; font-family: "Playfair Display", serif; font-size: 1.25rem; font-style: italic; }
.navlinks { display: flex; align-items: center; gap: 28px; }
.navlinks > a:not(.btn) { font-size: .875rem; font-weight: 600; text-decoration: none; }
.navlinks > a:not(.btn):hover { color: var(--teal-dark); }

.hero { position: relative; overflow: hidden; padding: 88px 0 104px; }
.hero::before { content: ""; position: absolute; right: -180px; top: -240px; width: 560px; height: 560px; border-radius: 50%; background: var(--aqua); opacity: .8; }
.hero-grid { position: relative; display: grid; grid-template-columns: 1.08fr .92fr; align-items: center; gap: 80px; }
.actions { display: flex; align-items: center; flex-wrap: wrap; gap: 20px; margin: 32px 0 24px; }
.trust { display: flex; flex-wrap: wrap; gap: 10px 18px; color: var(--muted); font-size: .8rem; }
.trust span { display: inline-flex; align-items: center; gap: 7px; }
.trust span::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--coral); }

.hero-visual { position: relative; min-height: 560px; }
.hero-visual::before { content: ""; position: absolute; inset: 28px 22px 24px 18px; border-radius: 190px 190px 32px 32px; background: linear-gradient(145deg, #ccebed, #f8ded5); }
.hero-crop { position: absolute; overflow: hidden; background: #fff; box-shadow: var(--shadow-lg); }
.hero-crop img { width: 100%; height: 100%; object-fit: cover; }
.hero-crop-main { left: 0; top: 0; width: 78%; height: 490px; border: 10px solid #fff; border-radius: 170px 170px 24px 24px; }
.hero-crop-main img { object-position: 51% 42%; transform: scale(1.2); }
.hero-crop-small { right: 0; bottom: 0; width: 47%; height: 230px; border: 7px solid #fff; border-radius: 22px; }
.hero-crop-small img { object-position: 50% 46%; transform: scale(1.32); }

.support, .products, .inside, .steps-section, .faq { padding: 104px 0; }
.support, .steps-section { background: #fff; }
.section-head { max-width: 760px; margin: 0 auto 52px; text-align: center; }
.section-head > p:last-child { max-width: 640px; margin: 20px auto 0; color: var(--muted); }

.support-grid { display: grid; grid-template-columns: repeat(5, 1fr); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.support-card { min-height: 150px; display: flex; flex-direction: column; justify-content: center; gap: 16px; padding: 24px; border-right: 1px solid var(--line); }
.support-card:last-child { border-right: 0; }
.support-card i { color: var(--coral); font-size: .7rem; font-style: normal; font-weight: 700; letter-spacing: .12em; }
.support-card b { max-width: 145px; font-size: .9rem; line-height: 1.45; }

.product-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; }
.product { overflow: hidden; display: flex; flex-direction: column; border: 1px solid rgba(24, 38, 61, .07); border-radius: var(--radius-md); background: var(--paper); box-shadow: var(--shadow-sm); }
.product-image { position: relative; height: 410px; display: grid; place-items: center; padding: 24px; background: #f7fbfb; }
.product:nth-child(2) .product-image { background: #fdf6f3; }
.product-image img { width: 100%; height: 100%; object-fit: contain; }
.product-image span { position: absolute; left: 18px; top: 18px; z-index: 1; padding: 7px 12px; border-radius: 999px; background: var(--ink); color: #fff; font-size: .7rem; font-weight: 700; }
.product-body { flex: 1; display: flex; flex-direction: column; padding: 30px; }
.product-body p { margin: 14px 0 20px; color: var(--muted); }
.product-body .btn { margin-top: auto; }
.language-tags { display: flex; gap: 8px; margin-bottom: 22px; }
.language-tags b { padding: 6px 12px; border-radius: 999px; background: var(--aqua); color: var(--teal-dark); font-size: .72rem; }

.inside { background: var(--aqua); }
.inside-grid { display: grid; grid-template-columns: .92fr 1.08fr; align-items: center; gap: 76px; }
.inside-grid > div:last-child > p:not(.eyebrow) { max-width: 570px; margin-top: 20px; color: var(--muted); }
.language-panel { position: relative; min-height: 430px; display: grid; place-items: center; overflow: hidden; border-radius: var(--radius-lg); background: var(--ink); color: #fff; box-shadow: var(--shadow-lg); text-align: center; }
.language-panel strong { position: relative; font-family: "Playfair Display", serif; font-size: clamp(2.7rem, 5vw, 4.4rem); line-height: .98; }
.language-panel strong i { color: #79d3da; font-size: .5em; }
.language-panel > span { position: absolute; font-size: 8rem; font-weight: 700; opacity: .05; }
.language-panel > span:first-child { left: -10px; top: -38px; }
.language-panel > span:nth-child(2) { right: -10px; bottom: -45px; }
.checks { display: grid; gap: 14px; margin: 28px 0 32px; }
.checks p { display: flex; align-items: flex-start; gap: 12px; }
.checks b { flex: 0 0 25px; height: 25px; display: grid; place-items: center; border-radius: 50%; background: #fff; color: var(--teal-dark); font-size: .75rem; }

.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.step { padding: 32px; border: 1px solid var(--line); border-radius: var(--radius-sm); background: var(--paper); }
.step em { display: block; margin-bottom: 28px; color: var(--coral); font-size: .72rem; font-style: normal; font-weight: 700; letter-spacing: .12em; }
.step p { margin-top: 12px; color: var(--muted); }

.quote { padding: 88px 0; background: var(--peach); text-align: center; }
.quote blockquote { max-width: 820px; margin: 0 auto; font-family: "Playfair Display", serif; font-size: clamp(1.9rem, 3.7vw, 2.9rem); font-style: italic; line-height: 1.3; text-wrap: balance; }

.faq-wrap { max-width: 780px; }
.faq details { border-bottom: 1px solid var(--line); }
.faq summary { min-height: 68px; display: flex; align-items: center; justify-content: space-between; gap: 24px; cursor: pointer; list-style: none; font-weight: 700; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; color: var(--teal); font-size: 1.4rem; font-weight: 400; }
.faq details[open] summary::after { content: "-"; }
.faq details p { max-width: 680px; padding: 0 40px 22px 0; color: var(--muted); }
.faq details p a { color: var(--teal-dark); font-weight: 600; }

.closing { padding: 0 0 104px; }
.closing-box { position: relative; overflow: hidden; padding: 72px 36px; border-radius: var(--radius-lg); background: var(--ink); color: #fff; text-align: center; }
.closing-box::before { content: ""; position: absolute; left: -80px; top: -90px; width: 220px; height: 220px; border: 48px solid rgba(255, 255, 255, .05); border-radius: 50%; }
.closing-box .eyebrow { color: #8fd5d9; }
.closing-box h2 { max-width: 650px; margin-inline: auto; }
.closing-box > p:not(.eyebrow) { margin: 18px 0 26px; color: #cbd3dc; }
.btn.light { position: relative; background: #fff; color: var(--ink); box-shadow: none; }
.btn.light:hover { background: var(--aqua); }

footer { padding: 42px 0 48px; color: var(--muted); text-align: center; font-size: .82rem; }
.footer-mark { margin: 0 auto 14px; }
footer p { max-width: 680px; margin: 0 auto 10px; }
footer a { color: var(--teal-dark); font-weight: 600; }

@media (max-width: 900px) {
  .hero-grid, .inside-grid { grid-template-columns: 1fr; gap: 56px; }
  .hero-visual { width: min(100%, 580px); min-height: 580px; margin-inline: auto; }
  .support-grid { grid-template-columns: repeat(2, 1fr); border: 0; gap: 1px; background: var(--line); }
  .support-card { min-height: 125px; border: 0; background: #fff; }
  .support-card:last-child { grid-column: 1 / -1; }
  .language-panel { width: min(100%, 620px); margin-inline: auto; }
}

@media (max-width: 760px) {
  .navlinks > a:not(.btn) { display: none; }
  .product-grid, .steps { grid-template-columns: 1fr; }
  .product-grid { max-width: 620px; margin-inline: auto; }
}

@media (max-width: 540px) {
  .wrap { width: min(100% - 28px, 1120px); }
  .announcement { padding-inline: 14px; font-size: .7rem; }
  nav { min-height: 64px; }
  .brand { font-size: 1.04rem; }
  .brand-mark { width: 38px; height: 38px; }
  .btn.small { min-height: 38px; padding: 7px 13px; font-size: .78rem; }
  .hero { padding: 56px 0 76px; }
  h1 { font-size: clamp(2.65rem, 13vw, 3.7rem); }
  .lead { font-size: 1rem; }
  .actions { align-items: stretch; }
  .actions .btn { width: 100%; }
  .hero-visual { min-height: 455px; }
  .hero-visual::before { inset: 20px 14px 20px 10px; }
  .hero-crop-main { width: 82%; height: 400px; border-width: 7px; border-radius: 135px 135px 20px 20px; }
  .hero-crop-small { width: 48%; height: 180px; border-width: 5px; }
  .support, .products, .inside, .steps-section, .faq { padding: 76px 0; }
  .section-head { margin-bottom: 38px; }
  .support-grid { grid-template-columns: 1fr; }
  .support-card:last-child { grid-column: auto; }
  .product-image { height: 320px; padding: 14px; }
  .product-body { padding: 24px; }
  .language-panel { min-height: 330px; border-radius: var(--radius-md); }
  .step { padding: 26px; }
  .quote { padding: 68px 0; }
  .closing { padding-bottom: 76px; }
  .closing-box { padding: 56px 22px; border-radius: var(--radius-md); }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .btn { transition: none; }
}
