/* ================================================
   Magic Home Cleaning Services — Main Stylesheet
   Theme: Orange #F28E2B → Purple #5E2D79
   ================================================ */

@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700;800;900&family=Inter:wght@300;400;500;600;700&display=swap');

/* ================================================
   CSS VARIABLES
   ================================================ */
:root {
  --orange: #F28E2B;
  --purple: #5E2D79;
  --gradient: linear-gradient(135deg, #F28E2B 0%, #5E2D79 100%);
  --gradient-r: linear-gradient(135deg, #5E2D79 0%, #F28E2B 100%);
  --white: #ffffff;
  --light: #FFF8F2;
  --light2: #F5ECF9;
  --dark: #1a1228;
  --dark2: #0d0d1a;
  --gray: #64748b;
  --gray2: #94a3b8;
  --border: #e8e0f0;
  --shadow-s: 0 2px 16px rgba(94,45,121,.08);
  --shadow-m: 0 6px 30px rgba(94,45,121,.13);
  --shadow-l: 0 12px 55px rgba(94,45,121,.18);
  --glow-o: 0 6px 30px rgba(242,142,43,.35);
  --glow-p: 0 6px 30px rgba(94,45,121,.35);
  --r-s: 8px;
  --r-m: 16px;
  --r-l: 28px;
  --r-xl: 50px;
  --ease: all .3s cubic-bezier(.4,0,.2,1);
  --font-h: 'Poppins', sans-serif;
  --font-b: 'Inter', sans-serif;
}

/* ================================================
   RESET & BASE
   ================================================ */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body { font-family:var(--font-b); color:var(--dark); background:var(--white); line-height:1.6; overflow-x:hidden; }
img { max-width:100%; height:auto; display:block; }
a { text-decoration:none; color:inherit; transition:var(--ease); }
ul { list-style:none; }
button { cursor:pointer; border:none; background:none; font-family:inherit; }
input, textarea, select { font-family:inherit; }

/* ================================================
   TOP BAR
   ================================================ */
.top-bar {
  background: var(--gradient);
  padding: 8px 0;
  position: relative;
  z-index: 1002;
}
.top-bar-inner {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.top-bar-contacts {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.top-bar-contacts a {
  color: var(--white);
  font-size: 12.5px;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 4px 14px;
  border-radius: var(--r-xl);
  background: rgba(255,255,255,.16);
  backdrop-filter: blur(8px);
  white-space: nowrap;
  transition: var(--ease);
}
.top-bar-contacts a:hover { background: rgba(255,255,255,.28); transform: translateY(-1px); }
.top-bar-contacts a svg { width:15px; height:15px; fill:currentColor; flex-shrink:0; }
.top-bar-right {
  font-size: 12px;
  color: rgba(255,255,255,.82);
  font-weight: 500;
  white-space: nowrap;
}

/* ================================================
   MARQUEE
   ================================================ */
.marquee-bar {
  background: var(--dark2);
  padding: 9px 0;
  overflow: hidden;
  border-bottom: 2px solid var(--orange);
  position: relative;
}
.marquee-bar::before,
.marquee-bar::after {
  content: '';
  position: absolute;
  top: 0; bottom: 0;
  width: 80px;
  z-index: 2;
  pointer-events: none;
}
.marquee-bar::before { left:0; background: linear-gradient(to right, var(--dark2), transparent); }
.marquee-bar::after  { right:0; background: linear-gradient(to left, var(--dark2), transparent); }
.marquee-track {
  display: flex;
  width: max-content;
  animation: marquee 40s linear infinite;
}
.marquee-track:hover { animation-play-state: paused; }
.marquee-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 28px;
  white-space: nowrap;
  font-size: 12.5px;
  font-weight: 600;
  color: rgba(255,255,255,.85);
}
.marquee-item .dot { color: var(--orange); font-size: 18px; line-height:1; }
.marquee-item .hl { background: var(--gradient); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; font-weight:700; }
@keyframes marquee { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

/* ================================================
   HEADER / NAVIGATION
   ================================================ */
.site-header {
  background: var(--white);
  box-shadow: 0 2px 18px rgba(94,45,121,.10);
  position: sticky;
  top: 0;
  z-index: 1000;
  transition: box-shadow .3s;
}
.site-header.scrolled { box-shadow: 0 4px 32px rgba(94,45,121,.18); }
.nav-wrap {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 76px;
}
.nav-logo img { height:62px; width:auto; transition:transform .3s; }
.nav-logo img:hover { transform:scale(1.04); }

.nav-menu { display:flex; align-items:center; gap:4px; }
.nav-item { position:relative; }
.nav-link {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 9px 14px;
  font-size: 13.5px;
  font-weight: 600;
  color: var(--dark);
  border-radius: var(--r-s);
  font-family: var(--font-h);
  white-space: nowrap;
  transition: var(--ease);
}
.nav-link:hover, .nav-link.active { color:var(--orange); background:rgba(242,142,43,.08); }
.nav-link .arr { font-size:9px; transition:transform .3s; }
.nav-item:hover .nav-link .arr { transform:rotate(180deg); }

/* Dropdown */
.dropdown {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  min-width: 270px;
  background: var(--white);
  border-radius: var(--r-m);
  box-shadow: var(--shadow-l);
  padding: 10px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-10px);
  transition: all .3s cubic-bezier(.4,0,.2,1);
  border-top: 3px solid var(--orange);
  z-index: 200;
}
.nav-item:hover .dropdown { opacity:1; visibility:visible; transform:translateY(0); }
.drop-cat {
  padding: 6px 12px 3px;
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  background: var(--gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.drop-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 9px 12px;
  font-size: 13px;
  font-weight: 500;
  color: var(--dark);
  border-radius: var(--r-s);
  transition: var(--ease);
}
.drop-item::before { content:'✦'; font-size:7px; color:var(--orange); flex-shrink:0; }
.drop-item:hover { background:linear-gradient(135deg,rgba(242,142,43,.09),rgba(94,45,121,.09)); color:var(--purple); padding-left:18px; }
.drop-div { height:1px; background:var(--border); margin:5px 12px; }

.nav-cta { display:flex; align-items:center; gap:10px; }
.btn-get-quote {
  padding: 10px 22px;
  background: var(--gradient);
  color: var(--white);
  border-radius: var(--r-xl);
  font-size: 13px;
  font-weight: 700;
  font-family: var(--font-h);
  box-shadow: var(--glow-o);
  white-space: nowrap;
  transition: var(--ease);
}
.btn-get-quote:hover { transform:translateY(-2px); box-shadow:0 10px 30px rgba(242,142,43,.45); }

/* Hamburger */
.hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  padding: 8px;
  border-radius: var(--r-s);
  transition: var(--ease);
}
.hamburger:hover { background:rgba(242,142,43,.1); }
.hamburger span {
  display: block;
  width: 24px;
  height: 2.5px;
  background: var(--gradient);
  border-radius: 10px;
  transition: all .4s cubic-bezier(.4,0,.2,1);
  transform-origin: center;
}
.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
   ================================================ */
.mob-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.55);
  z-index: 9998;
  backdrop-filter: blur(4px);
}
.mob-overlay.open { display:block; }
.mob-menu {
  position: fixed;
  top: 0; right: 0;
  width: min(88%, 400px);
  height: 100vh;
  background: var(--white);
  z-index: 9999;
  transform: translateX(110%);
  transition: transform .42s cubic-bezier(.4,0,.2,1);
  display: flex;
  flex-direction: column;
  box-shadow: -8px 0 50px rgba(0,0,0,.22);
  overflow: hidden;
}
.mob-menu.open { transform:translateX(0); }
.mob-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 20px;
  background: var(--gradient);
  flex-shrink: 0;
}
.mob-head img { height:46px; width:auto; }
.mob-close {
  color: var(--white);
  font-size: 22px;
  width: 36px; height:36px;
  display: flex; align-items:center; justify-content:center;
  border-radius: 50%;
  background: rgba(255,255,255,.2);
  transition: var(--ease);
}
.mob-close:hover { background:rgba(255,255,255,.35); transform:rotate(90deg); }
.mob-nav { flex:1; overflow-y:auto; padding:16px 0; }
.mob-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 24px;
  font-size: 14.5px;
  font-weight: 600;
  color: var(--dark);
  border-bottom: 1px solid rgba(0,0,0,.04);
  font-family: var(--font-h);
  transition: var(--ease);
}
.mob-link:hover { color:var(--orange); background:rgba(242,142,43,.05); padding-left:30px; }
.mob-link .chv { font-size:20px; transition:transform .3s; }
.mob-link.expanded .chv { transform:rotate(90deg); }
.mob-drop { display:none; background:var(--light); }
.mob-drop.open { display:block; }
.mob-drop-cat {
  padding: 10px 28px 3px;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  background: var(--gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.mob-drop-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 28px;
  font-size: 13px;
  font-weight: 500;
  color: var(--gray);
  border-bottom: 1px solid rgba(0,0,0,.04);
  transition: var(--ease);
}
.mob-drop-item::before { content:'◆'; font-size:6px; color:var(--orange); }
.mob-drop-item:hover { color:var(--purple); background:rgba(94,45,121,.05); padding-left:36px; }
.mob-footer {
  padding: 20px;
  background: var(--gradient);
  flex-shrink: 0;
}
.mob-footer .ci {
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--white);
  font-size: 13.5px;
  font-weight: 500;
  padding: 7px 0;
}
.mob-footer .ci .ico {
  width:32px; height:32px;
  background: rgba(255,255,255,.2);
  border-radius: 50%;
  display:flex; align-items:center; justify-content:center;
  font-size:14px;
}

