﻿/*
 * ================================================================
 *  HRID RAKSHA â€” Complete Website Stylesheet
 *  Cardiac Emergency Response | Bengaluru
 *  "Cuz every beat matters!"
 * ================================================================
 */

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

/* ================================================================
   1. ROOT VARIABLES
   ================================================================ */
:root {
  --clr-primary:       #800f2f;
  --clr-primary-hover: #6b0d28;
  --clr-primary-light: #fce8ed;
  --clr-accent:        #800f2f;
  --clr-gold:          #F59E0B;
  --clr-green:         #10B981;
  --clr-dark:          #1a0a10;
  --clr-dark-2:        #2d1218;
  --clr-dark-3:        #4a1f28;
  --clr-gray:          #64748B;
  --clr-gray-light:    #CBD5E1;
  --clr-border:        #E2E8F0;
  --clr-white:         #FFFFFF;
  --clr-off-white:     #fff5f7;
  --clr-light-red:     #fce8ed;

  --gradient-primary:  linear-gradient(135deg, #800f2f 0%, #9e1239 50%, #800f2f 100%);
  --gradient-dark:     linear-gradient(160deg, #800f2f 0%, #6b0d28 100%);
  --gradient-hero:     linear-gradient(135deg, rgba(128,15,47,0.96) 0%, rgba(128,15,47,0.8) 100%);

  --font-heading: 'Poppins', sans-serif;
  --font-body:    'Inter', sans-serif;

  --section-pad:     100px 0;
  --container-max:   1280px;
  --container-pad:   0 40px;

  --shadow-sm:   0 2px 8px rgba(0,0,0,0.08);
  --shadow-md:   0 8px 24px rgba(0,0,0,0.12);
  --shadow-lg:   0 20px 60px rgba(0,0,0,0.15);
  --shadow-red:  0 8px 30px rgba(128,15,47,0.3);
  --shadow-redl: 0 20px 60px rgba(128,15,47,0.25);

  --radius-sm:   8px;
  --radius-md:   16px;
  --radius-lg:   24px;
  --radius-xl:   32px;
  --radius-full: 9999px;

  --transition:       all 0.3s cubic-bezier(0.4,0,0.2,1);
  --transition-slow:  all 0.6s cubic-bezier(0.4,0,0.2,1);

  --z-nav:    100;
  --z-modal:  200;
}

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

/* ================================================================
   3. TYPOGRAPHY
   ================================================================ */
h1, h2, h3, h4, h5, h6 { font-family: var(--font-heading); line-height: 1.2; font-weight: 700; }
h1 { font-size: clamp(2.4rem, 5vw, 4.5rem); }
h2 { font-size: clamp(1.9rem, 4vw, 3rem); }
h3 { font-size: clamp(1.3rem, 2.5vw, 1.75rem); }
h4 { font-size: clamp(1.05rem, 2vw, 1.3rem); }
p  { font-size: 1rem; line-height: 1.85; color: var(--clr-gray); }

.text-gradient {
  background: var(--gradient-primary);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.text-white   { color: var(--clr-white) !important; }
.text-primary { color: var(--clr-primary) !important; }
.text-dark    { color: var(--clr-dark) !important; }

.tag {
  display: inline-block;
  background: var(--clr-light-red);
  color: var(--clr-primary);
  font-family: var(--font-heading);
  font-size: 0.78rem; font-weight: 600;
  letter-spacing: 2px; text-transform: uppercase;
  padding: 6px 16px; border-radius: var(--radius-full);
  border: 1px solid rgba(128,15,47,0.2);
  margin-bottom: 16px;
}
.tag.white {
  background: rgba(255,255,255,0.12);
  color: var(--clr-white);
  border-color: rgba(255,255,255,0.3);
}

/* ================================================================
   4. LAYOUT
   ================================================================ */
.container {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: var(--container-pad);
}
.section       { padding: var(--section-pad); }
.section-alt   { padding: var(--section-pad); background: var(--clr-off-white); }
.section-dark  { padding: var(--section-pad); background: var(--gradient-dark); }
.section-red   { padding: var(--section-pad); background: var(--gradient-primary); }

.section-header{ text-align: center; max-width: 700px; margin: 0 auto 64px; }
.section-header h2 { margin-bottom: 16px; }
.section-header p  { font-size: 1.05rem; }

.grid-2 { display: grid; grid-template-columns: repeat(2,1fr); gap: 48px; align-items: center; }
.grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 28px; }
.grid-4 { display: grid; grid-template-columns: repeat(4,1fr); gap: 24px; }
.flex-center   { display: flex; align-items: center; justify-content: center; }
.flex-between  { display: flex; align-items: center; justify-content: space-between; }

/* ================================================================
   5. BUTTONS
   ================================================================ */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 14px 32px; border-radius: var(--radius-full);
  font-family: var(--font-heading); font-size: 0.95rem; font-weight: 600;
  letter-spacing: 0.3px; transition: var(--transition);
}
.btn-primary {
  background: var(--gradient-primary); color: var(--clr-white);
  box-shadow: var(--shadow-red);
}
.btn-primary:hover { transform: translateY(-3px); box-shadow: var(--shadow-redl); }
.btn-outline {
  background: transparent; color: var(--clr-white);
  border: 2px solid rgba(255,255,255,0.7); padding: 12px 30px;
}
.btn-outline:hover { background: var(--clr-white); color: var(--clr-primary); }
.btn-outline-dark {
  background: transparent; color: var(--clr-primary);
  border: 2px solid var(--clr-primary); padding: 12px 30px;
}
.btn-outline-dark:hover { background: var(--clr-primary); color: var(--clr-white); }
.btn-white {
  background: var(--clr-white); color: var(--clr-primary); box-shadow: var(--shadow-md);
}
.btn-white:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }
.btn-lg { padding: 18px 44px; font-size: 1.05rem; }

