@font-face {
    font-family: "IRANSansWeb(FaNum)";
    src: url("../fonts/IRANSansWebFaNum.eot");
    src: url("../fonts/IRANSansWebFaNum.eot?#iefix") format("embedded-opentype"),
      url("../fonts/IRANSansWebFaNum.woff2") format("woff2"),
      url("../fonts/IRANSansWebFaNum.woff") format("woff"),
      url("../fonts/IRANSansWebFaNum.ttf") format("truetype");
    font-weight: normal;
    font-style: normal;
    font-display: swap;
  }
  @font-face {
    font-family: "Far.Yekan";
    src: url("../fonts/FarYekan.eot");
    src: url("../fonts/FarYekan.eot?#iefix") format("embedded-opentype"),
      url("../fonts/FarYekan.woff2") format("woff2"),
      url("../fonts/FarYekan.woff") format("woff"),
      url("../fonts/FarYekan.ttf") format("truetype");
    font-weight: normal;
    font-style: normal;
    font-display: swap;
  }
  
  @font-face {
    font-family: "kalameh";
    src: url("../fonts/KalamehWebRegular.woff2");
    src: url("../fonts/FarYekan.woff2") format("woff2");
  }


  body{
    font-family: "Far.Yekan";
  }



  *, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

:root {
  --cream:        #f4efe8;
  --cream-dark:   #ebe4d9;
  --dark:         #0f1117;
  --dark-mid:     #1a1d27;
  --gold:         #c9a96e;
  --gold-light:   #e2cfa0;
  --gold-pale:    rgba(201,169,110,0.12);
  --teal:         #1f8a7e;
  --teal-light:   #2bb5a5;
  --teal-pale:    rgba(31,138,126,0.10);
  --text:         #3a3d45;
  --text-light:   #78808f;
  --white:        #ffffff;
  --glass:        rgba(255,255,255,0.55);
  --glass-border: rgba(255,255,255,0.35);
  --shadow-sm:    0 4px 20px rgba(0,0,0,0.06);
  --shadow-md:    0 10px 44px rgba(0,0,0,0.10);
  --shadow-lg:    0 24px 72px rgba(0,0,0,0.14);
}

html { scroll-behavior:smooth; }
body {
  font-family:'Segoe UI','Tahoma',sans-serif;
  background:var(--cream);
  color:var(--text);
  direction:rtl;
  text-align:right;
  overflow-x:hidden;
  line-height:1.7;
}
a { text-decoration:none; color:inherit; }
ul { list-style:none; }

/* ═══════════════════════════════════════════
   NAVBAR
═══════════════════════════════════════════ */
nav {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  padding:20px 48px;
  display:flex; align-items:center; justify-content:space-between;
  background:rgba(244,239,232,0.7);
  backdrop-filter:blur(20px) saturate(1.4);
  -webkit-backdrop-filter:blur(20px) saturate(1.4);
  border-bottom:1px solid rgba(201,169,110,0.18);
  transition:padding .35s, background .35s, box-shadow .35s;
}
nav.scrolled {
  padding:12px 48px;
  background:rgba(244,239,232,0.92);
  box-shadow:var(--shadow-sm);
}
.nav-logo {
  font-family:'Playfair Display',serif;
  font-size:1.55rem; color:var(--dark);
  display:flex; align-items:center; gap:10px;
  letter-spacing:.5px;
}
.nav-logo .pearl {
  width:30px; height:30px; border-radius:50%;
  background:radial-gradient(circle at 38% 35%, #fff 0%, var(--gold-light) 35%, var(--gold) 65%, #9a7530 100%);
  box-shadow:0 3px 14px rgba(201,169,110,0.45), inset 0 1px 4px rgba(255,255,255,0.7);
}
.nav-links { display:flex; gap:34px; align-items:center; }
.nav-links a {
  font-size:.91rem; color:var(--text);
  position:relative; padding-bottom:5px;
  transition:color .3s;
}
.nav-links a::after {
  content:''; position:absolute; bottom:0; right:0;
  width:0; height:1.5px;
  background:linear-gradient(90deg,var(--gold),var(--teal));
  transition:width .35s cubic-bezier(.4,0,.2,1);
}
.nav-links a:hover { color:var(--teal); }
.nav-links a:hover::after { width:100%; }
.nav-cta {
  background:linear-gradient(135deg,var(--teal),var(--teal-light));
  color:#fff !important; padding:10px 24px; border-radius:50px;
  font-size:.88rem; box-shadow:0 4px 18px rgba(31,138,126,0.3);
  transition:transform .25s, box-shadow .25s !important;
}
.nav-cta::after { display:none !important; }
.nav-cta:hover { transform:translateY(-2px); box-shadow:0 8px 28px rgba(31,138,126,0.4) !important; }

.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; }
.hamburger span { width:24px; height:2px; background:var(--dark); border-radius:2px; transition:.3s; }

