:root{
  --primary:#123a6d;
  --primary-dark:#0e2e58;
  --secondary:#f4f7fb;
  --accent:#d9a441;
  --accent-dark:#bf8c2f;
  --text:#1f2937;
  --white:#ffffff;
  --muted:#6b7280;
  --shadow:0 10px 25px rgba(0,0,0,.08);
  --radius:18px;
  --max-width:1140px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Arial,Helvetica,sans-serif;
  color:var(--text);
  background:var(--secondary);
  line-height:1.6;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
.container{width:min(92%,var(--max-width));margin:auto}
header{
  background:var(--primary);
  color:var(--white);
  position:sticky;
  top:0;
  z-index:1000;
  box-shadow:0 4px 16px rgba(0,0,0,.12);
}
.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 0;
  gap:18px;
  flex-wrap:wrap;
  position:relative;
}
.brand{
  display:flex;
  align-items:center;
  gap:12px;
  font-weight:700;
  font-size:1.02rem;
  min-width:0;
}
.brand span{line-height:1.2}
.logo{
  width:52px;
  height:52px;
  border-radius:50%;
  background:var(--white);
  overflow:hidden;
  display:grid;
  place-items:center;
  flex-shrink:0;
}
.logo img{width:100%;height:100%;object-fit:contain}

.nav-toggle{display:none}
.nav-toggle-label{
  display:none;
  width:48px;
  height:48px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.22);
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:6px;
  cursor:pointer;
  background:rgba(255,255,255,.06);
}
.nav-toggle-label span{
  display:block;
  width:22px;
  height:2.5px;
  background:#fff;
  border-radius:999px;
}

.menu{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  align-items:center;
}
.menu a{
  color:#eef3fb;
  font-weight:600;
  padding:8px 10px;
  border-radius:999px;
  font-size:.96rem;
}
.menu a:hover,.menu a.active{
  color:#123a6d;
  background:#ffd87a;
}

