
:root{
  --cream:#F6F1ED;
  --cream-soft:#FBF8F5;
  --navy:#0F3B68;
  --gold:#D1AB64;
  --white:#ffffff;
  --dark:#0F172A;
  --muted:#64748B;
  --line:rgba(15,59,104,.12);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:Arial,Helvetica,sans-serif;background:var(--cream);color:var(--dark);line-height:1.7;overflow-x:hidden}
a{text-decoration:none;color:inherit}
.container{width:min(1180px,calc(100% - 40px));margin:auto}
section{padding:96px 0;position:relative}

.nav{
  position:sticky;
  top:0;
  z-index:100;
  width:100%;
  background:rgba(246,241,237,.96);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}

.nav-inner{
  display:flex;
  justify-content:space-between;
  align-items:center;
  min-height:76px;
  padding:12px 0;
  gap:24px;
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  color:var(--navy);
  font-weight:900;
  flex:0 0 auto;
  min-width:220px;
  max-width:280px;
}

.brand-logo-frame{
  width:44px;
  height:44px;
  min-width:44px;
  max-width:44px;
  min-height:44px;
  max-height:44px;
  flex:0 0 44px;
  border-radius:50%;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
  background:transparent;
  border:none;
  box-shadow:none;
  line-height:0;
}

.brand-logo-frame img,
.brand-logo{
  width:44px !important;
  height:44px !important;
  max-width:44px !important;
  max-height:44px !important;
  min-width:44px !important;
  min-height:44px !important;
  object-fit:contain !important;
  object-position:center center !important;
  display:block !important;
}

.brand-text{
  font-size:15px;
  line-height:1.15;
  white-space:normal;
  letter-spacing:.1px;
  max-width:180px;
}

.nav-links{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:24px;
  font-size:14px;
  font-weight:800;
  color:var(--navy);
  flex:1;
}

.nav-links a:not(.btn){white-space:nowrap}

.menu-toggle{
  display:none;
  width:44px;
  height:44px;
  min-width:44px;
  border-radius:14px;
  border:1px solid var(--line);
  background:white;
  color:var(--navy);
  font-size:24px;
  font-weight:900;
  cursor:pointer;
}

.mobile-menu{
  display:none;
  border-top:1px solid var(--line);
  background:rgba(246,241,237,.98);
}

.mobile-menu.open{display:block}

.mobile-menu a{
  display:block;
  padding:16px 20px;
  border-bottom:1px solid var(--line);
  font-weight:800;
  color:var(--navy);
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:14px 22px;
  border-radius:999px;
  font-weight:900;
  border:none;
  cursor:pointer;
  transition:.25s ease;
  font-size:14px;
  line-height:1.1;
  white-space:nowrap;
}

.btn-primary{background:var(--navy);color:white;box-shadow:0 18px 38px rgba(15,59,104,.22)}
.btn-primary:hover{transform:translateY(-2px)}
.btn-secondary{background:rgba(255,255,255,.55);border:1px solid var(--line);color:var(--navy)}

.hero{
  min-height:78vh;
  display:flex;
  align-items:center;
  background:radial-gradient(circle at top right,rgba(209,171,100,.18),transparent 30%),linear-gradient(135deg,var(--cream),var(--cream-soft));
  padding:90px 0;
}

