/* ============================================================
   MTR Enterprises — Main Stylesheet
   Theme: #051347 (Navy) | #00AF07 (Green)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Playfair+Display:ital,wght@0,500;0,600;0,700;0,800;1,600&display=swap');

/* ── Variables ─────────────────────────────────────────────── */
:root {
  --primary:        #051347;
  --primary-light:  #0d2370;
  --primary-dark:   #020b2a;
  --accent:         #00AF07;
  --accent-light:   #00cc09;
  --accent-dark:    #008a05;
  --white:          #ffffff;
  --off-white:      #f8fafc;
  --light-bg:       #eef2f8;
  --text-dark:      #1a1f36;
  --text-mid:       #4a5568;
  --text-light:     #718096;
  --border:         #dde3ef;
  --gold:           #f5c518;
  --shadow-sm:      0 2px 8px rgba(5,19,71,.10);
  --shadow-md:      0 6px 24px rgba(5,19,71,.14);
  --shadow-lg:      0 12px 48px rgba(5,19,71,.18);
  --shadow-xl:      0 24px 80px rgba(5,19,71,.22);
  --transition:     all .3s cubic-bezier(.4,0,.2,1);
  --r-sm:           8px;
  --r-md:           14px;
  --r-lg:           22px;
  --r-xl:           40px;
}

/* ── Reset ─────────────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; overflow-x:hidden; }
body { font-family:'Inter',sans-serif; color:var(--text-dark); background:var(--white); overflow-x:hidden; line-height:1.7; }
img { max-width:100%; height:auto; display:block; }
a { text-decoration:none; color:inherit; transition:var(--transition); }
ul,ol { list-style:none; }
button { cursor:pointer; border:none; outline:none; background:none; }

/* ── Utilities ─────────────────────────────────────────────── */
.container { max-width:1220px; margin:0 auto; padding:0 20px; }
.section-pad { padding:90px 0; }
.section-pad-sm { padding:60px 0; }
.text-center { text-align:center; }
.text-white { color:var(--white)!important; }
.hidden { display:none; }
.flex { display:flex; }
.flex-center { display:flex; align-items:center; justify-content:center; }
.flex-between { display:flex; align-items:center; justify-content:space-between; }
.grid-2 { display:grid; grid-template-columns:repeat(2,1fr); gap:30px; }
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:30px; }
.grid-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:25px; }

/* ── Section Headings ──────────────────────────────────────── */
.section-label {
  display:inline-block;
  font-size:13px; font-weight:700; letter-spacing:3px; text-transform:uppercase;
  color:var(--accent); margin-bottom:12px;
}
.section-title {
  font-family:'Playfair Display',serif;
  font-size:clamp(28px,4vw,44px); font-weight:700;
  color:var(--primary); line-height:1.25; margin-bottom:18px;
}
.section-title span { color:var(--accent); }
.section-subtitle {
  font-size:16px; color:var(--text-mid); max-width:620px; margin:0 auto 48px;
  line-height:1.8;
}
.section-divider {
  width:60px; height:4px; border-radius:2px;
  background:linear-gradient(90deg,var(--primary),var(--accent));
  margin:14px auto 0;
}
.section-divider.left { margin:14px 0 0; }

/* ── Buttons ───────────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:14px 32px; border-radius:var(--r-xl);
  font-size:15px; font-weight:600; letter-spacing:.3px;
  transition:var(--transition); position:relative; overflow:hidden; z-index:1;
}
.btn::before {
  content:''; position:absolute; inset:0; opacity:0;
  background:rgba(255,255,255,.15); transition:var(--transition); z-index:-1;
}
.btn:hover::before { opacity:1; }
.btn-primary {
  background:linear-gradient(135deg,var(--primary),var(--primary-light));
  color:var(--white);
  box-shadow:0 4px 20px rgba(5,19,71,.35);
}
.btn-primary:hover { box-shadow:0 8px 30px rgba(5,19,71,.50); transform:translateY(-2px); color:var(--white); }
.btn-accent {
  background:linear-gradient(135deg,var(--accent),var(--accent-light));
  color:var(--white);
  box-shadow:0 4px 20px rgba(0,175,7,.35);
}
.btn-accent:hover { box-shadow:0 8px 30px rgba(0,175,7,.50); transform:translateY(-2px); color:var(--white); }
.btn-outline {
  border:2px solid var(--white); color:var(--white); background:transparent;
}
.btn-outline:hover { background:var(--white); color:var(--primary); }
.btn-outline-primary {
  border:2px solid var(--primary); color:var(--primary); background:transparent;
}
.btn-outline-primary:hover { background:var(--primary); color:var(--white); }

/* ── Cards ─────────────────────────────────────────────────── */
.card {
  background:var(--white); border-radius:var(--r-md);
  box-shadow:var(--shadow-md);
  transition:var(--transition); overflow:hidden;
  border:1px solid rgba(5,19,71,.06);
}
.card:hover { transform:translateY(-8px); box-shadow:var(--shadow-xl); }

/* Glass card */
.card-glass {
  background:rgba(255,255,255,.72);
  backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px);
  border:1px solid rgba(255,255,255,.6);
  border-radius:var(--r-md); box-shadow:var(--shadow-lg);
}

/* ========================================================
   TOP BAR
   ======================================================== */
.top-bar {
  background:linear-gradient(90deg,var(--primary-dark),var(--primary));
  padding:9px 0;
  font-size:13px; color:rgba(255,255,255,.88);
  position:relative; z-index:1000;
}
.top-bar .container { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:6px; }
.top-bar-left, .top-bar-right { display:flex; align-items:center; gap:18px; }
.top-bar a {
  color:rgba(255,255,255,.9); display:flex; align-items:center; gap:6px;
  font-weight:500;
}
.top-bar a:hover { color:var(--accent); }
.top-bar i { color:var(--accent); font-size:14px; }

/* ========================================================
   MARQUEE STRIP
   ======================================================== */
.marquee-strip {
  background:linear-gradient(90deg,var(--accent-dark),var(--accent),var(--accent-dark));
  padding:10px 0; overflow:hidden; position:relative; z-index:999;
}
.marquee-track {
  display:flex; width:max-content; animation:marqueeScroll 38s linear infinite;
}
.marquee-strip:hover .marquee-track { animation-play-state:paused; }
.marquee-item {
  white-space:nowrap; padding:0 30px;
  font-size:13.5px; font-weight:600; color:var(--white);
  display:flex; align-items:center; gap:10px;
}
.marquee-item i { font-size:15px; }
.marquee-sep { color:rgba(255,255,255,.5); margin:0 10px; }
@keyframes marqueeScroll {
  0%   { transform:translateX(0); }
  100% { transform:translateX(-50%); }
}