.hero{
  background:
    linear-gradient(rgba(18,58,109,.84), rgba(18,58,109,.76)),
    url('hero-main.jpg') center/cover no-repeat;
  color:var(--white);
  padding:92px 0 82px;
}
.hero-grid{
  display:grid;
  grid-template-columns:1.35fr .85fr;
  gap:28px;
  align-items:center;
}
.hero h1{
  font-size:clamp(2rem,4vw,3.7rem);
  line-height:1.12;
  margin:0 0 16px;
}
.hero p{
  max-width:700px;
  margin:0 0 22px;
  color:#eef3fb;
}
.hero-card{
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.16);
  backdrop-filter:blur(8px);
  border-radius:var(--radius);
  padding:24px;
}
.hero-card h3{margin-top:0}
.hero-card ul{padding-left:18px;margin:0}
.section{padding:74px 0}
.section-sm{padding:48px 0}
.section-title{text-align:center;margin-bottom:34px}
.section-title h1,.section-title h2{
  font-size:clamp(1.8rem,3vw,2.6rem);
  color:var(--primary);
  margin:0 0 8px;
}
.section-title p{
  max-width:760px;
  margin:auto;
  color:var(--muted);
}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.card{
  background:var(--white);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:24px;
}
.card h3{margin-top:0;color:var(--primary)}
.list{padding-left:18px}
.btn{
  display:inline-block;
  padding:12px 18px;
  border-radius:999px;
  font-weight:700;
  transition:.2s ease;
  text-align:center;
}
.btn-primary{background:var(--accent);color:#111827}
.btn-outline{border:2px solid rgba(255,255,255,.82);color:var(--white)}
.btn-dark{background:var(--primary);color:var(--white)}
.btn:hover{transform:translateY(-2px)}
.feature{text-align:center}
.feature .icon{
  width:56px;
  height:56px;
  border-radius:16px;
  background:#e7eef9;
  color:var(--primary);
  display:grid;
  place-items:center;
  font-weight:700;
  margin:0 auto 14px;
  font-size:1.1rem
}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.stat{
  background:var(--white);
  padding:24px;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  text-align:center
}
.stat strong{
  display:block;
  font-size:1.7rem;
  color:var(--primary)
}
.split-image img,
.gallery img,
.photo-card img{
  border-radius:14px;
  box-shadow:var(--shadow);
  width:100%;
  object-fit:cover;
}
.split-image img{min-height:360px}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.gallery img{height:250px}
.photo-card img{height:220px}
.fees-table{
  width:100%;
  border-collapse:collapse;
  background:var(--white);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow)
}
.fees-table th,.fees-table td{
  padding:14px;
  text-align:left;
  border-bottom:1px solid #e5e7eb;
}
.fees-table th{
  background:var(--primary);
  color:var(--white)
}
.map-box iframe{
  width:100%;
  min-height:340px;
  border:0;
  border-radius:var(--radius);
  box-shadow:var(--shadow)
}
.footer{
  background:#0f172a;
  color:#d1d5db;
  padding:26px 0;
  text-align:center
}
.notice{color:var(--muted);font-size:.95rem}
.page-hero{
  background:linear-gradient(135deg,#123a6d,#1d4f8c);
  color:white;
  padding:58px 0 48px
}
.page-hero h1{
  margin:0 0 8px;
  font-size:clamp(2rem,3vw,3rem)
}
.page-hero p{
  margin:0;
  color:#edf3ff;
  max-width:760px
}
.banner{
  background:linear-gradient(135deg,#123a6d,#0f335f);
  color:white;
  border-radius:var(--radius);
  padding:28px;
  box-shadow:var(--shadow)
}
.timeline{display:grid;gap:18px}
.timeline .item{
  background:var(--white);
  box-shadow:var(--shadow);
  border-radius:var(--radius);
  padding:20px
}
.badge{
  display:inline-block;
  background:#e8eef7;
  color:var(--primary);
  padding:8px 12px;
  border-radius:999px;
  font-weight:700;
  font-size:.92rem
}
.callout{
  border-left:5px solid var(--accent);
  padding:18px 18px 18px 20px;
  background:#fff9ec;
  border-radius:0 var(--radius) var(--radius) 0
}

/* tablet */
@media (max-width: 992px){
  .container{width:min(94%,var(--max-width))}
  .hero{padding:72px 0 62px}
  .hero-grid,.grid-2,.grid-3,.grid-4,.gallery,.stats{
    grid-template-columns:1fr 1fr;
  }
  .hero-grid > :first-child{
    grid-column:1 / -1;
  }
  .split-image img{min-height:300px}

  .nav-toggle-label{
    display:flex;
    margin-left:auto;
  }
  .menu{
    display:none;
    width:100%;
    flex-direction:column;
    align-items:stretch;
    gap:10px;
    padding:14px 0 4px;
  }
  .menu a{
    display:block;
    text-align:center;
    background:rgba(255,255,255,.08);
    padding:12px 10px;
    border-radius:12px;
  }
  .nav-toggle:checked ~ .menu{
    display:flex;
  }
}

/* phone */
@media (max-width: 640px){
  header{position:static}
  .nav{
    align-items:center;
    gap:12px;
    padding:12px 0;
  }
  .brand{
    width:calc(100% - 64px);
    justify-content:flex-start;
  }
  .brand span{
    font-size:.95rem;
  }
  .nav-toggle-label{
    width:44px;
    height:44px;
  }
  .hero{
    padding:56px 0 48px;
    background-position:center;
  }
  .hero-grid,.grid-2,.grid-3,.grid-4,.gallery,.stats{
    grid-template-columns:1fr;
  }
  .hero h1{
    font-size:2rem;
  }
  .hero-card,
  .card,
  .stat,
  .banner{
    padding:18px;
  }
  .section{
    padding:56px 0;
  }
  .section-sm{
    padding:36px 0;
  }
  .section-title{
    margin-bottom:24px;
  }
  .section-title h1,.section-title h2{
    font-size:1.7rem;
  }
  .btn{
    width:100%;
  }
  .gallery img{
    height:220px;
  }
  .split-image img{
    min-height:220px;
  }
  .page-hero{
    padding:42px 0 34px;
  }
  .page-hero h1{
    font-size:1.8rem;
  }
  .fees-table{
    display:block;
    overflow-x:auto;
    white-space:nowrap;
  }
  .map-box iframe{
    min-height:280px;
  }
  .callout{
    padding:16px;
  }
}