:root{
  --primary:#2a6b8a;
  --primary-dark:#164457;
  --secondary:#f3b33b;
  --secondary-dark:#d98a00;
  --accent:#2fb5b0; /* soft teal (not neon) */
  --paper:#fbfbfc;
  --light:#f8f9fa;
  --dark:#1f2a33;
  --gray:#5d6b78;
  --light-gray:#e9eef2;

  --radius:16px;
  --radius-lg:22px;

  --transition:all .45s cubic-bezier(.175,.885,.32,1.1);
  --shadow:0 14px 38px rgba(0,0,0,.08);
  --shadow-hover:0 18px 52px rgba(0,0,0,.12);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Poppins',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  line-height:1.6;
  color:var(--dark);
  background:var(--paper);
  overflow-x:hidden;
}

h1,h2,h3,h4,h5{
  font-family:'Montserrat',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  font-weight:700;
  line-height:1.15;
  margin-bottom:1rem;
}

a{color:inherit}
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 20px}

/* =========================
   Ambient background
========================= */
.ambient{
  position:fixed;inset:0;z-index:-5;pointer-events:none;
  overflow:hidden;
}
.ambient__orb{
  position:absolute; width:52vmax; height:52vmax; border-radius:50%;
  filter:blur(35px); opacity:.35;
  animation:orbFloat 18s ease-in-out infinite;
  transform:translate3d(0,0,0);
}
.ambient__orb--a{left:-12vmax; top:-16vmax; background:radial-gradient(circle at 30% 30%, rgba(42,107,138,.55), rgba(42,107,138,0) 60%); animation-duration:22s}
.ambient__orb--b{right:-18vmax; top:8vmax; background:radial-gradient(circle at 30% 30%, rgba(243,179,59,.55), rgba(243,179,59,0) 60%); animation-duration:26s; animation-delay:-8s}
.ambient__orb--c{left:22vmax; bottom:-20vmax; background:radial-gradient(circle at 30% 30%, rgba(47,181,176,.55), rgba(47,181,176,0) 60%); animation-duration:28s; animation-delay:-14s}

.ambient__grid{
  position:absolute; inset:-10%;
  background:
    radial-gradient(circle at 50% 50%, rgba(31,42,51,.035) 0 1px, transparent 1px 100%),
    linear-gradient(to right, rgba(31,42,51,.035) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(31,42,51,.03) 1px, transparent 1px);
  background-size: 30px 30px, 120px 120px, 120px 120px;
  mask-image: radial-gradient(circle at 50% 20%, black 0 60%, transparent 78%);
  opacity:.55;
  animation:gridDrift 22s linear infinite;
}

.ambient__routes{
  position:absolute; inset:0;
  opacity:.22;
  filter:drop-shadow(0 10px 18px rgba(0,0,0,.05));
}
.ambient__routes path{
  fill:none;
  stroke: rgba(42,107,138,.35);
  stroke-width:2.2;
  stroke-dasharray:7 10;
  animation: routeDash 14s linear infinite;
}
.ambient__routes path:nth-child(2){stroke: rgba(243,179,59,.32); animation-duration:18s}
.ambient__routes path:nth-child(3){stroke: rgba(47,181,176,.32); animation-duration:20s}

.ambient__dots{
  position:absolute; inset:0;
  opacity:.18;
}

.ambient__dot{
  position:absolute;
  width:6px;height:6px;border-radius:50%;
  background:rgba(31,42,51,.55);
  box-shadow:0 12px 28px rgba(0,0,0,.08);
  animation: dotFloat 10s ease-in-out infinite;
}

@keyframes orbFloat{
  0%,100%{transform:translate3d(0,0,0) scale(1)}
  50%{transform:translate3d(4vmax,-2vmax,0) scale(1.04)}
}
@keyframes gridDrift{
  0%{transform:translate3d(0,0,0)}
  100%{transform:translate3d(-3%,2%,0)}
}
@keyframes routeDash{
  0%{stroke-dashoffset:0}
  100%{stroke-dashoffset:-220}
}
@keyframes dotFloat{
  0%,100%{transform:translate3d(0,0,0); opacity:.75}
  50%{transform:translate3d(0,-18px,0); opacity:1}
}

/* Reduce Motion */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .ambient__orb,.ambient__grid,.ambient__routes path,.ambient__dot,
  .travel-icon, .status-text, .animate-on-scroll, .service-card, .btn{animation:none !important; transition:none !important}
}