/* ========================================================
   HEADER / NAVIGATION
   ======================================================== */
.header {
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  box-shadow:0 2px 20px rgba(5,19,71,.10);
  position:sticky; top:0; z-index:998;
  transition:var(--transition);
}
.header.scrolled { box-shadow:0 4px 30px rgba(5,19,71,.18); }
.nav { display:flex; align-items:center; justify-content:space-between; padding:14px 0; gap:20px; }
.logo img { height:58px; width:auto; }
.nav-menu { display:flex; align-items:center; gap:4px; }
.nav-menu > li { position:relative; }
/* Transparent bridge so hover stays active while moving mouse into dropdown */
.nav-menu > li:has(.dropdown-menu)::after {
  content:''; position:absolute; bottom:-10px; left:0; right:0; height:10px;
}
.nav-menu > li > a {
  display:flex; align-items:center; gap:5px;
  padding:10px 15px; border-radius:var(--r-sm);
  font-size:14.5px; font-weight:600; color:var(--primary);
  transition:var(--transition);
}
.nav-menu > li > a:hover,
.nav-menu > li > a.active { color:var(--accent); background:rgba(0,175,7,.07); }
.nav-cta-btn {
  background:linear-gradient(135deg,var(--accent),var(--accent-light));
  color:var(--white)!important; padding:10px 22px!important;
  border-radius:var(--r-xl)!important;
  box-shadow:0 4px 14px rgba(0,175,7,.35);
}
.nav-cta-btn:hover { box-shadow:0 6px 20px rgba(0,175,7,.50)!important; transform:translateY(-1px); color:var(--white)!important; }

/* Dropdown */
.dropdown-menu {
  position:absolute; top:calc(100% + 6px); left:50%; transform:translateX(-50%) translateY(8px);
  background:var(--white); border-radius:var(--r-md);
  box-shadow:var(--shadow-xl); min-width:220px;
  border:1px solid rgba(5,19,71,.08);
  opacity:0; visibility:hidden; pointer-events:none;
  transition:var(--transition); padding:8px 0;
}
.dropdown-menu::before {
  content:''; position:absolute; top:-6px; left:50%; transform:translateX(-50%);
  width:12px; height:12px; background:var(--white);
  border-top:1px solid rgba(5,19,71,.08); border-left:1px solid rgba(5,19,71,.08);
  transform:translateX(-50%) rotate(45deg);
}
.nav-menu li:hover > .dropdown-menu,
.nav-menu li.dropdown-open > .dropdown-menu {
  opacity:1; visibility:visible; pointer-events:all; transform:translateX(-50%) translateY(0);
}
.dropdown-menu li a {
  display:flex; align-items:center; gap:10px;
  padding:11px 20px; font-size:14px; font-weight:500; color:var(--text-dark);
  transition:var(--transition);
}
.dropdown-menu li a:hover { color:var(--accent); background:rgba(0,175,7,.06); padding-left:28px; }
.dropdown-menu li a i { color:var(--accent); font-size:14px; width:16px; }
.dropdown-arrow {
  font-size:10px!important; margin-left:2px;
  transition:transform .3s!important;
}
.nav-menu li:hover .dropdown-arrow,
.nav-menu li.dropdown-open .dropdown-arrow { transform:rotate(180deg); }

/* ── Hamburger ─────────────────────────────────────────────── */
.hamburger {
  display:none; flex-direction:column; gap:5px;
  width:36px; cursor:pointer; padding:4px;
  border-radius:var(--r-sm);
  transition:var(--transition);
}
.hamburger:hover { background:rgba(5,19,71,.06); }
.hamburger span {
  display:block; height:2.5px; width:100%;
  background:var(--primary); border-radius:4px;
  transition:var(--transition);
}
.hamburger.open span:nth-child(1) { transform:translateY(7.5px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.hamburger.open span:nth-child(3) { transform:translateY(-7.5px) rotate(-45deg); }

/* ── Mobile Menu ───────────────────────────────────────────── */
.mobile-menu {
  display:none; position:fixed; top:0; right:-100%; width:min(320px,88vw);
  height:100vh; background:var(--primary);
  z-index:10000; flex-direction:column;
  transition:.4s cubic-bezier(.4,0,.2,1); overflow-y:auto;
  box-shadow:-8px 0 40px rgba(0,0,0,.35);
}
.mobile-menu.open { right:0; }
.mobile-menu-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:20px 24px; border-bottom:1px solid rgba(255,255,255,.12);
}
.mobile-menu-header img { height:46px; }
.mobile-close {
  color:rgba(255,255,255,.7); font-size:22px; cursor:pointer;
  width:36px; height:36px; display:flex; align-items:center; justify-content:center;
  border-radius:50%; transition:var(--transition);
}
.mobile-close:hover { background:rgba(255,255,255,.1); color:var(--white); }
.mobile-nav-list { padding:20px 0; flex:1; }
.mobile-nav-list > li > a {
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 24px; color:rgba(255,255,255,.88); font-weight:600; font-size:15px;
  transition:var(--transition); border-bottom:1px solid rgba(255,255,255,.06);
}
.mobile-nav-list > li > a:hover { color:var(--accent); background:rgba(255,255,255,.05); padding-left:30px; }
.mobile-dropdown-toggle { background:none; border:none; color:rgba(255,255,255,.6); font-size:12px; }
.mobile-sub-menu { display:none; background:rgba(0,0,0,.25); padding:6px 0; }
.mobile-sub-menu.open { display:block; }
.mobile-sub-menu li a {
  display:flex; align-items:center; gap:10px;
  padding:11px 24px 11px 38px; font-size:14px; color:rgba(255,255,255,.75);
  transition:var(--transition);
}
.mobile-sub-menu li a:hover { color:var(--accent); padding-left:46px; }
.mobile-sub-menu li a i { color:var(--accent); font-size:13px; }
.mobile-contact-bar {
  padding:20px 24px; border-top:1px solid rgba(255,255,255,.12);
  display:flex; flex-direction:column; gap:12px;
}
.mobile-contact-bar a {
  display:flex; align-items:center; gap:10px; color:rgba(255,255,255,.85);
  font-size:14px; font-weight:500;
}
.mobile-contact-bar i { color:var(--accent); }
.mobile-overlay {
  display:none; position:fixed; inset:0;
  background:rgba(0,0,0,.5); z-index:9999;
  backdrop-filter:blur(4px);
}
.mobile-overlay.active { display:block; }

/* ========================================================
   HERO SLIDER
   ======================================================== */
.hero-section {
  position:relative; width:100%;
  overflow:hidden; background:var(--primary-dark);
  aspect-ratio:16/9;
}
.hero-slide {
  position:absolute; inset:0; width:100%; height:100%;
  background-size:cover; background-position:center center;
  opacity:0; transition:opacity 1s ease; display:flex; align-items:center;
}
.hero-slide.active { opacity:1; }
.hero-slide::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg, rgba(5,19,71,.78) 0%, rgba(5,19,71,.45) 60%, rgba(0,0,0,.25) 100%);
}
.hero-content {
  position:relative; z-index:2; padding:40px 60px; max-width:680px;
  animation:heroFadeIn .9s ease both;
}
.hero-slide.active .hero-content { animation-name:heroFadeIn; }
@keyframes heroFadeIn {
  from { opacity:0; transform:translateX(-30px); }
  to   { opacity:1; transform:translateX(0); }
}
.hero-badge {
  display:inline-flex; align-items:center; gap:7px;
  background:rgba(0,175,7,.22); border:1px solid rgba(0,175,7,.5);
  color:var(--accent-light); padding:5px 16px; border-radius:var(--r-xl);
  font-size:12px; font-weight:700; letter-spacing:2px; text-transform:uppercase;
  margin-bottom:18px; backdrop-filter:blur(8px);
}
.hero-title {
  font-family:'Playfair Display',serif;
  font-size:clamp(26px,4.5vw,58px); font-weight:800;
  color:var(--white); line-height:1.18; margin-bottom:16px;
}
.hero-title span { color:var(--accent-light); }
.hero-subtitle {
  font-size:clamp(14px,1.6vw,18px); color:rgba(255,255,255,.88);
  margin-bottom:30px; line-height:1.75; max-width:520px;
}
.hero-buttons { display:flex; gap:12px; flex-wrap:nowrap; align-items:center; }
.hero-controls {
  position:absolute; bottom:28px; left:50%; transform:translateX(-50%);
  display:flex; align-items:center; gap:24px; z-index:10;
}
.hero-prev,.hero-next {
  width:44px; height:44px; border-radius:50%;
  background:rgba(255,255,255,.18); border:1.5px solid rgba(255,255,255,.45);
  color:var(--white); font-size:15px;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:var(--transition);
  backdrop-filter:blur(10px);
}
.hero-prev:hover,.hero-next:hover { background:var(--accent); border-color:var(--accent); transform:scale(1.08); }
.hero-dots { display:flex; gap:8px; }
.hero-dot {
  width:10px; height:10px; border-radius:50%;
  background:rgba(255,255,255,.4); cursor:pointer; transition:var(--transition);
}
.hero-dot.active { background:var(--accent); transform:scale(1.3); }