/* ================================================
   BUTTONS
   ================================================ */
.btn { display:inline-flex; align-items:center; gap:8px; font-family:var(--font-h); font-weight:700; border-radius:var(--r-xl); transition:var(--ease); position:relative; overflow:hidden; }
.btn::after { content:''; position:absolute; top:0; left:-100%; width:100%; height:100%; background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent); transition:left .5s; }
.btn:hover::after { left:100%; }

.btn-primary {
  padding: 13px 32px;
  background: var(--gradient);
  color: var(--white);
  font-size: 14.5px;
  box-shadow: var(--glow-o);
}
.btn-primary:hover { transform:translateY(-3px); box-shadow:0 12px 35px rgba(242,142,43,.45); }

.btn-outline {
  padding: 12px 30px;
  background: transparent;
  color: var(--orange);
  border: 2px solid var(--orange);
  font-size: 14.5px;
}
.btn-outline:hover { background:var(--gradient); color:var(--white); border-color:transparent; transform:translateY(-3px); box-shadow:var(--glow-o); }

.btn-white {
  padding: 13px 32px;
  background: var(--white);
  color: var(--purple);
  font-size: 14.5px;
  box-shadow: 0 4px 20px rgba(0,0,0,.15);
}
.btn-white:hover { background:var(--gradient); color:var(--white); transform:translateY(-3px); box-shadow:var(--glow-o); }

/* ================================================
   LAYOUT / SECTIONS
   ================================================ */
.container { max-width:1320px; margin:0 auto; padding:0 24px; }
.section { padding:90px 0; }
.section-alt { background:var(--light); }
.section-dark { background:var(--dark2); color:var(--white); }

