/* ==========================================================================
   Dr. Nigar Qəhrəmanova — Premium Medical Design System
   Self-hosted Manrope · Vanilla CSS · WCAG AA · No external dependencies
   ========================================================================== */

/* ---- Font (self-hosted variable woff2) ---- */
/* Manrope — Azerbaijani glyphs (Ə ə Ş ş Ğ ğ İ ı Ö ö Ü ü Ç ç) come from the latin-ext subset */
@font-face {
  font-family: "Manrope";
  font-style: normal;
  font-weight: 400 800;
  font-display: swap;
  src: url("/fonts/manrope-ext.woff2") format("woff2");
  unicode-range: U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}
@font-face {
  font-family: "Manrope";
  font-style: normal;
  font-weight: 400 800;
  font-display: swap;
  src: url("/fonts/manrope-variable.woff2") format("woff2");
  unicode-range: U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}

/* ---- Design tokens ---- */
:root {
  --ink:        #15302E;
  --primary:    #0E4C49;
  --primary-700:#0A3A38;
  --primary-600:#0C403D;
  --primary-50: #EAF3F1;
  --primary-100:#D7E8E5;
  --accent:     #BE9A57;   /* muted gold — decorative / large only */
  --accent-soft:#F3ECDD;
  --rose:       #A86A70;   /* women's-health warmth — tertiary accent */
  --rose-soft:  #F6ECEC;
  --bg:         #FFFFFF;
  --bg-soft:    #F4F8F7;
  --bg-deep:    #0B302E;   /* dark sections */
  --line:       #E1EAE8;
  --line-strong:#CBD9D6;
  --text:       #233A38;
  --muted:      #5B6E6B;
  --white:      #FFFFFF;

  --radius:     14px;
  --radius-lg:  22px;
  --radius-pill:999px;
  --shadow-sm:  0 1px 2px rgba(11,48,46,.06), 0 1px 3px rgba(11,48,46,.05);
  --shadow:     0 6px 20px -8px rgba(11,48,46,.18), 0 2px 6px rgba(11,48,46,.06);
  --shadow-lg:  0 24px 60px -18px rgba(11,48,46,.30);
  --container:  1180px;
  --gutter:     clamp(20px, 5vw, 56px);
  --sp-section: clamp(64px, 9vw, 132px);

  --ff: "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

/* ---- Reset / base ---- */
*,*::before,*::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } *{ animation-duration:.01ms!important; transition-duration:.01ms!important; } }

body {
  font-family: var(--ff);
  font-weight: 450;
  color: var(--text);
  background: var(--bg);
  line-height: 1.65;
  font-size: clamp(16px, 1.05vw, 17.5px);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

img,video { display:block; max-width:100%; height:auto; }
svg { display:inline-block; vertical-align:middle; width:1.2em; height:1.2em; flex:0 0 auto; }
a { color: var(--primary); text-decoration: none; transition: color .18s ease; }
a:hover { color: var(--primary-700); }
strong { font-weight: 700; }
ul,ol { padding-left: 1.2em; }
li { margin: .35em 0; }

h1,h2,h3,h4 { color: var(--ink); line-height: 1.14; font-weight: 750; letter-spacing: -0.018em; text-wrap: balance; }
h1 { font-size: clamp(2.1rem, 5.2vw, 3.65rem); font-weight: 800; }
h2 { font-size: clamp(1.7rem, 3.5vw, 2.6rem); }
h3 { font-size: clamp(1.22rem, 2vw, 1.5rem); font-weight: 720; }
h4 { font-size: 1.08rem; font-weight: 720; }
p { text-wrap: pretty; }

:focus-visible { outline: 3px solid var(--accent); outline-offset: 2px; border-radius: 4px; }

/* ---- Layout helpers ---- */
.container { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: var(--gutter); }
.section { padding-block: var(--sp-section); }
.section--soft { background: var(--bg-soft); }
.section--tight { padding-block: clamp(48px,6vw,84px); }
.eyebrow {
  display:inline-flex; align-items:center; gap:.55em;
  font-size:.78rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase;
  color: var(--primary); margin-bottom: 1rem;
}
.eyebrow::before { content:""; width:26px; height:2px; background:var(--accent); display:inline-block; }
.lead { font-size: clamp(1.05rem,1.6vw,1.22rem); color: var(--text); }
.muted { color: var(--muted); }
.center { text-align:center; }
.measure { max-width: 70ch; }
.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.75rem}.mt-4{margin-top:2.5rem}

