/* ═══════════════════════════════════════════
   MEDIPLAN — Global Stylesheet
   ═══════════════════════════════════════════ */

:root {
  --blue:       #263A99;
  --blue-dark:  #1a2870;
  --blue-light: #97B4DE;
  --cream:      #F0EBE5;
  --cream-dark: #DCD1BF;
  --dark:       #1F292E;
  --gray:       #868A8C;
  --gray-light: #ACB0B2;
  --white:      #FFFFFF;
  --radius:     15px;
  --font-head:  'Lexend', sans-serif;
  --font-body:  'Work Sans', sans-serif;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-body);
  color: var(--gray);
  background: var(--white);
  line-height: 1.65;
  overflow-x: hidden;
}
h1,h2,h3,h4,h5,h6 {
  font-family: var(--font-head);
  color: var(--dark);
  font-weight: 500;
  line-height: 1.1;
}
a { text-decoration: none; color: inherit; }
img { display: block; width: 100%; }
svg { display: inline-block; vertical-align: middle; }

/* ── CONTAINER ───────────────────────────── */
.container { max-width: 1290px; margin: 0 auto; padding: 0 70px; }
@media(max-width:1024px){ .container { padding: 0 30px; } }
@media(max-width:600px) { .container { padding: 0 20px; } }

/* ── BUTTONS ─────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-head); font-size: 15px; font-weight: 500;
  padding: 14px 28px; border-radius: 30px; cursor: pointer;
  transition: all .25s ease; border: none; letter-spacing: .01em;
  white-space: nowrap;
}
.btn-primary { background: var(--blue); color: var(--white); }
.btn-primary:hover { background: var(--blue-dark); transform: translateY(-1px); }
.btn-outline-blue { background: transparent; color: var(--blue); border: 1.5px solid var(--blue); }
.btn-outline-blue:hover { background: var(--blue); color: var(--white); }
.btn-outline-white { background: transparent; color: var(--white); border: 1.5px solid rgba(255,255,255,.5); }
.btn-outline-white:hover { background: rgba(255,255,255,.12); border-color: var(--white); }
.btn-dark   { background: var(--dark); color: var(--white); }
.btn-dark:hover { background: #0f1c20; }
.btn-cream  { background: var(--cream); color: var(--dark); }
.btn-cream:hover { background: var(--cream-dark); }
.btn-sm { padding: 11px 22px; font-size: 14px; }
.btn-white { background: var(--white); color: var(--blue); }
.btn-white:hover { background: var(--cream); }

/* ── TAGS / LABELS ───────────────────────── */
.tag {
  font-size: 12px; font-weight: 500; letter-spacing: .12em;
  text-transform: uppercase; color: var(--blue-light);
  margin-bottom: 16px; display: block;
}
.tag-pill {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 12px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase;
  color: var(--blue); background: #EEF2FF; padding: 7px 16px; border-radius: 20px;
  margin-bottom: 28px; width: fit-content;
}
.tag-pill .dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--blue); animation: pulse 2s ease-in-out infinite;
}
@keyframes pulse {
  0%,100% { opacity:1; transform:scale(1); }
  50%      { opacity:.4; transform:scale(.7); }
}

/* ── SECTIONS ────────────────────────────── */
.section     { padding: 110px 0; }
.section-alt { background: var(--cream); }
@media(max-width:768px){ .section { padding: 72px 0; } }

.section-header { margin-bottom: 56px; }
.section-header.center { text-align: center; }
.section-header h2 {
  font-size: clamp(28px, 3.5vw, 50px);
  letter-spacing: -.025em; font-weight: 600;
}
.section-header p {
  font-size: 16px; color: var(--gray);
  margin-top: 16px; max-width: 540px; line-height: 1.7;
}
.section-header.center p { margin: 16px auto 0; }

/* ── BRAND GRAPHIC OVERLAYS ──────────────── */
.bg-graphic {
  position: absolute; pointer-events: none;
  overflow: visible; user-select: none; z-index: 0;
}
.bg-graphic svg { display: block; width: 100%; height: 100%; }

/* ── FADE UP ANIMATION ───────────────────── */
.fade-up {
  opacity: 0; transform: translateY(28px);
  transition: opacity .65s ease, transform .65s ease;
}
.fade-up.visible { opacity: 1; transform: translateY(0); }

