/*
Theme Name: Road Aid Europe
Theme URI: https://roadaideurope.com
Author: Road Aid Europe
Author URI: https://roadaideurope.com
Description: A modern, professional WordPress theme for Road Aid Europe - 24/7 Roadside Assistance services in Albania and Europe.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: road-aid-europe
Tags: business, emergency-services, roadside-assistance, modern, dark-theme
*/

/* RBNo 3.1 – all weights & italics (matches files in assets/fonts/) */
@font-face {
  font-family: "RBNo 3.1";
  src: url("assets/fonts/RBNo3.1-Thin.otf") format("opentype");
  font-weight: 100;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "RBNo 3.1";
  src: url("assets/fonts/RBNo3.1-ThinItalic.otf") format("opentype");
  font-weight: 100;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "RBNo 3.1";
  src: url("assets/fonts/RBNo3.1-ExtraLight.otf") format("opentype");
  font-weight: 200;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "RBNo 3.1";
  src: url("assets/fonts/RBNo3.1-ExtraLightItalic.otf") format("opentype");
  font-weight: 200;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "RBNo 3.1";
  src: url("assets/fonts/RBNo3.1-Light.otf") format("opentype");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "RBNo 3.1";
  src: url("assets/fonts/RBNo3.1-LightItalic.otf") format("opentype");
  font-weight: 300;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "RBNo 3.1";
  src: url("assets/fonts/RBNo3.1-Book.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "RBNo 3.1";
  src: url("assets/fonts/RBNo3.1-BookItalic.otf") format("opentype");
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "RBNo 3.1";
  src: url("assets/fonts/RBNo3.1-Medium.otf") format("opentype");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "RBNo 3.1";
  src: url("assets/fonts/RBNo3.1-MediumItalic.otf") format("opentype");
  font-weight: 500;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "RBNo 3.1";
  src: url("assets/fonts/RBNo3.1-Bold.otf") format("opentype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "RBNo 3.1";
  src: url("assets/fonts/RBNo3.1-BoldItalic.otf") format("opentype");
  font-weight: 700;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "RBNo 3.1";
  src: url("assets/fonts/RBNo3.1-Extrabold.otf") format("opentype");
  font-weight: 800;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "RBNo 3.1";
  src: url("assets/fonts/RBNo3.1-ExtraboldItalic.otf") format("opentype");
  font-weight: 800;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "RBNo 3.1";
  src: url("assets/fonts/RBNo3.1-Black.otf") format("opentype");
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "RBNo 3.1";
  src: url("assets/fonts/RBNo3.1-BlackItalic.otf") format("opentype");
  font-weight: 900;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "RBNo 3.1";
  src: url("assets/fonts/RBNo3.1-Ultra.otf") format("opentype");
  font-weight: 800;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "RBNo 3.1";
  src: url("assets/fonts/RBNo3.1-UltraItalic.otf") format("opentype");
  font-weight: 800;
  font-style: italic;
  font-display: swap;
}

/* Road Aid Europe color palette */
:root {
  --primary-blue: #0E2A47;
  --accent-red: #D32F2F;
  --white: #FFFFFF;
  --shadow: 0 20px 60px rgba(0,0,0,.25);
  --radius: 18px;
  --radius2: 26px;
  --max: 1140px;
  /* Default (dark) – overridden by prefers-color-scheme */
  --bg: #0a1f35;
  --panel: #0E2A47;
  --text: #FFFFFF;
  --muted: rgba(255, 255, 255, 0.75);
  --line: rgba(255, 255, 255, 0.1);
  --brand: #D32F2F;
  --brand2: #b71c1c;
  --nav-bg: rgba(10, 31, 53, 0.85);
  --gradient-start: rgba(211, 47, 47, 0.15);
  --gradient-end: rgba(211, 47, 47, 0.06);
  --card-bg: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  --input-bg: rgba(0, 0, 0, 0.25);
  --icon-bg: rgba(211, 47, 47, 0.2);
  --icon-border: rgba(211, 47, 47, 0.35);
  --icon-color: #ffcdd2;
  --stat-bg: rgba(0, 0, 0, 0.2);
  --focus-ring: rgba(211, 47, 47, 0.4);
  --font-heading: "RBNo 3.1", sans-serif;
  --font-body: "RBNo 3.1", sans-serif;
  /* Map — dark mode: white countries */
  --map-country: #FFFFFF;
  --map-stroke: rgba(255, 255, 255, 0.35);
  --map-sea: transparent;
}

/* Light mode (system preference or default) */
@media (prefers-color-scheme: light) {
  :root {
    --bg: #FFFFFF;
    --panel: #f5f6f8;
    --text: #0E2A47;
    --muted: #5a6b7d;
    --line: rgba(14, 42, 71, 0.12);
    --brand: #D32F2F;
    --brand2: #b71c1c;
    --nav-bg: rgba(255, 255, 255, 0.9);
    --gradient-start: rgba(211, 47, 47, 0.08);
    --gradient-end: rgba(211, 47, 47, 0.04);
    --card-bg: linear-gradient(180deg, rgba(14, 42, 71, 0.03), rgba(14, 42, 71, 0.02));
    --input-bg: rgba(14, 42, 71, 0.06);
    --icon-bg: rgba(211, 47, 47, 0.12);
    --icon-border: rgba(211, 47, 47, 0.25);
    --icon-color: #D32F2F;
  --stat-bg: rgba(14, 42, 71, 0.06);
  --focus-ring: rgba(211, 47, 47, 0.25);
  --map-country: #0E2A47;
  --map-stroke: rgba(14, 42, 71, 0.5);
  --map-sea: transparent;
  }
}

/* Dark mode (system preference) */
@media (prefers-color-scheme: dark) {
  :root {
    --bg: #0a1f35;
    --panel: #0E2A47;
    --text: #FFFFFF;
    --muted: rgba(255, 255, 255, 0.75);
    --line: rgba(255, 255, 255, 0.1);
    --brand: #D32F2F;
    --brand2: #b71c1c;
    --nav-bg: rgba(10, 31, 53, 0.85);
    --gradient-start: rgba(211, 47, 47, 0.15);
    --gradient-end: rgba(211, 47, 47, 0.06);
    --card-bg: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
    --input-bg: rgba(0, 0, 0, 0.25);
    --icon-bg: rgba(211, 47, 47, 0.2);
    --icon-border: rgba(211, 47, 47, 0.35);
    --icon-color: #ffcdd2;
    --stat-bg: rgba(0, 0, 0, 0.2);
    --focus-ring: rgba(211, 47, 47, 0.4);
  }
}

/* Default (no preference): use dark theme */
@media (prefers-color-scheme: no-preference) {
  :root {
    --bg: #0a1f35;
    --panel: #0E2A47;
    --text: #FFFFFF;
    --muted: rgba(255, 255, 255, 0.75);
    --line: rgba(255, 255, 255, 0.1);
    --brand: #D32F2F;
    --brand2: #b71c1c;
    --nav-bg: rgba(10, 31, 53, 0.85);
    --gradient-start: rgba(211, 47, 47, 0.15);
    --gradient-end: rgba(211, 47, 47, 0.06);
    --card-bg: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
    --input-bg: rgba(0, 0, 0, 0.25);
    --icon-bg: rgba(211, 47, 47, 0.2);
    --icon-border: rgba(211, 47, 47, 0.35);
    --icon-color: #ffcdd2;
    --stat-bg: rgba(0, 0, 0, 0.2);
    --focus-ring: rgba(211, 47, 47, 0.4);
  }
}

*{ box-sizing:border-box; }
html{
  scroll-behavior: smooth;
  color-scheme: light dark;
}
body{
  margin:0;
  font-family: var(--font-body);
  font-weight: 400;
  background: radial-gradient(1200px 800px at 20% 10%, var(--gradient-start), transparent 55%),
              radial-gradient(900px 700px at 90% 20%, var(--gradient-end), transparent 55%),
              var(--bg);
  color: var(--text);
  line-height: 1.55;
}
a{ color:inherit; text-decoration:none; }
h1, h2, h3, h4, h5, h6 { font-family: var(--font-heading); }
h1, .h1 { font-weight: 900; }
h2, h3, h4 { font-weight: 700; }
h5, h6 { font-weight: 400; }
.container{ width:min(var(--max), calc(100% - 0px)); margin:0 auto; }
.nav{
  position:sticky; top:0; z-index:50;
  backdrop-filter: blur(10px);
  background: var(--nav-bg);
  border-bottom: 1px solid var(--line);
}
.nav-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding: 14px 0;
  gap: 14px;
}
.brand{
  display: flex;
  align-items: center;
}
.brand img,
.logo-img{
  height: 48px;
  width: auto;
  max-width: 200px;
  object-fit: contain;
  display: block;
}
.menu{
  display:flex; flex-wrap:wrap; gap: 12px;
  justify-content:center;
}
.menu a{
  font-size: 13px;
  color: var(--muted);
  padding: 8px 10px;
  border-radius: 12px;
  transition: .2s ease;
  border: 1px solid transparent;
}
.menu a:hover{
  color: var(--text);
  border-color: var(--line);
  background: rgba(255,255,255,.03);
}
.nav-cta{
  display:flex; align-items:center; gap:10px;
  min-width: 240px;
  justify-content:flex-end;
}

/* ── Language Switcher (desktop) ── */
.lang-switcher{
  position:relative;
}
.lang-current{
  display:inline-flex; align-items:center; gap:6px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--line);
  border-radius:12px;
  padding:7px 10px;
  color:var(--text);
  font-size:13px;
  font-weight:600;
  cursor:pointer;
  transition:.2s ease;
  white-space:nowrap;
  font-family:inherit;
}
.lang-current:hover{
  border-color:rgba(255,255,255,.16);
  background:rgba(255,255,255,.06);
}
.lang-flag{
  font-size:18px;
  line-height:1;
}
.lang-chevron{
  transition:transform .2s ease;
  opacity:.5;
}
.lang-switcher.open .lang-chevron{
  transform:rotate(180deg);
}
.lang-dropdown{
  display:none;
  position:absolute;
  top:calc(100% + 6px);
  right:0;
  min-width:180px;
  background:var(--card-bg, #0e1a2a);
  border:1px solid var(--line);
  border-radius:14px;
  padding:6px;
  margin:0;
  list-style:none;
  box-shadow:0 16px 48px rgba(0,0,0,.4);
  z-index:200;
  animation:langDropIn .15s ease-out;
}
@keyframes langDropIn{
  from{ opacity:0; transform:translateY(-6px); }
  to{ opacity:1; transform:translateY(0); }
}
.lang-switcher.open .lang-dropdown{
  display:block;
}
.lang-dropdown li{
  margin:0;
}
.lang-dropdown a{
  display:flex; align-items:center; gap:10px;
  padding:9px 12px;
  border-radius:10px;
  color:var(--muted);
  text-decoration:none;
  font-size:13px;
  transition:.15s ease;
}
.lang-dropdown a:hover{
  background:rgba(255,255,255,.06);
  color:var(--text);
}
.lang-dropdown .active a{
  background:rgba(211,47,47,.1);
  color:var(--brand);
}
.lang-name{
  flex:1;
}
.lang-code-label{
  font-size:11px;
  font-weight:700;
  letter-spacing:.04em;
  opacity:.4;
}

/* ── Language Switcher (mobile menu) ── */
.mobile-lang-switcher{
  position:relative;
  margin-top:12px;
  padding-top:12px;
  border-top:1px solid var(--line);
}
.mobile-lang-current{
  display:flex; align-items:center; gap:8px;
  width:100%;
  background:rgba(255,255,255,.04);
  border:1px solid var(--line);
  border-radius:12px;
  padding:10px 14px;
  color:var(--text);
  font-size:14px;
  font-weight:600;
  cursor:pointer;
  font-family:inherit;
  transition:.2s ease;
}
.mobile-lang-current:hover{
  border-color:rgba(255,255,255,.16);
  background:rgba(255,255,255,.06);
}
.mobile-lang-switcher .lang-chevron{
  margin-left:auto;
}
.mobile-lang-dropdown{
  display:none;
  margin:6px 0 0;
  padding:4px;
  list-style:none;
  background:rgba(255,255,255,.03);
  border:1px solid var(--line);
  border-radius:12px;
}
.mobile-lang-switcher.open .mobile-lang-dropdown{
  display:block;
  animation:langDropIn .15s ease-out;
}
.mobile-lang-dropdown a{
  display:flex; align-items:center; gap:10px;
  padding:10px 14px;
  border-radius:10px;
  color:var(--muted);
  text-decoration:none;
  font-size:14px;
  transition:.15s ease;
}
.mobile-lang-dropdown a:hover{
  background:rgba(255,255,255,.06);
  color:var(--text);
}
.mobile-lang-dropdown .active a{
  background:rgba(211,47,47,.1);
  color:var(--brand);
}

.btn{
  cursor:pointer;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.03);
  color: var(--text);
  padding: 10px 14px;
  border-radius: 14px;
  font-weight: 600;
  font-size: 13px;
  transition: .2s ease;
  display:inline-flex; align-items:center; gap:10px;
  white-space: nowrap;
}
.btn:hover{ transform: translateY(-1px); border-color: rgba(255,255,255,.16); }
.btn.primary{
  border: none;
  background: linear-gradient(135deg, var(--brand), var(--brand2));
  box-shadow: 0 14px 40px rgba(211, 47, 47, 0.25);
}
.btn.primary:hover{ box-shadow: 0 18px 50px rgba(211, 47, 47, 0.35); }
.pill{
  display:inline-flex; gap:10px; align-items:center;
  padding: 8px 12px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255,255,255,.03);
  color: var(--muted);
  font-size: 12px;
}
/* ======= HERO — centered, conversion-focused ======= */
.hero{ padding: 0px 0 0px; }
.hero-centered{
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
}
.h1{
  font-family: var(--font-heading);
  font-weight: 900;
  font-size: clamp(34px, 5vw, 60px);
  line-height: 1.06;
  margin: 18px 0 16px;
  letter-spacing: -1px;
}
.text-brand{ color: var(--brand); }
.lead{
  color: var(--muted);
  font-size: 18px;
  margin: 0 auto 22px;
  max-width: 54ch;
  line-height: 1.6;
}
.hero-actions{
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 22px;
  justify-content: center;
}
.hero-sub{
  margin-top: 28px;
  font-size: 13px;
  color: var(--muted);
  letter-spacing: .5px;
  font-weight: 500;
}
.btn-lg{
  padding: 14px 28px !important;
  font-size: 15px !important;
  border-radius: 16px;
}