.hero-grid{display:grid;grid-template-columns:1fr .95fr;gap:70px;align-items:center}
.eyebrow{text-transform:uppercase;letter-spacing:3px;font-size:12px;font-weight:900;color:var(--gold);margin-bottom:22px}
.hero h1{font-family:Georgia,'Times New Roman',serif;font-size:clamp(54px,7vw,92px);line-height:.94;letter-spacing:-4px;color:var(--navy);margin-bottom:28px}
.hero p{font-size:20px;line-height:1.8;color:#334155;margin-bottom:36px;max-width:640px}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap}

.hero-card{
  background:linear-gradient(160deg,var(--navy),#081625);
  color:white;
  padding:42px;
  border-radius:38px;
  position:relative;
  overflow:hidden;
  box-shadow:0 36px 90px rgba(15,59,104,.25);
  min-height:430px;
}

.hero-card::before{content:'';position:absolute;width:340px;height:340px;border-radius:50%;background:rgba(209,171,100,.18);right:-80px;top:-80px}
.hero-card-content{position:relative;z-index:2}
.hero-card h3{font-family:Georgia,'Times New Roman',serif;font-size:42px;line-height:1.04;margin-bottom:18px}
.hero-card p{color:rgba(255,255,255,.78);font-size:16px;line-height:1.8}

.metric-box,.glass-box{margin-top:26px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:28px;padding:24px}
.bars{display:flex;align-items:flex-end;gap:14px;height:150px;margin-top:20px}
.bars div{flex:1;border-radius:999px 999px 8px 8px;background:linear-gradient(180deg,var(--gold),#F0D7A0)}
.bars div:nth-child(1){height:38%}.bars div:nth-child(2){height:56%}.bars div:nth-child(3){height:74%}.bars div:nth-child(4){height:92%}

.trust-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:42px;max-width:660px}
.trust-item{padding:18px;border-radius:22px;background:rgba(255,255,255,.55);border:1px solid var(--line);color:var(--navy);font-weight:900;text-align:center}

.section-title{text-align:center;max-width:760px;margin:0 auto 60px}
.section-title h2{font-family:Georgia,'Times New Roman',serif;font-size:clamp(40px,5vw,72px);line-height:.98;letter-spacing:-3px;color:var(--navy);margin-bottom:22px}
.section-title p{font-size:18px;color:var(--muted);line-height:1.8}

.cards-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.cards-grid.two{grid-template-columns:repeat(2,1fr)}
.card{background:rgba(255,255,255,.58);border:1px solid var(--line);border-radius:34px;padding:34px;box-shadow:0 18px 40px rgba(15,59,104,.06)}
.card-num{font-size:54px;font-weight:900;color:rgba(209,171,100,.34);margin-bottom:18px}
.card h3,.form-card h3{font-family:Georgia,'Times New Roman',serif;font-size:30px;line-height:1.08;color:var(--navy);margin-bottom:16px}
.card p,.form-card p{color:var(--muted);line-height:1.85}

.dark-section{background:linear-gradient(145deg,var(--navy),#081625);color:white}
.dark-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:center}
.dark-grid h2,.dark-section h2{font-family:Georgia,'Times New Roman',serif;font-size:clamp(42px,6vw,78px);line-height:.96;letter-spacing:-3px}
.dark-section p{color:rgba(255,255,255,.74);font-size:18px;line-height:1.9}
.tags{display:flex;flex-wrap:wrap;gap:16px}
.tag{padding:15px 20px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);font-weight:900}
.light-tag{padding:14px 18px;border-radius:999px;background:white;border:1px solid var(--line);font-weight:900;color:var(--navy);box-shadow:0 12px 34px rgba(15,59,104,.05)}

.cta-box{background:white;padding:70px;border-radius:42px;border:1px solid var(--line);box-shadow:0 26px 80px rgba(15,59,104,.08);max-width:960px;margin:auto;text-align:center}
.cta-box h2{font-family:Georgia,'Times New Roman',serif;font-size:clamp(42px,5vw,72px);line-height:.96;color:var(--navy);margin-bottom:22px}
.cta-box p{max-width:720px;margin:0 auto 34px;font-size:18px;color:var(--muted);line-height:1.8}

.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:36px;align-items:start}
.form-card{background:rgba(255,255,255,.58);border:1px solid var(--line);border-radius:34px;padding:34px;box-shadow:0 18px 40px rgba(15,59,104,.06)}
.field{display:grid;gap:8px}
form{display:grid;gap:18px}
input,textarea,select{width:100%;padding:16px 18px;border-radius:18px;border:1px solid var(--line);background:white;font-family:inherit;font-size:15px}
textarea{min-height:120px}

.footer{background:#081625;padding:70px 0 40px;color:white}
.footer-top{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-brand h3{font-family:Georgia,'Times New Roman',serif;font-size:34px;margin-bottom:14px}
.footer-brand p{color:rgba(255,255,255,.65);max-width:440px}
.socials{display:flex;gap:18px;flex-wrap:wrap;align-items:center}
.social-link{padding:14px 20px;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);font-weight:900}
.footer-bottom{padding-top:28px;color:rgba(255,255,255,.55);font-size:14px}

.modal-overlay{position:fixed;inset:0;background:rgba(8,22,37,.72);backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;z-index:999;padding:22px}
.modal-overlay.open{display:flex}
.modal{width:min(720px,100%);background:var(--cream);border-radius:34px;padding:34px;position:relative;max-height:92vh;overflow:auto}
.modal-close{position:absolute;top:18px;right:18px;width:42px;height:42px;border-radius:50%;border:none;background:white;font-size:22px;cursor:pointer}
.modal h2{font-family:Georgia,'Times New Roman',serif;color:var(--navy);font-size:42px;line-height:1;margin-bottom:12px}
.modal p{color:var(--muted);margin-bottom:22px}

@media(max-width:1100px){
  .nav-links{gap:18px;font-size:13px}
  .brand{min-width:200px;max-width:240px}
}

@media(max-width:980px){
  .hero-grid,.dark-grid,.cards-grid,.cards-grid.two,.form-grid{grid-template-columns:1fr}
  .nav-links{display:none}
  .menu-toggle{display:flex;align-items:center;justify-content:center}
  .trust-row{grid-template-columns:1fr}
  .brand{min-width:auto;max-width:none}
}

@media(max-width:700px){
  .brand-logo-frame{width:40px;height:40px;min-width:40px;max-width:40px;min-height:40px;max-height:40px;flex-basis:40px}
  .brand-logo-frame img,.brand-logo{width:40px !important;height:40px !important;max-width:40px !important;max-height:40px !important;min-width:40px !important;min-height:40px !important}
  .brand-text{font-size:14px;max-width:150px}
  .hero h1,.section-title h2,.dark-grid h2,.dark-section h2,.cta-box h2{letter-spacing:-2px}
  .cta-box{padding:36px 24px}
  section{padding:72px 0}
}