/* ========================================================
   QUICK CONTACT FORM
   ======================================================== */
.quick-contact {
  background:linear-gradient(135deg,var(--primary),var(--primary-light));
  padding:48px 0;
  position:relative; overflow:hidden;
}
.quick-contact::before {
  content:''; position:absolute; inset:0;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.quick-contact-inner {
  position:relative; display:flex; align-items:center;
  gap:40px; flex-wrap:wrap;
}
.quick-contact-text { flex:1; min-width:260px; }
.quick-contact-text h2 {
  font-family:'Playfair Display',serif;
  font-size:clamp(22px,3vw,34px); color:var(--white); font-weight:700; margin-bottom:10px;
}
.quick-contact-text p { color:rgba(255,255,255,.8); font-size:15px; }
.quick-form {
  flex:1.8; min-width:300px;
  display:flex; gap:14px; flex-wrap:wrap; align-items:flex-end;
}
.quick-form .form-group { flex:1; min-width:180px; }
.form-label { display:block; font-size:12px; font-weight:600; color:rgba(255,255,255,.75); margin-bottom:7px; letter-spacing:.5px; }
.form-input {
  width:100%; padding:14px 18px; border-radius:var(--r-md);
  border:1.5px solid rgba(255,255,255,.25); background:rgba(255,255,255,.12);
  color:var(--white); font-size:14.5px; font-family:'Inter',sans-serif;
  transition:var(--transition);
  backdrop-filter:blur(8px);
}
.form-input::placeholder { color:rgba(255,255,255,.5); }
.form-input:focus { outline:none; border-color:var(--accent); background:rgba(255,255,255,.2); box-shadow:0 0 0 3px rgba(0,175,7,.25); }
.form-message { font-size:13px; margin-top:10px; padding:10px 16px; border-radius:var(--r-sm); }
.form-message.success { background:rgba(0,175,7,.2); color:#a8ffac; border:1px solid rgba(0,175,7,.4); }
.form-message.error { background:rgba(255,80,80,.2); color:#ffb3b3; border:1px solid rgba(255,80,80,.4); }

/* ── Standard Form (Contact Page) ─────────────────────────── */
.contact-form .form-group { margin-bottom:22px; }
.contact-form .form-label { color:var(--text-dark); font-size:14px; font-weight:600; margin-bottom:8px; }
.contact-form .form-input,
.contact-form .form-textarea {
  width:100%; padding:14px 18px; border-radius:var(--r-md);
  border:1.5px solid var(--border); background:var(--white);
  color:var(--text-dark); font-size:15px; font-family:'Inter',sans-serif;
  transition:var(--transition);
}
.contact-form .form-textarea { height:140px; resize:vertical; }
.contact-form .form-input:focus,
.contact-form .form-textarea:focus { outline:none; border-color:var(--accent); box-shadow:0 0 0 3px rgba(0,175,7,.15); }

/* ========================================================
   ABOUT SECTION
   ======================================================== */
.about-section { background:var(--white); }
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.about-img-wrap {
  position:relative; border-radius:var(--r-lg); overflow:hidden;
  box-shadow:var(--shadow-xl);
}
.about-img-wrap img { width:100%; height:460px; object-fit:cover; }
.about-exp-badge {
  position:absolute; bottom:28px; right:-20px;
  background:linear-gradient(135deg,var(--accent),var(--accent-light));
  color:var(--white); padding:20px 28px; border-radius:var(--r-md);
  box-shadow:var(--shadow-lg); text-align:center;
}
.about-exp-badge .num { font-size:44px; font-weight:900; line-height:1; font-family:'Playfair Display',serif; }
.about-exp-badge .label { font-size:12px; font-weight:700; letter-spacing:1px; text-transform:uppercase; opacity:.9; }
.about-points { margin-top:28px; display:flex; flex-direction:column; gap:14px; }
.about-point {
  display:flex; align-items:flex-start; gap:14px;
  padding:16px 20px; border-radius:var(--r-md);
  background:var(--off-white); border-left:4px solid var(--accent);
  transition:var(--transition);
}
.about-point:hover { background:var(--light-bg); transform:translateX(6px); }
.about-point i { color:var(--accent); font-size:20px; margin-top:2px; flex-shrink:0; }
.about-point h4 { font-size:15px; font-weight:700; color:var(--primary); margin-bottom:3px; }
.about-point p { font-size:14px; color:var(--text-mid); line-height:1.6; }

/* ========================================================
   STATS / SUCCESS STORY
   ======================================================== */
.stats-section {
  background:linear-gradient(135deg,var(--primary),var(--primary-light));
  position:relative; overflow:hidden;
}
.stats-section::after {
  content:''; position:absolute; bottom:-50px; right:-50px;
  width:280px; height:280px; border-radius:50%;
  background:rgba(0,175,7,.12); pointer-events:none;
}
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:30px; }
.stat-card {
  text-align:center; padding:40px 20px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:var(--r-lg); background:rgba(255,255,255,.06);
  backdrop-filter:blur(10px); transition:var(--transition);
}
.stat-card:hover { background:rgba(255,255,255,.12); transform:translateY(-6px); }
.stat-num {
  font-family:'Playfair Display',serif;
  font-size:54px; font-weight:800; color:var(--accent-light); line-height:1;
}
.stat-suffix { font-size:30px; color:var(--white); font-weight:700; }
.stat-label { font-size:14px; color:rgba(255,255,255,.8); font-weight:500; margin-top:8px; letter-spacing:.5px; }
.stat-icon { font-size:28px; color:rgba(255,255,255,.3); margin-bottom:12px; }

/* ========================================================
   WHY CHOOSE US
   ======================================================== */
.why-section { background:var(--light-bg); }
.why-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.why-card {
  background:var(--white); padding:38px 28px; border-radius:var(--r-lg);
  box-shadow:var(--shadow-md); text-align:center;
  transition:var(--transition); position:relative; overflow:hidden;
  border-top:4px solid transparent;
}
.why-card::after {
  content:''; position:absolute; top:0; left:0; right:0; height:4px;
  background:linear-gradient(90deg,var(--primary),var(--accent));
  transform:scaleX(0); transform-origin:left; transition:var(--transition);
}
.why-card:hover::after { transform:scaleX(1); }
.why-card:hover { box-shadow:var(--shadow-xl); transform:translateY(-8px); }
.why-icon {
  width:72px; height:72px; margin:0 auto 20px;
  background:linear-gradient(135deg,rgba(0,175,7,.1),rgba(5,19,71,.08));
  border-radius:var(--r-lg);
  display:flex; align-items:center; justify-content:center;
  font-size:30px; color:var(--accent);
  transition:var(--transition);
}
.why-card:hover .why-icon { background:linear-gradient(135deg,var(--accent),var(--accent-light)); color:var(--white); }
.why-card h3 { font-size:18px; font-weight:700; color:var(--primary); margin-bottom:12px; }
.why-card p { font-size:14.5px; color:var(--text-mid); line-height:1.75; }

/* ========================================================
   SPECIALIZATION SECTION
   ======================================================== */
.special-section { background:var(--white); }
.special-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.special-list { display:flex; flex-direction:column; gap:16px; }
.special-item {
  display:flex; align-items:flex-start; gap:16px;
  padding:20px; border-radius:var(--r-md);
  border:1.5px solid var(--border); background:var(--white);
  cursor:pointer; transition:var(--transition);
}
.special-item:hover, .special-item.active {
  border-color:var(--accent); background:rgba(0,175,7,.04);
  box-shadow:var(--shadow-md); transform:translateX(6px);
}
.special-item-icon {
  width:52px; height:52px; flex-shrink:0;
  background:linear-gradient(135deg,var(--primary),var(--primary-light));
  border-radius:var(--r-md);
  display:flex; align-items:center; justify-content:center;
  font-size:22px; color:var(--white);
}
.special-item h4 { font-size:16px; font-weight:700; color:var(--primary); margin-bottom:6px; }
.special-item p { font-size:14px; color:var(--text-mid); line-height:1.65; }
.special-img-wrap { border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-xl); }
.special-img-wrap img { width:100%; height:460px; object-fit:cover; }

/* ========================================================
   SERVICES SECTION
   ======================================================== */
.services-section { background:var(--light-bg); }
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:30px; }
.service-card {
  background:var(--white); border-radius:var(--r-lg);
  overflow:hidden; box-shadow:var(--shadow-md);
  transition:var(--transition); display:flex; flex-direction:column;
  border:1px solid rgba(5,19,71,.06);
}
.service-card:hover { transform:translateY(-10px); box-shadow:var(--shadow-xl); }
.service-card-img { overflow:hidden; height:220px; }
.service-card-img img { width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.service-card:hover .service-card-img img { transform:scale(1.08); }
.service-card-body { padding:26px; flex:1; display:flex; flex-direction:column; }
.service-card-body h3 { font-size:19px; font-weight:700; color:var(--primary); margin-bottom:10px; }
.service-card-body p { font-size:14.5px; color:var(--text-mid); line-height:1.7; flex:1; margin-bottom:20px; }
.service-card-footer {
  display:flex; align-items:center; justify-content:space-between;
  padding-top:16px; border-top:1px solid var(--border);
}
.service-link { color:var(--accent); font-weight:700; font-size:14px; display:flex; align-items:center; gap:6px; }
.service-link:hover { color:var(--primary); gap:10px; }
.service-tag {
  background:rgba(0,175,7,.1); color:var(--accent-dark);
  padding:4px 12px; border-radius:var(--r-xl);
  font-size:12px; font-weight:600;
}

/* ========================================================
   HIGHLIGHTS / FEATURES
   ======================================================== */
.highlights-section {
  background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 60%,var(--primary-light) 100%);
  position:relative; overflow:hidden;
}
.highlights-section::before {
  content:''; position:absolute; top:-100px; right:-100px;
  width:400px; height:400px; border-radius:50%;
  background:radial-gradient(circle,rgba(0,175,7,.18) 0%,transparent 70%);
}
.highlights-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; position:relative; }
.highlight-item {
  text-align:center; padding:32px 18px;
  border-radius:var(--r-lg);
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  backdrop-filter:blur(10px);
  transition:var(--transition);
}
.highlight-item:hover { background:rgba(255,255,255,.12); transform:translateY(-6px); }
.highlight-item i { font-size:34px; color:var(--accent-light); margin-bottom:16px; }
.highlight-item h4 { font-size:15px; font-weight:700; color:var(--white); margin-bottom:6px; }
.highlight-item p { font-size:13px; color:rgba(255,255,255,.72); line-height:1.6; }