.sec-hd { text-align:center; margin-bottom:58px; }
.sec-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 18px;
  background: linear-gradient(135deg,rgba(242,142,43,.1),rgba(94,45,121,.1));
  border: 1px solid rgba(242,142,43,.25);
  border-radius: var(--r-xl);
  font-size: 11.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--orange);
  margin-bottom: 12px;
}
.sec-title {
  font-family: var(--font-h);
  font-size: clamp(26px,3.8vw,42px);
  font-weight: 800;
  line-height: 1.2;
  color: var(--dark);
  margin-bottom: 14px;
}
.sec-title .gr { background:var(--gradient); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.sec-sub { font-size:clamp(14px,1.7vw,16.5px); color:var(--gray); max-width:620px; margin:0 auto; line-height:1.75; }
.title-bar { width:70px; height:4px; background:var(--gradient); border-radius:10px; margin:14px auto 0; }

/* ================================================
   HERO SLIDER
   ================================================ */
.hero-section { position:relative; overflow:hidden; }
.hero-slider {
  position: relative;
  width: 100%;
  height: 88vh;
  min-height: 520px;
  max-height: 900px;
  overflow: hidden;
}
.slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity .85s cubic-bezier(.4,0,.2,1);
}
.slide.active { opacity:1; }
.slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.06);
  transition: transform 7s ease;
}
.slide.active img { transform:scale(1); }
.slide-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, rgba(26,18,40,.82) 0%, rgba(200,85,0,.38) 100%);
  display: flex;
  align-items: center;
  width: 100%;
}
.slide-content {
  width: 100%;
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 70px;
  color: var(--white);
}
.slide-badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 5px 16px;
  background: rgba(255,255,255,.14);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,.2);
  border-radius: var(--r-xl);
  font-size: 11.5px;
  font-weight: 600;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  margin-bottom: 14px;
  opacity: 0;
  animation: none;
}
.slide.active .slide-badge { animation: suUp .6s .2s ease forwards; }
.slide-title {
  font-family: var(--font-h);
  font-size: clamp(26px,4.5vw,60px);
  font-weight: 900;
  line-height: 1.14;
  margin-bottom: 16px;
  text-shadow: 0 2px 12px rgba(0,0,0,.28);
  opacity: 0;
}
.slide.active .slide-title { animation: suUp .6s .4s ease forwards; }
.slide-title .hl { background:linear-gradient(135deg,#F28E2B,#ffcf80); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.slide-desc {
  font-size: clamp(13.5px,1.7vw,17.5px);
  color: rgba(255,255,255,.88);
  max-width: 570px;
  line-height: 1.72;
  margin-bottom: 28px;
  opacity: 0;
}
.slide.active .slide-desc { animation: suUp .6s .6s ease forwards; }
.slide-btns { display:flex; gap:14px; flex-wrap:nowrap; align-items:center; opacity:0; }
.slide.active .slide-btns { animation: suUp .6s .8s ease forwards; }

.hero-prev, .hero-next {
  position: absolute;
  top: 50%; transform: translateY(-50%);
  z-index: 10;
  width: 48px; height:48px;
  background: rgba(255,255,255,.14);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,.2);
  border-radius: 50%;
  color: var(--white);
  font-size: 18px;
  display: flex; align-items:center; justify-content:center;
  transition: var(--ease);
}
.hero-prev:hover, .hero-next:hover { background:var(--gradient); transform:translateY(-50%) scale(1.1); }
.hero-prev { left:18px; }
.hero-next { right:18px; }
.hero-dots { position:absolute; bottom:18px; left:50%; transform:translateX(-50%); display:flex; gap:8px; z-index:10; }
.dot {
  width: 10px; height:10px;
  border-radius: 50%;
  background: rgba(255,255,255,.4);
  cursor: pointer;
  transition: var(--ease);
}
.dot.active { background:var(--orange); width:28px; border-radius:5px; }

@keyframes suUp { from{opacity:0;transform:translateY(22px)} to{opacity:1;transform:translateY(0)} }

/* ================================================
   QUICK CONTACT FORM (below hero)
   ================================================ */
.quick-form-section {
  background: var(--gradient);
  padding: 0;
  overflow: hidden;
  position: relative;
}
.quick-form-section::before { content:''; position:absolute; top:-50%; right:-15%; width:380px; height:380px; border-radius:50%; background:rgba(255,255,255,.06); }
.quick-form-section::after  { content:''; position:absolute; bottom:-40%; left:-8%; width:280px; height:280px; border-radius:50%; background:rgba(255,255,255,.04); }
.qf-inner {
  max-width: 1320px;
  margin: 0 auto;
  padding: 36px 24px;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 40px;
  align-items: center;
  position: relative;
  z-index: 1;
}
.qf-text h2 { font-family:var(--font-h); font-size:clamp(18px,2.5vw,28px); font-weight:800; color:var(--white); margin-bottom:5px; }
.qf-text p  { color:rgba(255,255,255,.82); font-size:14px; }
.qf-form { display:flex; gap:10px; flex-wrap:wrap; }
.qf-form .f-wrap { flex:1; min-width:170px; }
.qf-form input {
  width: 100%;
  padding: 13px 20px;
  border-radius: var(--r-xl);
  border: 2px solid rgba(255,255,255,.28);
  background: rgba(255,255,255,.14);
  backdrop-filter: blur(10px);
  color: var(--white);
  font-size: 13.5px;
  outline: none;
  transition: var(--ease);
}
.qf-form input::placeholder { color:rgba(255,255,255,.68); }
.qf-form input:focus { border-color:rgba(255,255,255,.75); background:rgba(255,255,255,.2); }
.qf-form .qf-btn {
  padding: 13px 28px;
  background: var(--white);
  color: var(--purple);
  border-radius: var(--r-xl);
  font-size: 13.5px;
  font-weight: 700;
  font-family: var(--font-h);
  box-shadow: 0 4px 16px rgba(0,0,0,.2);
  white-space: nowrap;
  transition: var(--ease);
}
.qf-form .qf-btn:hover { background:var(--dark2); color:var(--white); transform:translateY(-2px); }
.qf-msg { width:100%; padding:9px 14px; border-radius:var(--r-s); font-size:13px; font-weight:600; text-align:center; display:none; }
.qf-msg.ok { background:rgba(255,255,255,.18); color:var(--white); border:1px solid rgba(255,255,255,.38); display:block; }
.qf-msg.err { background:rgba(255,60,60,.2); color:var(--white); border:1px solid rgba(255,100,100,.4); display:block; }

/* ================================================
   ABOUT (HOME SECTION)
   ================================================ */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:center; }
.about-img-wrap { position:relative; }
.about-img-main { width:100%; border-radius:var(--r-l); box-shadow:var(--shadow-l); overflow:hidden; }
.about-img-main img { width:100%; height:470px; object-fit:cover; border-radius:var(--r-l); }
.about-frame {
  position: absolute;
  top: -18px; left: -18px;
  width: 100%; height: 100%;
  border: 3px solid var(--orange);
  border-radius: var(--r-l);
  opacity: .25;
}
.about-float {
  position: absolute;
  bottom: -22px; right: -22px;
  background: var(--gradient);
  color: var(--white);
  padding: 18px 22px;
  border-radius: var(--r-m);
  box-shadow: var(--glow-o);
  text-align: center;
  z-index: 2;
}
.about-float .num { font-family:var(--font-h); font-size:34px; font-weight:900; line-height:1; display:block; }
.about-float .lbl { font-size:11.5px; font-weight:600; opacity:.9; display:block; margin-top:3px; }
.about-content { padding-left:10px; }
.about-features { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin:20px 0; }
.af {
  display: flex;
  align-items: center;
  gap: 9px;
  font-size: 13.5px;
  font-weight: 500;
  color: var(--dark);
}
.af-ico {
  width:30px; height:30px;
  background: linear-gradient(135deg,rgba(242,142,43,.12),rgba(94,45,121,.12));
  border-radius: 8px;
  display: flex; align-items:center; justify-content:center;
  font-size:15px;
  flex-shrink: 0;
}
.about-nums { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:30px; padding-top:28px; border-top:1px solid var(--border); }
.astat { text-align:center; }
.astat .n { font-family:var(--font-h); font-size:30px; font-weight:900; background:var(--gradient); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; display:block; }
.astat .l { font-size:11.5px; font-weight:600; color:var(--gray); margin-top:3px; display:block; }
.about-btns { margin-top:28px; display:flex; gap:12px; flex-wrap:wrap; }