/* skip link */
.skip-link{ position:absolute; left:14px; top:-60px; background:var(--primary); color:#fff; padding:10px 16px; border-radius:8px; z-index:200; transition:top .2s; }
.skip-link:focus{ top:14px; color:#fff; }

/* ---- Buttons ---- */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:.5em;
  font: inherit; font-weight:700; font-size:.97rem; line-height:1;
  padding: .95em 1.5em; border-radius: var(--radius-pill);
  border: 1.5px solid transparent; cursor:pointer; transition: all .2s ease;
  text-align:center; white-space:nowrap;
}
.btn--primary { background: var(--primary); color:#fff; box-shadow: var(--shadow-sm); }
.btn--primary:hover { background: var(--primary-700); color:#fff; transform: translateY(-2px); box-shadow: var(--shadow); }
.btn--wa { background:#1faf54; color:#fff; }
.btn--wa:hover { background:#178c43; color:#fff; transform: translateY(-2px); }
.btn--ghost { background: transparent; color: var(--primary); border-color: var(--line-strong); }
.btn--ghost:hover { border-color: var(--primary); background: var(--primary-50); color:var(--primary-700); }
.btn--light { background:#fff; color:var(--primary); }
.btn--light:hover { background:var(--accent-soft); color:var(--primary-700); transform:translateY(-2px); }
.btn--lg { padding: 1.05em 1.9em; font-size: 1.02rem; }
.btn--block { width:100%; }
.btn-row { display:flex; flex-wrap:wrap; gap:.7rem; }

/* ---- Header / nav ---- */
.site-header {
  position: sticky; top:0; z-index:100;
  background: rgba(255,255,255,.86); backdrop-filter: saturate(140%) blur(12px);
  border-bottom: 1px solid var(--line);
  transition: box-shadow .25s ease, background .25s ease;
}
.site-header.is-scrolled { box-shadow: var(--shadow-sm); }
.nav { display:flex; align-items:center; justify-content:space-between; gap:1rem; min-height:74px; }
.brand { display:flex; align-items:center; gap:.7rem; font-weight:800; color:var(--ink); letter-spacing:-.02em; font-size:1.06rem; }
.brand:hover{ color:var(--ink); }
.brand__mark { width:42px; height:42px; border-radius:12px; background:linear-gradient(140deg,var(--primary),var(--primary-700)); color:#fff; display:grid; place-items:center; font-weight:800; font-size:1.15rem; flex:0 0 auto; box-shadow: var(--shadow-sm); }
.brand__mark span{ background:linear-gradient(180deg,#fff,#d9ece9); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.brand__sub{ display:block; font-size:.7rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); margin-top:1px; }
.nav__links { display:flex; align-items:center; gap:.3rem; list-style:none; padding:0; margin:0; }
.nav__links a { display:block; padding:.55em .8em; border-radius:10px; color:var(--text); font-weight:600; font-size:.93rem; white-space:nowrap; }
.nav__links a:hover, .nav__links a[aria-current="page"] { color:var(--primary-700); background:var(--primary-50); }
.nav__menu { display:flex; align-items:center; gap:1.4rem; }
.nav__cta { display:flex; align-items:center; gap:.6rem; }
.nav__toggle { display:none; background:none; border:1.5px solid var(--line-strong); border-radius:10px; width:46px; height:46px; cursor:pointer; align-items:center; justify-content:center; }
.nav__toggle span, .nav__toggle span::before, .nav__toggle span::after { content:""; display:block; width:20px; height:2px; background:var(--ink); border-radius:2px; position:relative; transition:.2s; }
.nav__toggle span::before{ position:absolute; top:-6px; } .nav__toggle span::after{ position:absolute; top:6px; }
.nav__toggle[aria-expanded="true"] span{ background:transparent; }
.nav__toggle[aria-expanded="true"] span::before{ top:0; transform:rotate(45deg); }
.nav__toggle[aria-expanded="true"] span::after{ top:0; transform:rotate(-45deg); }

@media (max-width: 940px){
  .nav__toggle{ display:inline-flex; order:3; }
  .nav__menu {
    position:fixed; inset:74px 0 auto 0; background:#fff; border-bottom:1px solid var(--line);
    flex-direction:column; align-items:stretch; gap:0; padding:12px var(--gutter) 22px;
    box-shadow:var(--shadow-lg); transform:translateY(-12px); opacity:0; pointer-events:none; transition:.22s;
    max-height:calc(100vh - 74px); overflow:auto;
  }
  .nav__menu.is-open{ transform:none; opacity:1; pointer-events:auto; }
  .nav__links{ flex-direction:column; align-items:stretch; }
  .nav__links a{ padding:.85em .4em; border-bottom:1px solid var(--line); border-radius:0; }
  .nav__cta{ margin-top:1rem; flex-direction:column; align-items:stretch; }
  .nav__cta .btn{ width:100%; }
}

/* ---- Hero ---- */
.hero { position:relative; background: linear-gradient(180deg,#fff 0%, var(--bg-soft) 100%); overflow:hidden; }
.hero::before{ content:""; position:absolute; inset:0; background:
  radial-gradient(60% 70% at 88% 0%, rgba(190,154,87,.10), transparent 60%),
  radial-gradient(50% 60% at 8% 100%, rgba(14,76,73,.07), transparent 60%); pointer-events:none; }
.hero__grid { display:grid; grid-template-columns: 1.08fr .92fr; gap: clamp(28px,5vw,72px); align-items:center; padding-block: clamp(48px,7vw,104px); position:relative; }
.hero__eyebrow{ color:var(--primary); }
.hero h1 { margin-top:.2rem; }
.hero h1 .hl { color:var(--primary); }
.hero__sub { margin-top:1.3rem; font-size:clamp(1.05rem,1.5vw,1.22rem); color:var(--text); max-width:36ch; }
.hero__cta{ margin-top:2rem; }
.hero__trust{ margin-top:2.4rem; display:flex; gap:clamp(18px,3vw,40px); flex-wrap:wrap; }
.hero__trust .stat strong{ display:block; font-size:1.7rem; font-weight:800; color:var(--ink); letter-spacing:-.02em; line-height:1; }
.hero__trust .stat span{ font-size:.85rem; color:var(--muted); font-weight:600; }
.hero__media{ position:relative; }
.hero__portrait{ width:100%; aspect-ratio:4/4.6; border-radius:26px; overflow:hidden; box-shadow:var(--shadow-lg); background:linear-gradient(160deg,var(--primary-50),#fff); }
.hero__portrait img{ width:100%; height:100%; object-fit:cover; }
.hero__badge{ position:absolute; left:-18px; bottom:30px; background:#fff; border-radius:16px; box-shadow:var(--shadow); padding:14px 18px; display:flex; align-items:center; gap:12px; max-width:250px; }
.hero__badge .ic{ width:42px;height:42px;border-radius:11px;background:var(--primary-50);display:grid;place-items:center;color:var(--primary);flex:0 0 auto;}
.hero__badge b{ display:block; color:var(--ink); font-size:.95rem; } .hero__badge small{ color:var(--muted); font-size:.8rem; }
@media (max-width: 880px){
  .hero__grid{ grid-template-columns:1fr; }
  .hero__media{ order:-1; max-width:440px; }
  .hero__badge{ left:auto; right:-6px; }
}

/* ---- Trust strip ---- */
.trust-strip{ background:var(--bg-deep); color:#cfe3e0; }
.trust-strip .container{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; padding-block:clamp(34px,4vw,52px); }
.trust-strip .ti b{ display:block; color:#fff; font-weight:750; font-size:1.02rem; }
.trust-strip .ti span{ font-size:.88rem; color:#9fc0bb; }
.trust-strip .ti .k{ color:var(--accent); font-weight:800; font-size:1.45rem; display:block; letter-spacing:-.02em; }
@media (max-width:760px){ .trust-strip .container{ grid-template-columns:repeat(2,1fr);} }

/* ---- Section header ---- */
.sec-head{ max-width:62ch; margin-bottom: clamp(30px,4vw,52px); }
.sec-head.center{ margin-inline:auto; }
.sec-head p{ margin-top:.9rem; color:var(--muted); font-size:1.08rem; }

/* ---- Cards / grids ---- */
.grid{ display:grid; gap: clamp(16px,2vw,24px); }
.grid--3{ grid-template-columns:repeat(3,1fr); }
.grid--2{ grid-template-columns:repeat(2,1fr); }
.grid--4{ grid-template-columns:repeat(4,1fr); }
@media (max-width:980px){ .grid--3,.grid--4{ grid-template-columns:repeat(2,1fr);} }
@media (max-width:600px){ .grid--2,.grid--3,.grid--4{ grid-template-columns:1fr;} }

.card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:clamp(22px,2.4vw,30px); transition:.22s; position:relative; overflow:hidden; }
.card:hover{ border-color:var(--primary-100); box-shadow:var(--shadow); transform:translateY(-3px); }
.card__ic{ width:52px; height:52px; border-radius:14px; background:var(--primary-50); color:var(--primary); display:grid; place-items:center; margin-bottom:1.1rem; }
.card__ic svg{ width:26px; height:26px; }
.card h3{ font-size:1.18rem; }
.card p{ color:var(--muted); margin-top:.5rem; font-size:.97rem; }
.card .more{ display:inline-flex; align-items:center; gap:.4em; margin-top:1rem; font-weight:700; font-size:.92rem; color:var(--primary); }
.card .more svg{ width:16px; height:16px; transition:transform .2s; }
.card:hover .more svg{ transform:translateX(4px); }
.card--accent::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:4px; background:linear-gradient(var(--primary),var(--accent)); }

/* pillar service card (featured) */
.pillar{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(16px,2vw,24px); }
@media (max-width:900px){ .pillar{ grid-template-columns:1fr; } }
.pillar .card{ padding-block:clamp(26px,3vw,38px); }

/* simple link list (services/diseases index) */
.linklist{ list-style:none; padding:0; margin:0; display:grid; grid-template-columns:repeat(2,1fr); gap:.4rem 1.5rem; }
@media (max-width:680px){ .linklist{ grid-template-columns:1fr; } }
.linklist a{ display:flex; align-items:center; justify-content:space-between; gap:1rem; padding:.85em .4em; border-bottom:1px solid var(--line); color:var(--text); font-weight:600; }
.linklist a:hover{ color:var(--primary); padding-left:.7em; }
.linklist a span.t{ color:var(--accent); }

/* tag chips */
.chips{ display:flex; flex-wrap:wrap; gap:.5rem; }
.chip{ font-size:.85rem; font-weight:600; color:var(--primary-700); background:var(--primary-50); border:1px solid var(--primary-100); padding:.4em .85em; border-radius:var(--radius-pill); }

/* ---- Article / content pages ---- */
.page-hero{ background:linear-gradient(180deg,var(--bg-soft),#fff); border-bottom:1px solid var(--line); }
.page-hero .container{ padding-block: clamp(38px,5vw,66px); }
.breadcrumb{ font-size:.85rem; color:var(--muted); margin-bottom:1rem; display:flex; gap:.5em; flex-wrap:wrap; }
.breadcrumb a{ color:var(--muted); } .breadcrumb a:hover{ color:var(--primary); }
.breadcrumb .sep{ color:var(--line-strong); }
.page-hero h1{ max-width:20ch; }
.page-hero .lead{ margin-top:1rem; max-width:62ch; color:var(--text); }

.prose{ max-width:74ch; }
.prose > * + *{ margin-top:1.1rem; }
.prose h2{ margin-top:2.4rem; font-size:clamp(1.4rem,2.4vw,1.85rem); }
.prose h3{ margin-top:1.8rem; }
.prose ul,.prose ol{ padding-left:1.25em; } .prose li{ margin:.45em 0; }
.prose .answer{ background:var(--primary-50); border-left:4px solid var(--primary); border-radius:0 12px 12px 0; padding:1.1em 1.3em; font-size:1.06rem; color:var(--ink); }
.prose .note{ background:var(--accent-soft); border-radius:12px; padding:1em 1.2em; font-size:.97rem; }

/* content layout with sidebar */
.content-layout{ display:grid; grid-template-columns: 1fr 320px; gap: clamp(28px,4vw,60px); align-items:start; }
@media (max-width:920px){ .content-layout{ grid-template-columns:1fr; } }
.sidebar{ position:sticky; top:96px; display:grid; gap:1rem; }
.side-card{ border:1px solid var(--line); border-radius:var(--radius-lg); padding:24px; background:#fff; }
.side-card--cta{ background:linear-gradient(160deg,var(--primary),var(--primary-700)); color:#fff; border:0; box-shadow:var(--shadow); }
.side-card--cta h3{ color:#fff; } .side-card--cta p{ color:#cfe3e0; font-size:.95rem; margin-top:.4rem; }
.side-card--cta .btn{ margin-top:1rem; }
.side-card h4{ margin-bottom:.8rem; font-size:.8rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }
.side-links{ list-style:none; padding:0; margin:0; }
.side-links li{ margin:0; } .side-links a{ display:block; padding:.5em 0; border-bottom:1px solid var(--line); font-weight:600; font-size:.95rem; color:var(--text);} .side-links a:hover{ color:var(--primary);}

/* fact rows */
.facts{ list-style:none; padding:0; margin:1.4rem 0; display:grid; gap:.1rem; }
.facts li{ display:flex; gap:.8rem; padding:.7em 0; border-bottom:1px dashed var(--line); margin:0; }
.facts .ic{ color:var(--primary); flex:0 0 auto; margin-top:2px; }

/* ---- FAQ accordion ---- */
.faq{ border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background:#fff; }
.faq + .faq{ margin-top:.7rem; }
.faq__q{ width:100%; text-align:left; background:none; border:0; font:inherit; font-weight:700; color:var(--ink); padding:1.05em 1.2em; display:flex; justify-content:space-between; gap:1rem; align-items:center; cursor:pointer; font-size:1.02rem; }
.faq__q:hover{ color:var(--primary); }
.faq__q .pm{ flex:0 0 auto; width:24px; height:24px; position:relative; }
.faq__q .pm::before,.faq__q .pm::after{ content:""; position:absolute; background:var(--primary); border-radius:2px; left:50%; top:50%; transform:translate(-50%,-50%); transition:.2s; }
.faq__q .pm::before{ width:13px; height:2px; } .faq__q .pm::after{ width:2px; height:13px; }
.faq__q[aria-expanded="true"] .pm::after{ transform:translate(-50%,-50%) rotate(90deg); opacity:0; }
.faq__a{ max-height:0; overflow:hidden; transition:max-height .28s ease; }
.faq__a > div{ padding:0 1.2em 1.2em; color:var(--text); }
.faq-cat{ margin-top:2.6rem; } .faq-cat:first-child{ margin-top:0; }
.faq-cat > h2{ font-size:1.3rem; margin-bottom:1rem; padding-bottom:.5rem; border-bottom:2px solid var(--primary-50); }

/* ---- CTA band ---- */
.cta-band{ background:linear-gradient(150deg,var(--primary),var(--primary-700)); color:#fff; border-radius:var(--radius-lg); padding:clamp(34px,5vw,64px); text-align:center; position:relative; overflow:hidden; }
.cta-band::after{ content:""; position:absolute; inset:0; background:radial-gradient(50% 80% at 80% 10%, rgba(190,154,87,.22), transparent 60%); }
.cta-band h2{ color:#fff; position:relative; } .cta-band p{ color:#cfe3e0; max-width:54ch; margin:1rem auto 0; position:relative; }
.cta-band .btn-row{ justify-content:center; margin-top:1.8rem; position:relative; }

/* ---- About / bio ---- */
.bio-grid{ display:grid; grid-template-columns: .85fr 1.15fr; gap:clamp(28px,4vw,60px); align-items:start; }
@media (max-width:880px){ .bio-grid{ grid-template-columns:1fr; } }
.bio-card{ border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; position:sticky; top:96px; }
.bio-card__img{ aspect-ratio:1/1.12; background:linear-gradient(160deg,var(--primary-50),#fff); }
.bio-card__img img{ width:100%; height:100%; object-fit:cover; }
.bio-card__body{ padding:24px; }
.bio-card__body h3{ font-size:1.25rem; } .bio-card__body .role{ color:var(--primary); font-weight:700; font-size:.9rem; }
.timeline{ list-style:none; padding:0; margin:0; }
.timeline li{ position:relative; padding:0 0 1.4rem 1.6rem; border-left:2px solid var(--line); margin:0; }
.timeline li::before{ content:""; position:absolute; left:-7px; top:4px; width:12px; height:12px; border-radius:50%; background:var(--primary); border:2px solid #fff; }
.timeline li:last-child{ border-left-color:transparent; }
.timeline b{ color:var(--ink); }

/* ---- Contact ---- */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(24px,4vw,48px); }
@media (max-width:820px){ .contact-grid{ grid-template-columns:1fr; } }
.contact-card{ border:1px solid var(--line); border-radius:var(--radius-lg); padding:clamp(22px,3vw,32px); }
.contact-row{ display:flex; gap:1rem; padding:1rem 0; border-bottom:1px solid var(--line); align-items:flex-start; }
.contact-row:last-child{ border-bottom:0; }
.contact-row .ic{ width:44px; height:44px; border-radius:12px; background:var(--primary-50); color:var(--primary); display:grid; place-items:center; flex:0 0 auto; }
.contact-row b{ display:block; color:var(--ink); } .contact-row a,.contact-row span{ color:var(--muted); }
.map-embed{ border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--line); aspect-ratio:16/10; background:var(--bg-soft); }
.map-embed iframe{ width:100%; height:100%; border:0; }
.form-field{ margin-bottom:1rem; }
.form-field label{ display:block; font-weight:600; font-size:.9rem; margin-bottom:.4rem; color:var(--ink); }
.form-field input,.form-field textarea,.form-field select{ width:100%; font:inherit; padding:.8em 1em; border:1.5px solid var(--line-strong); border-radius:12px; background:#fff; color:var(--ink); }
.form-field input:focus,.form-field textarea:focus,.form-field select:focus{ outline:none; border-color:var(--primary); box-shadow:0 0 0 3px var(--primary-50); }

/* ---- vCard page ---- */
.vcard{ max-width:520px; margin-inline:auto; border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow); }
.vcard__top{ background:linear-gradient(150deg,var(--primary),var(--primary-700)); color:#fff; padding:32px; text-align:center; }
.vcard__avatar{ width:104px; height:104px; border-radius:50%; margin:0 auto 1rem; background:#fff; overflow:hidden; border:3px solid rgba(255,255,255,.5); }
.vcard__avatar img{ width:100%; height:100%; object-fit:cover; }
.vcard__top h1{ color:#fff; font-size:1.6rem; letter-spacing:-.01em; } .vcard__top .role{ color:#d7ece9; font-weight:600; margin-top:.3rem; }
.vcard__body{ padding:24px; }
.vcard__actions{ display:grid; grid-template-columns:1fr 1fr; gap:.7rem; margin-top:1rem; }
.vcard__socials{ display:flex; justify-content:center; gap:.8rem; margin-top:1.4rem; }
.soc{ width:44px; height:44px; border-radius:12px; border:1px solid var(--line); display:grid; place-items:center; color:var(--primary); }
.soc:hover{ background:var(--primary-50); transform:translateY(-2px); }

/* ---- Footer ---- */
.site-footer{ background:var(--bg-deep); color:#aecbc6; padding-block: clamp(48px,6vw,80px) 0; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:clamp(24px,3vw,48px); }
@media (max-width:860px){ .footer-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .footer-grid{ grid-template-columns:1fr; } }
.site-footer h4{ color:#fff; font-size:.82rem; letter-spacing:.1em; text-transform:uppercase; margin-bottom:1rem; }
.site-footer a{ color:#aecbc6; } .site-footer a:hover{ color:#fff; }
.footer-links{ list-style:none; padding:0; margin:0; display:grid; gap:.6rem; font-size:.95rem; }
.footer-brand .brand{ color:#fff; } .footer-brand .brand__sub{ color:#7fa8a2; }
.footer-brand p{ margin-top:1rem; font-size:.95rem; color:#9fc0bb; max-width:32ch; }
.footer-contact{ display:grid; gap:.7rem; font-size:.95rem; }
.footer-contact b{ color:#fff; }
.footer-bottom{ margin-top:clamp(36px,4vw,56px); border-top:1px solid rgba(255,255,255,.1); padding-block:24px; display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; font-size:.85rem; color:#7fa8a2; }
.footer-bottom a{ color:#cfe3e0; font-weight:600; }
.site-by{ display:inline-flex; align-items:center; gap:.4em; }

/* ---- Floating WhatsApp ---- */
.fab{ position:fixed; right:18px; bottom:18px; z-index:90; width:58px; height:58px; border-radius:50%; background:#1faf54; color:#fff; display:grid; place-items:center; box-shadow:0 10px 30px -6px rgba(31,175,84,.6); transition:.2s; }
.fab:hover{ transform:translateY(-3px) scale(1.04); color:#fff; }
.fab svg{ width:30px; height:30px; }
@media (max-width:520px){ .fab{ width:54px; height:54px; right:14px; bottom:14px; } }

/* ---- utilities ---- */
.divider{ height:1px; background:var(--line); border:0; margin-block:2rem; }
.badge-soft{ display:inline-flex; align-items:center; gap:.4em; background:var(--rose-soft); color:var(--rose); font-weight:700; font-size:.8rem; padding:.4em .8em; border-radius:var(--radius-pill); }
.text-accent{ color:var(--accent); }
.last-updated{ font-size:.82rem; color:var(--muted); margin-top:2.5rem; padding-top:1rem; border-top:1px solid var(--line); }