/* ========================================================
   REVIEWS / TESTIMONIALS
   ======================================================== */
.reviews-section { background:var(--off-white); }
.reviews-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.review-card {
  background:var(--white); padding:30px 26px; border-radius:var(--r-lg);
  box-shadow:var(--shadow-md); transition:var(--transition);
  border-top:4px solid var(--accent); position:relative;
}
.review-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-xl); }
.review-card::after {
  content:'\201C'; position:absolute; top:16px; right:22px;
  font-size:72px; color:rgba(0,175,7,.1); font-family:Georgia,serif;
  line-height:1;
}
.review-stars { display:flex; gap:3px; margin-bottom:14px; }
.review-stars i { color:var(--gold); font-size:15px; }
.review-text { font-size:14.5px; color:var(--text-mid); line-height:1.75; margin-bottom:20px; font-style:italic; }
.review-author { display:flex; align-items:center; gap:14px; }
.review-avatar {
  width:46px; height:46px; border-radius:50%;
  background:linear-gradient(135deg,var(--primary),var(--accent));
  display:flex; align-items:center; justify-content:center;
  color:var(--white); font-size:17px; font-weight:700; flex-shrink:0;
}
.review-name { font-weight:700; color:var(--primary); font-size:15px; }
.review-loc { font-size:12.5px; color:var(--text-light); margin-top:2px; }
.review-source { margin-left:auto; }
.review-source i { color:#4285F4; font-size:22px; }

/* ========================================================
   FAQ
   ======================================================== */
.faq-section { background:var(--white); }
.faq-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:18px; }
.faq-item {
  border:1.5px solid var(--border); border-radius:var(--r-md);
  overflow:hidden; transition:var(--transition);
}
.faq-item:hover { border-color:var(--accent); box-shadow:var(--shadow-sm); }
.faq-item.active { border-color:var(--accent); box-shadow:var(--shadow-md); }
.faq-q {
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 22px; cursor:pointer;
  background:var(--white); transition:var(--transition);
}
.faq-item.active .faq-q { background:rgba(0,175,7,.04); }
.faq-q h4 { font-size:15px; font-weight:600; color:var(--primary); line-height:1.5; padding-right:12px; }
.faq-icon {
  width:30px; height:30px; border-radius:50%; flex-shrink:0;
  background:var(--light-bg); color:var(--accent);
  display:flex; align-items:center; justify-content:center;
  font-size:14px; transition:var(--transition);
}
.faq-item.active .faq-icon { background:var(--accent); color:var(--white); transform:rotate(45deg); }
.faq-a {
  max-height:0; overflow:hidden; transition:max-height .35s ease, padding .3s ease;
  font-size:14.5px; color:var(--text-mid); line-height:1.75;
}
.faq-item.active .faq-a { max-height:300px; }
.faq-a-inner { padding:0 22px 20px; }