/* Pulse dot (live indicator) */
.pulse-dot{
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #4caf50;
  display: inline-block;
  animation: pulseDot 2s ease-in-out infinite;
  box-shadow: 0 0 0 0 rgba(76, 175, 80, 0.5);
}
.pulse-dot-lg{
  width: 10px; height: 10px;
}
@keyframes pulseDot {
  0%, 100% { box-shadow: 0 0 0 0 rgba(76, 175, 80, 0.5); }
  50% { box-shadow: 0 0 0 6px rgba(76, 175, 80, 0); }
}

/* Legacy grid kept for other pages */
.hero-grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 26px;
  align-items: stretch;
}
.card{
  background: var(--card-bg);
  border: 1px solid var(--line);
  border-radius: var(--radius2);
  box-shadow: var(--shadow);
}
.card.pad{ padding: 18px; }
.mini{ display:grid; gap: 12px; height: 100%; align-content: start; }
.mini h3{ font-family: var(--font-heading); font-weight: 700; margin: 0; font-size: 14px; letter-spacing:.3px; }
.mini p{ margin:0; color: var(--muted); font-size: 13px; }
.stat{
  display:flex; gap:12px; align-items:flex-start;
  padding: 14px;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: var(--stat-bg);
}
.icon{
  width: 34px; height: 34px; border-radius: 12px;
  background: var(--icon-bg);
  border: 1px solid var(--icon-border);
  display:grid; place-items:center;
  flex: 0 0 auto;
  font-weight: 800;
  color: var(--icon-color);
}
.section{ padding: 46px 0; }
.section-title{
  display:flex; justify-content:space-between; align-items:flex-end;
  gap: 16px; margin-bottom: 18px;
}
.section-title h2{ font-family: var(--font-heading); font-weight: 700; margin:0; font-size: 22px; letter-spacing: -.2px; }
.section-title p{ margin:0; color: var(--muted); font-size: 13px; max-width: 70ch; }
.grid-3{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.grid-2{ display:grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.service{
  padding: 18px;
  border-radius: var(--radius2);
  border: 1px solid var(--line);
  background: rgba(255,255,255,.02);
  transition: .2s ease;
}
.service:hover{ transform: translateY(-2px); border-color: rgba(255,255,255,.16); }
.service h3{ font-family: var(--font-heading); font-weight: 700; margin: 10px 0 6px; font-size: 15px; }
.service p{ margin:0; color: var(--muted); font-size: 13px; }
.form{ display:grid; gap: 10px; }
label{ font-size: 12px; color: var(--muted); }
input, textarea, select{
  width: 100%;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: var(--input-bg);
  color: var(--text);
  outline: none;
  font-size: 14px;
}
textarea{ min-height: 110px; resize: vertical; }
.row{ display:grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.note{ color: var(--muted); font-size: 12px; }
input[type="radio"], input[type="checkbox"]{
  width: auto;
  margin-right: 8px;
  cursor: pointer;
}
input[type="radio"]:checked, input[type="checkbox"]:checked{
  accent-color: var(--brand);
}
.steps{
  display:grid; gap: 10px; padding-left: 0; margin: 0; list-style: none;
}
.steps li{
  display:flex; gap: 10px; align-items:flex-start;
  padding: 12px 12px;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.02);
}
.badge{
  width: 26px; height: 26px; border-radius: 9px;
  background: var(--icon-bg);
  border: 1px solid var(--icon-border);
  display:grid; place-items:center;
  font-weight: 800;
  color: var(--icon-color);
  flex:0 0 auto;
  margin-top: 2px;
}
.split{ display:grid; grid-template-columns: 1.1fr .9fr; gap: 14px; align-items: start; }
.map{
  border-radius: var(--radius2);
  border: 1px dashed var(--line);
  background: linear-gradient(135deg, var(--gradient-start), var(--gradient-end));
  padding: 18px;
  min-height: 230px;
  display:grid;
  align-content: center;
  gap: 8px;
  text-align:center;
  color: var(--muted);
}
.footer{
  padding: 26px 0 40px;
  border-top: 1px solid var(--line);
  margin-top: 26px;
}
.footer-grid{
  display:grid;
  grid-template-columns: 1.3fr 1fr 1fr;
  gap: 18px;
}
.footer h4{ margin:0 0 10px; font-size: 14px; }
.footer a{ color: var(--muted); font-size: 13px; display:block; padding: 6px 0; }
.footer a:hover{ color: var(--text); }
.tiny{ color: var(--muted); font-size: 12px; }
.sticky-help{
  position: fixed;
  right: 16px;
  bottom: 16px;
  z-index: 60;
  display:flex;
  gap: 10px;
  align-items:center;
}
.fab{
  border: none;
  border-radius: 999px;
  padding: 12px 14px;
  font-weight: 800;
  box-shadow: var(--shadow);
}
.fab.whatsapp{ background: #25D366; color:#04140b; }
.fab.call{ background: linear-gradient(135deg, var(--brand), var(--brand2)); color:white; }
.hamburger{
  display:none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.03);
  padding: 10px 12px;
  border-radius: 14px;
  cursor:pointer;
  transition: background-color 0.3s ease;
  width: 44px;
  height: 44px;
  flex-shrink: 0;
}

.hamburger:hover {
  background: rgba(255,255,255,.06);
}

.hamburger:active {
  transform: scale(0.95);
}

.hamburger-line {
  width: 20px;
  height: 2px;
  background: var(--text);
  border-radius: 2px;
  transition: all 0.3s cubic-bezier(0.68, -0.55, 0.265, 1.55);
  transform-origin: center;
}

.hamburger:hover .hamburger-line {
  background: var(--brand);
}

/* Hamburger to X animation when active */
.hamburger[aria-expanded="true"] .hamburger-line:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

.hamburger[aria-expanded="true"] .hamburger-line:nth-child(2) {
  opacity: 0;
  transform: scaleX(0);
}

.hamburger[aria-expanded="true"] .hamburger-line:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

.icon svg{
  width: 18px;
  height: 18px;
  display:block;
}
.icon svg path, .icon svg circle, .icon svg rect, .icon svg line, .icon svg polyline{
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}


/* Animations */
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes slideInRight {
  from {
    opacity: 0;
    transform: translateX(30px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes slideInLeft {
  from {
    opacity: 0;
    transform: translateX(100%);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes pulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.05); }
}

@keyframes shimmer {
  0% { background-position: -1000px 0; }
  100% { background-position: 1000px 0; }
}

/* Animation classes */
.fade-in-up {
  animation: fadeInUp 0.6s ease-out forwards;
  opacity: 0;
}

.fade-in {
  animation: fadeIn 0.8s ease-out forwards;
  opacity: 0;
}

.slide-in-right {
  animation: slideInRight 0.6s ease-out forwards;
  opacity: 0;
}

/* Stagger animations for children */
.fade-in-up-delay-1 { animation-delay: 0.1s; }
.fade-in-up-delay-2 { animation-delay: 0.2s; }
.fade-in-up-delay-3 { animation-delay: 0.3s; }
.fade-in-up-delay-4 { animation-delay: 0.4s; }

/* Smooth transitions */
* {
  transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease;
}

/* Enhanced hover effects */
.service {
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1), 
              border-color 0.3s ease, 
              box-shadow 0.3s ease;
}

.service:hover {
  transform: translateY(-4px) scale(1.02);
  box-shadow: 0 8px 25px rgba(211, 47, 47, 0.15);
}

.card {
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.card:hover {
  transform: translateY(-2px);
  box-shadow: 0 25px 70px rgba(0, 0, 0, 0.5);
}

.btn {
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
  overflow: hidden;
}

.btn::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.1);
  transform: translate(-50%, -50%);
  transition: width 0.6s, height 0.6s;
}

.btn:hover::before {
  width: 300px;
  height: 300px;
}

.btn.primary {
  position: relative;
  overflow: hidden;
}

.btn.primary::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
  transition: left 0.5s;
}

.btn.primary:hover::after {
  left: 100%;
}

/* Sticky help buttons animation */
.sticky-help {
  animation: slideInRight 0.6s ease-out 0.3s both;
}

.fab {
  transition: transform 0.3s cubic-bezier(0.68, -0.55, 0.265, 1.55), 
              box-shadow 0.3s ease;
}

.fab:hover {
  transform: scale(1.1) rotate(5deg);
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.4);
}