/* ================================================
   SERVICES CARDS
   ================================================ */
.srv-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(270px,1fr)); gap:24px; }
.srv-card {
  background: var(--white);
  border-radius: var(--r-m);
  overflow: hidden;
  box-shadow: var(--shadow-s);
  transition: var(--ease);
  position: relative;
}
.srv-card:hover { transform:translateY(-9px); box-shadow:var(--shadow-l); }
.srv-img { position:relative; height:208px; overflow:hidden; }
.srv-img img { width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.srv-card:hover .srv-img img { transform:scale(1.08); }
.srv-img-overlay { position:absolute; inset:0; background:var(--gradient); opacity:0; transition:var(--ease); }
.srv-card:hover .srv-img-overlay { opacity:.2; }
.srv-icon {
  position: absolute;
  bottom: -20px; left:18px;
  width: 44px; height:44px;
  background: var(--gradient);
  border-radius: 11px;
  display: flex; align-items:center; justify-content:center;
  font-size: 21px; color:var(--white);
  box-shadow: var(--glow-o);
  z-index: 1;
}
.srv-body { padding:30px 18px 18px; }
.srv-cat { font-size:10.5px; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:var(--orange); margin-bottom:5px; }
.srv-title { font-family:var(--font-h); font-size:16.5px; font-weight:700; color:var(--dark); margin-bottom:9px; line-height:1.3; }
.srv-desc { font-size:13px; color:var(--gray); line-height:1.65; margin-bottom:14px; }
.srv-link { display:inline-flex; align-items:center; gap:5px; font-size:13px; font-weight:700; color:var(--orange); font-family:var(--font-h); transition:var(--ease); }
.srv-link:hover { gap:10px; color:var(--purple); }

/* ================================================
   WHY CHOOSE US
   ================================================ */
.why-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.why-card {
  background: rgba(255,255,255,.045);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--r-m);
  padding: 34px 24px;
  position: relative;
  overflow: hidden;
  transition: var(--ease);
}
.why-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--gradient); transform:scaleX(0); transition:transform .35s; }
.why-card:hover::before { transform:scaleX(1); }
.why-card:hover { background:rgba(255,255,255,.07); transform:translateY(-5px); border-color:rgba(242,142,43,.22); }
.why-ico { width:62px; height:62px; background:var(--gradient); border-radius:17px; display:flex; align-items:center; justify-content:center; font-size:27px; margin-bottom:18px; box-shadow:var(--glow-o); }
.why-num { position:absolute; top:18px; right:18px; font-family:var(--font-h); font-size:52px; font-weight:900; color:rgba(255,255,255,.04); line-height:1; user-select:none; }
.why-card h3 { font-family:var(--font-h); font-size:17.5px; font-weight:700; color:var(--white); margin-bottom:10px; }
.why-card p { font-size:13.5px; color:rgba(255,255,255,.62); line-height:1.72; }

/* ================================================
   SUCCESS STORY
   ================================================ */
.success-grid { display:grid; grid-template-columns:1fr 1fr; gap:68px; align-items:center; }
.success-content .sec-hd { text-align:left; margin-bottom:24px; }
.success-content .title-bar { margin:12px 0 0; }
.timeline { position:relative; padding-left:28px; margin-top:26px; }
.timeline::before { content:''; position:absolute; left:7px; top:0; bottom:0; width:2px; background:var(--gradient); }
.tl-item { position:relative; margin-bottom:22px; }
.tl-item::before { content:''; position:absolute; left:-24px; top:5px; width:12px; height:12px; border-radius:50%; background:var(--gradient); box-shadow:0 0 0 4px rgba(242,142,43,.15); }
.tl-year { font-size:11px; font-weight:700; color:var(--orange); text-transform:uppercase; letter-spacing:1px; margin-bottom:3px; }
.tl-title { font-family:var(--font-h); font-size:15px; font-weight:700; color:var(--dark); margin-bottom:4px; }
.tl-desc { font-size:13px; color:var(--gray); line-height:1.6; }
.stats-grid { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.stat-card {
  background: var(--light);
  border-radius: var(--r-m);
  padding: 28px 22px;
  text-align: center;
  border: 1px solid rgba(242,142,43,.14);
  position: relative;
  overflow: hidden;
  transition: var(--ease);
}
.stat-card::after { content:''; position:absolute; bottom:0; left:0; right:0; height:3px; background:var(--gradient); transform:scaleX(0); transition:transform .35s; }
.stat-card:hover::after { transform:scaleX(1); }
.stat-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-m); }
.stat-ico { font-size:26px; margin-bottom:9px; display:block; }
.stat-n { font-family:var(--font-h); font-size:40px; font-weight:900; background:var(--gradient); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; display:block; line-height:1; }
.stat-l { font-size:12.5px; font-weight:600; color:var(--gray); margin-top:7px; display:block; }

/* ================================================
   SPECIALISATION
   ================================================ */
.spec-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.spec-card {
  background: var(--white);
  border-radius: var(--r-m);
  padding: 28px 18px;
  text-align: center;
  box-shadow: var(--shadow-s);
  border: 1px solid transparent;
  transition: var(--ease);
  position: relative;
  overflow: hidden;
}
.spec-card::after { content:''; position:absolute; inset:0; background:var(--gradient); opacity:0; transition:opacity .35s; border-radius:var(--r-m); }
.spec-card:hover { transform:translateY(-8px); }
.spec-card:hover::after { opacity:1; }
.spec-card > * { position:relative; z-index:1; }
.spec-card:hover .spec-ico,
.spec-card:hover h4,
.spec-card:hover p { color:var(--white) !important; -webkit-text-fill-color:var(--white) !important; background:none !important; -webkit-background-clip:unset !important; background-clip:unset !important; }
.spec-ico { font-size:40px; margin-bottom:13px; display:block; }
.spec-card h4 { font-family:var(--font-h); font-size:14.5px; font-weight:700; color:var(--dark); margin-bottom:7px; }
.spec-card p { font-size:12.5px; color:var(--gray); line-height:1.6; }

/* ================================================
   HIGHLIGHTS MARQUEE / BAND
   ================================================ */