/* ========================================================
   CTA SECTION
   ======================================================== */
.cta-section {
  background:linear-gradient(135deg,var(--accent-dark),var(--accent),var(--accent-light));
  position:relative; overflow:hidden; text-align:center; padding:80px 0;
}
.cta-section::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(5,19,71,.35),rgba(5,19,71,.1));
}
.cta-inner { position:relative; z-index:1; }
.cta-section h2 {
  font-family:'Playfair Display',serif;
  font-size:clamp(26px,4vw,46px); font-weight:800;
  color:var(--white); margin-bottom:16px;
}
.cta-section p { color:rgba(255,255,255,.9); font-size:17px; max-width:600px; margin:0 auto 36px; }
.cta-buttons { display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }
.cta-phone {
  background:var(--white); color:var(--primary)!important; font-weight:700;
  padding:14px 32px; border-radius:var(--r-xl);
  display:inline-flex; align-items:center; gap:8px;
  font-size:15px; box-shadow:0 6px 24px rgba(0,0,0,.2);
  transition:var(--transition);
}
.cta-phone:hover { background:var(--primary); color:var(--white)!important; transform:translateY(-2px); }

/* ========================================================
   GALLERY PAGE
   ======================================================== */
.gallery-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.gallery-item {
  border-radius:var(--r-md); overflow:hidden;
  box-shadow:var(--shadow-md); position:relative; cursor:pointer;
  aspect-ratio:4/3;
}
.gallery-item img { width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.gallery-item:hover img { transform:scale(1.08); }
.gallery-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top,rgba(5,19,71,.85) 0%,transparent 60%);
  opacity:0; transition:var(--transition); display:flex; align-items:flex-end; padding:20px;
}
.gallery-item:hover .gallery-overlay { opacity:1; }
.gallery-overlay h4 { color:var(--white); font-size:16px; font-weight:700; }
.gallery-overlay p { color:rgba(255,255,255,.8); font-size:13px; }
.gallery-zoom {
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%) scale(0);
  width:52px; height:52px; border-radius:50%;
  background:rgba(255,255,255,.2); color:var(--white);
  display:flex; align-items:center; justify-content:center; font-size:20px;
  transition:var(--transition); backdrop-filter:blur(8px);
}
.gallery-item:hover .gallery-zoom { transform:translate(-50%,-50%) scale(1); }

/* Lightbox */
.lightbox {
  display:none; position:fixed; inset:0; z-index:99999;
  background:rgba(0,0,0,.95); align-items:center; justify-content:center;
  padding:20px;
}
.lightbox.active { display:flex; }
.lightbox-img { max-width:90vw; max-height:85vh; border-radius:var(--r-md); box-shadow:var(--shadow-xl); }
.lightbox-close {
  position:absolute; top:20px; right:28px;
  color:var(--white); font-size:36px; cursor:pointer;
  transition:var(--transition); background:rgba(255,255,255,.1); border-radius:50%;
  width:48px; height:48px; display:flex; align-items:center; justify-content:center;
}
.lightbox-close:hover { background:rgba(255,255,255,.2); transform:rotate(90deg); }

/* ========================================================
   SERVICE LANDING PAGE
   ======================================================== */