/* =========================
   Header
========================= */
header{
  position:fixed;top:0;left:0;width:100%;z-index:1000;
  background:rgba(255,255,255,.72);
  backdrop-filter: blur(12px);
  border-bottom:1px solid rgba(31,42,51,.06);
  transition:var(--transition);
}
header.scrolled{
  background:rgba(255,255,255,.9);
  box-shadow:0 14px 35px rgba(0,0,0,.08);
}
.header-container{
  display:flex;justify-content:space-between;align-items:center;
  padding:18px 0;
}
.brand{
  display:flex;align-items:center;gap:14px;text-decoration:none;
  padding:6px 10px;border-radius:14px;
  transition:var(--transition);
}
.brand:hover{background:rgba(42,107,138,.06); transform:translateY(-1px)}
/* Контейнер логотипа — фиксируем высоту, чтобы ничего не менялось вокруг */
.brand__logoSlot{
  height: 56px;            /* высота зоны (можешь менять) */
  display: flex;
  align-items: center;
  overflow: visible;       /* чтобы логотип мог быть чуть больше, не влияя на блоки */
}

/* Меняем размер ТОЛЬКО у картинки */
.brand__logo{
  height: 200px;            /* <-- меняй ТОЛЬКО это */
  width: auto;             /* ширина считается пропорционально */
        /* ограничение по ширине */       /* не растём выше slot */
  object-fit: contain;
  display: block;
  flex: 0 0 auto;
  filter: drop-shadow(0 10px 16px rgba(0,0,0,.10));
  transform-origin: left center;
}

/* Если есть hover-анимация — пусть масштабируется только картинка */
.brand:hover .brand__logo{
  transform: scale(1.03);
}
.brand__name{
  font-size:20px;font-weight:700;color:var(--primary);
  letter-spacing:.2px;
}
.brand__name span{color:var(--secondary)}
.mobile-menu-btn{
  display:none;
  background:transparent;border:none;
  font-size:24px;cursor:pointer;color:var(--primary);
  padding:10px;border-radius:12px;transition:var(--transition);
}
.mobile-menu-btn:hover{background:rgba(42,107,138,.08)}
nav ul{display:flex;list-style:none;gap:28px}
nav a{
  text-decoration:none;
  color:var(--dark);
  font-weight:600;
  font-size:15px;
  transition:var(--transition);
  position:relative;
  padding:6px 0;
}
nav a:hover, nav a.active{color:var(--primary)}
nav a::after{
  content:'';
  position:absolute;left:0;bottom:0;
  width:0;height:2px;background:var(--primary);
  transition:var(--transition);
}
nav a:hover::after, nav a.active::after{width:100%}

/* =========================
   Hero
========================= */
.hero{
  padding:175px 0 110px;
  position:relative;
  overflow:hidden;
  background: linear-gradient(135deg, rgba(42,107,138,.10), rgba(243,179,59,.10));
  border-bottom:1px solid rgba(31,42,51,.06);
}
.hero-bg{position:absolute;inset:0;z-index:0}
.travel-icon{
  position:absolute;
  font-size:24px;
  color:rgba(42,107,138,.12);
  animation: float 7s ease-in-out infinite;
}
.plane{top:22%;left:10%}
.suitcase{top:64%;right:13%; animation-delay: 1.4s}
.passport{bottom:26%;left:22%; animation-delay: 2.6s}
.compass{top:34%;right:24%; animation-delay: 3.6s}
.map{bottom:18%;right:6%; animation-delay: 4.4s}

@keyframes float{
  0%,100%{transform:translateY(0) rotate(0deg)}
  50%{transform:translateY(-18px) rotate(4deg)}
}