.highlights-band {
  background: var(--gradient);
  padding: 0;
  position: relative;
  overflow: hidden;
}
.hl-grid { display:grid; grid-template-columns:repeat(5,1fr); }
.hl-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 30px 16px;
  color: var(--white);
  border-right: 1px solid rgba(255,255,255,.15);
  transition: var(--ease);
}
.hl-item:last-child { border-right:none; }
.hl-item:hover { background:rgba(255,255,255,.08); }
.hl-ico { font-size:34px; margin-bottom:10px; }
.hl-text { font-family:var(--font-h); font-size:13px; font-weight:700; line-height:1.45; }

/* ================================================
   REVIEWS
   ================================================ */
.reviews-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.rev-card {
  background: var(--white);
  border-radius: var(--r-m);
  padding: 28px;
  box-shadow: var(--shadow-s);
  border: 1px solid var(--border);
  position: relative;
  overflow: hidden;
  transition: var(--ease);
}
.rev-card::before { content:'"'; position:absolute; top:8px; right:16px; font-family:Georgia,serif; font-size:96px; color:rgba(242,142,43,.07); line-height:1; user-select:none; }
.rev-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-m); border-color:rgba(242,142,43,.22); }
.rev-stars { display:flex; gap:2px; margin-bottom:13px; }
.rev-stars span { color:var(--orange); font-size:15px; }
.rev-text { font-size:13.5px; color:var(--gray); line-height:1.78; margin-bottom:18px; font-style:italic; }
.rev-author { display:flex; align-items:center; gap:11px; }
.rev-av {
  width: 46px; height:46px;
  border-radius: 50%;
  background: var(--gradient);
  display: flex; align-items:center; justify-content:center;
  color: var(--white);
  font-family: var(--font-h);
  font-size: 17px;
  font-weight: 700;
  flex-shrink: 0;
}
.rev-name { font-family:var(--font-h); font-size:14.5px; font-weight:700; color:var(--dark); }
.rev-loc { font-size:12px; color:var(--gray2); margin-top:2px; }
.rev-badge { display:inline-flex; align-items:center; gap:3px; padding:2px 9px; background:rgba(242,142,43,.1); border-radius:var(--r-xl); font-size:11px; font-weight:600; color:var(--orange); margin-top:3px; }

/* ================================================
   FAQ
   ================================================ */