/* ================================================================
   6. NAVBAR
   ================================================================ */
.navbar {
  position: fixed; top: 56px; left: 0; right: 0; z-index: var(--z-nav);
  padding: 14px 0; transition: var(--transition-slow);
}
.navbar.scrolled {
  background: rgba(255,255,255,0.97);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  padding: 14px 0; box-shadow: 0 4px 20px rgba(128,15,47,0.12);
}
.navbar.scrolled .nav-link { color: rgba(128,15,47,0.75); }
.navbar.scrolled .nav-link:hover,
.navbar.scrolled .nav-link.active { color: var(--clr-primary); background: rgba(128,15,47,0.07); }
.navbar.scrolled .logo-name { color: var(--clr-primary); }
.navbar.scrolled .logo-tagline { color: rgba(128,15,47,0.55); }
.navbar.scrolled .phone-link { color: rgba(128,15,47,0.7); }
.navbar.scrolled .hamburger span { background: var(--clr-primary); }
.navbar .container { display: flex; align-items: center; justify-content: space-between; gap: 24px; }

.navbar-logo { display: flex; align-items: center; gap: 12px; }
.logo-icon {
  width: 46px; height: 46px;
  background: var(--gradient-primary); border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 0 20px rgba(128,15,47,0.45); flex-shrink: 0;
}
.logo-icon svg { width: 22px; height: 22px; fill: #fff; }
.logo-text { display: flex; flex-direction: column; }
.logo-name { font-family: var(--font-heading); font-size: 1.25rem; font-weight: 800; color: var(--clr-white); line-height: 1; }
.logo-tagline { font-size: 0.62rem; color: rgba(255,255,255,0.55); letter-spacing: 1.2px; text-transform: uppercase; margin-top: 2px; }

.navbar-menu { display: flex; align-items: center; gap: 0; }
.nav-link {
  font-family: var(--font-heading); font-size: 0.85rem; font-weight: 500;
  color: rgba(255,255,255,0.82); padding: 8px 10px; border-radius: var(--radius-sm);
  transition: var(--transition); white-space: nowrap;
}
.nav-link:hover, .nav-link.active { color: var(--clr-white); background: rgba(255,255,255,0.1); }

.navbar-cta { display: flex; align-items: center; gap: 12px; }
.phone-link {
  font-family: var(--font-heading); font-size: 0.83rem; font-weight: 600;
  color: rgba(255,255,255,0.7); display: flex; align-items: center; gap: 6px;
}
.phone-link:hover { color: var(--clr-white); }

.hamburger { display: none; flex-direction: column; gap: 5px; cursor: pointer; padding: 6px; }
.hamburger span { display: block; width: 24px; height: 2px; background: #fff; border-radius: 2px; transition: var(--transition); }
.hamburger.open span:nth-child(1) { transform: rotate(45deg) translate(5px,5px); }
.hamburger.open span:nth-child(2) { opacity: 0; }
.hamburger.open span:nth-child(3) { transform: rotate(-45deg) translate(5px,-5px); }

/* ================================================================
   6b. COURSES MEGA-DROPDOWN
   ================================================================ */
.has-dropdown { position: relative; }
.dropdown-chevron { font-size: 0.6rem; margin-left: 3px; display: inline-block; transition: transform 0.25s ease; }
.has-dropdown:hover .dropdown-chevron,
.has-dropdown.open   .dropdown-chevron { transform: rotate(180deg); }

.nav-dropdown {
  position: absolute; top: calc(100% + 14px); left: 50%;
  transform: translateX(-50%) translateY(8px);
  background: #fff; border-radius: var(--radius-lg);
  box-shadow: 0 24px 64px rgba(0,0,0,0.14), 0 4px 16px rgba(128,15,47,0.1);
  border: 1px solid var(--clr-border);
  display: flex; min-width: 540px;
  opacity: 0; pointer-events: none;
  transition: opacity 0.22s ease, transform 0.22s ease;
  z-index: 300;
}
.has-dropdown:hover .nav-dropdown,
.has-dropdown.open   .nav-dropdown {
  opacity: 1; pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}
.nav-dropdown-col {
  flex: 1; padding: 16px 12px;
  display: flex; flex-direction: column; gap: 2px;
}
.nav-dropdown-col:first-child { border-right: 1px solid var(--clr-border); }

.dropdown-link {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px; border-radius: var(--radius-sm);
  font-family: var(--font-heading); font-size: 0.84rem; font-weight: 500;
  color: var(--clr-dark-3); transition: var(--transition); white-space: nowrap;
}
.dropdown-link i { width: 16px; text-align: center; color: var(--clr-primary); font-size: 0.8rem; flex-shrink: 0; }
.dropdown-link:hover { background: var(--clr-light-red); color: var(--clr-primary); }
.dropdown-link.dropdown-all {
  margin-top: 6px; padding-top: 12px; font-weight: 600; color: var(--clr-primary);
  border-top: 1px solid var(--clr-border);
}
.dropdown-link.dropdown-all:hover { background: var(--gradient-primary); color: #fff; }
.dropdown-link.dropdown-all:hover i { color: #fff; }

/* scrolled-state dropdown text remains readable */
.navbar.scrolled .dropdown-toggle { color: rgba(128,15,47,0.75); }
.navbar.scrolled .has-dropdown:hover .dropdown-toggle,
.navbar.scrolled .has-dropdown.open  .dropdown-toggle { color: var(--clr-primary); background: rgba(128,15,47,0.07); }

/* ================================================================
   7. EMERGENCY BANNER
   ================================================================ */
.emergency-banner { background: var(--clr-primary); padding: 12px 0; position: fixed; top: 0; left: 0; right: 0; z-index: 201; transition: opacity 0.3s ease; }
.emergency-content { display: flex; align-items: center; justify-content: center; gap: 20px; flex-wrap: wrap; }
.emergency-text { font-family: var(--font-heading); font-size: 0.88rem; font-weight: 600; color: rgba(255,255,255,0.95); display: flex; align-items: center; gap: 6px; }
.emergency-phone {
  font-family: var(--font-heading); font-size: 0.9rem; font-weight: 700;
  color: #fff; border: 1px solid rgba(255,255,255,0.45); padding: 5px 14px;
  border-radius: var(--radius-full); display: flex; align-items: center; gap: 5px; transition: var(--transition);
}
.emergency-phone:hover { background: rgba(255,255,255,0.18); }

/* ================================================================
   8. HERO
   ================================================================ */
.hero {
  min-height: 100vh; background: var(--gradient-dark);
  position: relative; overflow: hidden; display: flex; align-items: center;
}
.hero-bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 70% 60% at 75% 50%, rgba(128,15,47,0.18) 0%, transparent 70%),
    radial-gradient(ellipse 40% 50% at 15% 80%, rgba(128,15,47,0.08) 0%, transparent 60%);
}
.hero-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size: 64px 64px;
}
.hero .container {
  position: relative; z-index: 2;
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 80px; align-items: center;
  padding-top: 130px; padding-bottom: 80px;
}
.hero-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(128,15,47,0.14); border: 1px solid rgba(128,15,47,0.32);
  border-radius: var(--radius-full); padding: 7px 16px; margin-bottom: 28px;
}
.hero-badge span { font-family: var(--font-heading); font-size: 0.78rem; font-weight: 600; color: #fce8ed; letter-spacing: 1px; text-transform: uppercase; }
.pulse-dot { width: 8px; height: 8px; background: #fce8ed; border-radius: 50%; animation: pulse-dot 2s infinite; }
@keyframes pulse-dot { 0%,100%{transform:scale(1);opacity:1} 50%{transform:scale(1.6);opacity:0.65} }

.hero-title { font-size: clamp(2.6rem, 4.5vw, 4.8rem); font-weight: 900; line-height: 1.05; color: #fff; margin-bottom: 24px; }
.hero-title .highlight { background: var(--gradient-primary); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.hero-desc { font-size: 1.08rem; color: rgba(255,255,255,0.68); line-height: 1.82; margin-bottom: 40px; max-width: 520px; }
.hero-actions { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; margin-bottom: 56px; }

.hero-stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; padding-top: 40px; border-top: 1px solid rgba(255,255,255,0.1); }
.hero-stat { text-align: center; }
.hero-stat-num { font-family: var(--font-heading); font-size: 2rem; font-weight: 800; color: #fff; line-height: 1; margin-bottom: 4px; }
.hero-stat-num em { color: #fce8ed; font-style: normal; }
.hero-stat-lbl { font-size: 0.75rem; color: rgba(255,255,255,0.48); letter-spacing: 0.5px; line-height: 1.4; }

/* Hero Visual */
.hero-visual { position: relative; display: flex; align-items: center; justify-content: center; }
.hero-circle { position: relative; width: 480px; height: 480px; }
.circle-ring {
  position: absolute; border-radius: 50%;
  border: 1px solid rgba(128,15,47,0.22); inset: 0;
  animation: spin-ring 22s linear infinite;
}
.circle-ring.r2 { inset: 50px; border-color: rgba(128,15,47,0.3); animation-duration: 16s; animation-direction: reverse; }
.circle-ring.r3 { inset: 100px; border-color: rgba(128,15,47,0.15); animation-duration: 30s; }
.circle-core {
  position: absolute; inset: 130px; border-radius: 50%;
  background: radial-gradient(circle, rgba(128,15,47,0.28) 0%, rgba(128,15,47,0.04) 70%);
  display: flex; align-items: center; justify-content: center;
  animation: core-glow 1.5s ease-in-out infinite;
}
@keyframes spin-ring { to { transform: rotate(360deg); } }
@keyframes core-glow { 0%,100%{box-shadow:0 0 30px rgba(128,15,47,0.15)} 50%{box-shadow:0 0 80px rgba(128,15,47,0.4)} }

.heart-large { font-size: 80px; animation: heartbeat 1.4s ease-in-out infinite; color: #ff3040; }
@keyframes heartbeat {
  0%,100%{transform:scale(1)}
  14%{transform:scale(1.18)}
  28%{transform:scale(1)}
  42%{transform:scale(1.1)}
  56%{transform:scale(1)}
}

/* ECG line at bottom of hero visual */
.ecg-wrap { position: absolute; bottom: 40px; left: 10px; right: 10px; }
.ecg-svg { width: 100%; height: 56px; overflow: visible; }
.ecg-path {
  fill: none; stroke: #800f2f; stroke-width: 2.2;
  stroke-dasharray: 900; stroke-dashoffset: 900;
  animation: draw-ecg 2.8s ease-in-out infinite;
  filter: drop-shadow(0 0 6px rgba(255,82,82,0.6));
}
@keyframes draw-ecg {
  0%{stroke-dashoffset:900;opacity:1}
  70%{stroke-dashoffset:0;opacity:1}
  85%,100%{stroke-dashoffset:0;opacity:0}
}

/* Floating info cards */
.float-card {
  position: absolute;
  background: rgba(255,255,255,0.07);
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(255,255,255,0.14); border-radius: var(--radius-md);
  padding: 14px 18px; display: flex; align-items: center; gap: 12px;
}
.float-card.fc1 { top: 40px; right: 10px; animation: float 4s ease-in-out infinite; }
.float-card.fc2 { bottom: 110px; left: 10px; animation: float 4s ease-in-out infinite 2s; }
@keyframes float { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-12px)} }
.fc-icon { width: 38px; height: 38px; background: var(--gradient-primary); border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 16px; flex-shrink: 0; }
.fc-val { font-family: var(--font-heading); font-size: 1.15rem; font-weight: 700; color: #fff; line-height:1; }
.fc-lbl { font-size: 0.68rem; color: rgba(255,255,255,0.55); margin-top:2px; }

/* ================================================================
   9. STATS SECTION
   ================================================================ */
.stats-section { background: var(--gradient-dark); padding: 80px 0; }
.stats-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 1px; background: rgba(255,255,255,0.08); border-radius: var(--radius-xl); overflow: hidden; }
.stat-card {
  background: rgba(255,255,255,0.08); padding: 48px 28px; text-align: center;
  position: relative; transition: var(--transition);
}
.stat-card:hover { background: rgba(255,255,255,0.16); }
.stat-card::after { content:''; position:absolute; top:0; left:50%; transform:translateX(-50%); width:48px; height:3px; background:var(--gradient-primary); opacity:0; transition:var(--transition); }
.stat-card:hover::after { opacity:1; }
.stat-ico { width:54px; height:54px; background:rgba(128,15,47,0.14); border-radius:var(--radius-md); display:flex; align-items:center; justify-content:center; margin:0 auto 16px; font-size:22px; transition:var(--transition); }
.stat-card:hover .stat-ico { background:var(--gradient-primary); box-shadow:var(--shadow-red); }
.stat-num { font-family:var(--font-heading); font-size:2.8rem; font-weight:900; color:#fff; line-height:1; margin-bottom:8px; }
.stat-num .unit { font-size:1.4rem; color:#fce8ed; }
.stat-lbl { font-size:0.83rem; color:rgba(255,255,255,0.55); line-height:1.5; }
.stat-src { font-size:0.68rem; color:rgba(255,255,255,0.45); margin-top:6px; font-style:italic; }

/* ================================================================
   10. SERVICE CARDS
   ================================================================ */
.service-card {
  background: var(--clr-white); border-radius: var(--radius-lg);
  padding: 40px 30px; border: 1px solid var(--clr-border);
  transition: var(--transition); position: relative; overflow: hidden;
}
.service-card::before { content:''; position:absolute; top:0; left:0; right:0; height:4px; background:var(--gradient-primary); transform:scaleX(0); transform-origin:left; transition:transform 0.4s ease; }
.service-card:hover { transform:translateY(-8px); box-shadow:var(--shadow-red); border-color:transparent; }
.service-card:hover::before { transform:scaleX(1); }
.svc-icon { width:70px; height:70px; background:var(--clr-light-red); border-radius:var(--radius-md); display:flex; align-items:center; justify-content:center; font-size:30px; margin-bottom:24px; transition:var(--transition); }
.service-card:hover .svc-icon { background:var(--gradient-primary); box-shadow:var(--shadow-red); }
.service-card h3 { color:var(--clr-dark); margin-bottom:12px; font-size:1.2rem; }
.service-card p { font-size:0.93rem; line-height:1.75; margin-bottom:24px; }
.svc-link { display:inline-flex; align-items:center; gap:6px; color:var(--clr-primary); font-family:var(--font-heading); font-size:0.88rem; font-weight:600; transition:var(--transition); }
.svc-link:hover { gap:10px; }

/* ================================================================
   11. WHY CHOOSE US
   ================================================================ */
.feature-list { display:flex; flex-direction:column; gap:24px; }
.feature-item { display:flex; gap:18px; align-items:flex-start; }
.feat-icon { width:50px; height:50px; border-radius:var(--radius-md); background:var(--gradient-primary); display:flex; align-items:center; justify-content:center; font-size:20px; flex-shrink:0; color:#fff; box-shadow:var(--shadow-red); }
.feat-content h4 { color:var(--clr-dark); margin-bottom:5px; font-size:1rem; }
.feat-content p { font-size:0.9rem; margin:0; }

.why-visual-box {
  background: var(--gradient-dark); border-radius: var(--radius-xl);
  padding: 48px 40px; position: relative; overflow: hidden;
}
.why-visual-box::before { content:''; position:absolute; top:-40%; right:-15%; width:280px; height:280px; background:radial-gradient(circle, rgba(128,15,47,0.28) 0%, transparent 70%); border-radius:50%; }
.cert-item { display:flex; align-items:center; gap:14px; padding:18px 20px; background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.08); border-radius:var(--radius-md); margin-bottom:16px; transition:var(--transition); }
.cert-item:hover { background:rgba(128,15,47,0.12); border-color:rgba(128,15,47,0.3); }
.cert-ico { width:46px; height:46px; background:var(--gradient-primary); border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:20px; flex-shrink:0; }
.cert-title { font-family:var(--font-heading); font-size:0.9rem; font-weight:600; color:#fff; }
.cert-sub { font-size:0.75rem; color:rgba(255,255,255,0.48); margin-top:2px; }

/* ================================================================
   12. PROCESS STEPS
   ================================================================ */
.process-track { display:grid; grid-template-columns:repeat(4,1fr); gap:32px; position:relative; margin-top:60px; }
.process-track::before { content:''; position:absolute; top:36px; left:calc(12.5% + 18px); right:calc(12.5% + 18px); height:2px; background:linear-gradient(90deg, var(--clr-primary), #cc4a6b); }
.process-step { text-align:center; position:relative; }
.step-num { width:72px; height:72px; background:var(--gradient-primary); border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:var(--font-heading); font-size:1.5rem; font-weight:800; color:#fff; margin:0 auto 20px; box-shadow:var(--shadow-red); position:relative; z-index:1; }
.process-step h4 { color:var(--clr-dark); margin-bottom:8px; font-size:0.98rem; }
.process-step p { font-size:0.86rem; line-height:1.6; }

/* ================================================================
   13. TESTIMONIALS
   ================================================================ */
.testi-card {
  background: var(--clr-white); border-radius: var(--radius-lg);
  padding: 36px 30px; border: 1px solid var(--clr-border);
  transition: var(--transition); position: relative;
}
.testi-card:hover { box-shadow:var(--shadow-md); transform:translateY(-5px); }
.quote-mark { font-size:64px; line-height:1; color:var(--clr-primary); opacity:0.12; font-family:Georgia,serif; position:absolute; top:14px; right:22px; }
.stars { color:var(--clr-gold); font-size:0.88rem; letter-spacing:2px; margin-bottom:14px; }
.testi-text { font-size:0.93rem; line-height:1.82; color:var(--clr-dark-3); margin-bottom:24px; font-style:italic; }
.testi-author { display:flex; align-items:center; gap:14px; }
.t-avatar { width:46px; height:46px; border-radius:50%; background:var(--gradient-primary); display:flex; align-items:center; justify-content:center; font-family:var(--font-heading); font-size:1rem; font-weight:700; color:#fff; flex-shrink:0; }
.t-name { font-family:var(--font-heading); font-weight:600; color:var(--clr-dark); font-size:0.93rem; }
.t-role { font-size:0.78rem; color:var(--clr-gray); }

/* ================================================================
   14. CTA SECTION
   ================================================================ */
.cta-section { padding: 100px 0; background:var(--gradient-primary); position:relative; overflow:hidden; }
.cta-section::before { content:''; position:absolute; inset:0; background: radial-gradient(circle at 20% 50%, rgba(255,255,255,0.06) 0%, transparent 50%), radial-gradient(circle at 80% 50%, rgba(0,0,0,0.08) 0%, transparent 50%); }
.cta-inner { position:relative; z-index:2; text-align:center; max-width:740px; margin:0 auto; }
.cta-inner h2 { color:#fff; font-size:clamp(1.9rem,4vw,3rem); margin-bottom:18px; }
.cta-inner p { color:rgba(255,255,255,0.85); font-size:1.08rem; margin-bottom:40px; }
.cta-btns { display:flex; align-items:center; justify-content:center; gap:16px; flex-wrap:wrap; }

/* ================================================================
   15. CLIENTS
   ================================================================ */
.clients-grid { display:flex; flex-wrap:wrap; gap:14px; justify-content:center; align-items:center; }
.client-pill {
  background: var(--clr-white); border:1px solid var(--clr-border);
  border-radius: var(--radius-md); padding:18px 28px;
  font-family: var(--font-heading); font-size:0.92rem; font-weight:600; color:var(--clr-gray);
  transition: var(--transition); min-width:150px; text-align:center;
}
.client-pill:hover { border-color:var(--clr-primary); color:var(--clr-primary); box-shadow:var(--shadow-sm); transform:translateY(-2px); }

/* ================================================================
   16. PAGE HERO (inner pages)
   ================================================================ */
.page-hero {
  min-height: 55vh; background: var(--gradient-dark);
  display: flex; align-items: center; padding-top: 150px;
  position: relative; overflow: hidden;
}
.page-hero::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 70% 50%, rgba(128,15,47,0.2) 0%, transparent 60%); }
.page-hero .container { position:relative; z-index:2; text-align:left; padding-bottom:60px; }
.page-hero h1 { color:#fff; margin-bottom:18px; max-width:680px; }
.page-hero p { color:rgba(255,255,255,0.7); font-size:1.1rem; max-width:620px; }
.breadcrumb { display:flex; align-items:center; gap:8px; margin-bottom:20px; flex-wrap:wrap; }
.breadcrumb a { font-size:0.82rem; color:rgba(255,255,255,0.5); }
.breadcrumb a:hover { color:#fff; }
.breadcrumb .sep { font-size:0.82rem; color:rgba(255,255,255,0.28); }
.breadcrumb .cur { font-size:0.82rem; color:#cc4a6b; }

/* ================================================================
   17. MISSION / VALUES
   ================================================================ */
.mission-card { background:var(--clr-white); border-radius:var(--radius-lg); padding:44px 36px; border:1px solid var(--clr-border); position:relative; overflow:hidden; }
.mission-card::after { content:''; position:absolute; bottom:0; left:0; right:0; height:4px; background:var(--gradient-primary); }
.mission-card h3 { color:var(--clr-dark); margin-bottom:14px; display:flex; align-items:center; gap:10px; }
.prob-stat { background:rgba(128,15,47,0.07); border:1px solid rgba(128,15,47,0.18); border-radius:var(--radius-md); padding:28px 20px; text-align:center; }
.prob-stat .ps-num { font-family:var(--font-heading); font-size:2.4rem; font-weight:900; color:var(--clr-primary); display:block; line-height:1; margin-bottom:8px; }
.prob-stat .ps-lbl { font-size:0.86rem; color:var(--clr-dark-3); line-height:1.5; }
.value-item { display:flex; gap:18px; padding:28px; border-radius:var(--radius-md); background:var(--clr-off-white); border:1px solid var(--clr-border); transition:var(--transition); }
.value-item:hover { border-color:var(--clr-primary); box-shadow:var(--shadow-sm); }
.val-ico { width:52px; height:52px; background:var(--gradient-primary); border-radius:var(--radius-sm); display:flex; align-items:center; justify-content:center; font-size:22px; flex-shrink:0; color:var(--clr-white); }
.val-content h4 { color:var(--clr-dark); margin-bottom:6px; }
.val-content p { font-size:0.88rem; margin:0; }

/* ================================================================
   18. CONTACT
   ================================================================ */
.contact-box { background:var(--clr-white); border-radius:var(--radius-lg); padding:44px 36px; border:1px solid var(--clr-border); height:100%; }
.ci-item { display:flex; gap:18px; margin-bottom:30px; }
.ci-icon { width:50px; height:50px; background:var(--clr-light-red); border-radius:var(--radius-md); display:flex; align-items:center; justify-content:center; font-size:20px; flex-shrink:0; transition:var(--transition); }
.ci-item:hover .ci-icon { background:var(--gradient-primary); }
.ci-text h4 { color:var(--clr-dark); margin-bottom:4px; font-size:0.97rem; }
.ci-text p, .ci-text a { font-size:0.92rem; color:var(--clr-gray); }
.ci-text a:hover { color:var(--clr-primary); }

.form-group { margin-bottom:22px; }
.form-group label { display:block; font-family:var(--font-heading); font-size:0.86rem; font-weight:600; color:var(--clr-dark); margin-bottom:7px; }
.form-group input,
.form-group textarea,
.form-group select { width:100%; padding:13px 16px; border:2px solid var(--clr-border); border-radius:var(--radius-sm); font-size:0.94rem; color:var(--clr-dark); background:var(--clr-off-white); transition:var(--transition); }
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus { border-color:var(--clr-primary); background:#fff; box-shadow:0 0 0 4px rgba(128,15,47,0.1); }
.form-group textarea { height:140px; resize:vertical; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.form-error { display:block; font-size:0.8rem; color:#C62828; margin-top:5px; }

/* Contact quick-action cards */
.contact-quick-card {
  border-radius:var(--radius-lg); padding:40px 28px; text-align:center;
  display:block; transition:var(--transition);
}
.contact-quick-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-redl); }
.contact-quick-card-primary { background:var(--gradient-primary); }
.contact-quick-card-dark    { background:var(--gradient-dark); }
.contact-quick-card-neutral { background:var(--clr-off-white); border:1px solid var(--clr-border); }

/* ================================================================
   19. BLOG CARDS
   ================================================================ */
.blog-card { background:var(--clr-white); border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--clr-border); transition:var(--transition); }
.blog-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-md); border-color:transparent; }
.blog-thumb { height:210px; display:flex; align-items:center; justify-content:center; font-size:56px; }
.blog-thumb.t1{background:linear-gradient(135deg,#800f2f,#9e1239)}
.blog-thumb.t2{background:linear-gradient(135deg,#800f2f,#6b0d28)}
.blog-thumb.t3{background:linear-gradient(135deg,#6b0d28,#800f2f)}
.blog-thumb.t4{background:linear-gradient(135deg,#800f2f,#9e1239)}
.blog-thumb.t5{background:linear-gradient(135deg,#4a0920,#800f2f)}
.blog-thumb.t6{background:linear-gradient(135deg,#800f2f,#4a0920)}
.blog-body { padding:26px; }
.blog-cat { display:inline-block; background:var(--clr-light-red); color:var(--clr-primary); font-family:var(--font-heading); font-size:0.72rem; font-weight:600; padding:4px 11px; border-radius:var(--radius-full); letter-spacing:0.5px; text-transform:uppercase; margin-bottom:11px; }
.blog-card h3 { color:var(--clr-dark); font-size:1.05rem; margin-bottom:10px; line-height:1.4; }
.blog-card p { font-size:0.88rem; margin-bottom:18px; }
.blog-meta { display:flex; align-items:center; gap:14px; font-size:0.78rem; color:var(--clr-gray); }

/* ================================================================
   20. FAQ ACCORDION
   ================================================================ */
.faq-item { border:1px solid var(--clr-border); border-radius:var(--radius-md); overflow:hidden; margin-bottom:14px; transition:var(--transition); }
.faq-item:hover { border-color:var(--clr-primary); }
.faq-q { padding:18px 22px; display:flex; justify-content:space-between; align-items:center; cursor:pointer; background:#fff; transition:var(--transition); }
.faq-q:hover { background:var(--clr-light-red); }
.faq-q h4 { font-size:0.97rem; color:var(--clr-dark); flex:1; padding-right:14px; }
.faq-toggle { width:30px; height:30px; background:var(--clr-light-red); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:16px; color:var(--clr-primary); flex-shrink:0; transition:var(--transition); font-weight:700; }
.faq-item.open .faq-toggle { background:var(--gradient-primary); color:#fff; transform:rotate(45deg); }
.faq-a { max-height:0; overflow:hidden; transition:max-height 0.4s ease, padding 0.3s ease; background:var(--clr-off-white); }
.faq-a.open { max-height:600px; padding:18px 22px; }
.faq-a p { font-size:0.91rem; margin:0; line-height:1.8; }

/* ================================================================
   21. PRICING CARDS
   ================================================================ */
.pricing-card {
  background:var(--clr-white); border-radius:var(--radius-xl);
  padding:44px 32px; border:2px solid var(--clr-border);
  text-align:center; position:relative; transition:var(--transition);
}
.pricing-card.featured { border-color:var(--clr-primary); box-shadow:var(--shadow-red); transform:scale(1.04); }
.pricing-card:not(.featured):hover { border-color:var(--clr-primary); transform:translateY(-6px); }
.p-badge { position:absolute; top:-14px; left:50%; transform:translateX(-50%); background:var(--gradient-primary); color:#fff; font-family:var(--font-heading); font-size:0.72rem; font-weight:700; padding:5px 18px; border-radius:var(--radius-full); white-space:nowrap; }
.p-ico { width:68px; height:68px; margin:0 auto 18px; background:var(--clr-light-red); border-radius:var(--radius-md); display:flex; align-items:center; justify-content:center; font-size:28px; transition:var(--transition); }
.pricing-card:hover .p-ico, .pricing-card.featured .p-ico { background:var(--gradient-primary); }
.pricing-card h3 { color:var(--clr-dark); margin-bottom:6px; }
.pricing-card .p-sub { font-size:0.86rem; color:var(--clr-gray); margin-bottom:22px; }
.p-features { text-align:left; display:flex; flex-direction:column; gap:11px; margin-bottom:28px; }
.p-feat { display:flex; align-items:center; gap:10px; font-size:0.86rem; color:var(--clr-dark-3); }
.p-feat .tick { width:20px; height:20px; background:var(--clr-light-red); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:10px; color:var(--clr-primary); flex-shrink:0; }

/* ================================================================
   22. CHECKLIST & INFO BOXES
   ================================================================ */
.check-list { display:flex; flex-direction:column; gap:13px; }
.check-item { display:flex; align-items:flex-start; gap:12px; font-size:0.94rem; color:var(--clr-dark-3); }
.check-item .ci { width:22px; height:22px; background:var(--gradient-primary); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:11px; color:#fff; flex-shrink:0; margin-top:2px; }

.info-box { background:var(--clr-light-red); border:1px solid rgba(128,15,47,0.2); border-radius:var(--radius-md); padding:24px 28px; margin-top:32px; }
.info-box p { font-size:0.93rem; color:var(--clr-dark-3); margin:0; }
.info-box strong { color:var(--clr-primary); }

/* ================================================================
   23. FOOTER
   ================================================================ */
.footer { background: #800f2f; color:#fff; padding-top:80px; }
.footer-top { display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:48px; padding-bottom:60px; border-bottom:1px solid rgba(255,255,255,0.07); }
.footer-brand p { font-size:0.88rem; color:rgba(255,255,255,0.68); line-height:1.8; margin:16px 0 22px; max-width:310px; }
.social-links { display:flex; gap:10px; }
.soc-link { width:38px; height:38px; border-radius:var(--radius-sm); background:rgba(255,255,255,0.07); display:flex; align-items:center; justify-content:center; font-size:14px; color:rgba(255,255,255,0.55); transition:var(--transition); }
.soc-link:hover { background:var(--gradient-primary); color:#fff; transform:translateY(-3px); }
.footer-widget h4 { font-size:0.9rem; font-weight:700; color:#fff; margin-bottom:18px; text-transform:uppercase; letter-spacing:1px; }
.footer-links { display:flex; flex-direction:column; gap:9px; }
.footer-links a { font-size:0.86rem; color:rgba(255,255,255,0.68); display:flex; align-items:center; gap:7px; transition:var(--transition); }
.footer-links a:hover { color:#fff; padding-left:4px; }
.f-contact-item { display:flex; align-items:flex-start; gap:11px; margin-bottom:14px; }
.f-contact-item .fci { font-size:14px; color:#fce8ed; margin-top:3px; flex-shrink:0; }
.f-contact-item .fct { font-size:0.82rem; color:rgba(255,255,255,0.48); line-height:1.6; }
.f-contact-item .fct a { color:rgba(255,255,255,0.65); }
.f-contact-item .fct a:hover { color:#fff; }
.footer-bottom { padding:22px 0; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:8px; }
.footer-bottom p { font-size:0.8rem; color:rgba(255,255,255,0.3); margin:0; }

/* ================================================================
   24. BACK TO TOP
   ================================================================ */
.back-top { position:fixed; bottom:24px; right:24px; width:46px; height:46px; background:var(--gradient-primary); border-radius:50%; display:flex; align-items:center; justify-content:center; color:#fff; font-size:16px; box-shadow:var(--shadow-red); opacity:0; pointer-events:none; transform:translateY(10px); transition:var(--transition); z-index:50; cursor:pointer; }
.back-top.show { opacity:1; pointer-events:auto; transform:translateY(0); }
.back-top:hover { transform:translateY(-4px); box-shadow:var(--shadow-redl); }

/* ================================================================
   25. SCROLL ANIMATIONS
   ================================================================ */
.reveal { opacity:0; transform:translateY(32px); transition:opacity 0.65s ease, transform 0.65s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-right { opacity:0; transform:translateX(-32px); transition:opacity 0.65s ease, transform 0.65s ease; }
.reveal-right.visible { opacity:1; transform:translateX(0); }
.reveal-left { opacity:0; transform:translateX(32px); transition:opacity 0.65s ease, transform 0.65s ease; }
.reveal-left.visible { opacity:1; transform:translateX(0); }
.d1{transition-delay:0.1s} .d2{transition-delay:0.2s} .d3{transition-delay:0.3s} .d4{transition-delay:0.4s} .d5{transition-delay:0.5s} .d6{transition-delay:0.6s}

/* ================================================================
   26. SCROLLBAR & SELECTION
   ================================================================ */
::selection { background:rgba(128,15,47,0.2); color:var(--clr-dark); }
::-webkit-scrollbar { width:6px; }
::-webkit-scrollbar-track { background:#fff; }
::-webkit-scrollbar-thumb { background:var(--clr-primary); border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:var(--clr-primary-hover); }

/* ================================================================
   27. RESPONSIVE
   ================================================================ */
@media(max-width:1200px){
  :root{ --container-pad:0 32px; }
  .stats-grid{ grid-template-columns:repeat(2,1fr); }
  .footer-top{ grid-template-columns:1fr 1fr; gap:36px; }
}
@media(max-width:1024px){
  .hero .container{ grid-template-columns:1fr; gap:60px; text-align:center; padding-top:110px; }
  .hero-desc{ max-width:100%; }
  .hero-actions{ justify-content:center; }
  .hero-visual{ display:none; }
  .grid-4{ grid-template-columns:repeat(2,1fr); }
  .process-track{ grid-template-columns:repeat(2,1fr); }
  .process-track::before{ display:none; }
  .grid-2{ grid-template-columns:1fr; gap:40px; }
  /* Navbar: activate hamburger at tablet/small desktop */
  .navbar-menu{
    display:none; position:fixed; top:0; left:0; right:0; bottom:0;
    background:rgba(26,10,16,0.97); flex-direction:column; align-items:center; justify-content:center;
    gap:4px; z-index:var(--z-nav); padding:20px; overflow-y:auto;
  }
  .navbar-menu.open{ display:flex; }
  .nav-link{ font-size:1.1rem; padding:10px 20px; width:100%; text-align:center; color:rgba(255,255,255,0.88); }
  .hamburger{ display:flex; z-index:calc(var(--z-nav) + 1); }
  .phone-link{ display:none; }
  /* Mobile dropdown accordion */
  .has-dropdown { width:100%; flex-direction:column; }
  .dropdown-toggle { display:flex; align-items:center; justify-content:center; gap:8px; }
  .nav-dropdown {
    position:static; transform:none; min-width:unset; width:100%;
    flex-direction:column; box-shadow:none; border:none;
    background:rgba(255,255,255,0.07); border-radius:var(--radius-md);
    opacity:1; pointer-events:none; max-height:0; overflow:hidden;
    transition:max-height 0.35s ease;
  }
  .has-dropdown.open .nav-dropdown { pointer-events:auto; max-height:700px; }
  .has-dropdown:hover .nav-dropdown { opacity:1; transform:none; }
  .nav-dropdown-col { padding:4px 16px; border:none; }
  .nav-dropdown-col:first-child { border-right:none; }
  .dropdown-link { color:rgba(255,255,255,0.78); font-size:0.93rem; padding:9px 14px; justify-content:center; }
  .dropdown-link i { color:rgba(255,255,255,0.55); }
  .dropdown-link:hover { background:rgba(255,255,255,0.1); color:#fff; }
  .dropdown-link.dropdown-all { border-top:1px solid rgba(255,255,255,0.12); color:#fce8ed; margin-top:4px; padding-top:10px; }
  .dropdown-link.dropdown-all:hover { background:var(--gradient-primary); color:#fff; }
}
@media(max-width:768px){
  :root{ --container-pad:0 20px; --section-pad:70px 0; }
  .navbar-cta .btn{ display:none; }
  .grid-3{ grid-template-columns:1fr; }
  .grid-4{ grid-template-columns:1fr 1fr; }
  .stats-grid{ grid-template-columns:1fr 1fr; }
  .hero-stats{ grid-template-columns:repeat(3,1fr); gap:12px; }
  .hero-stat-num{ font-size:1.5rem; }
  .form-row{ grid-template-columns:1fr; }
  .footer-top{ grid-template-columns:1fr; gap:28px; }
  .footer-bottom{ flex-direction:column; text-align:center; }
  .pricing-card.featured{ transform:none; }
  .process-track{ grid-template-columns:1fr; }
}
@media(max-width:480px){
  h1{ font-size:2.1rem; }
  h2{ font-size:1.75rem; }
  .hero-stats{ grid-template-columns:1fr; }
  .grid-4{ grid-template-columns:1fr; }
  .stats-grid{ grid-template-columns:1fr; }
  .btn-lg{ padding:14px 28px; }
}

/* WordPress admin bar offset for fixed navbar */
body.admin-bar .navbar { top: 32px; }
@media screen and (max-width: 782px) { body.admin-bar .navbar { top: 46px; } }

/* ================================================================
   BLOG TOPIC PILLS (WordPress archive / blog page)
   ================================================================ */
.topic-pill {
  display: inline-block;
  background: var(--clr-light-red);
  color: var(--clr-primary);
  border: 1px solid rgba(128, 15, 47, 0.18);
  border-radius: var(--radius-full);
  padding: 6px 16px;
  font-size: 0.82rem;
  font-weight: 500;
  cursor: pointer;
  transition: background var(--dur-fast) ease, color var(--dur-fast) ease;
  text-decoration: none;
}
.topic-pill:hover,
.topic-pill.active {
  background: var(--clr-primary);
  color: #fff;
  border-color: var(--clr-primary);
}