/* ══════════════════════════════════════════
   PRELAUNCHING BAR
   ══════════════════════════════════════════ */
.prelaunching-bar {
  background: var(--blue); padding: 10px 20px;
  text-align: center; font-size: 13px;
  color: rgba(255,255,255,.9); font-weight: 500; letter-spacing: .02em;
}
.prelaunching-bar strong { color: var(--white); }
.prelaunching-bar a { color: var(--blue-light); text-decoration: underline; font-weight: 600; }

/* ══════════════════════════════════════════
   HEADER
   ══════════════════════════════════════════ */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: var(--white); box-shadow: 0 1px 0 rgba(0,0,0,.07);
  transition: box-shadow .3s;
}
.header-inner {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 70px; gap: 24px;
}
@media(max-width:1024px){ .header-inner { padding: 12px 30px; } }
@media(max-width:600px) { .header-inner { padding: 12px 20px; } }


/* ── LOGO IMAGE ──────────────────────────────── */
.logo-img { display: flex; align-items: center; flex-shrink: 0; }
.logo-img img { height: 32px; width: auto; display: block; }
.footer-logo-img img { height: 32px; width: auto; display: block; margin-bottom: 14px; }
@media(max-width:600px){ .logo-img img { height: 28px; } }


.site-nav { display: flex; align-items: center; gap: 4px; }
.site-nav a {
  font-size: 15px; font-weight: 500; color: var(--dark);
  padding: 8px 16px; border-radius: 8px;
  transition: color .2s, background .2s;
}
.site-nav a:hover,
.site-nav a[aria-current="page"] { color: var(--blue); background: #EEF2FF; }

.header-cta { display: flex; align-items: center; gap: 10px; }

.hamburger {
  display: none; cursor: pointer;
  flex-direction: column; gap: 5px; padding: 8px;
  background: none; border: none;
}
.hamburger span {
  display: block; width: 22px; height: 2px;
  background: var(--dark); transition: .3s; border-radius: 2px;
}

.mobile-nav {
  display: none; flex-direction: column;
  background: var(--white); border-top: 1px solid var(--cream-dark);
  padding: 16px 20px 24px;
}
.mobile-nav.open { display: flex; }
.mobile-nav a {
  padding: 12px 0; font-size: 16px; font-weight: 500; color: var(--dark);
  border-bottom: 1px solid var(--cream); display: block;
}
.mobile-nav a:last-child { border: none; }
.mobile-nav .btn { margin-top: 16px; text-align: center; justify-content: center; }

@media(max-width:768px){
  .site-nav  { display: none; }
  .hamburger { display: flex; }
}

/* ══════════════════════════════════════════
   MARQUEE
   ══════════════════════════════════════════ */
.marquee-bar {
  background: var(--cream); overflow: hidden; padding: 18px 0;
  border-top: 1px solid var(--cream-dark);
  border-bottom: 1px solid var(--cream-dark);
}
.marquee-track {
  display: flex; gap: 48px; width: max-content;
  animation: marquee 24s linear infinite;
}
.marquee-track:hover { animation-play-state: paused; }
.marquee-item {
  font-family: var(--font-head); font-size: 13px; font-weight: 500;
  color: var(--gray); letter-spacing: .06em; text-transform: uppercase;
  display: flex; align-items: center; gap: 12px; white-space: nowrap;
}
.marquee-item svg { color: var(--blue-light); flex-shrink: 0; }
@keyframes marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ══════════════════════════════════════════
   HERO (home)
   ══════════════════════════════════════════ */
.hero {
  display: grid; grid-template-columns: 58% 1fr;
  min-height: 90vh; align-items: stretch;
  padding: 0 70px;
  position: relative; overflow: hidden;
}
@media(max-width:1024px){ .hero { grid-template-columns:1fr; padding:0 30px; min-height:auto; } }
@media(max-width:600px) { .hero { padding:0 20px; } }

.hero-left {
  display: flex; flex-direction: column; justify-content: center;
  padding: 120px 60px 80px 0;
  position: relative; z-index: 1;
}
@media(max-width:1024px){ .hero-left { padding: 80px 0 40px; } }

.hero-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 12px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase;
  color: var(--blue); background: #EEF2FF; padding: 7px 16px; border-radius: 20px;
  margin-bottom: 28px; width: fit-content;
}
.hero h1 {
  font-size: clamp(38px,5vw,72px);
  line-height: .95; letter-spacing: -.03em;
  color: var(--dark); margin-bottom: 24px; font-weight: 600;
}
.hero h1 em { font-style: normal; color: var(--blue); }
.hero-sub {
  font-size: 17px; line-height: 1.65; color: var(--gray);
  max-width: 500px; margin-bottom: 40px;
}
.hero-actions { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 52px; }
.hero-stats { display: flex; gap: 36px; flex-wrap: wrap; }
.stat-num {
  font-family: var(--font-head); font-size: 28px; font-weight: 600;
  color: var(--dark); letter-spacing: -.02em;
}
.stat-label { font-size: 13px; color: var(--gray-light); margin-top: 2px; }