.fab:active {
  transform: scale(0.95);
}

/* Mobile menu animation - slides from right to left */
.mobile-menu {
  display: none;
  padding: 10px 0 16px;
  max-height: 0;
  overflow: hidden;
  transition: all 0.3s ease-out;
  transform: translateX(100%);
  opacity: 0;
  position: relative;
}

.mobile-menu.show {
  display: block;
  max-height: 500px;
  animation: slideInLeft 0.3s ease-out forwards;
  transform: translateX(0);
  opacity: 1;
}

.mobile-menu a {
  display: block;
  padding: 10px 0;
  color: var(--muted);
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  transition: all 0.2s ease;
  opacity: 0;
  transform: translateX(30px);
}

.mobile-menu.show a {
  opacity: 1;
  transform: translateX(0);
  animation: slideInLeft 0.3s ease-out forwards;
}

.mobile-menu.show a:nth-child(1) { animation-delay: 0.05s; }
.mobile-menu.show a:nth-child(2) { animation-delay: 0.1s; }
.mobile-menu.show a:nth-child(3) { animation-delay: 0.15s; }
.mobile-menu.show a:nth-child(4) { animation-delay: 0.2s; }
.mobile-menu.show a:nth-child(5) { animation-delay: 0.25s; }
.mobile-menu.show a:nth-child(6) { animation-delay: 0.3s; }
.mobile-menu.show a:nth-child(7) { animation-delay: 0.35s; }

