:root{--cream:#F7F0DF;--soft:#FFF9EC;--navy:#082D4F;--gold:#C99A3E;--text:#1F2A35;--muted:#6B7280;--white:#fff;--border:#E8DCC4}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{position:relative;overflow-x:hidden;margin:0;background:var(--soft);color:var(--text);font-family:Inter,Arial,sans-serif;line-height:1.6}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
.container{position:relative;z-index:3;width:min(1120px,calc(100% - 32px));margin:auto}
.ambient-background{position:fixed;z-index:2;top:-44px;left:-96px;display:grid;width:calc(100% + 192px);height:calc(100vh + 192px);grid-template-columns:repeat(24,1fr);grid-auto-rows:44px;align-items:center;justify-items:center;overflow:hidden;pointer-events:none;animation:dotFieldTravel 15s linear infinite}
.ambient-node{width:var(--size);height:var(--size);border-radius:50%;background:var(--node-color);opacity:.12;box-shadow:0 0 0 2px #ffffff22;animation:nodePulse var(--duration) ease-in-out var(--delay) infinite}
.site-header{position:sticky;top:0;z-index:20;background:#fff9ecee;border-bottom:1px solid var(--border);backdrop-filter:blur(14px)}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;padding:0 40px;min-height:76px}
.brand-logo{width:70px;height:70px;object-fit:contain}
.nav-links{display:flex;align-items:center;gap:25px;font-weight:800;color:#324252}
.menu-toggle{display:none}
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:0 20px;border:1px solid transparent;border-radius:6px;font-weight:800;cursor:pointer}
.btn-primary{background:var(--gold);color:#111827}
.btn-secondary{background:var(--white);border-color:var(--border);color:var(--navy)}
section{position:relative;padding:82px 0}
.hero{padding:88px 0 76px;background:linear-gradient(115deg,#fff9ecfa,#f7f0dfeb 54%,#082d4f12)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:start}
.eyebrow{color:var(--navy);font-size:.8rem;font-weight:900;text-transform:uppercase;letter-spacing:.08em}
.eyebrow:before{content:"";display:inline-block;width:32px;height:2px;margin-right:10px;vertical-align:middle;background:var(--gold)}
h1,h2,h3{margin:0;color:var(--navy);line-height:1.12}
h1,h2{font-family:"Playfair Display",Georgia,serif}
h1{font-size:clamp(2.75rem,5vw,4.6rem)}
h2{font-size:clamp(2rem,4vw,3.1rem)}
.hero-subtitle{font-size:1.2rem;color:#2e3b47}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:28px}
.supporting-line{display:flex;gap:10px;color:var(--muted);font-weight:700}
.supporting-line:before{content:"";width:9px;height:9px;margin-top:8px;border-radius:50%;background:#6f806b;flex:none}
.profile-proof{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:18px;align-items:center;width:min(100%,610px);margin-top:18px;padding:18px 20px;border:1px solid var(--border);border-radius:8px;background:#fff;box-shadow:0 8px 22px #082d4f0f}
.profile-proof-main{display:flex;min-width:0;align-items:center;gap:13px}
.profile-proof-logo{width:52px;height:52px;flex:none;object-fit:contain}
.profile-proof-copy{display:grid;min-width:0;gap:4px}
.profile-proof-copy strong{color:var(--text);font-size:.92rem;line-height:1.24}
.profile-proof-copy a{color:var(--muted);font-size:.76rem;font-weight:700}
.profile-proof-copy a span{padding-left:5px;color:var(--navy);font-size:1.05rem}
.profile-proof-stat{display:grid;gap:3px;justify-items:start;align-self:center;white-space:nowrap}
.profile-proof-stat strong{color:#5b6470;font-size:.78rem}
.profile-proof-stat small{color:var(--muted);font-size:.67rem}
.profile-star{color:#2c9b78;font-size:.72rem}
.card{border:1px solid var(--border);border-radius:8px;background:#fff;box-shadow:0 8px 22px #082d4f0f}
.form-card{display:grid;gap:12px;padding:24px}
.form-card label{display:grid;gap:5px;color:#354150;font-size:.85rem;font-weight:800}
.form-card input,.form-card select,.form-card textarea{width:100%;min-height:44px;padding:10px;border:1px solid #d8dde5;border-radius:6px;font:inherit}
.form-card textarea{min-height:100px;resize:vertical}
.form-card .form-grid{display:grid;gap:14px}
.form-card .field{display:grid;gap:6px}
.form-card label{display:grid;gap:6px;color:#354150;font-size:.85rem;font-weight:800}
.form-card input,.form-card select,.form-card textarea{display:block;width:100%;min-width:0}
.form-card textarea{min-height:110px}
.hero-form .btn{width:100%}
.success-message{display:none;color:#43533f;font-weight:700}
.success-message.show{display:block}
.proof-strip{padding:22px 0;background:var(--navy);color:#fff}
.proof-wrap{display:grid;grid-template-columns:1.2fr repeat(4,auto);gap:18px;align-items:center}
.proof-wrap span{padding:8px 12px;border:1px solid #f0d7a47a;border-radius:999px;color:#f0d7a4;font-size:.84rem;font-weight:800}
.section-alt{background:var(--cream)}
.section-heading{display:grid;grid-template-columns:.85fr .65fr;gap:26px;align-items:end;margin-bottom:34px}
.section-heading p,.card p,.notice p{margin:8px 0 0;color:var(--muted)}
.grid{display:grid;gap:18px}
.services-grid{grid-template-columns:repeat(4,1fr)}
.service-card,.feature-card,.blog-card{display:flex;flex-direction:column;padding:22px;min-height:205px}
.service-card a,.blog-card a{margin-top:auto;padding-top:18px;color:var(--navy);font-weight:900;font-size:.88rem}
.split{display:grid;grid-template-columns:.85fr 1.15fr;gap:42px;align-items:center}
.check-list{display:grid;gap:12px;margin:0;padding:0;list-style:none}
.check-list li{padding:15px;border:1px solid var(--border);border-radius:8px;background:#fff;font-weight:700}
.check-list li:before{content:"✓";display:inline-grid;place-items:center;width:27px;height:27px;margin-right:10px;border-radius:50%;background:var(--navy);color:#f0d7a4}
.process-grid,.feature-grid{grid-template-columns:repeat(4,1fr)}
.process-grid{counter-reset:steps}
.process-card{min-height:220px;padding:24px}
.process-card:before{counter-increment:steps;content:"0" counter(steps);display:grid;place-items:center;width:46px;height:46px;margin-bottom:24px;border-radius:50%;background:var(--navy);color:#f0d7a4;font-weight:900}
.testimonial-showcase{background:linear-gradient(135deg,var(--soft),var(--cream),#082d4f14)}
.laptop-frame{width:min(940px,100%);margin:auto;padding:18px 28px 0;border:1px solid #c99a3e88;border-radius:18px 18px 10px 10px;background:linear-gradient(145deg,#082d4f,#0d3d68)}
.laptop-camera{width:8px;height:8px;margin:0 auto 12px;border-radius:50%;background:#f0d7a4}
.laptop-screen{position:relative;overflow:hidden;aspect-ratio:16/9;background:#f9efd8}
.review-slides,.review-slide,.review-slide img{position:absolute;inset:0;width:100%;height:100%}
.review-slide{margin:0;opacity:0;transition:opacity .7s}
.review-slide.active{opacity:1}
.review-slide img{object-fit:contain;object-position:center}
.laptop-base{width:calc(100% + 96px);height:26px;margin:0 -48px;border-radius:0 0 40px 40px;background:linear-gradient(#d8b76c,#a97820)}
.review-shell{position:relative;z-index:4;display:grid;grid-template-columns:48px minmax(0,1fr) 48px;gap:14px;align-items:center}
.review-arrow{display:grid;place-items:center;width:48px;height:48px;border:1px solid #c99a3e66;border-radius:50%;background:#fff9ece6;color:var(--navy);font-size:2rem;font-weight:900;line-height:1;box-shadow:0 8px 20px #082d4f12;cursor:pointer}
.review-arrow:hover,.review-arrow:focus-visible{background:var(--gold);color:#111827}
.review-dots{position:relative;z-index:4;display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-top:24px}
.review-dots button{appearance:none;-webkit-appearance:none;display:block;flex:0 0 auto;width:10px;height:10px;padding:0;border:0;border-radius:50%;background:#082d4f44;cursor:pointer}
.review-dots button.active{width:30px;border-radius:999px;background:var(--gold)}
.notice,.confidentiality-note{padding:24px;border:1px solid #c99a3e77;border-radius:8px;background:linear-gradient(135deg,#fff,#fff7e4)}
.blog-grid{grid-template-columns:repeat(3,1fr)}
.faq-list{display:grid;gap:12px;max-width:900px;margin:auto}
.confidentiality-note{max-width:900px;margin:0 auto 22px;border-left:4px solid var(--gold)}
.confidentiality-note p{margin:6px 0 0;color:var(--muted)}
.faq-item{overflow:hidden;border:1px solid var(--border);border-radius:8px;background:#fff}
.faq-item button{width:100%;padding:18px 20px;border:0;background:#fff;color:var(--navy);text-align:left;font:inherit;font-weight:900;cursor:pointer}
.faq-item button:after{content:"+";float:right}
.faq-item.open button:after{content:"-"}
.faq-item p{display:none;margin:0;padding:0 20px 18px;color:var(--muted)}
.faq-item.open p{display:block}
.contact-band{background:var(--navy);color:#fff;text-align:center}
.contact-band h2{color:#fff}
.contact-band .hero-actions{justify-content:center}
footer{padding:34px 0;background:#061f37;color:#ffffffcc}
footer p{margin:4px 0}
.wave-section{--wave-fill:var(--soft);padding-bottom:122px}
.wave-to-soft{--wave-fill:var(--soft)}
.wave-to-cream{--wave-fill:var(--cream)}
.wave-to-navy{--wave-fill:var(--navy)}
.wave-section:before,.wave-section:after{content:"";position:absolute;z-index:2;left:0;bottom:-1px;width:100%;pointer-events:none;background-repeat:repeat-x;background-position:0 100%}
.wave-section:before{height:64px;background:var(--wave-fill);background-size:960px 72px;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 960 72'%3E%3Cpath d='M0 35C155 2 285 12 436 37c183 31 333 35 524-5v40H0Z' fill='%23000'/%3E%3C/svg%3E") 0 100%/960px 72px repeat-x;-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 960 72'%3E%3Cpath d='M0 35C155 2 285 12 436 37c183 31 333 35 524-5v40H0Z' fill='%23000'/%3E%3C/svg%3E") 0 100%/960px 72px repeat-x;animation:waterWave 24s linear infinite}
.wave-section:after{height:52px;background:color-mix(in srgb,var(--wave-fill) 82%,transparent);background-size:760px 58px;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 760 58'%3E%3Cpath d='M0 25c122-23 241-18 363 7 143 29 250 27 397-7v33H0Z' fill='%23000'/%3E%3C/svg%3E") 0 100%/760px 58px repeat-x;-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 760 58'%3E%3Cpath d='M0 25c122-23 241-18 363 7 143 29 250 27 397-7v33H0Z' fill='%23000'/%3E%3C/svg%3E") 0 100%/760px 58px repeat-x;animation:waterWaveReverse 31s linear infinite}
.reveal-section{opacity:0;transform:translateY(20px);transition:opacity .7s,transform .7s}
.reveal-section.visible{opacity:1;transform:none}
.breathe-on-enter,.pop-on-enter,.pop-stagger,.stomp-stagger{animation-play-state:paused}
.visible .breathe-on-enter{animation:breathe .9s ease-out both}
.visible .pop-on-enter,.visible .pop-stagger{animation:pop .58s cubic-bezier(.2,.8,.2,1) both;animation-delay:calc(var(--i,0)*90ms)}
.visible .stomp-stagger{animation:stomp .62s cubic-bezier(.2,.9,.25,1) both;animation-delay:calc(var(--i,0)*120ms)}
@keyframes breathe{0%{opacity:0;transform:scale(.94)}
65%{transform:scale(1.025)}
100%{opacity:1;transform:scale(1)}
}
@keyframes pop{0%{opacity:0;transform:scale(.82)}
75%{transform:scale(1.035)}
100%{opacity:1;transform:scale(1)}
}
@keyframes stomp{0%{opacity:0;transform:translateY(-26px) scale(1.04)}
72%{transform:translateY(5px) scale(.985)}
100%{opacity:1;transform:none}
}
@keyframes dotFieldTravel{0%{transform:translate3d(-44px,44px,0)}
100%{transform:translate3d(44px,-44px,0)}
}
@keyframes nodePulse{0%,100%{opacity:.1;transform:translate3d(0,0,0) scale(.82)}
50%{opacity:.34;transform:translate3d(0,-3px,0) scale(1.18)}
}
@keyframes waterWave{to{background-position:960px 100%;mask-position:960px 100%;-webkit-mask-position:960px 100%}
}
@keyframes waterWaveReverse{to{background-position:-760px 100%;mask-position:-760px 100%;-webkit-mask-position:-760px 100%}
}

@media(max-width:900px){.nav-links{display:none}
.ambient-background{grid-template-columns:repeat(16,1fr);grid-auto-rows:42px}
.menu-toggle{display:block;width:44px;height:44px;border:1px solid var(--border);background:#fff}
.menu-toggle span{display:block;width:18px;height:2px;margin:4px auto;background:var(--navy)}
.nav-open .nav-links{position:absolute;top:76px;left:0;right:0;display:grid;padding:20px;background:#fff9ec}
.hero-grid,.section-heading,.split{grid-template-columns:1fr}
.services-grid{grid-template-columns:repeat(2,1fr)}
.process-grid,.feature-grid{grid-template-columns:repeat(2,1fr)}
.proof-wrap{grid-template-columns:1fr 1fr}
.nav-wrap{padding:0 16px}
}
@media(max-width:560px){section{padding:62px 0}
.ambient-background{grid-template-columns:repeat(11,1fr);grid-auto-rows:40px}
.wave-section{padding-bottom:96px}
.hero-copy,.section-heading,.split,.contact-band{text-align:left}
.section-heading{gap:14px}
.hero-subtitle,.supporting-line,.section-heading p,.card p,.notice p,.confidentiality-note p,.faq-item p,.contact-band p{text-wrap:pretty}
.services-grid,.process-grid,.feature-grid,.blog-grid,.proof-wrap{grid-template-columns:1fr}
.hero-actions{display:grid}
.btn{width:100%}
.review-shell{grid-template-columns:1fr;gap:12px}
.review-arrow{position:absolute;z-index:5;top:48%;width:42px;height:42px;font-size:1.7rem;background:#fff9ecf2}
.review-prev{left:4px}
.review-next{right:4px}
.profile-proof{grid-template-columns:1fr 1fr;gap:14px;padding:15px}
.profile-proof-main{grid-column:1/-1}
.profile-proof-stat{padding-left:0}
.laptop-frame{padding:14px 14px 0}
.laptop-screen{aspect-ratio:4/3}
.laptop-base{width:calc(100% + 34px);height:20px;margin:0 -17px}
}
@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation:none!important;transition:none!important;scroll-behavior:auto!important}
.reveal-section{opacity:1;transform:none}
}
.service-card:hover,.service-card:focus-within,.process-card:hover,.process-card:focus-within,.feature-card:hover,.feature-card:focus-within{z-index:3;border-color:#c99a3e99;animation:cardPulse 1.15s ease-in-out infinite!important}
@keyframes cardPulse{0%,100%{transform:scale(1);box-shadow:0 10px 26px #082d4f14}
50%{transform:scale(1.035);box-shadow:0 18px 38px #082d4f2b}
}
@media(prefers-reduced-motion:reduce){
.service-card:hover,.service-card:focus-within,.process-card:hover,.process-card:focus-within,.feature-card:hover,.feature-card:focus-within{border-color:#c99a3e99;transform:none}
}