.hero-right {
  position: relative; display: flex; flex-direction: column; gap: 14px;
  padding: 40px 0 40px 40px; z-index: 1;
}
@media(max-width:1024px){ .hero-right { padding:0 0 60px; display:grid; grid-template-columns:1fr 1fr; gap:16px; } }
@media(max-width:600px) { .hero-right { grid-template-columns:1fr; } }

.hero-img-main { border-radius: var(--radius); overflow: hidden; height: 420px; flex: 1; }
.hero-img-main img { height: 100%; object-fit: cover; }

.hero-card {
  background: var(--blue); color: var(--white);
  border-radius: var(--radius); padding: 30px;
  display: flex; flex-direction: column; justify-content: space-between;
}
.hero-card h3 { font-size: 20px; font-weight: 500; color: var(--white); margin-bottom: 10px; }
.hero-card p  { font-size: 14px; color: rgba(255,255,255,.7); line-height: 1.5; }
.hero-card .card-cta {
  margin-top: 20px; font-size: 13px; font-weight: 600; color: var(--white);
  display: flex; align-items: center; gap: 6px;
  text-transform: uppercase; letter-spacing: .08em;
}
.hero-card .card-cta::after { content: '→'; font-size: 16px; }

/* ── HERO IMAGE STRIP ─────────────────────── */
.hero-image-strip { background: var(--white); padding: 0 70px 60px; }
.hero-image-inner {
  border-radius: var(--radius); overflow: hidden;
  box-shadow: 0 20px 60px rgba(38,58,153,.10);
}
.hero-image-inner img { width: 100%; display: block; object-fit: cover; max-height: 580px; }
@media(max-width:1024px){ .hero-image-strip { padding: 0 30px 48px; } }
@media(max-width:600px) { .hero-image-strip { padding: 0 20px 36px; } }

/* ══════════════════════════════════════════
   HERO — INNER PAGES (split)
   ══════════════════════════════════════════ */
.hero-inner {
  display: grid; grid-template-columns: 1fr 1fr;
  min-height: 88vh; align-items: stretch; overflow: hidden;
  position: relative;
}
@media(max-width:900px){ .hero-inner { grid-template-columns:1fr; min-height:auto; } }

.hero-inner-left {
  display: flex; flex-direction: column; justify-content: center;
  padding: 120px 60px 80px 70px; background: var(--white); position: relative; z-index: 1;
}
@media(max-width:1024px){ .hero-inner-left { padding: 80px 40px 60px 30px; } }
@media(max-width:900px) { .hero-inner-left { padding: 70px 20px 50px; } }

.hero-inner-left h1 {
  font-size: clamp(36px,4.5vw,66px);
  letter-spacing: -.03em; font-weight: 600; margin-bottom: 22px; line-height: .95;
}
.hero-inner-left h1 em { font-style: normal; color: var(--blue); }
.hero-inner-sub {
  font-size: 17px; line-height: 1.7; color: var(--gray);
  max-width: 480px; margin-bottom: 36px;
}
.hero-inner-actions { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 44px; }
.hero-badges { display: flex; gap: 10px; flex-wrap: wrap; }
.badge {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 13px; font-weight: 500; color: var(--dark);
  background: var(--cream); padding: 8px 14px; border-radius: 30px;
}
.badge svg { color: var(--blue); }