.mobile-menu a:hover {
  color: var(--text);
  padding-left: 10px;
  background: rgba(255, 255, 255, 0.03);
}

.mobile-menu .mobile-provider-btn {
  margin-top: 12px;
  padding: 12px 16px;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.03);
  border-radius: 14px;
  text-align: center;
  font-weight: 600;
  font-size: 13px;
  border-bottom: none;
}

.mobile-menu .mobile-provider-btn:hover {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.12);
  transform: translateX(0);
  padding-left: 16px;
}

/* Input focus animations */
input:focus, textarea:focus, select:focus {
  border-color: var(--brand);
  box-shadow: 0 0 0 3px var(--focus-ring);
  transform: translateY(-1px);
}

/* Loading states */
.loading {
  position: relative;
  overflow: hidden;
}

.loading::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.1), transparent);
  animation: shimmer 1.5s infinite;
}

/* ======= HOW IT WORKS — Step cards ======= */
.steps-grid{ margin-top: 8px; }
.step-card{
  text-align: center;
  padding: 28px 20px;
  border-radius: var(--radius2);
  border: 1px solid var(--line);
  background: var(--card-bg);
  position: relative;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.step-card:hover{
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(0,0,0,.2);
}
.step-number{
  position: absolute;
  top: -14px;
  left: 50%;
  transform: translateX(-50%);
  width: 28px; height: 28px;
  border-radius: 10px;
  background: linear-gradient(135deg, var(--brand), var(--brand2));
  color: #fff;
  font-weight: 800;
  font-size: 13px;
  display: grid;
  place-items: center;
  box-shadow: 0 4px 14px rgba(211, 47, 47, 0.35);
}
.step-icon{
  width: 52px; height: 52px;
  border-radius: 16px;
  background: var(--icon-bg);
  border: 1px solid var(--icon-border);
  display: grid;
  place-items: center;
  margin: 8px auto 14px;
  color: var(--icon-color);
}
.step-icon svg{
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.step-card h3{
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 16px;
  margin: 0 0 6px;
}
.step-card p{
  color: var(--muted);
  font-size: 13px;
  margin: 0;
  line-height: 1.5;
}

/* Centered section title variant */
.section-title.centered{
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.section-title.centered p{
  max-width: 52ch;
}

/* ======= TRUST BAR ======= */
.trust-bar{
  padding: 32px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.trust-grid{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  flex-wrap: wrap;
}
.trust-item{
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 8px 36px;
  gap: 4px;
}
.trust-value{
  font-family: var(--font-heading);
  font-weight: 900;
  font-size: 22px;
  letter-spacing: -.3px;
  color: var(--text);
}
.trust-label{
  font-size: 12px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .8px;
  font-weight: 500;
}
.trust-divider{
  width: 1px;
  height: 36px;
  background: var(--line);
}

/* ======= BUSINESS CARDS ======= */
.biz-card{
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.biz-card-header{
  display: flex;
  align-items: center;
  gap: 12px;
}
.biz-card-header h3{
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 17px;
  margin: 0;
}
.biz-card p{
  color: var(--muted);
  font-size: 14px;
  margin: 0;
  line-height: 1.55;
}
.check-list{
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 8px;
}
.check-list li{
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  color: var(--muted);
}
.check-list li::before{
  content: '';
  width: 18px; height: 18px;
  min-width: 18px;
  border-radius: 6px;
  background: var(--icon-bg);
  border: 1px solid var(--icon-border);
  display: grid;
  place-items: center;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23ffcdd2' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 10px;
}
.biz-card .btn{
  align-self: flex-start;
  margin-top: auto;
}

/* ======= EMERGENCY SECTION ======= */
.emergency-section{ padding-bottom: 0; }
.emergency-banner{
  background: linear-gradient(135deg, rgba(211, 47, 47, 0.12), rgba(211, 47, 47, 0.04));
  border: 1px solid rgba(211, 47, 47, 0.25);
  border-radius: var(--radius2);
  padding: 36px 32px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 18px;
}
.emergency-badge{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  border-radius: 999px;
  background: rgba(211, 47, 47, 0.15);
  border: 1px solid rgba(211, 47, 47, 0.3);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.5px;
  color: var(--brand);
  text-transform: uppercase;
}
.emergency-content h2{
  font-family: var(--font-heading);
  font-weight: 900;
  font-size: 28px;
  margin: 12px 0 6px;
}
.emergency-content p{
  color: var(--muted);
  font-size: 15px;
  margin: 0;
  max-width: 48ch;
}
.emergency-actions{
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: center;
}
.btn-whatsapp{
  background: #25D366 !important;
  border-color: #25D366 !important;
  color: #04140b !important;
}
.btn-whatsapp:hover{
  box-shadow: 0 14px 40px rgba(37, 211, 102, 0.25) !important;
}
.btn-whatsapp svg{ fill: currentColor; }
.emergency-note{
  font-size: 12px;
  color: var(--muted);
  margin: 0;
}

/* ======= EUROPE MAP SECTION ======= */
.europe-map-section{
  overflow: hidden;
}
.europe-map-wrapper,
.albania-map-wrapper{
  border-radius: var(--radius2);
  border: 1px solid var(--line);
  background: var(--card-bg);
  padding: 24px;
  max-width: 1100px;
  margin: 0 auto;
}
.albania-map-wrapper{
  max-width: 720px;
}

/* Coverage template: city list left, Albania map right */
.coverage-map-split{
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.08fr);
  gap: 28px 40px;
  align-items: start;
  max-width: 1100px;
  margin: 0 auto 28px;
}
.coverage-map-split-text .card{
  margin: 0;
}
.coverage-map-split-map .albania-map-wrapper{
  max-width: none;
  margin: 0;
}
.coverage-map-hint{
  margin: 16px 0 0;
  text-align: center;
  font-size: 13px;
  line-height: 1.5;
}
@media (max-width: 900px){
  .coverage-map-split{
    grid-template-columns: 1fr;
    gap: 24px;
  }
}
.europe-map-svg,
.albania-map-svg{
  width: 100%;
  height: auto;
  display: block;
}
/* Simplemaps helper layers — not needed for interaction (we use county paths + dots) */
.albania-map-svg #points,
.albania-map-svg #label_points{
  display: none;
}
.europe-map-svg path,
.albania-map-svg path{
  fill: var(--map-country);
  stroke: var(--map-stroke);
  stroke-width: .5;
  transition: fill .25s ease, stroke .25s ease;
}
.europe-map-svg path:hover,
.albania-map-svg path:hover{
  fill: rgba(211, 47, 47, 0.15);
  stroke: rgba(211, 47, 47, 0.35);
}
/* Red pulsing dots with glow (country / county dots) */
.europe-map-svg .map-dot.country-dot,
.albania-map-svg .map-dot.country-dot{
  fill: var(--brand);
  stroke: var(--white);
  stroke-width: 1.5;
  cursor: pointer;
  opacity: 1;
  filter: drop-shadow(0 0 4px var(--brand));
  animation: mapDotPulse 2s ease-in-out infinite;
}
.europe-map-svg .map-dot.country-dot:hover,
.albania-map-svg .map-dot.country-dot:hover{
  filter: drop-shadow(0 0 6px var(--brand)) drop-shadow(0 0 10px rgba(211, 47, 47, 0.5));
}
.europe-map-tooltip{
  position: fixed;
  z-index: 10000;
  padding: 8px 14px;
  background: var(--brand);
  color: var(--white);
  font-size: 0.95rem;
  font-weight: 600;
  border-radius: var(--radius1);
  box-shadow: 0 4px 12px rgba(0,0,0,0.25);
  pointer-events: none;
  white-space: normal;
  max-width: min(340px, calc(100vw - 16px));
  text-align: center;
  line-height: 1.35;
}
.map-dot-2{ animation-delay: .3s; }
.map-dot-3{ animation-delay: .6s; }
.map-dot-4{ animation-delay: .9s; }
@keyframes mapDotPulse {
  0%, 100% { opacity: 0.85; filter: drop-shadow(0 0 4px var(--brand)) drop-shadow(0 0 8px rgba(211, 47, 47, 0.4)); }
  50% { opacity: 1; filter: drop-shadow(0 0 8px var(--brand)) drop-shadow(0 0 16px rgba(211, 47, 47, 0.7)); }
}

/* ======= BLOG SLIDER (homepage) ======= */
.blog-section .section-title {
  margin-bottom: 28px;
}
.blog-slider-wrap {
  position: relative;
  padding: 0 48px;
  margin: 0 -48px;
}
.blog-slider-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 1px solid var(--line);
  background: var(--card-bg);
  color: var(--text);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .2s ease, color .2s ease, border-color .2s ease;
  box-shadow: 0 2px 8px rgba(0,0,0,.1);
}
.blog-slider-btn:hover {
  background: var(--brand);
  color: var(--white);
  border-color: var(--brand);
}
.blog-slider-prev { left: 0; }
.blog-slider-next { right: 0; }
.blog-slider-track {
  display: flex;
  gap: 24px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  padding: 8px 0 24px;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.blog-slider-track::-webkit-scrollbar {
  display: none;
}
.blog-slide {
  flex: 0 0 320px;
  scroll-snap-align: start;
  padding: 0;
  overflow: hidden;
  border-radius: var(--radius2);
  border: 1px solid var(--line);
  transition: box-shadow .25s ease, transform .25s ease;
}
.blog-slide:hover {
  box-shadow: 0 8px 24px rgba(0,0,0,.15);
  transform: translateY(-4px);
}
.blog-slide-link {
  display: block;
  text-decoration: none;
  color: inherit;
  height: 100%;
}
.blog-slide-image {
  height: 180px;
  background-size: cover;
  background-position: center;
  background-color: var(--line);
}
.blog-slide-image-placeholder {
  background: linear-gradient(135deg, var(--line) 0%, var(--card-bg) 100%);
}
.blog-slide-content {
  padding: 20px;
}
.blog-slide-date {
  display: block;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--brand);
  margin-bottom: 8px;
}
.blog-slide-title {
  font-size: 1.1rem;
  font-weight: 600;
  margin: 0 0 10px;
  line-height: 1.35;
  color: var(--text);
}
.blog-slide-title a { color: inherit; }
.blog-slide-excerpt {
  font-size: 14px;
  color: var(--muted);
  margin: 0 0 12px;
  line-height: 1.5;
}
.blog-slide-cta {
  font-size: 14px;
  font-weight: 600;
  color: var(--brand);
}
.blog-slide:hover .blog-slide-cta {
  text-decoration: underline;
}
.blog-slider-dots {
  display: flex;
  justify-content: center;
  gap: 10px;
  margin-top: 20px;
  flex-wrap: wrap;
}
.blog-slider-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border: none;
  background: var(--line);
  cursor: pointer;
  padding: 0;
  transition: background .2s ease, transform .2s ease;
}
.blog-slider-dot:hover,
.blog-slider-dot.active {
  background: var(--brand);
}
.blog-slider-dot.active {
  transform: scale(1.2);
}
.blog-slider-empty {
  text-align: center;
  padding: 48px 24px;
  color: var(--muted);
}

@media (max-width: 900px) {
  .blog-slider-wrap { padding: 0 44px; margin: 0 -24px; }
  .blog-slide { flex: 0 0 280px; }
  .blog-slider-btn { width: 44px; height: 44px; }
}
@media (max-width: 600px) {
  .blog-slider-wrap { padding: 0 40px; margin: 0 -16px; }
  .blog-slide { flex: 0 0 260px; }
  .blog-slider-btn { width: 40px; height: 40px; }
}

/* Light-mode checklist icon */
@media (prefers-color-scheme: light) {
  .check-list li::before{
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23D32F2F' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  }
}

/* Responsive Design - Enhanced Breakpoints */
@media (max-width: 1200px) {
  .container {
    padding: 0 20px;
  }
  
  .section-title {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }
}

@media (max-width: 980px) {
  .hero-grid { 
    grid-template-columns: 1fr; 
    gap: 20px;
  }
  
  .nav-cta { 
    min-width: auto; 
    gap: 8px;
  }
  
  /* Hide "Become a Provider" button on mobile - it's in the mobile menu now */
  .nav-cta .desktop-provider-btn,
  .desktop-provider-btn {
    display: none !important;
  }
  
  .nav-cta .btn {
    font-size: 12px;
    padding: 8px 12px;
  }
  
  .brand {
    min-width: 0;
  }
  
  .menu { 
    display: none !important; 
  }
  
  /* Show hamburger on mobile - MUST be visible */
  .hamburger,
  .nav-cta .hamburger,
  #hamburger,
  button.hamburger,
  button#hamburger {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
  }
  
  .grid-3 { 
    grid-template-columns: 1fr 1fr;
    gap: 12px;
  }
  
  .grid-2 { 
    grid-template-columns: 1fr; 
    gap: 12px;
  }
  
  .row { 
    grid-template-columns: 1fr; 
  }
  
  .split { 
    grid-template-columns: 1fr; 
  }
  
  .footer-grid { 
    grid-template-columns: 1fr; 
    gap: 24px;
  }
  
  .section {
    padding: 32px 0;
  }
  
  .hero {
    padding: 52px 0 24px;
  }
  
  .sticky-help {
    right: 12px;
    bottom: 12px;
    flex-direction: column;
    gap: 8px;
  }
  
  .fab {
    padding: 10px 12px;
    font-size: 12px;
  }

  /* Trust bar responsive */
  .trust-item{ padding: 8px 20px; }
  .trust-value{ font-size: 18px; }
  
  /* Emergency banner responsive */
  .emergency-banner{ padding: 28px 20px; }
  .emergency-content h2{ font-size: 24px; }
}

@media (max-width: 768px) {
  .container {
    padding: 0 16px;
  }
  
  .nav-inner {
    padding: 12px 0;
    flex-wrap: nowrap;
    gap: 10px;
  }
  
  .brand {
    flex: 1;
    min-width: 0;
  }
  
  .logo-img {
    height: 40px;
    max-width: 160px;
  }
  
  .nav-cta {
    min-width: auto;
    justify-content: flex-end;
    gap: 8px;
    margin-top: 0;
    order: 2;
    display: flex;
    align-items: center;
  }
  
  /* On mobile, nav-cta should only show hamburger and "Need Help Now" */
  .nav-cta .desktop-provider-btn {
    display: none !important;
  }
  
  /* Ensure hamburger is visible on mobile */
  .nav-cta .hamburger,
  .nav-cta button.hamburger,
  .nav-cta #hamburger {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    flex-shrink: 0;
  }
  
  /* Ensure hamburger lines are visible */
  .nav-cta .hamburger .hamburger-line,
  .hamburger .hamburger-line {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
  }
  
  /* Ensure "Need Help Now" button is visible and properly sized on mobile */
  .nav-cta .btn.primary {
    white-space: nowrap;
    font-size: 12px;
    padding: 8px 12px;
  }
  
  .h1 {
    font-size: clamp(28px, 7vw, 40px);
  }
  
  .lead {
    font-size: 15px;
  }
  
  .hero-actions {
    flex-direction: column;
  }
  
  .hero-actions .btn {
    width: 100%;
    justify-content: center;
  }
  
  .section-title h2 {
    font-size: 20px;
  }
  
  .card.pad {
    padding: 16px;
  }
  
  .service {
    padding: 16px;
  }
  
  .footer {
    padding: 24px 0 32px;
  }
  
  .sticky-help {
    right: 10px;
    bottom: 10px;
  }
  
  .fab {
    padding: 10px;
    font-size: 11px;
  }
  
  /* Trust bar stacks on mobile */
  .trust-grid{
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
  }
  .trust-divider{ display: none; }
  .trust-item{ padding: 12px 8px; }
  
  /* Steps grid 1 col */
  .grid-3{ grid-template-columns: 1fr; }
  
  /* Emergency */
  .emergency-banner{ padding: 24px 16px; }
  .emergency-content h2{ font-size: 22px; }
  .emergency-actions{ flex-direction: column; width: 100%; }
  .emergency-actions .btn{ width: 100%; justify-content: center; }
  .europe-map-wrapper,
  .albania-map-wrapper{ padding: 12px; }
}