.hero-content{
  position:relative; z-index:1;
  max-width:860px;margin:0 auto;text-align:center;
}
.hero-kicker{
  display:inline-flex;
  gap:10px; align-items:center;
  padding:8px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.62);
  border:1px solid rgba(31,42,51,.06);
  color:var(--primary-dark);
  font-weight:600;
  font-size:.95rem;
  box-shadow:0 10px 30px rgba(0,0,0,.06);
  margin-bottom:18px;
}
.hero h1{
  font-size:3.25rem;
  color:var(--primary);
  margin-bottom:16px;
  animation:fadeInUp 1s ease-out;
}
.hero p{
  font-size:1.15rem;
  color:var(--gray);
  max-width:740px;
  margin:0 auto 26px;
  animation:fadeInUp 1s ease-out .18s both;
}
.hero-actions{
  display:flex;justify-content:center;gap:14px;flex-wrap:wrap;
  margin-top:10px;
  animation:fadeInUp 1s ease-out .34s both;
}
.hero-stats{
  display:flex;justify-content:center;gap:44px;flex-wrap:wrap;
  margin-top:56px;
  animation:fadeInUp 1s ease-out .48s both;
}
.stat-item{text-align:center; min-width:160px}
.stat-number{font-size:2.35rem;font-weight:800;color:var(--primary);margin-bottom:6px}
.stat-text{font-size:1rem;color:var(--gray);font-weight:500}

/* =========================
   Status bar
========================= */
.status-bar{
  background:linear-gradient(to right, var(--primary), var(--accent));
  color:#fff;
  padding:14px 0;
  text-align:center;
  font-weight:600;
  overflow:hidden;
  position:relative;
}
.status-text{
  display:inline-block;
  padding-left:100%;
  white-space:nowrap;
  animation:scrollText 22s linear infinite;
  opacity:.96;
}
@keyframes scrollText{
  0%{transform:translateX(0)}
  100%{transform:translateX(-100%)}
}

/* =========================
   Sections
========================= */
.section{padding:96px 0}
.section-title{text-align:center;margin-bottom:58px}
.section-title h2{
  font-size:2.5rem;
  color:var(--primary);
  position:relative;
  display:inline-block;
  padding-bottom:14px;
}
.section-title h2::after{
  content:'';
  position:absolute;bottom:0;left:50%;
  transform:translateX(-50%);
  width:86px;height:4px;background:var(--secondary);
  border-radius:999px;
}
.section-title p{
  color:var(--gray);
  font-size:1.05rem;
  max-width:780px;
  margin:10px auto 0;
}

/* =========================
   Buttons
========================= */
.btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:14px 20px;
  background:linear-gradient(135deg, var(--primary), var(--primary-dark));
  color:#fff;
  border:none;
  border-radius:12px;
  font-family:'Montserrat',system-ui,sans-serif;
  font-weight:700;
  font-size:14px;
  cursor:pointer;
  transition:var(--transition);
  text-decoration:none;
  box-shadow:0 12px 28px rgba(42,107,138,.18);
}
.btn:hover{
  transform:translateY(-3px);
  box-shadow:0 18px 38px rgba(42,107,138,.22);
}
.btn:active{transform:translateY(-1px) scale(.99)}
.btn--ghost{
  background:rgba(255,255,255,.65);
  color:var(--primary);
  border:1px solid rgba(31,42,51,.10);
  box-shadow:0 12px 28px rgba(0,0,0,.06);
}
.btn--ghost:hover{
  background:rgba(255,255,255,.88);
  box-shadow:0 18px 38px rgba(0,0,0,.10);
}

/* =========================
   Services
========================= */
.services-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:26px;
}
.service-card{
  background:rgba(255,255,255,.86);
  border:1px solid rgba(31,42,51,.06);
  border-radius:var(--radius-lg);
  padding:34px 28px;
  box-shadow:var(--shadow);
  transition:var(--transition);
  position:relative;
  overflow:hidden;
}
.service-card::before{
  content:'';
  position:absolute; inset:-60px -80px auto auto;
  width:220px; height:220px;
  background: radial-gradient(circle at 30% 30%, rgba(243,179,59,.18), rgba(243,179,59,0) 65%);
  transform:rotate(12deg);
}
.service-card:hover{
  transform:translateY(-10px);
  box-shadow:var(--shadow-hover);
}
.service-icon{
  width:76px;height:76px;border-radius:20px;
  background: linear-gradient(135deg, rgba(42,107,138,.95), rgba(47,181,176,.92));
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:30px;
  margin-bottom:18px;
  box-shadow:0 18px 38px rgba(42,107,138,.18);
}
.service-top{display:flex;justify-content:space-between;align-items:flex-start;gap:14px}
.service-card h3{
  color:var(--primary);
  font-size:1.45rem;
  margin-bottom:10px;
}
.service-card p{color:var(--gray); margin-bottom:14px}