.faq-wrap { max-width:840px; margin:0 auto; }
.faq-item {
  background: var(--white);
  border-radius: var(--r-m);
  margin-bottom: 11px;
  box-shadow: var(--shadow-s);
  border: 1px solid transparent;
  overflow: hidden;
  transition: var(--ease);
}
.faq-item.open { border-color:rgba(242,142,43,.22); box-shadow:var(--shadow-m); }
.faq-q {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 19px 24px;
  cursor: pointer;
  user-select: none;
  gap: 14px;
}
.faq-q-text { font-family:var(--font-h); font-size:14.5px; font-weight:600; color:var(--dark); line-height:1.4; }
.faq-item.open .faq-q-text { background:var(--gradient); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.faq-ico {
  width: 31px; height:31px;
  background: linear-gradient(135deg,rgba(242,142,43,.1),rgba(94,45,121,.1));
  border-radius: 50%;
  display: flex; align-items:center; justify-content:center;
  flex-shrink: 0;
  font-size: 17px;
  color: var(--orange);
  transition: var(--ease);
}
.faq-item.open .faq-ico { background:var(--gradient); color:var(--white); transform:rotate(45deg); }
.faq-a { max-height:0; overflow:hidden; transition:max-height .42s cubic-bezier(.4,0,.2,1); }
.faq-item.open .faq-a { max-height:400px; }
.faq-a-inner { padding:0 24px 18px; font-size:13.5px; color:var(--gray); line-height:1.78; border-top:1px solid var(--border); padding-top:14px; }

/* ================================================
   CTA SECTION
   ================================================ */
.cta-section {
  background: var(--dark2);
  padding: 100px 0;
  position: relative;
  overflow: hidden;
  text-align: center;
}
.cta-section::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'%3E%3Cg fill='%23F28E2B' fill-opacity='0.04'%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"); pointer-events:none; }
.cta-inner { position:relative; z-index:1; }
.cta-inner h2 { font-family:var(--font-h); font-size:clamp(26px,4vw,48px); font-weight:900; color:var(--white); margin-bottom:16px; line-height:1.2; }
.cta-inner h2 span { background:var(--gradient); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.cta-inner p { font-size:16.5px; color:rgba(255,255,255,.68); max-width:580px; margin:0 auto 34px; line-height:1.72; }
.cta-btns { display:flex; justify-content:center; gap:14px; flex-wrap:wrap; }

/* ================================================
   FOOTER
   ================================================ */
.site-footer { background:var(--dark2); color:rgba(255,255,255,.72); padding-top:68px; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1.5fr; gap:46px; padding-bottom:46px; border-bottom:1px solid rgba(255,255,255,.08); }
.ft-logo { height:52px; width:auto; margin-bottom:16px; }
.ft-desc { font-size:13.5px; line-height:1.76; color:rgba(255,255,255,.58); margin-bottom:20px; }
.ft-social { display:flex; gap:9px; flex-wrap:wrap; }
.soc-btn {
  width:36px; height:36px;
  border-radius: 50%;
  background: rgba(255,255,255,.07);
  display: flex; align-items:center; justify-content:center;
  font-size: 14px;
  color: rgba(255,255,255,.68);
  border: 1px solid rgba(255,255,255,.1);
  transition: var(--ease);
}
.soc-btn:hover { background:var(--gradient); color:var(--white); transform:translateY(-3px); border-color:transparent; }
.ft-head {
  font-family: var(--font-h);
  font-size: 15px;
  font-weight: 700;
  color: var(--white);
  margin-bottom: 20px;
  position: relative;
  padding-bottom: 10px;
}
.ft-head::after { content:''; position:absolute; bottom:0; left:0; width:32px; height:2px; background:var(--gradient); border-radius:10px; }
.ft-links li { margin-bottom:9px; }
.ft-links a { font-size:13px; color:rgba(255,255,255,.58); display:flex; align-items:center; gap:5px; transition:var(--ease); }
.ft-links a::before { content:'›'; color:var(--orange); font-size:15px; font-weight:700; }
.ft-links a:hover { color:var(--orange); padding-left:4px; }
.ft-contact-item { display:flex; gap:11px; margin-bottom:14px; align-items:flex-start; }
.ft-c-ico { width:34px; height:34px; background:var(--gradient); border-radius:9px; display:flex; align-items:center; justify-content:center; font-size:14px; flex-shrink:0; color:var(--white); }
.ft-c-text { font-size:13px; color:rgba(255,255,255,.62); line-height:1.6; }
.ft-c-text a { color:rgba(255,255,255,.62); }
.ft-c-text a:hover { color:var(--orange); }
.footer-bottom {
  padding: 18px 24px;
  text-align: center;
  font-size: 12.5px;
  color: rgba(255,255,255,.42);
  max-width: 1320px;
  margin: 0 auto;
}
.footer-bottom a { color:rgba(255,255,255,.42); }
.footer-bottom .fb-brand { background:var(--gradient); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; font-weight:700; }
.footer-bottom .fb-designer { background:var(--gradient); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; font-weight:700; }
.footer-copy-bar { border-top:1px solid rgba(255,255,255,.07); }

/* ================================================
   FLOATING CONTACT BUTTONS
   ================================================ */
.float-btns {
  position: fixed;
  right: 20px; bottom:28px;
  z-index: 9980;
  display: flex;
  flex-direction: column;
  gap: 11px;
  align-items: flex-end;
}
.fl-btn {
  width: 54px; height:54px;
  border-radius: 50%;
  display: flex; align-items:center; justify-content:center;
  color: var(--white);
  font-size: 21px;
  box-shadow: 0 4px 20px rgba(0,0,0,.28);
  transition: var(--ease);
  position: relative;
  text-decoration: none;
}
.fl-btn:hover { transform:scale(1.12); }
.fl-phone { background:var(--gradient); }
.fl-wa    { background:#25D366; }
.fl-phone:hover { box-shadow:0 8px 28px rgba(242,142,43,.52); }
.fl-wa:hover    { box-shadow:0 8px 28px rgba(37,211,102,.52); }
.fl-pulse { position:absolute; inset:0; border-radius:50%; animation:pulse 2s cubic-bezier(0,.2,.2,1) infinite; }
.fl-phone .fl-pulse { border:3px solid var(--orange); }
.fl-wa    .fl-pulse { border:3px solid #25D366; }
.fl-tip {
  position: absolute;
  right: 62px;
  background: var(--dark);
  color: var(--white);
  padding: 5px 11px;
  border-radius: var(--r-s);
  font-size: 11.5px;
  font-weight: 600;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: var(--ease);
  transform: translateX(6px);
}
.fl-btn:hover .fl-tip { opacity:1; transform:translateX(0); }
@keyframes pulse { 0%{transform:scale(1);opacity:.65} 100%{transform:scale(1.72);opacity:0} }

/* ================================================
   PAGE HERO (inner pages)
   ================================================ */
.page-hero {
  background: var(--gradient);
  padding: 68px 0;
  position: relative;
  overflow: hidden;
  text-align: center;
}
.page-hero::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'%3E%3Cg fill='%23ffffff' fill-opacity='0.05'%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"); pointer-events:none; }
.ph-inner { position:relative; z-index:1; color:var(--white); }
.ph-badge { display:inline-flex; align-items:center; gap:6px; padding:5px 16px; background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.2); border-radius:var(--r-xl); font-size:11px; font-weight:600; letter-spacing:1.3px; text-transform:uppercase; margin-bottom:13px; }
.page-hero h1 { font-family:var(--font-h); font-size:clamp(26px,4vw,52px); font-weight:900; line-height:1.2; margin-bottom:14px; text-shadow:0 2px 10px rgba(0,0,0,.2); }
.page-hero p { font-size:clamp(13.5px,1.7vw,16.5px); color:rgba(255,255,255,.88); max-width:580px; margin:0 auto 22px; line-height:1.72; }
.breadcrumb { display:flex; align-items:center; justify-content:center; gap:7px; font-size:12.5px; color:rgba(255,255,255,.72); flex-wrap:wrap; }
.breadcrumb a { color:rgba(255,255,255,.72); }
.breadcrumb a:hover { color:var(--white); }
.bc-sep { color:rgba(255,255,255,.38); }
.bc-cur { color:rgba(255,255,255,.95); font-weight:600; }

/* ================================================
   SERVICE DETAIL PAGE
   ================================================ */
.svc-detail { padding:80px 0; }
.svc-grid { display:grid; grid-template-columns:2fr 1fr; gap:48px; align-items:start; }
.svc-main img { width:100%; height:380px; object-fit:cover; border-radius:var(--r-l); box-shadow:var(--shadow-l); margin-bottom:32px; }
.svc-main h2 { font-family:var(--font-h); font-size:24px; font-weight:800; color:var(--dark); margin:22px 0 10px; }
.svc-main p { font-size:14.5px; color:var(--gray); line-height:1.82; margin-bottom:16px; }
.svc-main ul { margin:14px 0; }
.svc-main ul li { display:flex; gap:9px; padding:7px 0; font-size:13.5px; color:var(--gray); line-height:1.6; border-bottom:1px solid var(--border); }
.svc-main ul li:last-child { border-bottom:none; }
.svc-main ul li::before { content:'✓'; color:var(--orange); font-weight:700; font-size:15px; flex-shrink:0; margin-top:1px; }
.svc-sidebar { position:sticky; top:96px; }
.side-card { background:var(--white); border-radius:var(--r-m); padding:28px; box-shadow:var(--shadow-m); margin-bottom:22px; border:1px solid var(--border); }
.side-title { font-family:var(--font-h); font-size:17px; font-weight:700; color:var(--dark); margin-bottom:16px; padding-bottom:11px; border-bottom:2px solid var(--orange); }
.side-form .fg { margin-bottom:12px; }
.side-form label { display:block; font-size:11.5px; font-weight:600; color:var(--dark); margin-bottom:4px; text-transform:uppercase; letter-spacing:.5px; }
.side-form input, .side-form textarea, .side-form select { width:100%; padding:10px 13px; border:1.5px solid var(--border); border-radius:var(--r-s); font-size:13.5px; color:var(--dark); outline:none; transition:var(--ease); background:var(--white); }
.side-form input:focus, .side-form textarea:focus { border-color:var(--orange); box-shadow:0 0 0 3px rgba(242,142,43,.1); }
.side-form textarea { height:82px; resize:vertical; }
.side-services li { margin-bottom:7px; }
.side-services a { display:flex; align-items:center; justify-content:space-between; padding:9px 13px; border-radius:var(--r-s); background:var(--light); font-size:13px; font-weight:500; color:var(--dark); transition:var(--ease); }
.side-services a:hover, .side-services a.active { background:var(--gradient); color:var(--white); }

/* ================================================
   GALLERY PAGE
   ================================================ */
.gallery-sec { padding:80px 0; }
.gal-filters { display:flex; justify-content:center; gap:9px; flex-wrap:wrap; margin-bottom:38px; }
.gf-btn { padding:8px 20px; border-radius:var(--r-xl); font-size:13px; font-weight:600; color:var(--gray); background:var(--light); border:1.5px solid transparent; transition:var(--ease); cursor:pointer; font-family:var(--font-h); }
.gf-btn:hover, .gf-btn.active { background:var(--gradient); color:var(--white); box-shadow:var(--glow-o); }
.gal-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.gal-item { border-radius:var(--r-m); overflow:hidden; position:relative; cursor:pointer; aspect-ratio:4/3; box-shadow:var(--shadow-s); }
.gal-item img { width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.gal-item:hover img { transform:scale(1.08); }
.gal-ov { position:absolute; inset:0; background:linear-gradient(to top,rgba(94,45,121,.82) 0%,transparent 55%); opacity:0; transition:var(--ease); display:flex; align-items:flex-end; padding:18px; }
.gal-item:hover .gal-ov { opacity:1; }
.gal-ov-title { font-family:var(--font-h); font-size:14px; font-weight:700; color:var(--white); }

/* ================================================
   CONTACT PAGE
   ================================================ */
.contact-sec { padding:80px 0; }
.contact-grid { display:grid; grid-template-columns:1fr 1.6fr; gap:52px; }
.ci-card { background:var(--gradient); border-radius:var(--r-l); padding:42px 32px; color:var(--white); position:relative; overflow:hidden; }
.ci-card::before { content:''; position:absolute; top:-40%; right:-20%; width:280px; height:280px; border-radius:50%; background:rgba(255,255,255,.07); }
.ci-card h2 { font-family:var(--font-h); font-size:24px; font-weight:800; margin-bottom:10px; position:relative; z-index:1; }
.ci-card > p { color:rgba(255,255,255,.84); font-size:13.5px; line-height:1.72; margin-bottom:30px; position:relative; z-index:1; }
.ci-items { display:flex; flex-direction:column; gap:18px; position:relative; z-index:1; }
.ci-item { display:flex; gap:13px; align-items:flex-start; }
.ci-ico { width:42px; height:42px; background:rgba(255,255,255,.16); border-radius:11px; display:flex; align-items:center; justify-content:center; font-size:17px; flex-shrink:0; }
.ci-lbl { font-size:10.5px; font-weight:700; text-transform:uppercase; letter-spacing:1px; opacity:.74; display:block; margin-bottom:2px; }
.ci-val { font-size:14.5px; font-weight:600; display:block; }
.ci-val a { color:var(--white); }
.ci-val a:hover { opacity:.8; }
.cf-card { background:var(--white); border-radius:var(--r-l); padding:42px 38px; box-shadow:var(--shadow-l); border:1px solid var(--border); }
.cf-card h2 { font-family:var(--font-h); font-size:24px; font-weight:800; color:var(--dark); margin-bottom:22px; }
.cf-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:16px; }
.cf-group { margin-bottom:16px; }
.cf-group label { display:block; font-size:11.5px; font-weight:600; color:var(--dark); margin-bottom:5px; text-transform:uppercase; letter-spacing:.5px; }
.cf-group input, .cf-group textarea, .cf-group select { width:100%; padding:12px 15px; border:2px solid var(--border); border-radius:var(--r-s); font-size:13.5px; color:var(--dark); outline:none; transition:var(--ease); background:var(--white); }
.cf-group input:focus, .cf-group textarea:focus, .cf-group select:focus { border-color:var(--orange); box-shadow:0 0 0 4px rgba(242,142,43,.09); }
.cf-group textarea { height:120px; resize:vertical; }

/* ================================================
   ABOUT PAGE — EXTRA
   ================================================ */
.about-page-grid { display:grid; grid-template-columns:1fr 1fr; gap:65px; align-items:center; }
.team-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:22px; }
.team-card { background:var(--white); border-radius:var(--r-m); padding:28px 20px; text-align:center; box-shadow:var(--shadow-s); transition:var(--ease); border:1px solid var(--border); }
.team-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-m); }
.team-av { width:70px; height:70px; border-radius:50%; background:var(--gradient); display:flex; align-items:center; justify-content:center; color:var(--white); font-family:var(--font-h); font-size:24px; font-weight:700; margin:0 auto 12px; }
.team-name { font-family:var(--font-h); font-size:15px; font-weight:700; color:var(--dark); margin-bottom:4px; }
.team-role { font-size:12.5px; color:var(--orange); font-weight:600; }
.values-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.val-card { background:var(--white); border-radius:var(--r-m); padding:26px 20px; box-shadow:var(--shadow-s); text-align:center; transition:var(--ease); }
.val-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-m); }
.val-ico { font-size:36px; margin-bottom:11px; display:block; }
.val-card h4 { font-family:var(--font-h); font-size:15px; font-weight:700; color:var(--dark); margin-bottom:7px; }
.val-card p { font-size:13px; color:var(--gray); line-height:1.65; }