.hero-inner-right { position: relative; overflow: hidden; }
.hero-inner-right img {
  height: 100%; min-height: 560px; object-fit: cover;
  transition: transform .6s ease;
}
.hero-inner-right:hover img { transform: scale(1.02); }
.hero-inner-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(135deg,rgba(38,58,153,.15) 0%,transparent 60%);
  pointer-events: none;
}
@media(max-width:900px){ .hero-inner-right { min-height: 320px; } .hero-inner-right img { min-height: 320px; } }

/* ══════════════════════════════════════════
   FEATURES GRID
   ══════════════════════════════════════════ */
.features-grid {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 20px;
}
@media(max-width:900px){ .features-grid { grid-template-columns:1fr 1fr; } }
@media(max-width:560px){ .features-grid { grid-template-columns:1fr; } }

.feature-card {
  background: var(--white); border-radius: var(--radius);
  padding: 36px 30px; border: 1px solid var(--cream-dark);
  transition: all .28s ease; position: relative; overflow: hidden;
}
.feature-card::after {
  content: ''; position: absolute; bottom:0; left:0; right:0;
  height: 3px; background: var(--blue);
  transform: scaleX(0); transform-origin: left; transition: transform .3s;
}
.feature-card:hover { transform:translateY(-4px); box-shadow:0 16px 48px rgba(38,58,153,.09); border-color:transparent; }
.feature-card:hover::after { transform: scaleX(1); }

.feature-icon {
  width: 48px; height: 48px; border-radius: 12px;
  background: #EEF2FF; display: flex; align-items: center; justify-content: center;
  margin-bottom: 20px; color: var(--blue); flex-shrink: 0;
}
.feature-num {
  font-family: var(--font-head); font-size: 12px; font-weight: 600;
  letter-spacing: .12em; color: var(--blue-light); text-transform: uppercase;
  margin-bottom: 20px;
}
.feature-card h3 { font-size: 18px; color: var(--dark); margin-bottom: 10px; font-weight: 500; }
.feature-card p  { font-size: 15px; line-height: 1.6; color: var(--gray); }

/* ══════════════════════════════════════════
   AUDIENCE CARDS
   ══════════════════════════════════════════ */
.audience-grid {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 20px;
}
@media(max-width:900px){ .audience-grid { grid-template-columns:1fr; } }

.audience-card {
  border-radius: var(--radius); overflow: hidden; position: relative;
  min-height: 480px; cursor: pointer; transition: transform .35s ease;
}
.audience-card:hover { transform: scale(1.015); }
.audience-card:hover .audience-overlay { opacity: .75; }
.audience-card:hover .audience-cta { transform: translateY(0); opacity: 1; }

.audience-img { position: absolute; inset: 0; }
.audience-img img { width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.audience-card:hover .audience-img img { transform: scale(1.04); }

.audience-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top,rgba(26,40,112,.9) 0%,rgba(26,40,112,.3) 60%,transparent 100%);
  opacity: .65; transition: opacity .3s;
}
.audience-body {
  position: relative; z-index: 2;
  height: 100%; display: flex; flex-direction: column; justify-content: flex-end;
  padding: 32px;
}
.audience-body h3 { font-size: 26px; font-weight: 600; color: var(--white); margin-bottom: 10px; }
.audience-body p  { font-size: 14px; color: rgba(255,255,255,.8); line-height: 1.5; margin-bottom: 20px; }
.audience-cta {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 13px; font-weight: 600; color: var(--white);
  letter-spacing: .08em; text-transform: uppercase;
  transform: translateY(8px); opacity: 0; transition: all .3s ease;
}
.audience-cta::after { content: '→'; font-size: 16px; transition: transform .2s; }
.audience-cta:hover::after { transform: translateX(4px); }

/* ══════════════════════════════════════════
   SPLIT LAYOUT
   ══════════════════════════════════════════ */