/* ═══════════════════════════════════════════
   ★ HERO — CINEMATIC
═══════════════════════════════════════════ */
.hero {
  position:relative;
  min-height:100vh;
  display:flex; align-items:center;
  overflow:hidden;
  background:var(--dark);
}
/* Multi-layer gradient sky */
.hero-bg {
  position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(ellipse 80% 60% at 75% 40%, #1a3a38 0%, transparent 65%),
    radial-gradient(ellipse 60% 50% at 20% 70%, #162e2a 0%, transparent 60%),
    radial-gradient(ellipse 50% 40% at 50% 10%, #1e2a22 0%, transparent 55%),
    linear-gradient(170deg, #0f1117 0%, #131820 40%, #0d1210 100%);
}
/* Subtle grain overlay */
.hero-grain {
  position:absolute; inset:0; z-index:1;
  opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:256px 256px;
  pointer-events:none;
}
/* Particle canvas */
#particles { position:absolute; inset:0; z-index:2; pointer-events:none; }

/* Decorative glow orbs */
.hero-orb {
  position:absolute; border-radius:50%; filter:blur(70px); pointer-events:none; z-index:2;
}
.hero-orb-1 { width:380px; height:380px; background:rgba(31,138,126,0.18); top:-80px; right:10%; }
.hero-orb-2 { width:280px; height:280px; background:rgba(201,169,110,0.12); bottom:-60px; left:5%; }
.hero-orb-3 { width:200px; height:200px; background:rgba(31,138,126,0.10); top:50%; left:30%; }

/* Inner layout */
.hero-inner {
  position:relative; z-index:3;
  width:100%; max-width:1260px;
  margin:0 auto; padding:0 60px;
  display:grid; grid-template-columns:1.15fr 0.85fr;
  align-items:center; gap:40px;
  min-height:100vh;
}

/* ── Left: Content ── */
.hero-content { padding:40px 0; }

.hero-badge {
  display:inline-flex; align-items:center; gap:9px;
  background:rgba(255,255,255,0.07);
  border:1px solid rgba(255,255,255,0.14);
  backdrop-filter:blur(8px);
  padding:7px 18px; border-radius:50px;
  font-size:.8rem; color:rgba(255,255,255,0.75);
  margin-bottom:28px;
  opacity:0; transform:translateY(18px);
  animation:fadeUp .7s .15s forwards;
}
.hero-badge .dot {
  width:7px; height:7px; border-radius:50%;
  background:var(--teal-light);
  box-shadow:0 0 8px var(--teal-light);
  animation:pulse 2.2s infinite;
}

.hero-title {
  font-family:'Playfair Display',serif;
  font-size:clamp(2.9rem,5.8vw,4.6rem);
  line-height:1.15; color:#fff;
  margin-bottom:26px;
  opacity:0; transform:translateY(32px);
  animation:fadeUp .85s .3s forwards;
}
.hero-title .line2 {
  display:block;
  background:linear-gradient(100deg, var(--gold-light) 0%, var(--gold) 40%, var(--teal-light) 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

.hero-desc {
  font-size:1.05rem; color:rgba(255,255,255,0.5);
  max-width:460px; margin-bottom:38px;
  opacity:0; transform:translateY(20px);
  animation:fadeUp .8s .5s forwards;
  line-height:1.8;
}

.hero-buttons {
  display:flex; gap:14px; flex-wrap:wrap;
  opacity:0; transform:translateY(18px);
  animation:fadeUp .8s .68s forwards;
}
.btn-primary {
  background:linear-gradient(135deg,var(--teal),var(--teal-light));
  color:#fff; padding:15px 34px; border-radius:50px;
  font-size:.94rem; border:none; cursor:pointer;
  box-shadow:0 6px 28px rgba(31,138,126,0.35);
  transition:transform .25s, box-shadow .25s;
  position:relative; overflow:hidden;
}
.btn-primary::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,0.15),transparent);
  opacity:0; transition:opacity .3s;
}
.btn-primary:hover { transform:translateY(-3px); box-shadow:0 10px 38px rgba(31,138,126,0.45); }
.btn-primary:hover::before { opacity:1; }

.btn-outline {
  background:rgba(255,255,255,0.06);
  backdrop-filter:blur(8px);
  color:rgba(255,255,255,0.85);
  padding:15px 30px; border-radius:50px;
  font-size:.94rem;
  border:1px solid rgba(255,255,255,0.18);
  cursor:pointer;
  transition:background .3s, border-color .3s, transform .25s;
}
.btn-outline:hover {
  background:rgba(255,255,255,0.12);
  border-color:var(--gold);
  transform:translateY(-3px);
}

/* Trust stats */
.hero-trust {
  display:flex; gap:38px; margin-top:50px; flex-wrap:wrap;
  opacity:0; transform:translateY(14px);
  animation:fadeUp .7s .88s forwards;
}
.trust-item { display:flex; align-items:center; gap:10px; }
.trust-divider { width:1px; height:36px; background:rgba(255,255,255,0.12); }
.trust-num {
  font-family:'Playfair Display',serif;
  font-size:1.55rem; font-weight:700;
  background:linear-gradient(135deg,var(--gold-light),var(--gold));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.trust-label { font-size:.76rem; color:rgba(255,255,255,0.4); line-height:1.4; }

/* ── Right: Visual ── */
.hero-visual {
  position:relative;
  display:flex; align-items:center; justify-content:center;
  height:480px;
}
.hero-image {
  position:relative; z-index:1;
  max-width:85%; max-height:100%;
  object-fit:contain;
  border-radius:24px;
  box-shadow:0 20px 60px rgba(0,0,0,0.3);
  animation:fadeUp .9s .4s forwards;
  opacity:0;
}

/* Main shape */
.hero-shape {
  position:absolute;
  width:360px; height:380px;
  border-radius:50%;
  background:
    radial-gradient(circle at 38% 35%, rgba(255,255,255,0.08) 0%, transparent 50%),
    linear-gradient(145deg, rgba(31,138,126,0.25) 0%, rgba(31,138,126,0.08) 60%, transparent 100%);
  border:1px solid rgba(255,255,255,0.08);
  backdrop-filter:blur(4px);
  animation:rotateSlow 30s linear infinite;
}

/* Ring decorations */
.hero-ring {
  position:absolute; border-radius:50%;
  border:1px solid rgba(255,255,255,0.06);
}
.hero-ring-1 { width:440px; height:440px; top:50%; left:50%; transform:translate(-50%,-50%); }
.hero-ring-2 { width:300px; height:300px; top:50%; left:50%; transform:translate(-50%,-50%); border-color:rgba(201,169,110,0.12); }
.hero-ring-3 { width:160px; height:160px; top:50%; left:50%; transform:translate(-50%,-50%); }

/* Pearl centerpiece */
.hero-pearl {
  position:absolute; top:50%; left:50%;
  transform:translate(-50%,-50%);
  width:100px; height:100px; border-radius:50%;
  background:radial-gradient(circle at 38% 35%, #fff 0%, var(--gold-light) 30%, var(--gold) 60%, #8a6520 100%);
  box-shadow:0 0 50px rgba(201,169,110,0.35), 0 0 100px rgba(201,169,110,0.15);
  z-index:2;
}

/* Glass floating cards */
.hero-float {
  position:absolute; z-index:3;
  background:var(--glass);
  backdrop-filter:blur(16px) saturate(1.3);
  -webkit-backdrop-filter:blur(16px) saturate(1.3);
  border:1px solid var(--glass-border);
  border-radius:18px;
  padding:16px 20px;
  display:flex; align-items:center; gap:14px;
  box-shadow:var(--shadow-md), inset 0 1px 0 rgba(255,255,255,0.4);
  white-space:nowrap;
}
.hero-float .hf-icon {
  width:42px; height:42px; border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  font-size:1.25rem; flex-shrink:0;
}
.hero-float .hf-text { line-height:1.35; }
.hero-float .hf-text .hf-label { font-size:.72rem; color:var(--text-light); }
.hero-float .hf-text .hf-val { font-size:.88rem; color:var(--dark); font-weight:600; }

.hero-float-1 { top:8%; right:2%; animation:floatA 5s ease-in-out infinite; }
.hero-float-1 .hf-icon { background:#e6f7f4; }
.hero-float-2 { bottom:14%; left:-4%; animation:floatB 5.5s ease-in-out infinite; }
.hero-float-2 .hf-icon { background:#fef4e4; }
.hero-float-3 { top:52%; right:-6%; animation:floatC 6s ease-in-out infinite; }
.hero-float-3 .hf-icon { background:#eef2fd; }

/* ═══════════════════════════════════════════
   SECTION HEADERS — upgraded
═══════════════════════════════════════════ */
.section { padding:110px 60px; }

.sec-header { margin-bottom:58px; }
.sec-header.center { text-align:center; }
.sec-header.center .sec-eyebrow { justify-content:center; }
.sec-header.center .sec-desc { margin-left:auto; margin-right:auto; }

.sec-eyebrow {
  display:inline-flex; align-items:center; gap:12px;
  margin-bottom:14px;
}
.sec-eyebrow .ey-line {
  width:32px; height:2px; border-radius:1px;
  background:linear-gradient(90deg,var(--gold),var(--teal));
}
.sec-eyebrow span {
  font-size:.75rem; text-transform:uppercase;
  letter-spacing:2.5px; color:var(--gold);
  font-weight:600;
}

.sec-title {
  font-family:'Playfair Display',serif;
  font-size:clamp(2rem,3.8vw,2.9rem);
  color:var(--dark); line-height:1.25;
  margin-bottom:16px;
  padding-bottom:12px;
}
.sec-title .grad {
  background:linear-gradient(110deg,var(--dark) 0%,var(--teal) 50%,var(--gold) 100%);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
/* animated underline accent */
.sec-title-wrap { position:relative; display:inline-block; }
.sec-title-wrap::after {
  content:''; position:absolute; bottom:0; right:0;
  width:60%; height:3px; border-radius:2px;
  background:linear-gradient(90deg,var(--gold),var(--teal),var(--gold));
  background-size:200% 100%;
  animation:shimmer 3s linear infinite;
}
.sec-header.center .sec-title-wrap { display:block; }
.sec-header.center .sec-title-wrap::after { left:50%; right:auto; width:80px; transform:translateX(-50%); }

.sec-desc {
  font-size:1rem; color:var(--text-light);
  max-width:520px; line-height:1.8;
}

/* ═══════════════════════════════════════════
   SERVICES
═══════════════════════════════════════════ */
.services { background:#fff; }

.services-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
  max-width:1100px; margin:0 auto;
}

.service-card {
  position:relative; overflow:hidden;
  background:var(--cream);
  border:1px solid rgba(31,138,126,0.08);
  border-radius:26px;
  padding:0;
  transition:transform .35s cubic-bezier(.4,0,.2,1), box-shadow .35s, border-color .35s;
  cursor:default;
}
.sc-image-wrapper {
  position:relative;
  width:100%;
  height:220px;
  overflow:hidden;
  border-radius:26px 26px 0 0;
  background:linear-gradient(135deg, var(--teal-pale), var(--gold-pale));
}
.sc-image {
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .5s cubic-bezier(.4,0,.2,1), filter .5s;
  filter:brightness(0.95);
}
.service-card:hover .sc-image {
  transform:scale(1.12);
  filter:brightness(1.05);
}
.service-card .sc-num,
.service-card .sc-icon,
.service-card h3,
.service-card p {
  padding:0 30px;
}
.service-card .sc-num {
  position:absolute;
  top:16px;
  left:20px;
  z-index:2;
  color:rgba(255,255,255,0.9);
  text-shadow:0 2px 8px rgba(0,0,0,0.2);
}
.service-card .sc-icon {
  margin-top:24px;
  margin-bottom:18px;
  position:relative;
  z-index:1;
}
.service-card h3 {
  padding-top:0;
  position:relative;
  z-index:1;
}
.service-card p {
  padding-bottom:32px;
  position:relative;
  z-index:1;
}
/* top accent bar */
.service-card::before {
  content:''; position:absolute; top:0; left:0; right:0;
  height:3px;
  background:linear-gradient(90deg,var(--teal),var(--gold));
  opacity:0; transition:opacity .35s;
}
.service-card:hover::before { opacity:1; }
.service-card:hover {
  transform:translateY(-8px);
  box-shadow:var(--shadow-lg);
  border-color:rgba(31,138,126,0.18);
  background:#fff;
}

/* large bg number */
.sc-num {
  position:absolute; top:14px; left:20px;
  font-family:'Playfair Display',serif;
  font-size:5.5rem; line-height:1;
  color:rgba(31,138,126,0.055);
  pointer-events:none; user-select:none;
  transition:color .4s;
}
.service-card:hover .sc-num { color:rgba(31,138,126,0.11); }

.sc-icon {
  width:58px; height:58px; border-radius:17px;
  display:flex; align-items:center; justify-content:center;
  font-size:1.65rem; margin-bottom:22px;
  position:relative; z-index:1;
}
.service-card:nth-child(1) .sc-icon { background:#e4f5f2; }
.service-card:nth-child(2) .sc-icon { background:#fdf1e2; }
.service-card:nth-child(3) .sc-icon { background:#edf2fe; }
.service-card:nth-child(4) .sc-icon { background:#f1eef9; }
.service-card:nth-child(5) .sc-icon { background:#e7f8ed; }
.service-card:nth-child(6) .sc-icon { background:#fef0f0; }

.service-card h3 { font-size:1.08rem; color:var(--dark); margin-bottom:8px; position:relative; z-index:1; }
.service-card p  { font-size:.84rem; color:var(--text-light); position:relative; z-index:1; }

/* ═══════════════════════════════════════════
   WHY US
═══════════════════════════════════════════ */
.why-us {
  display:grid; grid-template-columns:1fr 1fr; gap:0;
}
.why-visual {
  position:relative; overflow:hidden;
  min-height:480px;
  background:linear-gradient(155deg,#0f1a18 0%,#1a3836 40%,#145048 100%);
  display:flex; align-items:center; justify-content:center;
}
.why-image {
  position:relative; z-index:1;
  max-width:90%;
  max-height:90%;
  object-fit:contain;
  border-radius:20px;
  opacity:0.85;
  filter:brightness(1.1) contrast(1.05);
}
/* concentric rings */
.why-ring {
  position:absolute; border-radius:50%;
  border:1px solid rgba(255,255,255,0.06);
  top:50%; left:50%; transform:translate(-50%,-50%);
}
.why-ring:nth-child(1) { width:360px; height:360px; }
.why-ring:nth-child(2) { width:240px; height:240px; border-color:rgba(201,169,110,0.1); }
.why-ring:nth-child(3) { width:120px; height:120px; }
/* rotating ring */
.why-ring-spin {
  position:absolute; width:280px; height:280px;
  border-radius:50%;
  border:1px dashed rgba(201,169,110,0.18);
  top:50%; left:50%; transform:translate(-50%,-50%);
  animation:rotateSlow 40s linear infinite;
}
.why-pearl {
  position:relative; z-index:1;
  width:96px; height:96px; border-radius:50%;
  background:radial-gradient(circle at 38% 35%,#fff 0%,var(--gold-light) 32%,var(--gold) 62%,#8a6520 100%);
  box-shadow:0 0 44px rgba(201,169,110,0.35), 0 0 80px rgba(201,169,110,0.12);
}
/* corner decoration */
.why-deco {
  position:absolute; bottom:32px; right:32px;
  font-size:6rem; opacity:.04; color:#fff;
  font-family:'Playfair Display',serif;
  user-select:none; pointer-events:none;
}

.why-content {
  background:var(--cream);
  padding:90px 64px;
  display:flex; flex-direction:column; justify-content:center;
}
.why-list { display:flex; flex-direction:column; gap:30px; margin-top:4px; }
.why-item { display:flex; gap:20px; align-items:flex-start; }
.why-item .wy-num {
  min-width:40px; height:40px; border-radius:13px;
  background:linear-gradient(135deg,var(--teal),var(--teal-light));
  color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-family:'Playfair Display',serif; font-size:1.05rem;
  flex-shrink:0;
  box-shadow:0 4px 16px rgba(31,138,126,0.3);
}
.why-item h4 { font-size:1.03rem; color:var(--dark); margin-bottom:4px; }
.why-item p  { font-size:.84rem; color:var(--text-light); }

/* ═══════════════════════════════════════════
   INSTALLMENT — dark glass cards
═══════════════════════════════════════════ */
.installment {
  background:var(--dark);
  position:relative; overflow:hidden;
  text-align:center;
}
.installment .inst-bg-orb {
  position:absolute; border-radius:50%; filter:blur(80px); pointer-events:none;
}
.inst-bg-orb-1 { width:440px; height:440px; background:rgba(31,138,126,0.13); top:-140px; right:-100px; }
.inst-bg-orb-2 { width:320px; height:320px; background:rgba(201,169,110,0.08); bottom:-80px; left:-60px; }

.installment .sec-eyebrow span { color:var(--gold); }
.installment .sec-title { color:#fff; }
.installment .sec-title-wrap::after { background:linear-gradient(90deg,var(--gold),rgba(201,169,110,0.3)); background-size:200% 100%; }
.installment .sec-desc { color:rgba(255,255,255,0.45); }

.inst-grid {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:18px; max-width:960px; margin:0 auto;
  position:relative; z-index:1;
}
.inst-card {
  position:relative; overflow:hidden;
  background:rgba(255,255,255,0.055);
  border:1px solid rgba(255,255,255,0.1);
  border-radius:24px;
  padding:36px 24px 30px;
  transition:transform .35s, background .35s, border-color .35s, box-shadow .35s;
  backdrop-filter:blur(6px);
}
.inst-card::before {
  content:''; position:absolute; top:0; left:0; right:0;
  height:2px;
  background:linear-gradient(90deg,var(--gold),var(--teal));
  opacity:0; transition:opacity .35s;
}
.inst-card:hover::before { opacity:1; }
.inst-card:hover {
  transform:translateY(-6px);
  background:rgba(255,255,255,0.09);
  border-color:rgba(255,255,255,0.2);
  box-shadow:0 12px 40px rgba(0,0,0,0.25);
}
.inst-card .ic-icon {
  width:54px; height:54px; border-radius:16px;
  display:flex; align-items:center; justify-content:center;
  font-size:1.5rem; margin:0 auto 20px;
  background:rgba(255,255,255,0.07);
  border:1px solid rgba(255,255,255,0.1);
}
.inst-card h4 { font-size:1.02rem; color:#fff; margin-bottom:8px; }
.inst-card p  { font-size:.81rem; color:rgba(255,255,255,0.42); }

/* ═══════════════════════════════════════════
   TESTIMONIALS
═══════════════════════════════════════════ */
.testimonials { background:#fff; }

.testimonial-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:22px; max-width:1080px; margin:0 auto;
}
.testimonial-card {
  position:relative; overflow:hidden;
  background:var(--cream);
  border:1px solid rgba(31,138,126,0.08);
  border-radius:24px;
  padding:34px 28px 28px;
  transition:transform .35s, box-shadow .35s, border-color .35s, background .35s;
}
.testimonial-card::before {
  content:''; position:absolute; top:0; left:0; right:0;
  height:3px;
  background:linear-gradient(90deg,var(--teal),var(--gold));
  opacity:0; transition:opacity .35s;
}
.testimonial-card:hover::before { opacity:1; }
.testimonial-card:hover {
  transform:translateY(-6px);
  box-shadow:var(--shadow-lg);
  border-color:rgba(31,138,126,0.18);
  background:#fff;
}
.tc-quote {
  font-family:'Playfair Display',serif;
  font-size:3.8rem; line-height:.9;
  color:var(--gold); opacity:.4;
  margin-bottom:10px;
}
.tc-stars { color:var(--gold); font-size:.88rem; letter-spacing:3px; margin-bottom:14px; }
.testimonial-card > p { font-size:.87rem; color:var(--text-light); margin-bottom:22px; font-style:italic; }
.tc-author { display:flex; align-items:center; gap:12px; }
.tc-avatar {
  width:44px; height:44px; border-radius:50%;
  background:linear-gradient(135deg,var(--teal),var(--teal-light));
  display:flex; align-items:center; justify-content:center;
  color:#fff; font-size:1rem; font-weight:600;
  box-shadow:0 3px 12px rgba(31,138,126,0.3);
}
.tc-info h5 { font-size:.9rem; color:var(--dark); }
.tc-info span { font-size:.77rem; color:var(--text-light); }

/* ═══════════════════════════════════════════
   CONTACT
═══════════════════════════════════════════ */
.contact { display:grid; grid-template-columns:1.2fr 0.8fr; }
.contact-content {
  background:var(--cream);
  padding:100px 64px;
  display:flex; flex-direction:column; justify-content:center;
}
.contact-info { display:flex; flex-direction:column; gap:24px; }
.contact-item { display:flex; gap:18px; align-items:flex-start; }
.contact-item .ci-icon {
  width:50px; height:50px; border-radius:15px;
  background:#fff; border:1px solid rgba(31,138,126,0.1);
  display:flex; align-items:center; justify-content:center;
  font-size:1.3rem; flex-shrink:0;
  box-shadow:var(--shadow-sm);
}
.contact-item h4 { font-size:.92rem; color:var(--dark); margin-bottom:3px; }
.contact-item p  { font-size:.82rem; color:var(--text-light); }

.contact-visual {
  background:linear-gradient(155deg,#0f1a18 0%,#145048 60%,#1a3836 100%);
  position:relative; overflow:hidden;
  min-height:420px;
  display:flex; align-items:center; justify-content:center;
}
.cv-ring {
  position:absolute; border-radius:50%;
  border:1px solid rgba(255,255,255,0.07);
}
.cv-ring:nth-child(1) { width:320px; height:320px; bottom:-100px; right:-100px; }
.cv-ring:nth-child(2) { width:200px; height:200px; top:-60px; left:-60px; border-color:rgba(201,169,110,0.1); }
.cv-map {
  position:relative; z-index:1; text-align:center;
  color:rgba(255,255,255,0.6);
}
.cv-map .map-pin { font-size:2.8rem; margin-bottom:10px; opacity:.7; }
.cv-map p { font-size:.84rem; opacity:.5; }

/* ═══════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════ */
footer {
  background:var(--dark); color:rgba(255,255,255,0.45);
  padding:70px 60px 32px;
}
.footer-grid {
  display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr;
  gap:44px; padding-bottom:44px;
  border-bottom:1px solid rgba(255,255,255,0.07);
  margin-bottom:32px;
}
.footer-brand .nav-logo { margin-bottom:18px; color:#fff; }
.footer-brand p { font-size:.82rem; line-height:1.8; max-width:260px; }
.footer-col h5 { color:#fff; font-size:.9rem; margin-bottom:20px; letter-spacing:.3px; }
.footer-col ul li { margin-bottom:11px; }
.footer-col ul li a { font-size:.82rem; transition:color .3s; }
.footer-col ul li a:hover { color:var(--gold); }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; font-size:.78rem; }
.footer-social { display:flex; gap:10px; }
.footer-social a {
  width:38px; height:38px; border-radius:11px;
  background:rgba(255,255,255,0.06);
  display:flex; align-items:center; justify-content:center;
  font-size:1rem; color:rgba(255,255,255,0.45);
  transition:background .3s, transform .2s;
}
.footer-social a:hover { background:var(--teal); color:#fff; transform:translateY(-2px); }

/* ═══════════════════════════════════════════
   ANIMATIONS
═══════════════════════════════════════════ */
@keyframes fadeUp { to { opacity:1; transform:translateY(0); } }
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.3} }
@keyframes rotateSlow { to { transform:translate(-50%,-50%) rotate(360deg); } }
@keyframes floatA { 0%,100%{transform:translateY(0) translateX(0)} 50%{transform:translateY(-14px) translateX(4px)} }
@keyframes floatB { 0%,100%{transform:translateY(0) translateX(0)} 50%{transform:translateY(-10px) translateX(-6px)} }
@keyframes floatC { 0%,100%{transform:translateY(0) translateX(0)} 50%{transform:translateY(-12px) translateX(3px)} }
@keyframes shimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }

/* Scroll reveal */
.reveal { opacity:0; transform:translateY(26px); transition:opacity .65s cubic-bezier(.22,.61,0,1), transform .65s cubic-bezier(.22,.61,0,1); }
.reveal.visible { opacity:1; transform:translateY(0); }

/* ═══════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════ */
@media(max-width:1024px){
  .hero-inner { grid-template-columns:1fr; text-align:center; }
  .hero-content { order:2; padding:20px 0 40px; }
  .hero-visual { order:1; height:340px; }
  .hero-desc { margin-left:auto; margin-right:auto; }
  .hero-buttons { justify-content:center; }
  .hero-trust { justify-content:center; }
  .services-grid { grid-template-columns:repeat(2,1fr); }
  .why-us { grid-template-columns:1fr; }
  .why-visual { min-height:320px; order:2; }
  .why-content { order:1; padding:70px 48px; }
  .inst-grid { grid-template-columns:repeat(2,1fr); }
  .testimonial-grid { grid-template-columns:repeat(2,1fr); }
  .contact { grid-template-columns:1fr; }
  .contact-visual { min-height:300px; order:2; }
  .contact-content { order:1; }
  .footer-grid { grid-template-columns:1fr 1fr; }
}
@media(max-width:768px){
  nav { padding:16px 28px; }
  .nav-links {
    display:none; position:fixed; top:0; right:-100%;
    width:78%; height:100vh; background:var(--cream);
    flex-direction:column; padding:90px 36px 40px; gap:22px;
    transition:right .38s; z-index:999;
    box-shadow:-12px 0 44px rgba(0,0,0,0.12);
  }
  .nav-links.open { right:0; }
  .nav-links a { font-size:1rem; }
  .hamburger { display:flex; }
  .overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,0.4); z-index:998; }
  .overlay.show { display:block; }

  .hero-inner { padding:0 28px; }
  .section { padding:72px 28px; }
  .hero-visual { height:280px; }
  .hero-float { display:none; }
  .hero-shape { width:240px; height:260px; }
  .hero-pearl { width:70px; height:70px; }
  .hero-ring-1 { width:300px; height:300px; }
  .hero-ring-2 { width:200px; height:200px; }
  .hero-ring-3 { width:100px; height:100px; }

  .services-grid { grid-template-columns:1fr; max-width:480px; margin-left:auto; margin-right:auto; }
  .why-content { padding:56px 28px; }
  .inst-grid { grid-template-columns:1fr 1fr; }
  .testimonial-grid { grid-template-columns:1fr; max-width:480px; margin-left:auto; margin-right:auto; }
  .contact-content { padding:64px 28px; }
  footer { padding:52px 28px 28px; }
  .footer-grid { grid-template-columns:1fr; gap:28px; }
  .footer-bottom { flex-direction:column; gap:16px; text-align:center; }
}
@media(max-width:480px){
  .hero-title { font-size:2.3rem; }
  .sec-title { font-size:1.75rem; }
  .inst-grid { grid-template-columns:1fr; max-width:360px; margin-left:auto; margin-right:auto; }
  .hero-trust { gap:20px; }
  .trust-divider { display:none; }
}