.page-hero {
  position:relative; min-height:420px; display:flex; align-items:center;
  background-size:cover; background-position:center;
  overflow:hidden;
}
.page-hero::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(5,19,71,.88) 0%,rgba(5,19,71,.60) 70%,rgba(5,19,71,.30) 100%);
}
.page-hero-content { position:relative; z-index:2; padding:80px 0 60px; }
.breadcrumb { display:flex; align-items:center; gap:8px; margin-bottom:20px; flex-wrap:wrap; }
.breadcrumb a { color:rgba(255,255,255,.7); font-size:13.5px; }
.breadcrumb a:hover { color:var(--accent); }
.breadcrumb span { color:rgba(255,255,255,.4); font-size:13px; }
.breadcrumb .current { color:rgba(255,255,255,.9); font-size:13.5px; }
.page-hero h1 {
  font-family:'Playfair Display',serif;
  font-size:clamp(30px,5vw,60px); font-weight:800;
  color:var(--white); margin-bottom:16px; line-height:1.18;
}
.page-hero p { font-size:17px; color:rgba(255,255,255,.85); max-width:600px; line-height:1.75; }

/* Service content */
.service-content { background:var(--white); }
.service-body { display:grid; grid-template-columns:2fr 1fr; gap:50px; align-items:start; }
.service-body h2 { font-family:'Playfair Display',serif; font-size:28px; font-weight:700; color:var(--primary); margin-bottom:16px; }
.service-body h3 { font-size:21px; font-weight:700; color:var(--primary); margin:28px 0 14px; }
.service-body p { font-size:15px; color:var(--text-mid); line-height:1.8; margin-bottom:16px; }
.service-body ul { padding-left:0; margin-bottom:20px; }
.service-body ul li {
  padding:8px 0 8px 26px; position:relative;
  font-size:14.5px; color:var(--text-mid); border-bottom:1px solid var(--border);
}
.service-body ul li:last-child { border-bottom:none; }
.service-body ul li::before {
  content:'\f00c'; font-family:'Font Awesome 6 Free'; font-weight:900;
  position:absolute; left:0; color:var(--accent); font-size:13px;
}
.service-sidebar { position:sticky; top:110px; }
.sidebar-card {
  background:var(--off-white); border-radius:var(--r-lg);
  padding:28px; border:1px solid var(--border); margin-bottom:22px;
}
.sidebar-card h4 { font-size:17px; font-weight:700; color:var(--primary); margin-bottom:18px; }
.sidebar-card .footer-links a { color:var(--text-mid); }
.sidebar-card .footer-links a:hover { color:var(--accent); padding-left:8px; }
.sidebar-contact-list { display:flex; flex-direction:column; gap:14px; }
.sidebar-contact-list li { display:flex; align-items:flex-start; gap:12px; font-size:14px; color:var(--text-mid); }
.sidebar-contact-list i { color:var(--accent); font-size:16px; margin-top:2px; flex-shrink:0; }
.sidebar-contact-list a { color:var(--primary); font-weight:600; }
.sidebar-contact-list a:hover { color:var(--accent); }

/* ========================================================
   CONTACT PAGE
   ======================================================== */
.contact-grid { display:grid; grid-template-columns:1fr 1.4fr; gap:50px; align-items:start; }
.contact-info { padding:0; }
.contact-info h2 { font-family:'Playfair Display',serif; font-size:30px; font-weight:700; color:var(--primary); margin-bottom:12px; }
.contact-info p { color:var(--text-mid); font-size:15px; line-height:1.75; margin-bottom:28px; }
.contact-items { display:flex; flex-direction:column; gap:18px; }
.contact-item { display:flex; align-items:flex-start; gap:16px; }
.contact-item-icon {
  width:48px; height:48px; flex-shrink:0; border-radius:var(--r-md);
  background:linear-gradient(135deg,var(--primary),var(--primary-light));
  display:flex; align-items:center; justify-content:center;
  font-size:18px; color:var(--white);
}
.contact-item h4 { font-size:14px; font-weight:700; color:var(--primary); margin-bottom:4px; }
.contact-item p, .contact-item a { font-size:14.5px; color:var(--text-mid); }
.contact-item a:hover { color:var(--accent); }
.map-embed { border-radius:var(--r-lg); overflow:hidden; margin-top:30px; box-shadow:var(--shadow-md); }
.map-embed iframe { display:block; }

/* ========================================================
   FLOATING BUTTONS
   ======================================================== */