.split { display: grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
@media(max-width:900px){ .split { grid-template-columns:1fr; gap:40px; } }

.split-img { border-radius: var(--radius); overflow: hidden; }
.split-img img { height:540px; object-fit:cover; transition:transform .5s; }
.split-img:hover img { transform: scale(1.03); }
@media(max-width:600px){ .split-img img { height:280px; } }

.split-content h2 {
  font-size: clamp(26px,3vw,42px);
  letter-spacing: -.025em; margin-bottom:20px; font-weight:600;
}
.split-content p { font-size:16px; line-height:1.75; margin-bottom:28px; }

.check-list { list-style:none; display:flex; flex-direction:column; gap:13px; margin-bottom:36px; }
.check-list li {
  display:flex; align-items:flex-start; gap:13px;
  font-size:15px; line-height:1.5; color:var(--dark);
}
.check-list li .chk {
  width:22px; height:22px; border-radius:50%;
  background:var(--blue); flex-shrink:0; margin-top:1px;
  display:flex; align-items:center; justify-content:center;
  color:white;
}

/* ══════════════════════════════════════════
   STEPS / HOW IT WORKS
   ══════════════════════════════════════════ */
.steps {
  display: grid; grid-template-columns: repeat(4,1fr);
  gap: 24px; position: relative;
}
.steps::before {
  content:''; position:absolute;
  top:32px; left:calc(12.5% + 16px); right:calc(12.5% + 16px);
  height:2px; background:var(--cream-dark); z-index:0;
}
@media(max-width:900px){ .steps { grid-template-columns:1fr 1fr; } .steps::before { display:none; } }
@media(max-width:480px){ .steps { grid-template-columns:1fr; } }

.step-item { text-align:center; position:relative; z-index:1; }
.step-num {
  width:64px; height:64px; border-radius:50%;
  background:var(--blue); color:var(--white);
  font-family:var(--font-head); font-size:20px; font-weight:600;
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 20px; transition:transform .3s,box-shadow .3s;
}
.step-item:hover .step-num { transform:scale(1.1); box-shadow:0 8px 24px rgba(38,58,153,.3); }
.step-item h4 { font-size:16px; color:var(--dark); margin-bottom:8px; font-weight:500; }
.step-item p  { font-size:14px; color:var(--gray); line-height:1.5; }

/* ══════════════════════════════════════════
   VALUE GRID
   ══════════════════════════════════════════ */
.value-grid {
  display: grid; grid-template-columns:repeat(3,1fr); gap:20px;
}
@media(max-width:900px){ .value-grid { grid-template-columns:1fr 1fr; } }
@media(max-width:560px){ .value-grid { grid-template-columns:1fr; } }

.value-card {
  background:var(--white); border:1px solid var(--cream-dark);
  border-radius:var(--radius); padding:36px 30px;
  transition:all .28s ease; position:relative; overflow:hidden;
}
.value-card::after {
  content:''; position:absolute; bottom:0; left:0; right:0;
  height:3px; background:var(--blue);
  transform:scaleX(0); transform-origin:left; transition:transform .3s;
}
.value-card:hover { transform:translateY(-4px); box-shadow:0 16px 48px rgba(38,58,153,.09); border-color:transparent; }
.value-card:hover::after { transform:scaleX(1); }
.value-icon {
  width:48px; height:48px; border-radius:12px;
  background:#EEF2FF; display:flex; align-items:center; justify-content:center;
  margin-bottom:20px; color:var(--blue);
}
.value-card h3 { font-size:18px; color:var(--dark); margin-bottom:10px; font-weight:500; }
.value-card p  { font-size:15px; line-height:1.6; color:var(--gray); }

/* ══════════════════════════════════════════
   CTA BAND
   ══════════════════════════════════════════ */
.cta-band {
  background:var(--blue); position:relative; overflow:hidden; padding:90px 0;
}
.cta-band-inner { position:relative; z-index:1; text-align:center; }
.cta-band h2 {
  font-size:clamp(28px,4vw,56px); color:var(--white);
  letter-spacing:-.025em; font-weight:600; margin-bottom:16px;
}
.cta-band p { font-size:17px; color:rgba(255,255,255,.75); margin-bottom:40px; }
.cta-band-actions { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* ══════════════════════════════════════════
   PRELAUNCHING CALLOUT BAND
   ══════════════════════════════════════════ */
.prelaunching-section {
  background: linear-gradient(135deg,var(--blue) 0%,var(--blue-dark) 100%);
  padding: 70px 0; position: relative; overflow: hidden;
}
.prelaunching-inner {
  display: grid; grid-template-columns:1fr auto; gap:48px; align-items:center;
  position: relative; z-index: 1;
}
@media(max-width:768px){ .prelaunching-inner { grid-template-columns:1fr; gap:28px; } }
.prelaunching-text h2 {
  font-size:clamp(22px,3vw,36px); color:var(--white);
  letter-spacing:-.02em; font-weight:600; margin-bottom:12px;
}
.prelaunching-text p { font-size:16px; color:rgba(255,255,255,.75); max-width:540px; line-height:1.6; }

/* ══════════════════════════════════════════
   IMAGE HIGHLIGHT
   ══════════════════════════════════════════ */
.img-highlight {
  position:relative; border-radius:var(--radius);
  overflow:hidden; min-height:480px;
}
.img-highlight img { height:100%; min-height:480px; object-fit:cover; }
.img-highlight-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top,rgba(26,40,112,.85) 0%,rgba(26,40,112,.2) 55%,transparent 100%);
}
.img-highlight-body {
  position:absolute; bottom:0; left:0; right:0;
  padding:48px 44px; z-index:2;
}
.img-highlight-body h2 {
  font-size:clamp(22px,3vw,40px); color:var(--white);
  letter-spacing:-.025em; font-weight:600; margin-bottom:14px;
}
.img-highlight-body p { font-size:16px; color:rgba(255,255,255,.8); line-height:1.65; max-width:560px; margin-bottom:28px; }