@media (max-width: 480px) {
  .container {
    padding: 0 12px;
  }
  
  .h1 {
    font-size: 28px;
    line-height: 1.15;
  }
  
  .lead {
    font-size: 14px;
  }
  
  .btn {
    padding: 10px 14px;
    font-size: 12px;
  }
  
  .btn-lg{
    padding: 12px 20px !important;
    font-size: 14px !important;
  }
  
  .section {
    padding: 24px 0;
  }
  
  .hero {
    padding: 40px 0 16px;
  }
  
  .hero-sub{ font-size: 11px; }
  
  .card.pad {
    padding: 14px;
  }
  
  .stat {
    padding: 12px;
    flex-direction: column;
    gap: 8px;
  }
  
  .icon {
    width: 30px;
    height: 30px;
  }
  
  input, textarea, select {
    padding: 10px;
    font-size: 13px;
  }
  
  .sticky-help {
    right: 8px;
    bottom: 8px;
  }
  
  .fab {
    padding: 8px 10px;
    font-size: 10px;
  }
  
  .trust-grid{ grid-template-columns: 1fr 1fr; }
  .trust-value{ font-size: 16px; }
  .trust-label{ font-size: 10px; }
  
  .step-card{ padding: 24px 16px; }
  .europe-map-wrapper,
  .albania-map-wrapper{ padding: 6px; }
}