.service-price{
  text-align:right;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(31,42,51,.08);
  border-radius:14px;
  padding:10px 12px;
  min-width:130px;
  box-shadow:0 12px 26px rgba(0,0,0,.06);
}
.service-price__tag{
  display:block;
  font-size:.72rem;
  color:rgba(31,42,51,.70);
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.service-price__value{
  display:block;
  font-size:1.4rem;
  font-family:'Montserrat',system-ui,sans-serif;
  font-weight:800;
  color:var(--primary-dark);
  margin-top:2px;
}
.service-price__sub{
  display:block;
  font-size:.8rem;
  color:rgba(31,42,51,.68);
  font-weight:600;
  margin-top:-2px;
}
.service-bullets{
  list-style:none;
  display:grid;
  gap:10px;
  margin-top:14px;
}
.service-bullets li{
  position:relative;
  padding-left:22px;
  color:rgba(31,42,51,.82);
  font-weight:500;
}
.service-bullets li::before{
  content:'';
  position:absolute;
  left:0; top:.55em;
  width:10px;height:10px;
  border-radius:3px;
  background:linear-gradient(135deg, var(--secondary), var(--accent));
  transform:translateY(-50%);
}

.pricing-note{
  margin-top:34px;
  display:flex;
  gap:14px;
  align-items:flex-start;
  padding:18px 18px;
  border-radius:18px;
  background:rgba(255,255,255,.70);
  border:1px solid rgba(31,42,51,.08);
  box-shadow:0 18px 44px rgba(0,0,0,.06);
}
.pricing-note__icon{
  width:42px;height:42px;border-radius:14px;
  background:rgba(42,107,138,.12);
  display:flex;align-items:center;justify-content:center;
  color:var(--primary);
  flex:0 0 auto;
}
.pricing-note__text{color:rgba(31,42,51,.80);font-weight:500}

/* =========================
   Contact
========================= */
.contact-section{
  background:rgba(233,238,242,.55);
  position:relative;
  overflow:hidden;
}
.contact-container{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:54px;
  align-items:start;
}
.contact-form{
  background:rgba(255,255,255,.88);
  border:1px solid rgba(31,42,51,.06);
  padding:40px;
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow);
}
.form-group{margin-bottom:20px}
.form-group label{display:block;margin-bottom:8px;font-weight:600;color:var(--dark)}
.form-control{
  width:100%;
  padding:14px 14px;
  border:1px solid rgba(31,42,51,.10);
  border-radius:12px;
  font-size:16px;
  background:#fff;
  transition:var(--transition);
}
.form-control:focus{
  outline:none;
  border-color:rgba(42,107,138,.45);
  box-shadow:0 0 0 4px rgba(42,107,138,.10);
}
textarea.form-control{min-height:150px;resize:vertical}
.form-fineprint{
  margin-top:12px;
  font-size:.9rem;
  color:rgba(31,42,51,.70);
}
.form-fineprint a{color:var(--primary); text-decoration:none; font-weight:700}
.form-fineprint a:hover{text-decoration:underline}

.contact-info{
  display:grid;
  grid-template-columns:1fr;
  gap:22px;
}
.info-card{
  background:rgba(255,255,255,.88);
  border:1px solid rgba(31,42,51,.06);
  padding:28px 26px;
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow);
  transition:var(--transition);
}
.info-card:hover{transform:translateY(-6px); box-shadow:var(--shadow-hover)}
.info-icon{
  width:58px;height:58px;border-radius:18px;
  background: linear-gradient(135deg, rgba(243,179,59,.92), rgba(217,138,0,.92));
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:22px;
  margin-bottom:16px;
  box-shadow:0 18px 38px rgba(243,179,59,.18);
}
.info-card h3{color:var(--primary);font-size:1.25rem;margin-bottom:8px}
.hours{margin-top:10px;font-size:.92rem;color:rgba(31,42,51,.70)}

