:root{
  --bg:#f6f4ef;
  --surface:#ffffff;
  --surface-2:#f0ede6;
  --ink:#17212b;
  --muted:#5d6773;
  --line:rgba(23,33,43,.1);
  --accent:#d7a74b;
  --accent-2:#0f2f46;
  --success:#1d7f52;
  --shadow:0 18px 50px rgba(16,30,44,.08);
  --radius:24px;
  --max:1180px;
}
[data-theme="dark"]{
  --bg:#0d1720;
  --surface:#12202c;
  --surface-2:#162735;
  --ink:#f7f8fa;
  --muted:#b8c4cf;
  --line:rgba(255,255,255,.1);
  --accent:#efbc5a;
  --accent-2:#9ed0ff;
  --shadow:0 20px 60px rgba(0,0,0,.35);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:linear-gradient(180deg,var(--bg),color-mix(in srgb, var(--bg) 88%, #fff 12%));color:var(--ink);line-height:1.6}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(calc(100% - 2rem),var(--max));margin:0 auto}
.topbar{position:sticky;top:0;z-index:99;backdrop-filter:blur(16px);background:color-mix(in srgb, var(--bg) 80%, transparent);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:.9rem 0;gap:1rem}
.brand{display:flex;align-items:center;gap:.85rem;font-weight:800;letter-spacing:.01em}
.brand-mark{width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,var(--accent),#f7d698);display:grid;place-items:center;color:#1d1d1d;font-weight:900;box-shadow:var(--shadow)}
.brand small{display:block;font-size:.74rem;color:var(--muted);font-weight:600}
.nav-links{display:flex;align-items:center;gap:1.15rem;flex-wrap:wrap}
.nav-links a{font-weight:600;color:var(--muted)}
.nav-links a:hover,.nav-links a[aria-current="page"]{color:var(--ink)}
.nav-actions{display:flex;align-items:center;gap:.7rem}
.btn,.btn-secondary,.toggle-btn{display:inline-flex;align-items:center;justify-content:center;border:none;border-radius:999px;padding:.95rem 1.2rem;font-weight:800;cursor:pointer;transition:.25s ease;box-shadow:var(--shadow)}
.btn{background:linear-gradient(135deg,var(--accent),#efcb84);color:#161616}
.btn:hover{transform:translateY(-1px)}
.btn-secondary,.toggle-btn{background:var(--surface);color:var(--ink);border:1px solid var(--line)}
.hamburger{display:none;background:var(--surface);border:1px solid var(--line);width:46px;height:46px;border-radius:14px;align-items:center;justify-content:center;flex-direction:column;gap:4px;cursor:pointer}
.hamburger span{width:18px;height:2px;background:var(--ink);border-radius:2px}
.hero{padding:4.25rem 0 2.5rem}
.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:1.5rem;align-items:stretch}
.hero-card,.card{background:var(--surface);border:1px solid var(--line);border-radius:32px;box-shadow:var(--shadow);overflow:hidden}
.hero-copy{padding:clamp(1.4rem,3.5vw,3rem)}
.kicker{display:inline-flex;align-items:center;gap:.5rem;padding:.45rem .8rem;border-radius:999px;background:color-mix(in srgb, var(--accent) 16%, transparent);font-weight:800;color:var(--accent-2);font-size:.88rem;margin-bottom:1rem}
h1,h2,h3{line-height:1.1;margin:.15rem 0 1rem}
h1{font-size:clamp(2.4rem,5vw,4.9rem);letter-spacing:-.045em}
h2{font-size:clamp(1.75rem,3vw,3rem);letter-spacing:-.035em}
h3{font-size:clamp(1.1rem,2vw,1.45rem)}
.lead{font-size:clamp(1.05rem,1.8vw,1.28rem);color:var(--muted)}
.hero-actions{display:flex;gap:.8rem;flex-wrap:wrap;margin:1.4rem 0 1.1rem}
.hero-points,.check-list{display:grid;gap:.75rem;margin:1.2rem 0 0;padding:0;list-style:none}
.hero-points li,.check-list li{display:flex;gap:.75rem;align-items:flex-start;color:var(--muted)}
.dot{min-width:28px;width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#f3d08d);display:grid;place-items:center;color:#171717;font-weight:900}
.hero-media{position:relative;min-height:480px;background:#d7d0c5}
.hero-media img{width:100%;height:100%;object-fit:cover}
.hero-badge{position:absolute;bottom:22px;left:22px;right:22px;background:rgba(255,255,255,.88);backdrop-filter:blur(8px);border-radius:22px;padding:1rem 1.1rem;border:1px solid rgba(255,255,255,.55)}
[data-theme="dark"] .hero-badge{background:rgba(10,17,24,.82);border-color:rgba(255,255,255,.08)}
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin:1.25rem 0 0}
.stat{background:var(--surface);border:1px solid var(--line);padding:1.2rem;border-radius:22px;box-shadow:var(--shadow)}
.stat strong{display:block;font-size:1.7rem}
.section{padding:2rem 0 4rem}
.grid-2,.grid-3,.grid-4{display:grid;gap:1.25rem}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.panel{background:var(--surface);border:1px solid var(--line);border-radius:28px;padding:1.35rem;box-shadow:var(--shadow)}
.panel-image{border-radius:24px;overflow:hidden;aspect-ratio: 4 / 3;margin-bottom:1rem}
.panel-image.tall{aspect-ratio: 3 / 4}
.panel-image img{width:100%;height:100%;object-fit:cover}
.eyebrow{font-size:.8rem;letter-spacing:.12em;color:var(--muted);text-transform:uppercase;font-weight:800}
.price{font-size:2.1rem;font-weight:900;letter-spacing:-.04em;margin:.4rem 0}
.muted{color:var(--muted)}
.highlight{background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 18%, transparent), transparent);border-left:4px solid var(--accent)}
.split{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;align-items:center}
.ribbon{display:inline-flex;padding:.4rem .75rem;border-radius:999px;background:color-mix(in srgb, var(--accent) 14%, transparent);font-weight:800;color:var(--accent-2);font-size:.82rem}
.quote-box{background:linear-gradient(160deg,color-mix(in srgb, var(--surface) 82%, #fff 18%),var(--surface));padding:1.2rem;border:1px solid var(--line);border-radius:24px}
.gallery{columns:3 260px;column-gap:1rem}
.gallery figure{break-inside:avoid;margin:0 0 1rem;background:var(--surface);padding:.5rem;border-radius:22px;border:1px solid var(--line);box-shadow:var(--shadow)}
.gallery img{border-radius:18px}
.callout{padding:1.25rem;border-radius:24px;background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 14%, transparent), transparent);border:1px solid var(--line)}
.form-wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:1.25rem}
form{display:grid;gap:1rem}
label{font-weight:700;font-size:.96rem}
input,select,textarea{width:100%;margin-top:.42rem;padding:.95rem 1rem;border-radius:16px;border:1px solid var(--line);background:var(--surface);color:var(--ink);font:inherit}
textarea{min-height:120px;resize:vertical}
.field-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.options-box{display:grid;gap:.85rem}
.check-option{display:grid;grid-template-columns:auto 1fr auto;gap:.8rem;align-items:start;padding:.9rem 1rem;border:1px solid var(--line);border-radius:18px;background:var(--surface-2)}
.check-option input{width:18px;height:18px;margin:.2rem 0 0}
.check-option strong{display:block}
.cost-pill{font-weight:900;color:var(--accent-2)}
.estimate{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.1rem;border-radius:18px;background:var(--surface-2);border:1px solid var(--line);font-weight:800}
.small{font-size:.9rem;color:var(--muted)}
.accordion details{background:var(--surface);border:1px solid var(--line);padding:1rem 1.1rem;border-radius:18px}
.accordion details+details{margin-top:.9rem}
.accordion summary{cursor:pointer;font-weight:800}
.cta-band{background:linear-gradient(135deg,var(--accent-2),#203f55);color:#fdfdfd;border-radius:34px;padding:2rem;box-shadow:var(--shadow)}
.cta-band .btn-secondary{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.2);color:#fff}
.article-list{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.article-card{padding:1.15rem;border:1px solid var(--line);background:var(--surface);border-radius:24px;box-shadow:var(--shadow)}
footer{padding:2rem 0 4rem;color:var(--muted)}
.footer-grid{display:grid;grid-template-columns:1.2fr .8fr .8fr;gap:1.25rem}
.tag-row{display:flex;flex-wrap:wrap;gap:.6rem}.tag{padding:.5rem .8rem;border-radius:999px;background:var(--surface);border:1px solid var(--line);font-weight:700;font-size:.88rem}
.hide-visually{position:absolute !important;left:-9999px !important;top:auto !important;width:1px !important;height:1px !important;overflow:hidden !important}
.notice{padding:1rem 1.1rem;border-radius:20px;background:color-mix(in srgb, var(--success) 10%, transparent);border:1px solid color-mix(in srgb, var(--success) 35%, transparent)}
.page-hero{padding:2.2rem 0 1rem}
.page-hero .panel{padding:2rem}
.inline-image{border-radius:24px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
.mobile-drawer{display:none}
@media (max-width: 980px){
  .hero-grid,.split,.form-wrap,.grid-2,.footer-grid,.article-list{grid-template-columns:1fr}
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .stat-grid{grid-template-columns:repeat(2,1fr)}
  .nav-links,.nav-actions .desktop-only{display:none}
  .hamburger{display:flex}
  .mobile-drawer{display:none;position:fixed;inset:72px 0 auto 0;background:color-mix(in srgb, var(--bg) 97%, transparent);backdrop-filter:blur(16px);padding:1rem;border-bottom:1px solid var(--line);z-index:98}
  .mobile-drawer.open{display:grid;gap:.85rem}
  .mobile-drawer a,.mobile-drawer button{padding:1rem;border-radius:18px;background:var(--surface);border:1px solid var(--line);font-weight:700;text-align:left}
  .field-grid{grid-template-columns:1fr}
}
@media (max-width: 640px){
  .hero{padding:2.1rem 0 1.5rem}
  .hero-media{min-height:340px}
  .hero-copy{padding:1.2rem}
  .section{padding:1.2rem 0 2.6rem}
  .grid-3,.grid-4,.stat-grid{grid-template-columns:1fr}
  h1{font-size:2.2rem}
  .btn,.btn-secondary{width:100%}
  .hero-actions{display:grid;grid-template-columns:1fr}
}

html{scroll-behavior:smooth}.section-intro{max-width:820px;margin:0 0 1.4rem}.gallery-gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;align-items:start}.gallery-gallery .panel{padding:.65rem}.stacked-media{display:grid;gap:1rem}.media-strip{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.media-strip img{width:100%;height:240px;object-fit:cover;border-radius:22px;border:1px solid var(--line);box-shadow:var(--shadow)}
@media (max-width:980px){.gallery-gallery{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.gallery-gallery,.media-strip{grid-template-columns:1fr}.media-strip img{height:180px}}