/* ================================================
   TOAST POPUP NOTIFICATIONS
   ================================================ */
#toast-container {
  position: fixed;
  top: 24px;
  right: 24px;
  z-index: 99999;
  display: flex;
  flex-direction: column;
  gap: 12px;
  pointer-events: none;
  max-width: 380px;
  width: calc(100vw - 48px);
}
.toast {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 18px 20px 14px;
  background: #fff;
  border-radius: var(--r-m);
  box-shadow: 0 8px 40px rgba(0,0,0,.18), 0 2px 10px rgba(0,0,0,.10);
  pointer-events: all;
  position: relative;
  overflow: hidden;
  transform: translateX(120%);
  opacity: 0;
  transition: transform .42s cubic-bezier(.22,1,.36,1), opacity .42s ease;
  border-left: 4px solid var(--orange);
}
.toast.show { transform: translateX(0); opacity: 1; }
.toast.hide { transform: translateX(120%); opacity: 0; }
.toast.toast-error  { border-color: #e53e3e; }
.toast.toast-info   { border-color: #3182ce; }

.toast-icon {
  width: 38px; height: 38px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 18px;
  flex-shrink: 0;
  margin-top: 1px;
}
.toast-success .toast-icon { background: rgba(72,187,120,.15); }
.toast-error   .toast-icon { background: rgba(229,62,62,.12); }
.toast-info    .toast-icon { background: rgba(49,130,206,.12); }

.toast-body { flex: 1; min-width: 0; }
.toast-title {
  font-family: var(--font-h);
  font-size: 14.5px;
  font-weight: 700;
  color: var(--dark);
  margin-bottom: 4px;
  line-height: 1.3;
}
.toast-msg {
  font-size: 13px;
  color: var(--gray);
  line-height: 1.55;
  word-break: break-word;
}
.toast-ref {
  display: inline-block;
  margin-top: 6px;
  padding: 2px 9px;
  background: linear-gradient(135deg,rgba(242,142,43,.12),rgba(94,45,121,.12));
  border-radius: var(--r-xl);
  font-size: 11px;
  font-weight: 700;
  color: var(--orange);
  letter-spacing: .5px;
}
.toast-close {
  background: none;
  border: none;
  color: var(--gray2);
  font-size: 17px;
  line-height: 1;
  cursor: pointer;
  padding: 0 0 0 8px;
  flex-shrink: 0;
  transition: color .2s;
  margin-top: -2px;
}
.toast-close:hover { color: var(--dark); }
.toast-progress {
  position: absolute;
  bottom: 0; left: 0;
  height: 3px;
  background: var(--gradient);
  border-radius: 0 0 0 var(--r-m);
  animation: toastProg linear forwards;
}
.toast-error .toast-progress   { background: #e53e3e; }
.toast-info  .toast-progress   { background: #3182ce; }
@keyframes toastProg { from { width: 100%; } to { width: 0%; } }

/* ================================================
   ANIMATE ON SCROLL
   ================================================ */
.aos { opacity:0; transform:translateY(28px); transition:opacity .65s cubic-bezier(.4,0,.2,1), transform .65s cubic-bezier(.4,0,.2,1); }
.aos.done { opacity:1; transform:translateY(0); }
.aos.d1 { transition-delay:.1s; }
.aos.d2 { transition-delay:.2s; }
.aos.d3 { transition-delay:.3s; }
.aos.d4 { transition-delay:.4s; }
.aos.d5 { transition-delay:.5s; }
.aos.d6 { transition-delay:.6s; }

/* ================================================
   GLOSSY / MISC
   ================================================ */
.glass { background:rgba(255,255,255,.12); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); border:1px solid rgba(255,255,255,.2); }
.grad-text { background:var(--gradient); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.tag { display:inline-block; padding:3px 10px; background:linear-gradient(135deg,rgba(242,142,43,.12),rgba(94,45,121,.12)); border-radius:var(--r-xl); font-size:11.5px; font-weight:600; color:var(--orange); }

/* ================================================
   RESPONSIVE — TABLET
   ================================================ */
@media (max-width:1080px) {
  .spec-grid { grid-template-columns:repeat(2,1fr); }
  .why-grid  { grid-template-columns:1fr 1fr; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:32px; }
  .svc-grid { grid-template-columns:1fr; }
  .svc-sidebar { position:static; }
  .contact-grid { grid-template-columns:1fr; }
  .success-grid { grid-template-columns:1fr; gap:38px; }
  .about-grid { grid-template-columns:1fr; gap:30px; }
  .about-page-grid { grid-template-columns:1fr; gap:30px; }
  .hl-grid { grid-template-columns:repeat(3,1fr); }
  .values-grid { grid-template-columns:1fr 1fr; }
}

/* ================================================
   RESPONSIVE — MOBILE
   ================================================ */
@media (max-width:768px) {
  .hero-slider { height:100vw; min-height:320px; max-height:520px; }
  .slide-content { padding:0 22px; }
  .nav-menu, .nav-cta { display:none; }
  .hamburger { display:flex; }
  .top-bar-right { display:none; }
  .top-bar-contacts a:nth-child(3) { display:none; }
  .top-bar-inner { flex-wrap:nowrap; justify-content:center; }
  .top-bar-contacts { flex-wrap:nowrap; justify-content:center; gap:8px; }
  .qf-inner { grid-template-columns:1fr; gap:18px; }
  .qf-form { flex-direction:column; }
  .qf-form .f-wrap { min-width:unset; }
  .section { padding:60px 0; }
  .about-content { padding-left:0; }
  .about-features { grid-template-columns:1fr 1fr; gap:10px; }
  .about-nums { grid-template-columns:repeat(3,1fr); gap:12px; }
  .about-float { bottom:-14px; right:-10px; }
  .about-btns { flex-direction:column; }
  .about-btns .btn { text-align:center; justify-content:center; }
  .why-grid { grid-template-columns:1fr; }
  .reviews-grid { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr; gap:26px; }
  .gal-grid { grid-template-columns:repeat(2,1fr); }
  .cf-row { grid-template-columns:1fr; }
  .stats-grid { grid-template-columns:1fr 1fr; }
  .hl-grid { grid-template-columns:repeat(2,1fr); }
  .hl-item { border-right:none; border-bottom:1px solid rgba(255,255,255,.12); }
  .cta-btns { flex-direction:column; align-items:center; }
  .hero-prev { left:8px; } .hero-next { right:8px; }
  .hero-prev, .hero-next { width:38px; height:38px; font-size:14px; }
  .about-img-main img { height:280px; }
  .team-grid { grid-template-columns:1fr 1fr; }
}
@media (max-width:768px) {
  #toast-container { top:14px; right:12px; left:12px; width:auto; max-width:none; }
  .toast { padding:14px 14px 12px; gap:10px; }
  .toast-icon { width:32px; height:32px; font-size:15px; }
  .toast-title { font-size:13.5px; }
  .toast-msg { font-size:12.5px; }
}

@media (max-width:520px) {
  .spec-grid { grid-template-columns:1fr; }
  .hl-grid { grid-template-columns:1fr; }
  .gal-grid { grid-template-columns:1fr; }
  .stats-grid { grid-template-columns:1fr; }
  .about-nums { grid-template-columns:repeat(3,1fr); gap:8px; }
  .about-nums .astat .n { font-size:22px; }
  .about-nums .astat .l { font-size:10.5px; }
  .about-features { grid-template-columns:1fr 1fr; gap:8px; }
  .af { font-size:12.5px; gap:7px; }
  .team-grid { grid-template-columns:1fr; }
  .values-grid { grid-template-columns:1fr; }
  .top-bar-contacts a { font-size:11.5px; padding:3px 10px; }
  .slide-btns { gap:10px; }
  .slide-btns .btn-primary,
  .slide-btns .btn-outline { padding:10px 18px; font-size:13px; }
}

@media (max-width:380px) {
  .slide-btns { flex-wrap:wrap; gap:8px; }
}
