:root{
  --navy:#0f233f;
  --navy-2:#142d50;
  --gold:#c59b55;
  --gold-2:#f1d59d;
  --cream:#f8f3ea;
  --paper:#fffaf2;
  --text:#1b2430;
  --muted:#6d7480;
  --white:#ffffff;
  --line:rgba(15,35,63,.14);
  --shadow:0 24px 70px rgba(15,35,63,.14);
  --shadow-soft:0 16px 45px rgba(15,35,63,.10);
  --radius:28px;
  --max:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Arial, Helvetica, sans-serif;
  color:var(--text);
  background:linear-gradient(180deg,#fff 0%,#fbf7ef 48%,#fff 100%);
  line-height:1.6;
}
a{color:inherit;text-decoration:none}
img,svg{max-width:100%;display:block}
.container{width:min(92%,var(--max));margin:auto}

.header{
  position:sticky;
  top:0;
  z-index:20;
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line);
}
.nav{
  width:min(94%,1240px);
  margin:auto;
  min-height:78px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}
.brand{
  display:flex;
  align-items:center;
  gap:12px;
  font-weight:800;
  letter-spacing:.02em;
}
.brand-icon{
  width:46px;
  height:46px;
  border-radius:16px;
  display:grid;
  place-items:center;
  color:#fff;
  background:linear-gradient(135deg,var(--navy),var(--gold));
  box-shadow:0 12px 28px rgba(15,35,63,.2);
  font-size:.88rem;
}
.brand-name{font-size:1rem;color:var(--navy)}
.menu{
  list-style:none;
  display:flex;
  align-items:center;
  gap:10px;
  margin:0;
  padding:0;
}
.menu a{
  display:block;
  padding:10px 14px;
  border-radius:999px;
  color:#263142;
  font-weight:700;
  font-size:.93rem;
  transition:.25s ease;
}
.menu a:hover,.menu a:focus-visible{background:#f2eadc;color:var(--navy)}
.menu-highlight{
  background:var(--navy);
  color:#fff!important;
  box-shadow:0 12px 26px rgba(15,35,63,.2);
}
.menu-button{
  display:none;
  width:48px;
  height:48px;
  border:0;
  border-radius:15px;
  background:var(--navy);
  cursor:pointer;
  padding:12px;
}
.menu-button span{
  display:block;
  height:2px;
  margin:6px 0;
  background:#fff;
  border-radius:999px;
  transition:.25s ease;
}

.hero{
  position:relative;
  overflow:hidden;
  padding:96px 0 88px;
  background:
    radial-gradient(circle at 13% 20%,rgba(197,155,85,.25),transparent 28%),
    linear-gradient(135deg,#102542 0%,#17365d 52%,#f6efe3 52%,#fff 100%);
}
.hero-shape{position:absolute;border-radius:999px;filter:blur(2px);opacity:.75;pointer-events:none}
.shape-one{width:330px;height:330px;background:rgba(197,155,85,.22);right:-90px;top:70px}
.shape-two{width:220px;height:220px;background:rgba(255,255,255,.12);left:-60px;bottom:30px}
.hero-grid{
  position:relative;
  display:grid;
  grid-template-columns:1.05fr .95fr;
  align-items:center;
  gap:58px;
}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin:0 0 18px;
  color:var(--gold-2);
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-size:.78rem;
}
.eyebrow:before{
  content:"";
  width:36px;
  height:2px;
  background:currentColor;
  border-radius:999px;
}
.eyebrow.dark{color:var(--gold)}
.hero h1{
  margin:0;
  color:#fff;
  font-size:clamp(2.35rem,5vw,5.1rem);
  line-height:.97;
  letter-spacing:-.06em;
  max-width:820px;
}
.hero-text{
  margin:26px 0 0;
  color:rgba(255,255,255,.86);
  max-width:620px;
  font-size:1.18rem;
}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:52px;
  padding:14px 22px;
  border-radius:999px;
  font-weight:800;
  transition:.25s ease;
}
.button.primary{background:linear-gradient(135deg,var(--gold),#e8c67f);color:#102542;box-shadow:0 18px 45px rgba(197,155,85,.28)}
.button.secondary{border:1px solid rgba(255,255,255,.38);color:#fff;background:rgba(255,255,255,.08)}
.button:hover{transform:translateY(-3px)}
.visual-panel{
  position:relative;
  min-height:520px;
  display:grid;
  place-items:center;
}
.document-card{
  width:min(100%,430px);
  min-height:500px;
  padding:34px;
  border-radius:34px;
  background:linear-gradient(180deg,#fffaf2,#fff);
  box-shadow:var(--shadow);
  border:1px solid rgba(15,35,63,.1);
  position:relative;
  overflow:hidden;
}
.document-card:after{
  content:"";
  position:absolute;
  width:210px;
  height:210px;
  border-radius:999px;
  background:rgba(197,155,85,.13);
  right:-90px;
  bottom:-80px;
}
.paper-top{
  height:12px;
  width:42%;
  background:linear-gradient(90deg,var(--navy),var(--gold));
  border-radius:999px;
  margin-bottom:30px;
}
.paper-title{
  display:flex;
  align-items:center;
  gap:14px;
  color:var(--navy);
  font-size:1.12rem;
}
.paper-title span{
  width:54px;
  height:54px;
  border-radius:18px;
  background:linear-gradient(135deg,var(--navy),var(--gold));
  box-shadow:0 16px 30px rgba(15,35,63,.18);
}
.paper-lines{display:grid;gap:16px;margin:42px 0}
.paper-lines i{
  display:block;
  height:14px;
  border-radius:999px;
  background:#e9dfcf;
}
.paper-lines i:nth-child(1){width:96%}
.paper-lines i:nth-child(2){width:82%}
.paper-lines i:nth-child(3){width:92%}
.paper-lines i:nth-child(4){width:68%}
.paper-footer{position:relative;z-index:1;display:grid;gap:13px;margin-top:26px}
.paper-footer span{
  padding:14px 16px;
  border:1px solid rgba(15,35,63,.12);
  border-radius:17px;
  background:#fff;
  color:var(--navy);
  font-weight:800;
}
.mini-card{
  position:absolute;
  width:168px;
  padding:20px;
  border-radius:24px;
  background:rgba(15,35,63,.94);
  color:#fff;
  box-shadow:0 22px 45px rgba(15,35,63,.22);
  border:1px solid rgba(255,255,255,.14);
}
.mini-card strong{display:block;font-size:2rem;line-height:1;color:var(--gold-2)}
.mini-card span{display:block;margin-top:8px;font-size:.9rem;color:rgba(255,255,255,.82)}
.mini-card-left{left:0;top:58px}
.mini-card-right{right:0;bottom:70px;background:rgba(197,155,85,.96);color:#102542}
.mini-card-right strong,.mini-card-right span{color:#102542}

.section{padding:88px 0}
.section-title h2,.split-content h2,.location-box h2{
  margin:0;
  color:var(--navy);
  font-size:clamp(2rem,3.4vw,3.5rem);
  line-height:1.03;
  letter-spacing:-.04em;
}
.section-title p:last-child{max-width:620px;margin:18px auto 0;color:var(--muted);font-size:1.05rem}
.centered{text-align:center}
.intro-grid{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:34px;
  align-items:center;
}
.intro-box{
  padding:36px;
  border-radius:var(--radius);
  background:#fff;
  box-shadow:var(--shadow-soft);
  border:1px solid var(--line);
}
.intro-box p{margin:0;font-size:1.24rem;color:#253041}
.tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.tags span{
  padding:10px 14px;
  border-radius:999px;
  background:#f3eadb;
  color:var(--navy);
  font-weight:800;
  font-size:.9rem;
}
.cards-grid{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:18px;
  margin-top:42px;
}
.service-card{
  min-height:260px;
  padding:26px;
  border-radius:28px;
  background:#fff;
  box-shadow:var(--shadow-soft);
  border:1px solid var(--line);
  transition:.25s ease;
  position:relative;
  overflow:hidden;
}
.service-card:before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:6px;
  background:linear-gradient(90deg,var(--navy),var(--gold));
}
.service-card:hover{transform:translateY(-8px)}
.number{
  width:48px;
  height:48px;
  display:grid;
  place-items:center;
  border-radius:16px;
  background:#f6ecdb;
  color:var(--gold);
  font-weight:900;
}
.service-card h3{color:var(--navy);font-size:1.22rem;line-height:1.18;margin:24px 0 12px}
.service-card p{margin:0;color:var(--muted)}
.split{background:linear-gradient(180deg,#fff,var(--cream))}
.split-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:56px;
  align-items:center;
}
.image-abstract{
  min-height:460px;
  border-radius:36px;
  background:
    radial-gradient(circle at 30% 22%,rgba(197,155,85,.28),transparent 28%),
    linear-gradient(135deg,var(--navy),#1d4779);
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden;
}
.image-abstract:before{
  content:"";
  position:absolute;
  width:400px;
  height:400px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  right:-140px;
  top:-90px;
}
.building{
  position:absolute;
  left:50px;
  bottom:52px;
  width:220px;
  height:290px;
  padding:34px 26px;
  border-radius:26px 26px 8px 8px;
  background:rgba(255,255,255,.92);
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}
.building span{border-radius:10px;background:linear-gradient(180deg,#d7e1ea,#fff)}
.key-ring{
  position:absolute;
  right:80px;
  top:100px;
  width:122px;
  height:122px;
  border:18px solid var(--gold-2);
  border-radius:999px;
}
.key-ring:after{
  content:"";
  position:absolute;
  width:120px;
  height:16px;
  background:var(--gold-2);
  right:-96px;
  top:48px;
  border-radius:999px;
  box-shadow:36px 22px 0 -3px var(--gold-2),58px -20px 0 -3px var(--gold-2);
}
.signature-line{
  position:absolute;
  right:60px;
  bottom:80px;
  width:250px;
  height:8px;
  border-radius:999px;
  background:rgba(255,255,255,.8);
  box-shadow:0 26px 0 rgba(255,255,255,.55),0 52px 0 rgba(255,255,255,.35);
}
.split-content p{color:var(--muted);font-size:1.08rem}
.focus-list{display:grid;gap:12px;margin-top:28px}
.focus-list div{
  display:flex;
  align-items:center;
  gap:12px;
  padding:14px 16px;
  border-radius:16px;
  background:#fff;
  border:1px solid var(--line);
  box-shadow:0 10px 24px rgba(15,35,63,.06);
  color:var(--navy);
  font-weight:800;
}
.focus-list span{
  width:12px;
  height:12px;
  border-radius:999px;
  background:var(--gold);
  flex:0 0 auto;
}
.commission-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:24px;
  margin-top:38px;
}
.commission-card{
  min-height:240px;
  padding:34px;
  border-radius:34px;
  background:linear-gradient(135deg,#fff,#f9f1e4);
  border:1px solid var(--line);
  box-shadow:var(--shadow-soft);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:22px;
  overflow:hidden;
  position:relative;
}
.commission-card:after{
  content:"";
  position:absolute;
  width:180px;
  height:180px;
  border-radius:999px;
  background:rgba(197,155,85,.15);
  right:-70px;
  bottom:-80px;
}
.commission-label{
  display:inline-flex;
  padding:8px 12px;
  border-radius:999px;
  background:var(--navy);
  color:#fff;
  font-weight:900;
  font-size:.82rem;
}
.commission-card h3{margin:20px 0 0;color:var(--navy);font-size:clamp(1.35rem,2vw,2rem);line-height:1.1}
.commission-card strong{
  position:relative;
  z-index:1;
  font-size:clamp(3rem,6vw,5.5rem);
  color:var(--gold);
  letter-spacing:-.08em;
}
.location{padding-top:30px}
.location-box{
  border-radius:38px;
  background:linear-gradient(135deg,var(--navy),#1b426f);
  color:#fff;
  padding:48px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  box-shadow:var(--shadow);
  overflow:hidden;
  position:relative;
}
.location-box h2{color:#fff}
.location-box p:last-child{margin:14px 0 0;color:rgba(255,255,255,.82);font-size:1.12rem}
.location-mark{
  width:150px;
  height:150px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.18);
  display:grid;
  place-items:center;
  flex:0 0 auto;
}
.location-mark span{
  width:60px;
  height:60px;
  border-radius:60px 60px 60px 8px;
  background:var(--gold-2);
  transform:rotate(-45deg);
  position:relative;
}
.location-mark span:after{
  content:"";
  position:absolute;
  inset:18px;
  border-radius:999px;
  background:var(--navy);
}
.footer{
  padding:34px 0;
  background:#08172a;
  color:rgba(255,255,255,.78);
}
.footer-grid{
  display:grid;
  grid-template-columns:.7fr 1.4fr .4fr;
  gap:20px;
  align-items:center;
}
.footer p{margin:0}
.footer strong{color:#fff}

.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:none}
.delay-1{transition-delay:.12s}
.delay-2{transition-delay:.22s}

@media (max-width:1050px){
  .hero-grid,.intro-grid,.split-grid{grid-template-columns:1fr}
  .hero{background:linear-gradient(160deg,#102542 0%,#17365d 65%,#f6efe3 65%,#fff 100%)}
  .visual-panel{min-height:470px}
  .cards-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr}
}
@media (max-width:760px){
  .nav{min-height:70px}
  .brand-name{font-size:.92rem}
  .menu-button{display:block}
  .menu{
    position:absolute;
    top:70px;
    left:3%;
    right:3%;
    display:none;
    flex-direction:column;
    align-items:stretch;
    padding:14px;
    border-radius:24px;
    background:#fff;
    box-shadow:var(--shadow);
    border:1px solid var(--line);
  }
  .menu.open{display:flex}
  .menu a{text-align:center;padding:14px}
  .hero{padding:70px 0 60px}
  .hero h1{font-size:clamp(2.15rem,12vw,3.55rem)}
  .hero-text{font-size:1rem}
  .visual-panel{min-height:420px;place-items:end center}
  .document-card{min-height:410px;padding:26px;border-radius:28px}
  .mini-card{position:relative;inset:auto;width:100%;margin-top:12px}
  .visual-panel{display:block}
  .section{padding:64px 0}
  .intro-box,.location-box{padding:28px;border-radius:26px}
  .cards-grid,.commission-grid{grid-template-columns:1fr}
  .service-card{min-height:auto}
  .image-abstract{min-height:360px;border-radius:28px}
  .building{left:24px;bottom:28px;width:170px;height:230px;padding:26px 20px;gap:10px}
  .key-ring{right:40px;top:70px;width:84px;height:84px;border-width:13px}
  .key-ring:after{width:80px;height:12px;right:-66px;top:30px;box-shadow:24px 16px 0 -3px var(--gold-2),42px -14px 0 -4px var(--gold-2)}
  .signature-line{right:34px;bottom:52px;width:160px}
  .commission-card{flex-direction:column;align-items:flex-start;min-height:auto}
  .location-box{display:block}
  .location-mark{margin-top:28px;width:112px;height:112px}
}
@media (max-width:420px){
  .brand-icon{width:40px;height:40px;border-radius:14px}
  .brand-name{max-width:190px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .hero-actions .button{width:100%}
  .paper-footer span{font-size:.92rem}
  .section-title h2,.split-content h2,.location-box h2{font-size:2rem}
}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .reveal,.button,.service-card{transition:none}
}
