/* ==========================================================================
   Grootfaam Care — Design tokens
   ========================================================================== */
:root{
  --color-bg:        #FFFFFF;
  --color-bg-alt:    #EAF1F5;
  --color-card:      #FFFFFF;
  --color-sage:      #6E97AC;
  --color-sage-dark: #33586B;
  --color-sage-deep: #22394A;
  --color-honey:     #D9A7AD;
  --color-accent2:   #C48891;
  --color-text:      #22394A;
  --color-text-soft: #52626C;
  --color-border:    #DCE7EC;

  --font-display: 'Fraunces', Georgia, serif;
  --font-body:    'Work Sans', -apple-system, sans-serif;
  --font-caption: 'Work Sans', sans-serif;

  --radius-s: 6px;
  --radius-m: 12px;
  --radius-l: 20px;

  --container: 1120px;
}

*,*::before,*::after{ box-sizing:border-box; }

html{ scroll-behavior:smooth; }

body{
  margin:0;
  background:var(--color-bg);
  color:var(--color-text);
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}

img{ max-width:100%; display:block; }

a{ color:inherit; text-decoration:none; }

h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:600;
  line-height:1.15;
  margin:0 0 .5em;
  color:var(--color-sage-deep);
}

h1{ font-size:clamp(2.4rem, 5vw, 4rem); font-weight:500; letter-spacing:-0.01em; }
h2{ font-size:clamp(1.7rem, 3.2vw, 2.5rem); }
h3{ font-size:1.3rem; }

p{ margin:0 0 1em; color:var(--color-text-soft); }

.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:.5em;
  font-family:var(--font-caption);
  font-size:.78rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--color-sage-dark);
  font-weight:600;
  margin-bottom:1em;
}
.eyebrow::before{
  content:"";
  width:22px; height:1px;
  background:var(--color-honey);
  display:inline-block;
}

.container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 32px;
}

