:root {
  --ink:#1f2933;
  --muted:#667085;
  --line:#e6e9ef;
  --soft:#f7f3ef;
  --rose:#a45c52;
  --rose2:#7f423a;
  --cream:#fffaf5;
  --gold:#b08d57;
  --green:#51665a;
  --white:#fff;
  --shadow:0 18px 45px rgba(31,41,51,.10);
  --radius:22px}

* {
  box-sizing:border-box}

html {
  scroll-behavior:smooth}

body {
  margin:0;
  font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--ink);
  background:linear-gradient(180deg,#fffaf5 0%,#ffffff 45%,#f8fafc 100%);
  line-height:1.6}

.demo-bar {
  background:#1f2933;
  color:#fff;
  text-align:center;
  padding:10px 16px;
  font-size:14px;
  letter-spacing:.01em}

.demo-bar strong {
  color:#f8d9ce}

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

.top {
  position:sticky;
  top:0;
  z-index:20;
  background:rgba(255,250,245,.9);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(230,233,239,.75)}

.nav {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:16px 0}

.brand {
  display:flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
  color:var(--ink)}

.mark {
  width:44px;
  height:44px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:linear-gradient(145deg,var(--rose),var(--rose2));
  color:#fff;
  font-weight:800;
  box-shadow:0 10px 28px rgba(164,92,82,.25)}

.brand b {
  display:block;
  font-size:18px;
  line-height:1.1}

.brand span {
  display:block;
  font-size:12px;
  color:var(--muted);
  margin-top:2px}

.links {
  display:flex;
  gap:8px;
  align-items:center;
  flex-wrap:wrap;
  justify-content:flex-end}

.links a {
  color:#344054;
  text-decoration:none;
  font-size:14px;
  font-weight:500;
  padding:7px 10px;
  border:1px solid var(--line);
  border-radius:999px;
  background:rgba(255,255,255,.72)}

.links a:hover,.links a.active {
  background:#fff;
  color:var(--rose2);
  box-shadow:0 6px 16px rgba(31,41,51,.08)}

.menu-btn {
  display:none;
  border:1px solid var(--line);
  border-radius:12px;
  background:#fff;
  padding:10px 12px;
  color:var(--ink)}

.hero {
  padding:72px 0 52px}

.hero-grid {
  display:grid;
  grid-template-columns:1.08fr .92fr;
  gap:36px;
  align-items:center}

.eyebrow {
  display:inline-flex;
  gap:8px;
  align-items:center;
  background:#fff;
  border:1px solid var(--line);
  border-radius:999px;
  padding:8px 12px;
  color:var(--green);
  font-weight:700;
  font-size:13px}

.h1 {
  font-family:Georgia,serif;
  font-size:clamp(42px,6vw,76px);
  line-height:.96;
  margin:18px 0 18px;
  letter-spacing:-.04em;
  color:#222}

.lead {
  font-size:19px;
  color:#475467;
  max-width:680px}

.cta-row {
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:28px}

.btn {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  padding:13px 18px;
  text-decoration:none;
  font-weight:800;
  border:1px solid transparent}

.btn.primary {
  background:var(--rose2);
  color:#fff;
  box-shadow:0 12px 28px rgba(127,66,58,.22)}

.btn.secondary {
  background:#fff;
  color:var(--rose2);
  border-color:var(--line)}

.hero-card {
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  overflow:hidden}

.portrait {
  min-height:315px;
  background:radial-gradient(circle at 35% 20%,#f4d8cd,transparent 28%),linear-gradient(145deg,#f7eee7,#ffffff 45%,#f2ddd7);
  display:grid;
  place-items:center;
  text-align:center;
  padding:32px}

.portrait .circle {
  width:150px;
  height:150px;
  border-radius:50%;
  background:linear-gradient(145deg,#fff,#ecd1ca);
  border:1px solid #e8cfc8;
  display:grid;
  place-items:center;
  font-family:Georgia,serif;
  font-size:56px;
  color:var(--rose2);
  margin:auto}

.hero-card .info {
  padding:24px}

.meta {
  display:grid;
  gap:10px;
  margin-top:16px}

.meta div {
  display:flex;
  gap:10px;
  align-items:flex-start;
  color:#475467;
  font-size:15px}

.section {
  padding:42px 0}

.section h1,.section h2 {
  font-family:Georgia,serif;
  letter-spacing:-.025em;
  line-height:1.08;
  margin:0 0 14px}

.section h1 {
  font-size:clamp(36px,5vw,58px)}

.section h2 {
  font-size:clamp(30px,4vw,44px)}

.section p {
  color:#475467}

.grid {
  display:grid;
  gap:18px}

.grid.three {
  grid-template-columns:repeat(3,1fr)}

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

.card {
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:24px;
  box-shadow:0 10px 30px rgba(31,41,51,.06)}

.card h3 {
  margin:0 0 8px;
  font-size:20px}

.pill {
  display:inline-block;
  border:1px solid #eadbd4;
  background:#fff8f4;
  color:var(--rose2);
  padding:5px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:800;
  margin-bottom:12px}

.feature-list {
  padding-left:19px;
  color:#475467}

.feature-list li {
  margin:8px 0}

.page-head {
  padding:48px 0 20px;
  border-bottom:1px solid rgba(230,233,239,.65)}

.page-head p {
  font-size:18px;
  max-width:800px}

.timeline {
  display:grid;
  gap:16px}

.timeline-item {
  display:grid;
  grid-template-columns:130px 1fr;
  gap:18px;
  align-items:start}

.date {
  font-weight:900;
  color:var(--rose2)}

.quote {
  font-family:Georgia,serif;
  font-size:22px;
  line-height:1.35;
  color:#334155}

.placeholder {
  border:1.5px dashed #d6c0b8;
  border-radius:18px;
  background:#fffaf7;
  min-height:170px;
  display:grid;
  place-items:center;
  text-align:center;
  color:#7a5d55;
  padding:20px}

.form {
  display:grid;
  gap:14px}

.form label {
  font-weight:800;
  font-size:14px}

.form input,.form textarea,.form select {
  width:100%;
  padding:13px 14px;
  border:1px solid var(--line);
  border-radius:14px;
  font:inherit;
  background:#fff}

.form textarea {
  min-height:130px}

.notice {
  background:#fff8f4;
  border:1px solid #eadbd4;
  border-radius:18px;
  padding:18px;
  color:#6b4a43}

.footer {
  margin-top:52px;
  background:#1f2933;
  color:#d0d5dd;
  padding:34px 0}

.footer-grid {
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:24px}

.footer a {
  color:#fff;
  text-decoration:none}

.small {
  font-size:13px;
  color:#98a2b3}

.badge-row {
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:12px}

.badge {
  background:#f8fafc;
  border:1px solid var(--line);
  border-radius:999px;
  padding:7px 10px;
  font-size:13px;
  color:#475467}

.table {
  width:100%;
  border-collapse:collapse;
  background:#fff;
  border-radius:18px;
  overflow:hidden;
  border:1px solid var(--line)}

.table th,.table td {
  text-align:left;
  padding:14px;
  border-bottom:1px solid var(--line);
  vertical-align:top}

.table th {
  background:#f9fafb;
  color:#344054}

.table tr:last-child td {
  border-bottom:0}

@media(max-width:880px) {
  .hero-grid,.grid.three,.grid.two,.footer-grid {
  grid-template-columns:1fr}

.links {
  display:none;
  position:absolute;
  left:18px;
  right:18px;
  top:76px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  padding:12px;
  box-shadow:var(--shadow);
  justify-content:flex-start}

.links.open {
  display:flex}

.links a {
  width:100%}

.menu-btn {
  display:inline-flex}

.hero {
  padding-top:44px}

.timeline-item {
  grid-template-columns:1fr;
  gap:4px}

}

@media(max-width:520px) {
  .wrap {
  width:min(100% - 24px,1120px)}

.cta-row .btn {
  width:100%}

.card {
  padding:20px}

.h1 {
  font-size:42px}

.table {
  font-size:14px}

.table th,.table td {
  padding:10px}

.brand b {
  font-size:16px}

.mark {
  width:38px;
  height:38px}

}
