:root{
  --bs-body-font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;

  /* Brand + accents (not only blue) */
  --brand: #1d4ed8;          /* deep blue */
  --brand-2: #14b8a6;        /* teal */
  --accent: #f97316;         /* orange */
  --accent-2: #a855f7;       /* purple */
  --success: #16a34a;

  --ink: #0b1220;
  --muted: #64748b;
  --bg-soft: #f6f8fb;
  --card: #ffffff;

  --ring: rgba(29, 78, 216, 0.18);
  --shadow: 0 18px 45px rgba(15, 23, 42, 0.08);
  --shadow-lg: 0 28px 80px rgba(15, 23, 42, 0.12);

  --radius: 1.25rem;
  --radius-lg: 1.5rem;
}

html{ font-size: 16px; }
body{ color: var(--ink); background: #fff; }

a{ color: inherit; }
a:hover{ color: var(--brand); }

.skip-link{
  position:absolute; left:-999px; top:auto; width:1px; height:1px; overflow:hidden;
}
.skip-link:focus{
  left: 1rem; top: 1rem; width:auto; height:auto; padding:.55rem .85rem;
  background:#fff; border:1px solid rgba(15,23,42,.12); border-radius:.75rem; z-index:9999;
  box-shadow: var(--shadow);
}

.brand-dot{
  width: 12px; height: 12px; border-radius: 999px;
  background: linear-gradient(135deg, var(--brand), var(--brand-2));
  box-shadow: 0 12px 26px rgba(20, 184, 166, 0.18);
  display:inline-block;
}

.navbar{
  backdrop-filter: saturate(140%) blur(8px);
}
.navbar .nav-link{
  color: #111827;
  border-radius: 999px;
  padding: .45rem .8rem;
}
.navbar .nav-link:hover{
  background: rgba(20,184,166,.10);
  color: #0f766e;
}

.hero-section{
  background:
    radial-gradient(1000px 520px at 16% 14%, rgba(29,78,216, 0.14), transparent 60%),
    radial-gradient(900px 600px at 85% 22%, rgba(20,184,166, 0.14), transparent 55%),
    radial-gradient(900px 500px at 65% 90%, rgba(249,115,22, 0.10), transparent 60%),
    linear-gradient(180deg, #ffffff 0%, #ffffff 60%, var(--bg-soft) 100%);
}

.hero-title{
  font-family: Poppins, Inter, system-ui, sans-serif;
  letter-spacing: -0.03em;
  line-height: 1.05;
}

.badge.bg-primary-subtle{
  background: linear-gradient(135deg, rgba(20,184,166,.18), rgba(29,78,216,.14)) !important;
  color: #0f172a !important;
  border: 1px solid rgba(15,23,42,.08);
}

.hero-card{
  background: var(--card);
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: var(--radius);
  box-shadow: var(--shadow-lg);
}

.soft-card{
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}

.card-img-top{
  border-top-left-radius: var(--radius);
  border-top-right-radius: var(--radius);
}

.icon-bubble{
  width: 48px; height: 48px; border-radius: 16px;
  display:flex; align-items:center; justify-content:center;
  background: linear-gradient(135deg, rgba(29,78,216,.14), rgba(20,184,166,.12));
  color: #0f172a;
  font-size: 1.15rem;
  border: 1px solid rgba(15,23,42,.08);
}
.icon-bubble-sm{ width: 40px; height: 40px; border-radius: 14px; font-size: 1rem; }

.mini-stat{
  display:flex; gap:.75rem; align-items:center;
  padding: .8rem .9rem;
  border-radius: 1.05rem;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: #fff;
  transition: transform .18s ease, box-shadow .18s ease;
}
.mini-stat:hover{
  transform: translateY(-2px);
  box-shadow: 0 16px 34px rgba(15,23,42,.10);
}
.mini-stat-icn{
  width: 40px; height: 40px; border-radius: 14px;
  display:flex; align-items:center; justify-content:center;
  background: rgba(249,115,22, 0.14);
  color: #9a3412;
  border: 1px solid rgba(249,115,22,.18);
}

.brand-tile{
  background:#fff;
  border:1px solid rgba(15, 23, 42, 0.08);
  border-radius: 1rem;
  padding: .55rem;
  transition: transform .18s ease, box-shadow .18s ease;
}
.brand-tile:hover{
  transform: translateY(-2px);
  box-shadow: 0 18px 40px rgba(15,23,42,.10);
}

.timeline{
  display:flex; flex-direction:column; gap: 1rem;
  padding: 1.25rem;
  border-radius: var(--radius);
  background:
    radial-gradient(700px 250px at 20% 20%, rgba(20,184,166,.12), transparent 65%),
    linear-gradient(180deg, #fff 0%, var(--bg-soft) 100%);
  border: 1px solid rgba(15, 23, 42, 0.08);
}
.tl-item{ display:flex; gap: .95rem; align-items:flex-start; }
.tl-dot{
  width: 44px; height: 44px; border-radius: 16px;
  display:flex; align-items:center; justify-content:center;
  background: #fff;
  border: 1px solid rgba(15, 23, 42, 0.10);
  color: #0f172a;
  font-weight: 800;
  box-shadow: 0 12px 22px rgba(15,23,42,.08);
}

.chip{
  display:flex; align-items:center; gap:.5rem;
  border: 1px solid rgba(15, 23, 42, 0.10);
  background:
    linear-gradient(135deg, rgba(168,85,247,.10), rgba(20,184,166,.10));
  padding: .55rem .8rem;
  border-radius: 999px;
  font-size: .95rem;
}

.avatar{
  width: 46px; height: 46px; border-radius: 999px;
  object-fit: cover;
  border: 2px solid rgba(20, 184, 166, 0.25);
  box-shadow: 0 14px 28px rgba(15,23,42,.10);
}

.cta-card{
  border-radius: var(--radius-lg);
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: var(--shadow-lg);
}

.map-card{ position:relative; }
.map-overlay{
  position:absolute; left: 1rem; right: 1rem; bottom: 1rem;
  background: rgba(255,255,255,0.93);
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 1rem;
  padding: .9rem 1.05rem;
  box-shadow: 0 18px 40px rgba(15,23,42,.10);
}

.page-hero{
  background:
    radial-gradient(900px 450px at 15% 10%, rgba(20,184,166, 0.16), transparent 60%),
    radial-gradient(800px 550px at 85% 15%, rgba(168,85,247, 0.10), transparent 55%),
    linear-gradient(180deg, #ffffff 0%, var(--bg-soft) 100%);
}

.content-card{
  background:#fff;
  border:1px solid rgba(15, 23, 42, 0.08);
  border-radius: var(--radius);
  padding: 1.35rem;
  box-shadow: var(--shadow);
}
.content-card h2{ margin-top: 1.1rem; }
.content-card p, .content-card li{ line-height: 1.7; }

.cookie-banner{
  position: fixed;
  left: 0; right: 0; bottom: 0;
  background: rgba(10, 12, 18, 0.92);
  color: rgba(255,255,255,0.92);
  z-index: 1080;
  display: none;
}
.cookie-banner .text-muted{ color: rgba(255,255,255,0.75) !important; }
.cookie-icn{
  width: 44px; height: 44px; border-radius: 16px;
  display:flex; align-items:center; justify-content:center;
  background: rgba(20,184,166, 0.16);
  color: #7dd3fc;
  font-size: 1.15rem;
  border: 1px solid rgba(125,211,252,0.18);
}

/* Buttons */
.btn-primary{
  background: linear-gradient(135deg, var(--brand), var(--brand-2));
  border: 0;
  box-shadow: 0 14px 30px rgba(29, 78, 216, 0.22);
}
.btn-primary:hover{
  filter: brightness(1.02);
  box-shadow: 0 18px 42px rgba(20, 184, 166, 0.22);
}
.btn-outline-primary{
  border-color: rgba(20,184,166,0.55);
  color: #0f766e;
}
.btn-outline-primary:hover{
  background: rgba(20,184,166,0.12);
  color: #0f766e;
}
.btn:focus{ box-shadow: 0 0 0 .25rem var(--ring) !important; }

/* Accordion polish */
.accordion-button{
  border-radius: 1rem !important;
}
.accordion-item{
  border: 0;
  background: transparent;
  margin-bottom: .75rem;
}
.accordion-button{
  background: #fff;
  border: 1px solid rgba(15,23,42,.08);
  box-shadow: 0 12px 26px rgba(15,23,42,.06);
}
.accordion-button:not(.collapsed){
  background: linear-gradient(135deg, rgba(20,184,166,.10), rgba(29,78,216,.10));
  color: #0b1220;
}

/* Dark footer */
.site-footer{
  background:
    radial-gradient(900px 420px at 20% 0%, rgba(20,184,166,0.22), transparent 60%),
    radial-gradient(900px 520px at 80% 20%, rgba(168,85,247,0.16), transparent 55%),
    linear-gradient(180deg, #0b1220 0%, #070a10 100%);
  color: rgba(255,255,255,0.90);
}
.site-footer .text-muted{ color: rgba(255,255,255,0.70) !important; }
.site-footer a{ color: rgba(255,255,255,0.82); text-decoration: none; }
.site-footer a:hover{ color: #fff; text-decoration: underline; }
.site-footer .border-top{ border-color: rgba(255,255,255,0.12) !important; }

/* Cards spacing + subtle hover */
.soft-card, .content-card, .cta-card, .hero-card{
  transition: transform .18s ease, box-shadow .18s ease;
}
.soft-card:hover{
  transform: translateY(-2px);
  box-shadow: 0 22px 55px rgba(15,23,42,.10);
}

@media (max-width: 576px){
  .hero-title{ font-size: 2.2rem; }
}


/* ===== Section styling ===== */
section{ position: relative; }
.section-alt{
  background:
    radial-gradient(800px 380px at 20% 10%, rgba(249,115,22,.10), transparent 60%),
    radial-gradient(900px 520px at 85% 20%, rgba(20,184,166,.12), transparent 55%),
    linear-gradient(180deg, #ffffff 0%, var(--bg-soft) 100%);
}
section.py-5{ padding-top: 4.25rem !important; padding-bottom: 4.25rem !important; }
.bg-light{ background-color: var(--bg-soft) !important; }

/* Make every block feel intentional: subtle top divider */
section::before{
  content:"";
  position:absolute;
  left:0; right:0; top:0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(15,23,42,.08), transparent);
  opacity: .55;
}

/* ===== Reviews ===== */
.stars{
  color: #f59e0b;
  display:flex;
  gap: .18rem;
  font-size: 1rem;
  line-height: 1;
}
.review-summary{
  padding: .65rem .9rem;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.78);
  box-shadow: 0 14px 30px rgba(15,23,42,.06);
}
.review-card{
  border-radius: var(--radius);
  border: 1px solid rgba(15,23,42,.08);
  box-shadow: var(--shadow);
}
.review-card p{ color: rgba(11,18,32,.86); line-height: 1.65; }

/* ===== Images & cards ===== */
img{ max-width: 100%; height: auto; }
.object-fit-cover{ object-fit: cover; }
.card-img-top{ object-fit: cover; height: 210px; }
@media (max-width: 576px){
  .card-img-top{ height: 190px; }
}

/* ===== Better mobile layout ===== */
@media (max-width: 992px){
  section.py-5{ padding-top: 3.25rem !important; padding-bottom: 3.25rem !important; }
  .timeline{ padding: 1rem; }
  .map-overlay{ left: .75rem; right: .75rem; bottom: .75rem; }
}
@media (max-width: 576px){
  .navbar .btn{ width: 100%; }
  .hero-card{ padding: 1rem !important; }
  .mini-stat{ padding: .7rem .8rem; }
  .tl-dot{ width: 40px; height: 40px; border-radius: 14px; }
  .chip{ width: 100%; justify-content:center; }
  .review-summary{ width: 100%; justify-content: center; }
  .cookie-banner .btn{ width: 100%; }
  .cookie-banner .d-flex.gap-2{ flex-direction: column; }
  .map-card img{ border-radius: var(--radius) !important; }
  .cta-card .btn-lg{ width: 100%; }
  .accordion-button{ padding: .95rem 1rem; }
}

/* Improve readability for long text on small screens */
.lead{ line-height: 1.6; }


/* Icon tiles instead of image tiles */
.brand-tile-icon{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:.2rem;
  padding: .85rem .9rem;
}
.brand-tile-icon .bt-icn{
  width: 42px; height: 42px; border-radius: 16px;
  display:flex; align-items:center; justify-content:center;
  background: rgba(20,184,166,.14);
  border: 1px solid rgba(20,184,166,.18);
  color: #0f766e;
  margin-bottom: .35rem;
}

/* Path icons */
.path-icn{
  width: 46px; height: 46px; border-radius: 16px;
  display:flex; align-items:center; justify-content:center;
  background: rgba(168,85,247,.10);
  border: 1px solid rgba(168,85,247,.18);
  color: #6d28d9;
}

/* Avatar initials */
.avatar-text{
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight: 800;
  background: linear-gradient(135deg, rgba(20,184,166,.18), rgba(29,78,216,.14));
  color: #0b1220;
}