/* Print styles */
@media print {
  .nav,
  .sticky-help,
  .hamburger,
  .mobile-menu {
    display: none !important;
  }
  
  body {
    background: white;
    color: black;
  }
}

/* ======= PARTNERS + STORY (WP editor content on homepage) ======= */
.partners-section{
  padding-top: 8px;
  margin-bottom: 40px;
}
.partners-header{
  text-align: center;
  margin-bottom: 24px;
}
.partners-header h2{
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 22px;
  margin: 0 0 6px;
}
.partners-header p{
  color: var(--muted);
  font-size: 14px;
  margin: 0;
}

/* Partner card grid */
.partner-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.partner-card{
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 22px 16px;
  border-radius: var(--radius);
  border: 1px solid var(--line);
  background: var(--card-bg);
  text-align: center;
  transition: transform .3s ease, border-color .3s ease, box-shadow .3s ease;
}
.partner-card:hover{
  transform: translateY(-3px);
  border-color: rgba(211, 47, 47, .25);
  box-shadow: 0 8px 30px rgba(0,0,0,.15);
}
.partner-card-icon{
  width: 44px; height: 44px;
  border-radius: 12px;
  background: var(--icon-bg);
  border: 1px solid var(--icon-border);
  display: grid;
  place-items: center;
  color: var(--icon-color);
}
.partner-card-icon svg{
  stroke: currentColor;
  fill: none;
}
.partner-card-name{
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 15px;
  letter-spacing: .2px;
}
.partner-card-type{
  font-size: 11px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .8px;
  font-weight: 500;
}