/* ══════════════════════════════════════════
   QUOTE BAND
   ══════════════════════════════════════════ */
.quote-band { background:var(--cream); padding:80px 0; text-align:center; }
.quote-text {
  font-family:var(--font-head); font-size:clamp(18px,2.5vw,28px);
  color:var(--dark); font-weight:400; line-height:1.5;
  max-width:740px; margin:0 auto 24px; letter-spacing:-.01em;
}
.quote-text em { color:var(--blue); font-style:normal; }
.quote-attr { font-size:13px; color:var(--gray-light); font-weight:500; text-transform:uppercase; letter-spacing:.1em; }

/* ══════════════════════════════════════════
   TRUST ITEMS
   ══════════════════════════════════════════ */
.trust-items { display:flex; flex-direction:column; gap:13px; margin-bottom:32px; }
.trust-item { display:flex; align-items:center; gap:12px; font-size:14px; color:var(--dark); font-weight:500; }
.trust-icon {
  width:34px; height:34px; border-radius:50%;
  background:var(--blue); display:flex; align-items:center; justify-content:center;
  flex-shrink:0; color:white;
}

/* ══════════════════════════════════════════
   FORM
   ══════════════════════════════════════════ */
.form-section { padding: 110px 0; }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:start; }
@media(max-width:900px){ .form-grid { grid-template-columns:1fr; gap:48px; } }

.form-intro h2 { font-size:clamp(24px,3vw,40px); letter-spacing:-.025em; margin-bottom:18px; font-weight:600; }
.form-intro p { font-size:16px; line-height:1.75; margin-bottom:28px; }
.form-note {
  font-size:13px; color:var(--gray-light); line-height:1.6;
  padding:16px 20px; background:var(--cream); border-radius:10px;
  border-left:3px solid var(--blue-light);
  display:flex; align-items:flex-start; gap:10px;
}
.form-note svg { flex-shrink:0; color:var(--blue-light); margin-top:1px; }

.signup-form {
  background:var(--white); border-radius:20px; padding:44px 40px;
  box-shadow:0 4px 40px rgba(38,58,153,.1);
  border:1px solid rgba(38,58,153,.08);
}
@media(max-width:480px){ .signup-form { padding:30px 22px; } }

.form-badge {
  display:inline-flex; align-items:center; gap:8px;
  font-size:12px; font-weight:600; letter-spacing:.1em; text-transform:uppercase;
  color:var(--blue); background:#EEF2FF; padding:6px 14px; border-radius:20px;
  margin-bottom:18px;
}
.form-badge .dot { width:7px; height:7px; border-radius:50%; background:var(--blue); animation:pulse 2s ease-in-out infinite; }

.signup-form h3 { font-size:22px; font-weight:600; margin-bottom:6px; color:var(--dark); }
.form-sub { font-size:14px; color:var(--gray); margin-bottom:28px; }

.form-group { margin-bottom:14px; }
.form-group label { display:block; font-size:13px; font-weight:500; color:var(--dark); margin-bottom:5px; }
.form-control {
  width:100%; padding:13px 16px;
  border:1.5px solid var(--cream-dark); border-radius:10px;
  font-family:var(--font-body); font-size:15px; color:var(--dark);
  background:var(--white); outline:none;
  transition:border-color .2s,box-shadow .2s; -webkit-appearance:none;
}
.form-control:focus { border-color:var(--blue); box-shadow:0 0 0 3px rgba(38,58,153,.1); }
.form-control::placeholder { color:var(--gray-light); }
select.form-control { cursor:pointer; }