.section{ padding:96px 0; }
.section--tight{ padding:64px 0; }
.section--alt{ background:var(--color-bg-alt); }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  gap:.6em;
  padding:14px 28px;
  border-radius:9px;
  font-family:var(--font-body);
  font-weight:600;
  font-size:.95rem;
  cursor:pointer;
  border:1px solid transparent;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.btn-primary{
  background:var(--color-sage-dark);
  color:#fff;
}
.btn-primary:hover{ background:var(--color-sage-deep); transform:translateY(-2px); box-shadow:0 10px 24px -10px rgba(34,57,74,.35); }
.btn-secondary{
  background:transparent;
  color:var(--color-sage-deep);
  border-color:var(--color-sage-deep);
}
.btn-secondary:hover{ background:var(--color-sage-deep); color:#fff; transform:translateY(-2px); }

/* ---------- Header / Nav ---------- */
.site-header{
  position:sticky; top:0; z-index:50;
  background:var(--color-bg-alt);
  border-bottom:2px solid var(--color-sage-deep);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  padding:8px 32px;
  max-width:var(--container);
  margin:0 auto;
}
.logo{
  display:flex; align-items:center; gap:12px;
  font-family:var(--font-display);
  font-size:1.28rem;
  font-weight:600;
  color:var(--color-sage-deep);
}
.logo img.logo-mark{ height:84px; width:auto; flex-shrink:0; }
.logo .logo-sub{
  display:block;
  font-family:var(--font-caption);
  font-size:.62rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-weight:600;
  color:var(--color-honey);
}

.nav-links{
  display:flex; align-items:center; gap:36px;
  list-style:none; margin:0; padding:0;
}
.nav-links a{
  font-size:.95rem; font-weight:500;
  color:var(--color-text);
  position:relative;
  padding:4px 0;
}
.nav-links a::after{
  content:"";
  position:absolute; left:0; right:100%; bottom:-2px;
  height:2px; background:var(--color-accent2);
  transition:right .22s ease;
}
.nav-links a:hover::after, .nav-links a.active::after{ right:0; }
.nav-links a.active{ color:var(--color-sage-dark); }

.nav-cta{ display:flex; align-items:center; gap:18px; }

.nav-toggle{
  display:none;
  background:none; border:none; cursor:pointer;
  width:34px; height:34px;
  flex-direction:column; justify-content:center; align-items:center; gap:5px;
}
.nav-toggle span{ width:22px; height:2px; background:var(--color-sage-deep); display:block; }

/* ---------- Footer ---------- */
.site-footer{
  background:var(--color-sage-deep);
  color:#EFE9D8;
  padding:64px 0 32px;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.3fr 1fr 1fr;
  gap:40px;
  padding-bottom:40px;
  border-bottom:1px solid rgba(239,233,216,.18);
}
.footer-grid h4{ color:#fff; font-family:var(--font-caption); font-size:.8rem; letter-spacing:.1em; text-transform:uppercase; margin-bottom:1em; }
.site-footer p, .site-footer a{ color:#D9D2B9; font-size:.95rem; }
.site-footer a:hover{ color:#fff; }
.footer-bottom{
  padding-top:24px;
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px;
  font-size:.82rem; color:#B9B196;
}
.footer-logo{
  font-family:var(--font-display); color:#fff; font-size:1.3rem; margin-bottom:10px; display:block;
}

/* ---------- Growth-ring divider (signature motif) ---------- */
.rings-divider{ display:block; width:100%; height:auto; }
.rings-divider path, .rings-divider circle{ fill:none; }

/* ---------- Hero ---------- */
.hero{
  position:relative;
  padding:88px 0 40px;
  overflow:hidden;
}
.hero-grid{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:56px;
  align-items:center;
}
.hero h1{ margin-bottom:.4em; }
.hero-quote{
  font-family:var(--font-display);
  font-style:italic;
  font-size:1.05rem;
  color:var(--color-sage-dark);
  margin:0 0 22px;
  padding-left:18px;
  border-left:2px solid var(--color-honey);
}
.hero-quote span{
  display:block;
  font-family:var(--font-caption);
  font-style:normal;
  font-size:.78rem;
  letter-spacing:.05em;
  color:var(--color-text-soft);
  margin-top:6px;
}
.hero .lead{ font-size:1.15rem; max-width:46ch; }
.hero-actions{ display:flex; gap:16px; margin-top:32px; flex-wrap:wrap; }

.hero-art{
  position:relative;
  aspect-ratio:1/1;
  display:flex; align-items:center; justify-content:center;
}

/* ---------- Cards ---------- */
.grid{ display:grid; gap:28px; }
.grid-3{ grid-template-columns:repeat(3,1fr); }
.grid-2{ grid-template-columns:repeat(2,1fr); }

.card{
  background:var(--color-card);
  border:1px solid var(--color-border);
  border-radius:var(--radius-m);
  padding:36px 32px;
  transition:transform .2s ease, box-shadow .2s ease;
}
.card:hover{ transform:translateY(-4px); box-shadow:0 20px 40px -24px rgba(34,57,74,.14); }
.card .card-icon{
  width:48px; height:48px;
  margin-bottom:20px;
}
.card h3{ margin-bottom:.5em; }
.card p{ margin-bottom:0; font-size:.96rem; }

/* ---------- Section header ---------- */
.section-head{
  max-width:640px;
  margin:0 0 56px;
}
.section-head.center{ margin-left:auto; margin-right:auto; text-align:center; }

/* ---------- CTA band ---------- */
.cta-band{
  background:var(--color-sage-dark);
  border-radius:var(--radius-l);
  padding:64px 56px;
  color:#fff;
  display:flex; align-items:center; justify-content:space-between; gap:40px; flex-wrap:wrap;
}
.cta-band h2{ color:#fff; margin-bottom:.3em; }
.cta-band p{ color:#DDE7DA; margin-bottom:0; }
.cta-band .btn-primary{ background:#fff; color:var(--color-sage-deep); }
.cta-band .btn-primary:hover{ background:var(--color-honey); color:#fff; }

/* ---------- Page hero (inner pages) ---------- */
.page-hero{
  padding:64px 0 48px;
  text-align:left;
}
.page-hero .eyebrow{ margin-bottom:1.1em; }
.page-hero p.lead{ max-width:60ch; font-size:1.08rem; }

/* ---------- Team / bio ---------- */
.bio-grid{
  display:grid;
  grid-template-columns:.85fr 1.15fr;
  gap:56px;
  align-items:start;
}
.bio-portrait{
  border-radius:var(--radius-l);
  background:var(--color-bg-alt);
  aspect-ratio:4/5;
  display:flex; align-items:center; justify-content:center;
  border:1px solid var(--color-border);
  overflow:hidden;
}
.values-list{ list-style:none; margin:0; padding:0; display:grid; gap:18px; }
.values-list li{
  display:flex; gap:16px; align-items:flex-start;
  padding:18px 20px;
  background:var(--color-card);
  border-radius:var(--radius-s);
  border:1px solid var(--color-border);
}
.values-list .num{
  font-family:var(--font-display);
  color:var(--color-accent2);
  font-size:1.2rem;
  flex-shrink:0;
}

/* ---------- Service detail rows ---------- */
.service-row{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:56px;
  align-items:center;
  padding:56px 0;
  border-bottom:1px solid var(--color-border);
}
.service-row:last-child{ border-bottom:none; }
.service-row.reverse{ direction:rtl; }
.service-row.reverse > *{ direction:ltr; }
.service-tag{
  display:inline-block;
  font-size:.72rem; letter-spacing:.1em; text-transform:uppercase;
  font-weight:700; color:var(--color-sage-dark);
  background:rgba(126,156,123,.14);
  padding:5px 12px; border-radius:999px;
  margin-bottom:14px;
}
.service-list{ list-style:none; margin:18px 0 0; padding:0; display:grid; gap:10px; }
.service-list li{
  display:flex; gap:10px; align-items:flex-start;
  font-size:.95rem; color:var(--color-text-soft);
}
.service-list svg{ flex-shrink:0; margin-top:3px; }
.service-visual{
  border-radius:var(--radius-l);
  aspect-ratio:5/4;
  background:var(--color-bg-alt);
  border:1px solid var(--color-border);
  position:relative;
  overflow:hidden;
  display:flex; align-items:center; justify-content:center;
}

/* ---------- Pricing / packages ---------- */
.pricing-toggle{
  display:inline-flex;
  background:var(--color-bg-alt);
  border-radius:999px;
  padding:5px;
  gap:4px;
  margin-bottom:8px;
}
.pkg-card{
  background:var(--color-card);
  border:1px solid var(--color-border);
  border-radius:var(--radius-m);
  padding:40px 32px;
  display:flex; flex-direction:column;
  position:relative;
}
.pkg-card.featured{
  background:var(--color-sage-deep);
  color:#fff;
  border-color:var(--color-sage-deep);
  transform:scale(1.03);
}
.pkg-card.featured h3, .pkg-card.featured .pkg-price{ color:#fff; }
.pkg-card.featured p{ color:#D9E2D4; }
.pkg-card.featured .service-list li{ color:#D9E2D4; }
.pkg-badge{
  position:absolute; top:-14px; left:32px;
  background:var(--color-honey);
  color:#fff; font-size:.72rem; font-weight:700;
  letter-spacing:.06em; text-transform:uppercase;
  padding:6px 14px; border-radius:999px;
}
.pkg-price{
  font-family:var(--font-display);
  font-size:2.1rem;
  color:var(--color-sage-deep);
  margin:8px 0 4px;
}
.pkg-price span{ font-size:.9rem; font-weight:400; font-family:var(--font-body); color:var(--color-text-soft); }
.pkg-card .service-list{ margin-top:20px; margin-bottom:28px; flex-grow:1; }
.pkg-note{
  background:var(--color-bg-alt);
  border:1px dashed var(--color-honey);
  border-radius:var(--radius-s);
  padding:24px 28px;
  margin-top:24px;
  font-size:.92rem;
}

/* ---------- Tables ---------- */
.info-table{
  width:100%;
  border-collapse:collapse;
  background:var(--color-card);
  border:1px solid var(--color-border);
  border-radius:var(--radius-m);
  overflow:hidden;
}
.info-table th, .info-table td{
  text-align:left;
  padding:20px 24px;
  border-bottom:1px solid var(--color-border);
  vertical-align:top;
}
.info-table thead th{
  background:var(--color-bg-alt);
  font-family:var(--font-caption);
  font-size:.78rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-weight:600;
  color:var(--color-sage-dark);
}
.info-table tbody tr:last-child td{ border-bottom:none; }
.info-table td.num-cell{
  font-family:var(--font-display);
  font-size:1.3rem;
  color:var(--color-accent2);
  width:56px;
}
.info-table td.title-cell{
  font-weight:600;
  width:220px;
}
.info-table p{ margin:0; font-size:.95rem; }

@media (max-width:640px){
  .info-table, .info-table thead, .info-table tbody, .info-table th, .info-table td, .info-table tr{ display:block; }
  .info-table thead{ display:none; }
  .info-table tr{ padding:20px 20px; border-bottom:1px solid var(--color-border); }
  .info-table td{ border:none; padding:4px 0; width:auto; }
}

/* ---------- Contact ---------- */
.contact-grid{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:56px;
  align-items:start;
}
.contact-card{
  background:var(--color-card);
  border:1px solid var(--color-border);
  border-radius:var(--radius-l);
  padding:40px;
}
.contact-info-item{
  display:flex; gap:16px; align-items:flex-start;
  margin-bottom:24px;
}
.contact-info-item .ic{
  width:40px; height:40px; flex-shrink:0;
  border-radius:50%;
  background:var(--color-bg-alt);
  display:flex; align-items:center; justify-content:center;
}
.contact-info-item h4{ margin:0 0 2px; font-family:var(--font-body); font-weight:600; font-size:.98rem; color:var(--color-text); }
.contact-info-item p{ margin:0; font-size:.92rem; }

.form-field{ margin-bottom:20px; }
.form-field label{ display:block; font-size:.88rem; font-weight:600; margin-bottom:7px; color:var(--color-text); }
.form-field input, .form-field textarea, .form-field select{
  width:100%;
  padding:13px 16px;
  border-radius:var(--radius-s);
  border:1px solid var(--color-border);
  background:var(--color-bg);
  font-family:var(--font-body);
  font-size:.96rem;
  color:var(--color-text);
}
.form-field input:focus, .form-field textarea:focus, .form-field select:focus{
  outline:2px solid var(--color-sage);
  outline-offset:1px;
}
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }

/* ---------- Focus visibility ---------- */
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible{
  outline:2px solid var(--color-sage-dark);
  outline-offset:2px;
}

/* ---------- Responsive ---------- */
@media (max-width: 900px){
  .hero-grid, .bio-grid, .service-row, .service-row.reverse, .contact-grid{
    grid-template-columns:1fr;
    direction:ltr;
  }
  .service-row.reverse .service-visual{ order:-1; }
  .footer-grid{ grid-template-columns:1fr; gap:28px; }
  .grid-3{ grid-template-columns:1fr 1fr; }
  .pkg-card.featured{ transform:none; }
}

@media (max-width: 720px){
  .nav-links, .nav-cta .btn-secondary{ display:none; }
  .nav-toggle{ display:flex; }
  .nav-links.open{
    display:flex; position:absolute; top:100%; left:0; right:0;
    flex-direction:column; background:var(--color-bg);
    padding:24px 32px; gap:18px;
    border-bottom:1px solid var(--color-border);
  }
  .grid-3, .grid-2{ grid-template-columns:1fr; }
  .cta-band{ padding:40px 28px; flex-direction:column; text-align:center; }
  .form-row{ grid-template-columns:1fr; }
  .section{ padding:64px 0; }
}

@media (prefers-reduced-motion: reduce){
  *{ transition:none !important; scroll-behavior:auto !important; }
}