/* =========================
   Reviews
========================= */
.testimonials-section{background:transparent}
.reviews-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
  gap:22px;
}
.testimonial-card{
  background:rgba(255,255,255,.86);
  border:1px solid rgba(31,42,51,.06);
  border-radius:var(--radius-lg);
  padding:34px 28px;
  box-shadow:var(--shadow);
  transition:var(--transition);
  position:relative;
  overflow:hidden;
}
.testimonial-card:hover{transform:translateY(-8px); box-shadow:var(--shadow-hover)}
.review-meta{
  display:flex;justify-content:space-between;align-items:center;
  gap:14px;margin-bottom:14px;
}
.review-stars{color:rgba(243,179,59,.95); letter-spacing:.06em}
.review-date{font-size:.85rem;color:rgba(31,42,51,.62);font-weight:700}
.testimonial-text{
  font-size:1.05rem;
  font-style:italic;
  color:rgba(31,42,51,.86);
  margin-bottom:22px;
  line-height:1.85;
}
.testimonial-author{display:flex;align-items:center;gap:16px}
.author-avatar{
  width:58px;height:58px;border-radius:18px;
  background:rgba(42,107,138,.10);
  display:flex;align-items:center;justify-content:center;
  color:var(--primary);
  font-size:20px;font-weight:800;
}
.author-info h4{margin-bottom:4px;color:var(--primary)}
.author-info p{color:rgba(31,42,51,.68);font-size:.92rem}

.review-cta{margin-top:26px}
.review-cta__card{
  background:linear-gradient(135deg, rgba(42,107,138,.12), rgba(47,181,176,.10));
  border:1px solid rgba(31,42,51,.06);
  border-radius:var(--radius-lg);
  padding:28px 28px;
  box-shadow:0 18px 50px rgba(0,0,0,.06);
  text-align:center;
}
.review-cta__card h3{color:var(--primary); margin-bottom:10px}
.review-cta__card p{color:rgba(31,42,51,.76); margin-bottom:16px}

/* =========================
   Legal overlay
========================= */
.legal-overlay{
  position:fixed;inset:0;
  background:rgba(16,24,32,.55);
  backdrop-filter: blur(10px);
  z-index:5000;
  display:none;
  padding:18px;
}
.legal-overlay.is-open{display:flex}
.legal-shell{
  width:min(1050px, 100%);
  margin:auto;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(31,42,51,.10);
  border-radius:22px;
  box-shadow:0 26px 80px rgba(0,0,0,.22);
  overflow:hidden;
}
.legal-topbar{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 16px;
  background:rgba(255,255,255,.82);
  border-bottom:1px solid rgba(31,42,51,.08);
}
.legal-topbar__brand{
  display:flex;align-items:center;gap:12px;
  text-decoration:none;
  color:var(--primary-dark);
  font-weight:800;
}
.legal-topbar__logo{height:34px;width:auto;object-fit:contain}
.legal-close{
  border:none;background:rgba(31,42,51,.06);
  width:44px;height:44px;border-radius:14px;
  cursor:pointer;
  transition:var(--transition);
  color:rgba(31,42,51,.78);
}
.legal-close:hover{background:rgba(31,42,51,.10); transform:translateY(-1px)}
.legal-content{
  max-height:calc(100vh - 120px);
  overflow:auto;
  padding:28px 26px 30px;
}
.legal-doc{display:none}
.legal-doc.is-active{display:block}
.legal-doc h1{
  color:var(--primary);
  margin-bottom:18px;
  padding-bottom:12px;
  border-bottom:2px solid rgba(31,42,51,.08);
}
.legal-section{margin-bottom:24px}
.legal-section h2{
  color:var(--primary);
  font-size:1.35rem;
  margin-bottom:10px;
}
.legal-section h3{
  color:var(--primary-dark);
  font-size:1.08rem;
  margin-top:12px;
  margin-bottom:8px;
}
.legal-section p{margin-bottom:10px; line-height:1.85; color:rgba(31,42,51,.82)}
.legal-list{margin-left:18px; display:grid; gap:10px; color:rgba(31,42,51,.82)}
.legal-contact{
  background:rgba(233,238,242,.65);
  border:1px solid rgba(31,42,51,.08);
  border-radius:16px;
  padding:14px 14px;
  color:rgba(31,42,51,.84);
}

