
:root {
  --sand: #fff6e8;
  --sand-2: #f8ead4;
  --sun: #ffb84d;
  --sun-2: #ff8f4a;
  --terra: #c86f43;
  --cactus: #2f6b57;
  --cactus-2: #1e4f43;
  --ink: #22302d;
  --muted: #65716d;
  --paper: #ffffff;
  --line: rgba(34,48,45,.14);
  --sky: #dff6fb;
  --blue: #407b8f;
  --shadow: 0 20px 50px rgba(34,48,45,.14);
  --radius: 24px;
  --radius-sm: 16px;
  --max: 1180px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background: linear-gradient(180deg, var(--sand) 0%, #fff 44%, #fff9ef 100%);
  color: var(--ink);
  line-height: 1.55;
  overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
a:hover { color: var(--cactus); }
img, svg { max-width: 100%; display: block; }
.skip-link { position:absolute; left:-999px; top:auto; width:1px; height:1px; overflow:hidden; }
.skip-link:focus { left:16px; top:16px; width:auto; height:auto; padding:10px 14px; background:#fff; z-index:9999; border-radius:10px; box-shadow:var(--shadow); }
.container { width: min(var(--max), calc(100% - 32px)); margin-inline: auto; }
.header {
  position: sticky; top: 0; z-index: 1000; backdrop-filter: blur(18px);
  background: rgba(255,246,232,.88); border-bottom: 1px solid var(--line);
}
.nav { display:flex; align-items:center; justify-content:space-between; gap:16px; min-height:76px; }

.logo { display:flex; align-items:center; gap:10px; color: var(--ink); line-height:1; flex:0 0 auto; }
.site-logo-img { display:block; width:auto; object-fit:contain; }
.header .site-logo-img { height:58px; max-width:320px; border-radius:10px; }
.footer .site-logo-img { height:78px; max-width:330px; border-radius:12px; background:#fff; padding:4px; }
.logo-mark { width:46px; height:46px; border-radius:14px; background: linear-gradient(135deg,var(--sun),var(--terra)); display:grid; place-items:center; box-shadow:0 10px 24px rgba(200,111,67,.25); }
.logo-mark svg { width:31px; height:31px; }
.logo span small { display:block; font-size:12px; color:var(--muted); letter-spacing:.08em; text-transform:uppercase; font-weight:700; margin-top:-4px; }
.brand-banner { padding: 34px 0 12px; }
.brand-banner-card { background:#fff; border:1px solid var(--line); border-radius:30px; overflow:hidden; box-shadow:var(--shadow); }
.brand-banner-card img { width:100%; height:auto; display:block; }
.asset-grid { display:grid; grid-template-columns: repeat(3,1fr); gap:18px; }
.asset-card { background:#fff; border:1px solid var(--line); border-radius:22px; padding:16px; box-shadow:0 14px 34px rgba(34,48,45,.06); }
.asset-card img { width:100%; border-radius:16px; background:#fff; border:1px solid rgba(34,48,45,.08); }
.asset-card h3 { font-size:20px; margin:14px 0 8px; }
.asset-card p { color:var(--muted); margin:0 0 14px; font-size:14px; }
.asset-downloads { display:flex; flex-wrap:wrap; gap:8px; }
@media (max-width:1080px){ .header .site-logo-img { height:52px; max-width:260px; } }
@media (max-width:760px){ .header .site-logo-img { height:46px; max-width:190px; } .asset-grid { grid-template-columns:1fr; } }

.nav-links { display:flex; align-items:center; gap:4px; }
.nav-links a { padding:10px 12px; border-radius:999px; color:var(--muted); font-weight:750; font-size:14px; }
.nav-links a:hover, .nav-links a[aria-current="page"] { background:rgba(47,107,87,.10); color:var(--cactus-2); }
.nav-ctas { display:flex; align-items:center; gap:10px; }
.btn { display:inline-flex; align-items:center; justify-content:center; gap:9px; min-height:46px; padding:12px 18px; border-radius:999px; border:1px solid transparent; font-weight:850; transition:.2s ease; cursor:pointer; font-size:15px; }
.btn.primary { background:var(--cactus); color:#fff; box-shadow:0 12px 24px rgba(47,107,87,.24); }
.btn.primary:hover { background:var(--cactus-2); color:#fff; transform:translateY(-1px); }
.btn.secondary { background:#fff; color:var(--cactus-2); border-color:var(--line); }
.btn.secondary:hover { border-color:rgba(47,107,87,.3); transform:translateY(-1px); }
.btn.ghost { background:rgba(255,255,255,.55); border-color:var(--line); color:var(--ink); }
.btn.small { min-height:38px; padding:9px 13px; font-size:13px; }
.menu-toggle { display:none; width:46px; height:46px; border:1px solid var(--line); background:#fff; border-radius:14px; align-items:center; justify-content:center; }
.menu-toggle span { display:block; width:20px; height:2px; background:var(--ink); box-shadow:0 7px 0 var(--ink),0 -7px 0 var(--ink); }
.hero { position:relative; padding:76px 0 56px; overflow:hidden; }
.hero:before { content:""; position:absolute; inset:-120px -80px auto auto; width:480px; height:480px; background:radial-gradient(circle,var(--sun) 0 30%,rgba(255,184,77,.18) 31% 58%,transparent 60%); border-radius:50%; opacity:.62; z-index:-1; }
.hero-grid { display:grid; grid-template-columns: 1.02fr .98fr; gap:44px; align-items:center; }
.eyebrow { display:inline-flex; gap:9px; align-items:center; background:#fff; border:1px solid var(--line); padding:8px 12px; border-radius:999px; color:var(--cactus-2); font-weight:850; font-size:13px; box-shadow:0 10px 26px rgba(34,48,45,.06); }
.eyebrow:before { content:""; width:9px; height:9px; background:var(--sun-2); border-radius:999px; box-shadow:0 0 0 6px rgba(255,143,74,.14); }
h1, h2, h3 { line-height:1.05; letter-spacing:-.045em; margin:0; }
h1 { font-size: clamp(42px, 7vw, 82px); margin-top:18px; max-width: 850px; }
h2 { font-size: clamp(32px, 4.3vw, 58px); }
h3 { font-size: clamp(21px, 2.2vw, 30px); }
p.lead { font-size: clamp(18px,2vw,22px); color:var(--muted); max-width: 680px; margin: 20px 0 0; }
.hero-actions { display:flex; flex-wrap:wrap; gap:12px; margin-top:28px; }
.hero-note { margin-top:18px; color:var(--muted); font-size:14px; display:flex; flex-wrap:wrap; gap:10px; align-items:center; }
.hero-note span { display:inline-flex; align-items:center; gap:6px; }
.dot { width:8px; height:8px; border-radius:999px; background:var(--cactus); }
.art-card { background:rgba(255,255,255,.74); border:1px solid var(--line); border-radius:36px; box-shadow:var(--shadow); padding:18px; position:relative; overflow:hidden; }
.art-card:after { content:""; position:absolute; inset:auto -60px -90px auto; width:220px; height:220px; background:rgba(64,123,143,.12); border-radius:50%; z-index:0; }
.slider { position:relative; z-index:1; min-height:420px; }
.slide { display:none; }
.slide.active { display:block; animation:fadeUp .55s ease both; }
@keyframes fadeUp { from { opacity:0; transform:translateY(10px)} to { opacity:1; transform:translateY(0)} }
.slide img { width:100%; height:310px; object-fit:contain; border-radius:28px; background:linear-gradient(180deg,var(--sky),#fff1d5); }
.slide-caption { padding:18px 12px 6px; }
.slide-caption strong { font-size:23px; letter-spacing:-.03em; }
.slide-caption p { margin:6px 0 0; color:var(--muted); }
.slider-controls { display:flex; gap:8px; justify-content:center; margin-top:12px; }
.slider-controls button { width:11px; height:11px; border-radius:999px; border:0; background:rgba(34,48,45,.22); cursor:pointer; }
.slider-controls button.active { width:28px; background:var(--cactus); }
.trust-strip { padding: 4px 0 34px; }
.trust-grid { display:grid; grid-template-columns: repeat(6, 1fr); gap:12px; }
.trust-item { background:#fff; border:1px solid var(--line); border-radius:18px; padding:16px 12px; text-align:center; font-weight:850; color:var(--cactus-2); box-shadow:0 10px 28px rgba(34,48,45,.05); }
.section { padding: 72px 0; }
.section.tight { padding:48px 0; }
.section-head { display:flex; align-items:flex-end; justify-content:space-between; gap:24px; margin-bottom:28px; }
.section-head p { max-width:620px; color:var(--muted); margin:12px 0 0; font-size:17px; }
.grid { display:grid; gap:18px; }
.grid.cards-3 { grid-template-columns: repeat(3,1fr); }
.grid.cards-4 { grid-template-columns: repeat(4,1fr); }
.grid.cards-2 { grid-template-columns: repeat(2,1fr); }
.card { background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:24px; box-shadow:0 14px 34px rgba(34,48,45,.06); position:relative; overflow:hidden; }
.card h3 { font-size:24px; margin-bottom:10px; }
.card p { color:var(--muted); margin:0; }
.icon-bubble { width:54px; height:54px; border-radius:18px; background:linear-gradient(135deg,rgba(255,184,77,.30),rgba(47,107,87,.14)); display:grid; place-items:center; margin-bottom:16px; font-size:25px; }
.split { display:grid; grid-template-columns:.9fr 1.1fr; gap:36px; align-items:center; }
.panel { background:linear-gradient(135deg,#fff,var(--sand)); border:1px solid var(--line); border-radius:36px; padding:34px; box-shadow:var(--shadow); }
.bullets { display:grid; gap:12px; margin:22px 0 0; padding:0; list-style:none; }
.bullets li { display:flex; gap:10px; align-items:flex-start; color:var(--muted); }
.bullets li:before { content:"✓"; width:24px; height:24px; flex:0 0 24px; border-radius:999px; background:rgba(47,107,87,.12); color:var(--cactus-2); display:grid; place-items:center; font-weight:900; }
.ribbon { display:inline-flex; padding:7px 10px; border-radius:999px; background:rgba(255,143,74,.13); color:#9a4a2b; font-weight:850; font-size:13px; }
.cta-band { background:linear-gradient(135deg,var(--cactus-2),var(--cactus)); color:#fff; border-radius:36px; padding:40px; display:grid; grid-template-columns:1.2fr auto; align-items:center; gap:24px; box-shadow:var(--shadow); position:relative; overflow:hidden; }
.cta-band:after { content:""; position:absolute; width:320px; height:320px; right:-110px; top:-130px; background:rgba(255,184,77,.20); border-radius:50%; }
.cta-band p { margin:12px 0 0; color:rgba(255,255,255,.78); font-size:18px; max-width:720px; }
.cta-band .btn { position:relative; z-index:2; }
.cta-band .secondary { color:var(--cactus-2); }
.price { font-size:42px; font-weight:950; letter-spacing:-.06em; color:var(--cactus-2); }
.price small { font-size:15px; color:var(--muted); font-weight:800; letter-spacing:0; }
.steps { counter-reset:step; }
.step { position:relative; padding-left:70px; }
.step:before { counter-increment:step; content:counter(step); position:absolute; left:24px; top:24px; width:34px; height:34px; border-radius:12px; background:var(--cactus); color:#fff; display:grid; place-items:center; font-weight:950; }
.faq { display:grid; gap:12px; }
details { background:#fff; border:1px solid var(--line); border-radius:18px; padding:0; box-shadow:0 8px 22px rgba(34,48,45,.04); }
summary { cursor:pointer; padding:18px 20px; font-weight:850; list-style:none; }
summary::-webkit-details-marker { display:none; }
details p { margin:0; padding:0 20px 20px; color:var(--muted); }
.form { display:grid; gap:14px; }
.form label { display:grid; gap:6px; color:var(--ink); font-weight:800; font-size:14px; }
.form input, .form select, .form textarea { width:100%; border:1px solid var(--line); border-radius:16px; padding:13px 14px; font:inherit; background:#fff; color:var(--ink); outline:none; }
.form input:focus, .form select:focus, .form textarea:focus { border-color:rgba(47,107,87,.5); box-shadow:0 0 0 4px rgba(47,107,87,.10); }
.form textarea { min-height:120px; resize:vertical; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.share-row { display:flex; flex-wrap:wrap; gap:9px; margin-top:18px; }
.share-btn { display:inline-flex; align-items:center; gap:7px; padding:9px 11px; border-radius:999px; border:1px solid var(--line); background:#fff; color:var(--muted); font-weight:800; font-size:13px; cursor:pointer; }
.share-btn:hover { color:var(--cactus-2); border-color:rgba(47,107,87,.3); }
.floating-share { position:fixed; left:14px; top:44%; transform:translateY(-50%); display:flex; flex-direction:column; gap:8px; z-index:900; }
.floating-share .share-btn { width:42px; height:42px; padding:0; justify-content:center; border-radius:14px; box-shadow:0 8px 22px rgba(34,48,45,.12); }
.floating-share span.text { display:none; }
.article-list { display:grid; grid-template-columns:repeat(2,1fr); gap:18px; }
.article-card { display:block; min-height:210px; }
.tag { display:inline-flex; background:rgba(64,123,143,.12); color:var(--blue); padding:6px 9px; border-radius:999px; font-size:12px; font-weight:900; margin-bottom:14px; }
.article-hero { padding:58px 0 36px; }
.article-content { max-width:820px; margin:0 auto; font-size:18px; }
.article-content p, .article-content li { color:var(--muted); }
.article-content h2 { margin-top:42px; font-size:38px; }
.article-content h3 { margin-top:30px; font-size:26px; }
.article-content a { color:var(--cactus-2); font-weight:850; text-decoration:underline; text-decoration-thickness:2px; text-underline-offset:3px; }
.local-links { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.local-links a { background:#fff; border:1px solid var(--line); padding:15px; border-radius:16px; font-weight:850; color:var(--cactus-2); }
.footer { background:#1d2a27; color:#fff; padding:60px 0 96px; }
.footer-grid { display:grid; grid-template-columns:1.35fr .85fr .85fr 1fr; gap:26px; }
.footer a { color:rgba(255,255,255,.78); }
.footer a:hover { color:#fff; }
.footer h3 { font-size:16px; letter-spacing:.02em; margin-bottom:14px; }
.footer p { color:rgba(255,255,255,.72); margin:10px 0 0; }
.footer ul { list-style:none; padding:0; margin:0; display:grid; gap:9px; }
.subfooter { border-top:1px solid rgba(255,255,255,.12); margin-top:34px; padding-top:22px; color:rgba(255,255,255,.6); display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap; }
.mobile-sticky { display:none; position:fixed; bottom:0; left:0; right:0; z-index:1100; background:#fff; border-top:1px solid var(--line); box-shadow:0 -12px 30px rgba(34,48,45,.10); padding:8px 10px calc(8px + env(safe-area-inset-bottom)); }
.mobile-sticky a { flex:1; min-height:46px; font-size:13px; padding:8px 6px; }
.breadcrumbs { color:var(--muted); font-size:14px; margin-bottom:18px; }
.breadcrumbs a { color:var(--cactus-2); font-weight:800; }
.notice { background:rgba(255,184,77,.17); border:1px solid rgba(255,184,77,.4); color:#714415; padding:15px 16px; border-radius:18px; }
.map-card iframe { border:0; width:100%; min-height:320px; border-radius:24px; filter:saturate(.8); }
@media (max-width: 1080px) {
  .nav-links { position:absolute; inset:76px 16px auto 16px; background:#fff; border:1px solid var(--line); border-radius:22px; padding:12px; box-shadow:var(--shadow); flex-direction:column; align-items:stretch; display:none; }
  .nav-links.open { display:flex; }
  .nav-links a { border-radius:14px; padding:13px 14px; }
  .menu-toggle { display:flex; }
  .nav-ctas .secondary { display:none; }
  .hero-grid, .split { grid-template-columns:1fr; }
  .trust-grid { grid-template-columns:repeat(3,1fr); }
  .grid.cards-4 { grid-template-columns:repeat(2,1fr); }
  .floating-share { display:none; }
}
@media (max-width: 760px) {
  .container { width:min(100% - 22px, var(--max)); }
  .header .btn.primary { display:none; }
  .hero { padding:44px 0 34px; }
  .hero-grid { gap:26px; }
  .art-card { border-radius:26px; padding:10px; }
  .slide img { height:238px; border-radius:20px; }
  .trust-grid, .grid.cards-3, .grid.cards-4, .grid.cards-2, .article-list, .footer-grid, .local-links { grid-template-columns:1fr; }
  .section { padding:52px 0; }
  .section-head { display:block; }
  .cta-band { grid-template-columns:1fr; border-radius:26px; padding:28px; }
  .form-row { grid-template-columns:1fr; }
  .mobile-sticky { display:flex; gap:8px; }
  .footer { padding-bottom:112px; }
  .panel { border-radius:26px; padding:24px; }
  .article-content { font-size:16px; }
}