.form-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
@media(max-width:480px){ .form-row { grid-template-columns:1fr; } }

.form-check {
  display:flex; align-items:flex-start; gap:10px;
  margin-top:4px; margin-bottom:20px;
  font-size:13px; color:var(--gray); line-height:1.5;
}
.form-check input[type=checkbox] { width:16px; height:16px; margin-top:2px; flex-shrink:0; accent-color:var(--blue); }
.form-check a { color:var(--blue); }

.form-submit {
  width:100%; padding:16px; border-radius:10px;
  background:var(--blue); color:var(--white);
  font-family:var(--font-head); font-size:16px; font-weight:600;
  border:none; cursor:pointer; transition:background .2s,transform .15s;
}
.form-submit:hover { background:var(--blue-dark); transform:translateY(-1px); }
.form-submit:disabled { background:#aaa; cursor:not-allowed; transform:none; }
.form-submit.success { background:#16a34a; }

.form-privacy { font-size:12px; color:var(--gray-light); text-align:center; margin-top:14px; line-height:1.5; }

/* ── Form alert messages ─ */
.form-alert {
  padding:14px 18px; border-radius:10px; font-size:14px;
  margin-bottom:18px; display:none;
}
.form-alert.show { display:block; }
.form-alert.success { background:#dcfce7; color:#15803d; border:1px solid #86efac; }
.form-alert.error   { background:#fee2e2; color:#dc2626; border:1px solid #fca5a5; }

/* ══════════════════════════════════════════
   FOOTER
   ══════════════════════════════════════════ */
.site-footer {
  background: var(--blue); padding: 80px 70px 0;
  position: relative; overflow: hidden;
}
@media(max-width:1024px){ .site-footer { padding:60px 30px 0; } }
@media(max-width:600px) { .site-footer { padding:50px 20px 0; } }

.footer-bg-img {
  position:absolute; top:0; right:0; bottom:0; width:45%;
  background-image:url('https://mediplan.pt/wp-content/uploads/2024/09/footer.png');
  background-size:cover; background-position:center;
  opacity:.12; pointer-events:none;
}
.footer-top {
  position:relative; z-index:1;
  display:flex; justify-content:space-between; align-items:flex-start;
  gap:48px; flex-wrap:wrap; padding-bottom:56px;
}
.footer-logo {
  font-family:var(--font-head); font-size:28px; font-weight:600;
  color:var(--white); letter-spacing:-.02em; margin-bottom:14px;
}
.footer-logo span { color:rgba(151,180,222,.8); }
.footer-tagline { font-size:14px; color:rgba(255,255,255,.5); max-width:220px; line-height:1.6; }
.footer-socials { display:flex; gap:10px; margin-top:24px; }
.social-btn {
  width:38px; height:38px; border-radius:50%;
  border:1px solid rgba(255,255,255,.2);
  display:flex; align-items:center; justify-content:center;
  color:rgba(255,255,255,.7); transition:all .2s;
}
.social-btn:hover { background:rgba(255,255,255,.12); color:var(--white); border-color:rgba(255,255,255,.4); }

.footer-links { display:flex; gap:64px; flex-wrap:wrap; }
.footer-col h5 {
  font-size:12px; font-weight:600; letter-spacing:.1em; text-transform:uppercase;
  color:rgba(255,255,255,.4); margin-bottom:18px;
}
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:10px; }
.footer-col ul li a { font-size:15px; color:rgba(255,255,255,.7); transition:color .2s; }
.footer-col ul li a:hover { color:var(--white); }

.footer-bottom {
  position:relative; z-index:1;
  border-top:1px solid rgba(255,255,255,.12);
  padding:24px 0; display:flex; justify-content:space-between; align-items:center;
  flex-wrap:wrap; gap:12px;
}
.footer-bottom p { font-size:13px; color:rgba(255,255,255,.4); }
.footer-bottom a { color:rgba(255,255,255,.5); font-size:13px; }
.footer-bottom a:hover { color:rgba(255,255,255,.85); }