.float-contact {
  position:fixed; bottom:28px; right:24px; z-index:9000;
  display:flex; flex-direction:column; gap:14px; align-items:flex-end;
}
.float-btn {
  width:56px; height:56px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:22px; color:var(--white); cursor:pointer;
  box-shadow:0 6px 24px rgba(0,0,0,.3); transition:var(--transition);
  position:relative;
}
.float-btn:hover { transform:scale(1.1) translateY(-2px); }
.float-btn-label {
  position:absolute; right:66px; top:50%; transform:translateY(-50%);
  background:var(--primary); color:var(--white);
  padding:6px 14px; border-radius:var(--r-xl); font-size:13px; font-weight:600;
  white-space:nowrap; opacity:0; pointer-events:none; transition:var(--transition);
  box-shadow:var(--shadow-md);
}
.float-btn:hover .float-btn-label { opacity:1; right:70px; }
.float-phone { background:linear-gradient(135deg,var(--primary),var(--primary-light)); }
.float-whatsapp { background:linear-gradient(135deg,#25D366,#128C7E); }
.float-btn .pulse {
  position:absolute; inset:0; border-radius:50%;
  animation:pulsate 2.2s ease-out infinite;
}
.float-phone .pulse { background:rgba(5,19,71,.35); }
.float-whatsapp .pulse { background:rgba(37,211,102,.35); }
@keyframes pulsate {
  0%   { transform:scale(1);   opacity:.8; }
  70%  { transform:scale(1.55); opacity:0; }
  100% { transform:scale(1.55); opacity:0; }
}

/* ========================================================
   SCROLL-TO-TOP
   ======================================================== */
.scroll-top {
  position:fixed; bottom:28px; left:24px; z-index:9000;
  width:46px; height:46px; border-radius:50%;
  background:linear-gradient(135deg,var(--primary),var(--primary-light));
  color:var(--white); font-size:17px;
  display:flex; align-items:center; justify-content:center;
  box-shadow:var(--shadow-lg); cursor:pointer;
  opacity:0; visibility:hidden; transform:translateY(20px);
  transition:var(--transition);
}
.scroll-top.visible { opacity:1; visibility:visible; transform:translateY(0); }
.scroll-top:hover { background:var(--accent); transform:translateY(-3px); }

/* ========================================================
   FOOTER
   ======================================================== */
.footer {
  background:linear-gradient(180deg,var(--primary-dark) 0%,#010820 100%);
  color:rgba(255,255,255,.78); padding-top:70px;
}
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1.5fr; gap:40px; padding-bottom:50px; border-bottom:1px solid rgba(255,255,255,.08); }
.footer-brand img { height:54px; margin-bottom:18px; }
.footer-brand p { font-size:14px; line-height:1.8; color:rgba(255,255,255,.65); margin-bottom:20px; }
.footer-social { display:flex; gap:10px; }
.footer-social a {
  width:38px; height:38px; border-radius:var(--r-sm);
  background:rgba(255,255,255,.08); color:rgba(255,255,255,.7);
  display:flex; align-items:center; justify-content:center; font-size:16px;
  transition:var(--transition); border:1px solid rgba(255,255,255,.1);
}
.footer-social a:hover { background:var(--accent); color:var(--white); border-color:var(--accent); transform:translateY(-3px); }
.footer-col h4 { font-size:16px; font-weight:700; color:var(--white); margin-bottom:20px; position:relative; padding-bottom:12px; }
.footer-col h4::after { content:''; position:absolute; bottom:0; left:0; width:32px; height:2px; background:var(--accent); border-radius:2px; }
.footer-links { display:flex; flex-direction:column; gap:10px; }
.footer-links a { font-size:14px; color:rgba(255,255,255,.65); display:flex; align-items:center; gap:8px; transition:var(--transition); }
.footer-links a::before { content:'\f054'; font-family:'Font Awesome 6 Free'; font-weight:900; font-size:10px; color:var(--accent); }
.footer-links a:hover { color:var(--accent); padding-left:6px; }
.footer-contact-list { display:flex; flex-direction:column; gap:14px; }
.footer-contact-list li { display:flex; gap:12px; font-size:14px; color:rgba(255,255,255,.65); }
.footer-contact-list i { color:var(--accent); font-size:15px; margin-top:2px; flex-shrink:0; }
.footer-contact-list a { color:rgba(255,255,255,.65); }
.footer-contact-list a:hover { color:var(--accent); }
.footer-bottom {
  padding:22px 0; font-size:13px; color:rgba(255,255,255,.45);
}
.footer-bottom .container {
  display:flex; align-items:center; justify-content:center;
  flex-wrap:wrap; gap:6px;
}
.footer-bottom .container p + p::before {
  content:' · '; margin-right:6px; opacity:.5;
}
.footer-bottom a { color:var(--accent); font-weight:700; }
.footer-bottom a:hover { text-decoration:underline; }

/* ========================================================
   PAGE LOADER
   ======================================================== */
.page-loader {
  position:fixed; inset:0; z-index:99999;
  background:var(--primary);
  display:flex; align-items:center; justify-content:center;
  transition:opacity .5s ease, visibility .5s ease;
}
.page-loader.hidden { opacity:0; visibility:hidden; }
.loader-logo img { height:70px; animation:loaderPulse 1.2s ease infinite; }
@keyframes loaderPulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.6;transform:scale(.95)} }

/* ========================================================
   ANIMATIONS (AOS-style via JS)
   ======================================================== */
[data-aos] { opacity:0; transform:translateY(30px); transition:opacity .7s ease, transform .7s ease; }
/* CTA is critical — always show regardless of animation state */
.cta-section [data-aos],
.cta-section [data-aos].aos-animate { opacity:1 !important; transform:none !important; }
[data-aos="fade-left"] { transform:translateX(-30px); }
[data-aos="fade-right"] { transform:translateX(30px); }
[data-aos="zoom-in"] { transform:scale(.9); }
[data-aos].aos-animate { opacity:1; transform:none; }

/* ========================================================
   RESPONSIVE — Tablet 1024px
   ======================================================== */
@media (max-width:1024px) {
  .about-grid, .special-grid, .contact-grid { grid-template-columns:1fr; }
  .about-img-wrap, .special-img-wrap { max-height:320px; }
  .about-img-wrap img, .special-img-wrap img { height:320px; }
  .about-exp-badge { right:12px; }
  .stats-grid, .highlights-grid { grid-template-columns:repeat(2,1fr); gap:16px; }
  .stat-num { font-size:42px; }
  .stat-card { padding:28px 12px; }
  .services-grid, .why-grid { grid-template-columns:repeat(2,1fr); }
  .footer-grid { grid-template-columns:1fr 1fr; }
  .service-body { grid-template-columns:1fr; }
  .service-sidebar { position:static; }
}

/* ── Tablet 768px ───────────────────────────────────────────── */
@media (max-width:768px) {
  .nav-menu { display:none; }
  .hamburger { display:flex; }
  .mobile-menu { display:flex; }
  .hero-section { aspect-ratio:1/1; }
  .hero-content { padding:28px 22px 80px; }
  .hero-title { font-size:clamp(22px,6vw,36px); }
  .hero-subtitle { font-size:14px; }
  .faq-grid { grid-template-columns:1fr; }
  .reviews-grid { grid-template-columns:1fr; }
  .gallery-grid { grid-template-columns:repeat(2,1fr); }
  .services-grid { grid-template-columns:1fr; }
  .why-grid { grid-template-columns:1fr; }
  .quick-form { flex-direction:column; }
  .quick-form .form-group { min-width:100%; }
  .top-bar-left { display:none; }
  .top-bar-right a:last-child { display:none; }
  .hero-controls { bottom:14px; }
  .hero-prev,.hero-next { width:34px; height:34px; font-size:13px; }
  .hero-dots { gap:6px; }
  .hero-dot { width:8px; height:8px; }
  .section-pad { padding:60px 0; }
  .grid-2, .grid-3, .grid-4 { grid-template-columns:1fr; }
}

/* ── Mobile 480px ───────────────────────────────────────────── */
@media (max-width:480px) {
  .footer-grid { grid-template-columns:1fr; }
  .stats-grid { grid-template-columns:repeat(2,1fr); gap:12px; }
  .stat-num { font-size:34px; }
  .stat-card { padding:22px 10px; }
  .stat-label { font-size:12px; }
  .highlights-grid { grid-template-columns:repeat(2,1fr); }
  .gallery-grid { grid-template-columns:1fr; }
  .hero-buttons { flex-direction:row; flex-wrap:nowrap; gap:10px; }
  .hero-buttons .btn { font-size:12.5px; padding:10px 16px; gap:6px; white-space:nowrap; }
  .cta-buttons { flex-direction:column; align-items:center; }
  .footer-bottom .container { flex-direction:column; text-align:center; gap:4px; }
  .page-hero h1 { font-size:clamp(24px,7vw,38px); }
  .quick-contact-inner { flex-direction:column; }
  .contact-quick-grid { grid-template-columns:1fr !important; }
}