/* =========================
   Footer
========================= */
footer{
  background:linear-gradient(180deg, var(--primary-dark), #0f2a34);
  color:#fff;
  padding:78px 0 38px;
  position:relative;
  overflow:hidden;
}
footer::before{
  content:'';
  position:absolute; inset:-30% -20%;
  background: radial-gradient(circle at 20% 10%, rgba(243,179,59,.18), rgba(243,179,59,0) 60%),
              radial-gradient(circle at 85% 30%, rgba(47,181,176,.16), rgba(47,181,176,0) 62%);
  pointer-events:none;
}
.footer-container{
  position:relative;
  display:grid;
  grid-template-columns:1.25fr 1fr 1fr;
  gap:52px;
  margin-bottom:46px;
}
.footer-brand{
  display:flex;
  flex-direction: column;   /* лого сверху, текст снизу */
  align-items: center;       /* центрируем */
  text-align: center;        /* текст по центру */
  gap: 10px;
  margin-bottom: 14px;
}

/* Слот под лого — реальный размер, без вылезания */
.footer-brand__logoSlot{
  width: 800px;              /* <-- меняй ширину/размер тут */
  height: 140px;             /* <-- и тут */
  display:flex;
  align-items:center;
  justify-content:center;
  overflow: hidden;          /* важно: не перекрываем текст */
}

/* Сам логотип занимает слот */
.footer-brand__logo{
  width: 100%;
  height: 100%;
  object-fit: contain;
  display:block;
  filter: drop-shadow(0 12px 20px rgba(0,0,0,.20));
}

/* Текст всегда копируемый */
.footer-brand__text{
  user-select: text;
}

.footer-industry{
  color:rgba(255,255,255,.80);
  font-weight:600;
  font-size:.95rem;
  margin-top:-2px;
}
.footer-logo-text{font-size:22px;font-weight:800;color:#fff}
.footer-logo-text span{color:var(--secondary)}
.footer-about{
  font-size:.95rem;
  line-height:1.85;
  color:rgba(255,255,255,.78);
  max-width:520px;
}
.footer-links h3,.footer-legal h3{
  color:#fff;font-size:1.18rem;margin-bottom:18px;
  position:relative;padding-bottom:10px;
}
.footer-links h3::after,.footer-legal h3::after{
  content:'';
  position:absolute;left:0;bottom:0;
  width:44px;height:3px;border-radius:999px;
  background:var(--secondary);
}
.footer-links ul,.footer-legal ul{list-style:none}
.footer-links li,.footer-legal li{margin-bottom:10px}
.footer-links a,.footer-legal a{
  color:rgba(255,255,255,.78);
  text-decoration:none;
  transition:var(--transition);
  font-weight:600;
}
.footer-links a:hover,.footer-legal a:hover{color:var(--secondary); padding-left:6px}

.footer-bottom{
  position:relative;
  padding-top:28px;
  border-top:1px solid rgba(255,255,255,.12);
  text-align:center;
  color:rgba(255,255,255,.78);
  font-size:.92rem;
  display:grid;
  gap:6px;
}
.footer-bottom__meta{color:rgba(255,255,255,.70)}

/* =========================
   Scroll animations
========================= */
@keyframes fadeInUp{
  from{opacity:0; transform:translateY(26px)}
  to{opacity:1; transform:translateY(0)}
}
.animate-on-scroll{
  opacity:0;
  transform:translateY(26px);
  transition:var(--transition);
}
.animate-on-scroll.visible{
  opacity:1;
  transform:translateY(0);
}

/* =========================
   Responsive
========================= */
@media (max-width: 992px){
  .contact-container{grid-template-columns:1fr; gap:36px}
  .footer-container{grid-template-columns:1fr; gap:32px}
  .hero h1{font-size:2.7rem}
  .section-title h2{font-size:2.2rem}
}
@media (max-width: 768px){
  .header-container{padding:14px 0}
  .mobile-menu-btn{display:inline-flex}
  nav{
    position:fixed; top:78px; left:0; width:100%;
    background:rgba(255,255,255,.94);
    backdrop-filter: blur(12px);
    border-bottom:1px solid rgba(31,42,51,.08);
    padding:18px 18px 22px;
    transform:translateY(-105%);
    opacity:0;
    visibility:hidden;
    transition:var(--transition);
    z-index:999;
  }
  nav.active{
    transform:translateY(0);
    opacity:1;
    visibility:visible;
  }
  nav ul{flex-direction:column; gap:16px}
  .hero{padding:150px 0 80px}
  .hero h1{font-size:2.15rem}
  .hero-stats{gap:18px}
  .section{padding:74px 0}
  .contact-form{padding:28px 22px}
  .legal-content{padding:22px 18px}
}
@media (max-width: 576px){
  .brand__name{display:none}
  .brand__logo{height:42px}
  .service-top{flex-direction:column; align-items:flex-start}
  .service-price{text-align:left}
}