/* When real logos replace placeholder: <img> inside .partner-card */
.partner-card img{
  max-height: 36px;
  width: auto;
  object-fit: contain;
  filter: grayscale(1) opacity(.55);
  transition: filter .3s ease;
}
.partner-card:hover img{
  filter: grayscale(0) opacity(1);
}

/* ======= STORY SECTION ======= */
.story-section{
  border-top: 1px solid var(--line);
  padding-top: 36px;
}

/* Header */
.story-top{
  margin-bottom: 28px;
}
.story-label{
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--brand);
  margin-bottom: 10px;
}
.story-top h2{
  font-family: var(--font-heading);
  font-weight: 900;
  font-size: 28px;
  line-height: 1.12;
  margin: 0;
  letter-spacing: -.4px;
}

/* Two-column layout */
.story-grid{
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 28px;
  align-items: start;
}

/* Left: narrative text */
.story-narrative p{
  color: var(--muted);
  font-size: 15px;
  line-height: 1.75;
  margin: 0 0 16px;
}
.story-narrative p:last-child{ margin-bottom: 0; }

/* Right: quote + facts */
.story-sidebar{
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.story-quote{
  margin: 0;
  padding: 20px 22px;
  border-radius: var(--radius);
  background: linear-gradient(135deg, rgba(211, 47, 47, .1), rgba(211, 47, 47, .04));
  border-left: 3px solid var(--brand);
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 15px;
  line-height: 1.55;
  color: var(--text);
  font-style: italic;
}
.story-facts{
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.story-fact{
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  font-weight: 600;
  color: var(--muted);
}
.story-fact-icon{
  width: 30px; height: 30px;
  min-width: 30px;
  border-radius: 9px;
  background: var(--icon-bg);
  border: 1px solid var(--icon-border);
  display: grid;
  place-items: center;
  color: var(--icon-color);
}
.story-fact-icon svg{
  stroke: currentColor;
  fill: none;
}

/* Closing bar — full width */
.story-closing-bar{
  margin-top: 28px;
  padding-top: 24px;
  border-top: 1px solid var(--line);
  text-align: center;
}
.story-closing-bar p{
  color: var(--muted);
  font-size: 15px;
  line-height: 1.65;
  margin: 0 auto 16px;
  max-width: 56ch;
}
.story-closing-line{
  display: block;
  font-family: var(--font-heading);
  font-weight: 900;
  font-size: 18px;
  color: var(--text);
  letter-spacing: -.2px;
  line-height: 1.4;
  max-width: 48ch;
  margin: 0 auto;
}

@media (max-width: 980px) {
  .partner-grid{ grid-template-columns: repeat(3, 1fr); }
  .story-grid{ grid-template-columns: 1fr; gap: 24px; }
}
@media (max-width: 768px) {
  .partner-grid{ grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .partner-card{ padding: 18px 12px; }
  .story-top h2{ font-size: 24px; }
  .story-closing-line{ font-size: 16px; }
}
@media (max-width: 480px) {
  .partner-grid{ grid-template-columns: repeat(2, 1fr); }
  .partner-card{ padding: 14px 10px; gap: 6px; }
  .partner-card-name{ font-size: 13px; }
  .story-top h2{ font-size: 22px; }
  .story-narrative p{ font-size: 14px; }
  .story-quote{ font-size: 14px; padding: 16px 18px; }
  .story-closing-line{ font-size: 15px; }
}

/* WordPress specific styles */
.wp-block-group{ margin: 0; }
.wp-block-columns{ margin: 0; }
.wp-block-image{ margin: 0; }