/* ── Mobile 360px ───────────────────────────────────────────── */
@media (max-width:360px) {
  .container { padding:0 14px; }
  .hero-content { padding:20px 16px 76px; }
  .stat-num { font-size:28px; }
  .stat-card { padding:18px 8px; }
}

/* ========================================================
   POPUP ALERT — Form Submission
   ======================================================== */
.mtr-popup-overlay {
  position:fixed; inset:0; z-index:999999;
  background:rgba(5,19,71,.72);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  display:flex; align-items:center; justify-content:center;
  padding:20px;
  opacity:0; visibility:hidden;
  transition:opacity .35s ease, visibility .35s ease;
}
.mtr-popup-overlay.show { opacity:1; visibility:visible; }

.mtr-popup {
  background:#fff;
  border-radius:24px;
  padding:48px 40px 40px;
  max-width:480px; width:100%;
  text-align:center;
  position:relative;
  box-shadow:0 32px 80px rgba(5,19,71,.32);
  transform:scale(.85) translateY(24px);
  transition:transform .4s cubic-bezier(.34,1.56,.64,1);
}
.mtr-popup-overlay.show .mtr-popup { transform:scale(1) translateY(0); }

/* Close button */
.mtr-popup-close {
  position:absolute; top:16px; right:16px;
  width:36px; height:36px; border-radius:50%;
  background:#f1f5f9; border:none; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  font-size:16px; color:#64748b; transition:var(--transition);
}
.mtr-popup-close:hover { background:#e2e8f0; color:#1e293b; transform:rotate(90deg); }

/* Icon circle */
.mtr-popup-icon {
  width:90px; height:90px; border-radius:50%;
  margin:0 auto 24px;
  display:flex; align-items:center; justify-content:center;
  position:relative;
}
.mtr-popup.success .mtr-popup-icon { background:linear-gradient(135deg,#d1fae5,#a7f3d0); }
.mtr-popup.error   .mtr-popup-icon { background:linear-gradient(135deg,#fee2e2,#fecaca); }

/* SVG checkmark */
.mtr-check-svg, .mtr-x-svg { width:46px; height:46px; }
.mtr-check-circle {
  stroke:#059669; stroke-width:2.5; fill:none;
  stroke-dasharray:188; stroke-dashoffset:188;
  animation:drawCircle .7s .1s ease forwards;
  transform-origin:center; transform:rotate(-90deg);
}
.mtr-check-tick {
  stroke:#059669; stroke-width:3; fill:none; stroke-linecap:round; stroke-linejoin:round;
  stroke-dasharray:40; stroke-dashoffset:40;
  animation:drawTick .4s .7s ease forwards;
}
.mtr-x-circle {
  stroke:#dc2626; stroke-width:2.5; fill:none;
  stroke-dasharray:188; stroke-dashoffset:188;
  animation:drawCircle .7s .1s ease forwards;
  transform-origin:center; transform:rotate(-90deg);
}
.mtr-x-line1, .mtr-x-line2 {
  stroke:#dc2626; stroke-width:3; stroke-linecap:round;
  stroke-dasharray:25; stroke-dashoffset:25;
}
.mtr-x-line1 { animation:drawTick .3s .75s ease forwards; }
.mtr-x-line2 { animation:drawTick .3s .95s ease forwards; }
@keyframes drawCircle { to { stroke-dashoffset:0; } }
@keyframes drawTick   { to { stroke-dashoffset:0; } }

/* Popup text */
.mtr-popup-title {
  font-family:'Playfair Display',serif;
  font-size:24px; font-weight:800; margin-bottom:10px;
}
.mtr-popup.success .mtr-popup-title { color:#065f46; }
.mtr-popup.error   .mtr-popup-title { color:#991b1b; }
.mtr-popup-msg { font-size:15px; color:#475569; line-height:1.75; margin-bottom:20px; }

/* Enquiry ID badge */
.mtr-enquiry-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:linear-gradient(135deg,#f0fdf4,#dcfce7);
  border:1.5px solid #86efac; border-radius:10px;
  padding:10px 20px; margin-bottom:24px;
  font-size:13px; color:#166534; font-weight:700; letter-spacing:.5px;
}
.mtr-enquiry-badge i { color:#16a34a; }

/* Action buttons */
.mtr-popup-actions { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
.mtr-popup-btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:13px 24px; border-radius:50px; font-size:14px; font-weight:700;
  text-decoration:none; border:none; cursor:pointer; transition:var(--transition);
}
.mtr-popup-btn.primary {
  background:linear-gradient(135deg,var(--primary),var(--primary-light));
  color:#fff; box-shadow:0 6px 18px rgba(5,19,71,.28);
}
.mtr-popup-btn.primary:hover { transform:translateY(-2px); box-shadow:0 10px 26px rgba(5,19,71,.38); }
.mtr-popup-btn.whatsapp { background:#25D366; color:#fff; box-shadow:0 6px 18px rgba(37,211,102,.32); }
.mtr-popup-btn.whatsapp:hover { background:#22c55e; transform:translateY(-2px); }
.mtr-popup-btn.close-btn { background:#f1f5f9; color:#475569; }
.mtr-popup-btn.close-btn:hover { background:#e2e8f0; }

/* Countdown ring */
.mtr-countdown {
  display:flex; align-items:center; justify-content:center; gap:8px;
  margin-top:18px; font-size:12.5px; color:#94a3b8;
}
.mtr-countdown-ring { width:22px; height:22px; transform:rotate(-90deg); }
.mtr-countdown-track { fill:none; stroke:#e2e8f0; stroke-width:2.5; }
.mtr-countdown-fill {
  fill:none; stroke:var(--accent); stroke-width:2.5;
  stroke-linecap:round;
  stroke-dasharray:57;
  animation:countdownDrain 5s linear forwards;
}
@keyframes countdownDrain { from { stroke-dashoffset:0; } to { stroke-dashoffset:57; } }

@media (max-width:480px) {
  .mtr-popup { padding:36px 24px 32px; }
  .mtr-popup-title { font-size:20px; }
  .mtr-popup-actions { flex-direction:column; align-items:center; }
  .mtr-popup-btn { width:100%; justify-content:center; }
}
