*{margin:0;padding:0;box-sizing:border-box}
:root{--bg:#f7f5f0;--card:#fffdf9;--ink:#1a2333;--mut:#5f6878;--navy:#1a2f52;--navy-d:#12213c;--gold:#b98a2e;--gold-l:#d7b466;--line:#e5e0d3}
html{scroll-behavior:smooth}
body{font-family:'Red Hat Text',sans-serif;background:var(--bg);color:var(--ink);line-height:1.72;font-size:16.5px;overflow-x:hidden}
h1,h2,h3{font-family:'Libre Baskerville',serif;font-weight:700;line-height:1.28}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1120px;margin:0 auto;padding:0 24px}

.ribbon{background:var(--navy-d);color:#9aa5ba;font-size:13.5px;padding:9px 16px;text-align:center;position:relative;z-index:60}
.ribbon b{color:#f7f5f0}
.ribbon a{display:inline-block;margin-left:12px;background:var(--gold);color:#fff;font-weight:700;padding:3px 14px;border-radius:4px;font-size:13px}
.ribbon a:hover{background:#a67923}

header{position:sticky;top:0;z-index:50;background:rgba(247,245,240,.95);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:74px;max-width:1120px;margin:0 auto;padding:0 24px}
.logo{font-family:'Libre Baskerville',serif;font-weight:700;font-size:18px;display:flex;align-items:center;gap:12px;line-height:1.2}
.logo .zn{width:40px;height:40px;border:1.5px solid var(--gold);border-radius:2px;display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--gold);flex-shrink:0}
.logo small{display:block;font-family:'Red Hat Text',sans-serif;font-weight:500;font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--mut)}
nav.menu{display:flex;gap:28px;align-items:center}
nav.menu a{font-size:14.5px;font-weight:600;color:var(--mut);transition:.15s}
nav.menu a:hover,nav.menu a.on{color:var(--navy)}
.cta-btn{background:var(--navy);color:#fff!important;padding:11px 24px;border-radius:4px;font-weight:600!important}
.cta-btn:hover{background:var(--navy-d)}
.burger{display:none;background:none;border:0;cursor:pointer;padding:8px}
.burger span{display:block;width:26px;height:2px;background:var(--ink);margin:6px 0}

/* hero */
.hero{position:relative;overflow:hidden;background:var(--navy);color:#f7f5f0}
.hero .bgimg{position:absolute;inset:0;background:url(../img/hero.jpg) center/cover;opacity:.34}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(18,33,60,.92) 35%,rgba(18,33,60,.4) 90%)}
.hero .in{position:relative;z-index:2;max-width:1120px;margin:0 auto;padding:92px 24px 100px}
.hero .kicker{display:inline-flex;align-items:center;gap:12px;color:var(--gold-l);font-weight:600;letter-spacing:.2em;text-transform:uppercase;font-size:12px;margin-bottom:22px}
.hero .kicker::before{content:"";width:38px;height:1px;background:var(--gold-l)}
.hero h1{font-size:clamp(30px,4.6vw,52px)}
.hero h1 em{font-style:italic;color:var(--gold-l)}
.hero p{max-width:560px;color:#cdd4e0;font-size:17.5px;margin:20px 0 32px}
.btn{display:inline-block;background:var(--gold);color:#fff;padding:14px 30px;border-radius:4px;font-weight:600;font-size:15.5px;transition:.15s;border:0;cursor:pointer;font-family:'Red Hat Text',sans-serif}
.btn:hover{background:#a67923}
.btn.ghost{background:transparent;border:1.5px solid rgba(247,245,240,.55);color:#f7f5f0}
.btn.ghost:hover{background:#f7f5f0;color:var(--navy)}
.btn.navy{background:var(--navy)}
.btn.navy:hover{background:var(--navy-d)}

section{padding:84px 0}
.shead{max-width:680px;margin-bottom:46px}
.shead .eyebrow{display:inline-flex;align-items:center;gap:12px;color:var(--gold);font-weight:600;letter-spacing:.2em;text-transform:uppercase;font-size:12px;margin-bottom:12px}
.shead .eyebrow::before{content:"";width:30px;height:1px;background:var(--gold)}
.shead h2{font-size:clamp(25px,3.4vw,36px)}
.shead p{color:var(--mut);margin-top:12px}

/* services */
.svc-g{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.svc{background:var(--card);border:1px solid var(--line);border-radius:6px;padding:32px 30px;transition:.16s;position:relative}
.svc::after{content:"";position:absolute;bottom:0;left:0;width:0;height:3px;background:var(--gold);transition:.25s}
.svc:hover::after{width:100%}
.svc:hover{box-shadow:0 14px 38px rgba(26,35,51,.1)}
.svc .ico{width:48px;height:48px;border-radius:4px;background:#eef1f6;color:var(--navy);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.svc .ico svg{width:24px;height:24px}
.svc h3{font-size:19px;margin-bottom:8px}
.svc p{color:var(--mut);font-size:14.5px}

/* calc */
.calc{background:var(--card);border:1px solid var(--line);border-radius:8px;padding:40px}
.calc-g{display:grid;grid-template-columns:1.15fr .85fr;gap:44px}
.cfg label{display:block;font-weight:600;font-size:14.5px;margin:20px 0 8px}
.cfg input[type=range]{width:100%;accent-color:var(--gold)}
.seg{display:flex;gap:8px;flex-wrap:wrap}
.seg button{border:1px solid var(--line);background:#fff;padding:10px 18px;border-radius:4px;cursor:pointer;font-family:inherit;font-size:14px;transition:.12s}
.seg button.on{background:var(--navy);color:#fff;border-color:var(--navy);font-weight:600}
.calc-out{background:var(--navy);color:#f7f5f0;border-radius:6px;padding:32px;text-align:center;align-self:start}
.calc-out .sum{font-family:'Libre Baskerville',serif;font-weight:700;font-size:40px;color:var(--gold-l)}
.calc-out p{color:#9aa5ba;font-size:13.5px;margin-top:10px}

/* quote */
.quote{display:grid;grid-template-columns:.85fr 1.15fr;gap:50px;align-items:center}
.quote img{border-radius:6px;width:100%;height:440px;object-fit:cover;border:1px solid var(--line)}
.quote blockquote{font-family:'Libre Baskerville',serif;font-style:italic;font-size:22px;line-height:1.6;margin-bottom:18px}
.quote blockquote em{color:var(--gold);font-style:italic}
.quote .who{color:var(--mut)}

/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.step{background:var(--card);border:1px solid var(--line);border-radius:6px;padding:28px;border-top:3px solid var(--gold)}
.step .n{font-family:'Libre Baskerville',serif;font-size:26px;color:var(--gold)}
.step h3{font-size:17.5px;margin:8px 0 8px}
.step p{color:var(--mut);font-size:14.5px}

/* pricing rows */
.plist .row{display:flex;justify-content:space-between;align-items:baseline;gap:20px;padding:18px 4px;border-bottom:1px solid var(--line)}
.plist h3{font-size:17px}
.plist p{color:var(--mut);font-size:14px;margin-top:3px}
.plist .price{font-family:'Libre Baskerville',serif;color:var(--navy);font-size:18px;white-space:nowrap}

/* form */
.form-g{display:grid;grid-template-columns:1fr 1fr;gap:50px}
.fg{margin-bottom:16px}
.fg label{display:block;margin-bottom:7px;font-weight:600;font-size:14px}
input,select,textarea{width:100%;background:#fff;border:1px solid var(--line);border-radius:4px;color:var(--ink);padding:13px 15px;font-family:inherit;font-size:15px}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--gold)}
.fnote{font-size:13px;color:var(--mut);margin-top:10px}
.ok-msg{display:none;background:#eef1e6;border:1px solid #8a9a5e;color:#4d5c28;padding:16px;border-radius:4px;margin-top:14px}
.k-card{background:var(--card);border:1px solid var(--line);border-radius:6px;padding:26px;margin-bottom:16px}
.k-card h3{font-size:17.5px;margin-bottom:6px}
.k-card p,.k-card a{color:var(--mut);font-size:15px}

.band{background:var(--navy);color:#f7f5f0;padding:70px 0;text-align:center;position:relative;overflow:hidden}
.band::before{content:"§";position:absolute;right:6%;top:50%;transform:translateY(-50%);font-family:'Libre Baskerville',serif;font-size:220px;color:rgba(215,180,102,.08)}
.band h2{font-size:clamp(24px,3.6vw,38px)}
.band h2 em{font-style:italic;color:var(--gold-l)}
.band p{color:#9aa5ba;margin:10px 0 26px}
.band a{background:var(--gold);color:#fff;display:inline-block;padding:14px 32px;border-radius:4px;font-weight:600;position:relative}

footer{background:var(--navy-d);color:#9aa5ba;padding:54px 0 40px}
.f-g{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;max-width:1120px;margin:0 auto;padding:0 24px}
footer h4{font-family:'Libre Baskerville',serif;color:#f7f5f0;font-size:16px;margin-bottom:12px}
footer a,footer p{color:#9aa5ba;font-size:14.5px;display:block;margin-bottom:8px}
footer a:hover{color:#fff}
.f-bot{max-width:1120px;margin:34px auto 0;padding:20px 24px 0;border-top:1px solid #24334f;font-size:13px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}

.phero{background:var(--navy);color:#f7f5f0;position:relative;overflow:hidden}
.phero::before{content:"§";position:absolute;right:4%;top:-30px;font-family:'Libre Baskerville',serif;font-size:200px;color:rgba(215,180,102,.09)}
.phero .in{position:relative;max-width:1120px;margin:0 auto;padding:60px 24px 54px}
.phero .kicker{display:inline-flex;align-items:center;gap:12px;color:var(--gold-l);font-weight:600;letter-spacing:.2em;text-transform:uppercase;font-size:12px;margin-bottom:14px}
.phero .kicker::before{content:"";width:34px;height:1px;background:var(--gold-l)}
.phero h1{font-size:clamp(27px,4vw,44px)}
.phero h1 em{font-style:italic;color:var(--gold-l)}
.phero p{color:#cdd4e0;max-width:640px;margin-top:14px;font-size:16.5px}
section.hero,section.phero{padding:0}

@media(max-width:960px){
 .svc-g,.steps{grid-template-columns:1fr}
 .svc-g{grid-template-columns:1fr 1fr}
 .quote,.form-g,.calc-g{grid-template-columns:1fr}
 .quote img{height:340px}
 .f-g{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
 nav.menu{position:absolute;top:100%;left:0;right:0;background:var(--bg);flex-direction:column;gap:0;padding:10px 0 20px;border-bottom:1px solid var(--line);display:none}
 nav.menu.open{display:flex}
 nav.menu a{padding:14px 24px;width:100%;font-size:16px}
 .cta-btn{margin:12px 24px 0;width:calc(100% - 48px);text-align:center}
 .burger{display:block}
 .svc-g,.steps,.f-g{grid-template-columns:1fr}
 section{padding:58px 0}
 .hero .in{padding:58px 20px 66px}
 .phero .in{padding:42px 20px 38px}
 .calc{padding:24px 18px}
 .band::before,.phero::before{display:none}
}
