:root{
  /* Rose palette to match hearts */
  --rose-50:#fff1f5;
  --rose-100:#ffe4ea;
  --rose-200:#fdced7;
  --rose-300:#f8a9bb;
  --rose-400:#ef7f99;
  --rose-500:#e85c73;
  --ink:#3a2f28;
  --muted:#6e655f;
  --cream:#fbf5ef;
  --shadow: rgba(0,0,0,.06);

  /* Plaque sizing (adjust once, updates everywhere) */
  --plaque-w-mobile: 400px;
  --plaque-w-tablet: 600px;
  --plaque-w-desktop: 750px;
  --plaque-aspect: 4 / 3;

  /* Brand link colors */
  --link: var(--rose-500);
  --link-hover: var(--rose-400);
  --link-visited: var(--rose-500);


  /* Focus ring used for keyboard nav on links */
  --focus-ring: 0 0 0 3px rgba(5, 62, 176, .25);

  /* Alias for legacy usages */
  --link-blue: var(--link);
}

/* ========== Base ========== */
*{ box-sizing:border-box; }
html,body{ height:100%; }
body{ margin:0; font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif; color:var(--ink); background:#fff; }

/* ===== Global link styles (site-wide) ===== */
a {
  color: var(--link);
  text-decoration: underline;
  text-underline-offset: .12em;
  text-decoration-thickness: 1.5px;
}
a:hover { color: var(--link-hover); }
a:visited { color: var(--link-visited); }
a:focus-visible {
  outline: none;
  box-shadow: var(--focus-ring);
  border-radius: 4px;
}

/* Components that look like buttons/controls keep their own visuals */
.btn,
.btn:hover,
.btn:visited,
.nav .links a,
.socials .social,
.ig-follow {
  color: inherit;
  text-decoration: none;
}

/* Make “Read more” links use the brand color everywhere */
.read-more { color: var(--link) !important; }
.read-more:hover { color: var(--link-hover) !important; text-decoration: underline; }

/* ========== Header / Nav ========== */
header{
  position:fixed; top:0; left:0; right:0; z-index:1000;
  height:74px;
  background: linear-gradient(180deg, var(--rose-50), var(--rose-100));
  backdrop-filter:saturate(1.2) blur(8px);
  border-bottom:1px solid rgba(232,92,115,.28);
  box-shadow: 0 6px 18px rgba(232,92,115,.12);
}
.nav{
  height:100%; padding:0 16px;
  display:flex; align-items:center; justify-content:space-between;
  max-width:1200px; margin:0 auto; position:relative;
}
.nav-left{ display:flex; align-items:center; gap:4px; }
.nav-left img{ height:44px; width:auto; }
.brand{
  font-family:'Playfair Display', serif;
  font-size:19px; font-weight:700; letter-spacing:0.5px;
}
.nav-right{ display:flex; align-items:center; gap:22px; }
.nav a{
  text-decoration:none; color:var(--ink);
  font-family:'Playfair Display', serif; font-weight:600; letter-spacing:0.5px;
  padding:8px 12px; border-radius:10px;
}
.nav a[aria-current="page"]{ text-decoration:underline; text-underline-offset:6px; }
.nav a:hover{ background: rgba(232,92,115,.12); }

/* Hamburger */
.menu-toggle{
  display:none;
  background:none; border:1px solid transparent; padding:8px; margin-left:6px; border-radius:10px;
  cursor:pointer;
}
.menu-toggle:focus{ outline:2px solid #999; }
.menu-icon{ width:26px; height:2px; background:var(--ink); display:block; position:relative; }
.menu-icon::before, .menu-icon::after{
  content:""; position:absolute; left:0; right:0; height:2px; background: var(--ink);
}
.menu-icon::before{ top:-7px; }
.menu-icon::after{ top:7px; }

/* Mobile dropdown */
.mobile-panel{
  position:absolute; top:100%; right:10px; left:10px;
  background: linear-gradient(180deg, var(--rose-50), var(--rose-100));
  border:1px solid rgba(232,92,115,.28);
  border-radius:12px;
  box-shadow:0 12px 32px rgba(232,92,115,.18);
  display:none; flex-direction:column; padding:8px; margin-top:10px;
}
@media (max-width: 860px){
  .nav-right .links{ display:none; }
  .menu-toggle{ display:inline-grid; place-items:center; }
  .mobile-panel a{ padding:12px; }
  /* force show when nav has .open */
  .nav.open .mobile-panel,
  .nav.open #menuPanel{ display:flex !important; }
}

/* ========== Hero ========== */
.hero{
  position:relative;
  height:100svh;
  min-height:560px;
  display:grid; place-items:center;
  background-image:url('../images/hero-hearts.jpg'); /* desktop */
  background-size:cover; background-position:center; background-repeat:no-repeat;
  background-attachment:fixed;
}
.hero .center-plaque{
  width: clamp(480px, 60vw, 1280px);
  height:auto; display:block;
  border-radius:0; box-shadow:none;
}
.scroll-cue{
  position:absolute; bottom:18px; left:50%; transform:translateX(-50%);
  width:42px; height:42px; border-radius:50%;
  background:var(--cream);
  color:var(--ink);
  border:1.5px solid rgba(58,47,40,.28);
  display:grid; place-items:center;
  box-shadow:0 6px 16px rgba(58,47,40,.14);
  cursor:pointer; user-select:none;
  transition:transform .18s ease, box-shadow .18s ease, background-color .18s ease;
}
.scroll-cue span{ font-size:22px; line-height:1; color:var(--ink); }
.scroll-cue:hover,
.scroll-cue:focus-visible{
  transform:translateX(-50%) translateY(-2px);
  box-shadow:0 10px 22px rgba(58,47,40,.18);
  outline:none;
}
@media (max-width: 640px){
  header{
    position:fixed; top:0; left:0; right:0; z-index:1000;
    height:74px;
    background: linear-gradient(180deg, var(--rose-50), var(--rose-100));
    backdrop-filter:saturate(1.2) blur(8px);
    border-bottom:1px solid rgba(232,92,115,.28);
    box-shadow: 0 6px 18px rgba(232,92,115,.12);
  }
  .hero{
    background-image:url('../images/bg-hearts.jpg');
    background-attachment:scroll;
  }
  .hero .center-plaque{ width: 99vw; max-width: 1100px; }
}

/* ========== Sections ========== */
.section{ padding:96px 20px; }
.mission{ background:var(--cream); }
.container{ max-width:1000px; margin:0 auto; }
h2{ font-family:'Playfair Display',serif; font-weight:700; font-size:clamp(26px,3.4vw,40px); margin:0 0 10px; text-align:center; }
p.lead{ color:var(--muted); font-size:clamp(15px,1.4vw,18px); line-height:1.8; text-align:center; max-width:760px; margin:8px auto 0; }

/* ========== Footer ========== */
footer{ padding:40px 20px; text-align:center; color:#8b817a; font-size:14px; }

/* ========== Contact ========== */
.contact{ background: var(--cream); padding: 96px 20px 64px; }
.contact .container{ max-width: 1000px; }
.contact .intro{ text-align:center; max-width:760px; margin: 0 auto; }
.contact .intro h2{ margin-bottom: 10px; }
.contact .intro p{ color: var(--muted); line-height: 1.8; }
.socials{
  margin: 24px auto 6px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 14px;
  max-width: 900px;
}
.social{
  display:flex; align-items:center; gap:12px;
  text-decoration:none; color:var(--ink);
  background: linear-gradient(180deg, var(--rose-50), var(--rose-100));
  border:1px solid rgba(232,92,115,.28);
  border-radius:14px;
  padding:14px 16px;
  box-shadow: 0 10px 26px rgba(232,92,115,.12);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}
.social:hover{
  transform: translateY(-3px);
  background: linear-gradient(180deg, var(--rose-100), var(--rose-200));
  box-shadow: 0 16px 34px rgba(232,92,115,.18);
  border-color: rgba(232,92,115,.40);
}
.social svg{ width:22px; height:22px; flex: 0 0 22px; color: var(--ink); }
.social span{ font-family:'Playfair Display',serif; font-weight:600; letter-spacing:.3px; }

/* Newsletter (placeholder styling) */
.newsletter{
  margin: 18px auto 0;
  display:flex; justify-content:center; gap:10px; flex-wrap:wrap;
  max-width: 720px;
}
.newsletter input[type="email"]{
  flex:1 1 280px;
  min-width: 240px;
  padding:12px 14px;
  border-radius:12px;
  border:1px solid rgba(58,47,40,.22);
  font-size:16px;
}
.newsletter button{
  padding:12px 16px;
  border-radius:12px;
  border:1px solid rgba(58,47,40,.22);
  background: var(--ink);
  color:#fff;
  font-weight:700;
  cursor:pointer;
}
.newsletter button:hover{ filter: brightness(1.04); }

/* A11y helper */
.sr-only{
  position:absolute !important;
  width:1px; height:1px;
  padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0);
  white-space:nowrap; border:0;
}

/* ========== Care Kits Gallery ========== */

/* Base grid */
.care-grid{
  margin-top:12px;
  width: 100%;
  display:grid;
  gap:16px;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  justify-items: center;
  margin-bottom: 34px; /* keeps next section (“How to Get Involved”) on its own row */
}
@media (min-width: 1024px){
  .care-grid{ gap:18px; grid-template-columns: repeat(3, 1fr); }
}

/* 1–2 photo layout: two equal columns centered (until a 3rd is added) */
@media (min-width:680px){
  .care-grid:not(:has(.care-card:nth-child(3))){
    grid-template-columns: repeat(2, minmax(340px, 520px)) !important;
    justify-content:center;
    gap:18px !important;
  }
}
/* Mobile single column */
@media (max-width:640px){
  .care-grid{ grid-template-columns: 1fr !important; }
}

/* ===== Polaroid card ===== */
.care-card{
  position:relative;
  display:flex; flex-direction:column;
  width:100%; max-width:560px;

  /* “polaroid” paper */
  background:#fff;
  border-radius:14px;
  padding:12px 10px 24px;                 /* thicker bottom lip */
  border:1px solid rgba(232,92,115,.28);
  box-shadow:0 10px 26px rgba(232,92,115,.12);

  cursor:zoom-in;
  transition: box-shadow .25s ease, border-color .25s ease, transform .25s ease;
}
@media (max-width:40px){
  .care-card img{
    height: clamp(500px, 64vw, 300px);
    /*        ↑min     ↑preferred           ↑max */
  }
}


/* Optional red gradient ring on hover (around the paper) */
.care-card::before{
  content:"";
  position:absolute; inset:0;
  border-radius:14px;                /* match card radius */
  padding:2px;                       /* ring thickness */
  background: linear-gradient(90deg, var(--rose-400), var(--rose-500), var(--rose-400));
  -webkit-mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; 
          mask-composite: exclude;   /* show only the ring */
  opacity:0; transition:opacity .22s ease;
  pointer-events:none;
}
.care-card:hover::before,
.care-card:focus-within::before{ opacity:1; }

/* Photo */
.care-card img{
  display:block;
  width:100%;
  height:clamp(240px, 28vw, 360px);  /* equal visual height across cards */
  object-fit:contain;                 /* never crop */
  background:#fff;
  border-radius:10px;
  transition: transform .25s ease;
}
.care-card:hover,
.care-card:focus-within{
  transform:translateY(-2px);
  border-color: rgba(232,92,115,.46);
  box-shadow:0 14px 30px rgba(232,92,115,.20);
}
.care-card:hover img,
.care-card:focus-within img{
  transform: translateZ(0) scale(1.01);
}

/* Caption (non-italic) */
.care-card figcaption.care-date{
  margin:12px 6px 0;
  text-align:center;
  font-family:'Inter', system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  font-weight:600;
  font-size:14px;
  line-height:1.45;
  letter-spacing:.25px;
  color:var(--ink);
  opacity:.95;
  min-height:38px; /* keeps rows tidy if some captions wrap */
}

/* Soft rose hairline above caption */
.care-card figcaption.care-date::before{
  content:"";
  display:block;
  height:1px;
  width:90%;
  margin:0 auto 8px;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(232,92,115,.36) 15%,
    rgba(232,92,115,.36) 85%,
    transparent 100%
  );
  border-radius:1px;
  filter: drop-shadow(0 0 0.5px rgba(232,92,115,.22));
}

/* ========== Lightbox (fullscreen viewer) ========== */
.lightbox{
  position:fixed; inset:0; z-index:3000;
  display:none; align-items:center; justify-content:center;
  padding:20px;
  background:rgba(0,0,0,.9);
}
.lightbox.open{ display:flex; }
body.no-scroll{ overflow:hidden; }

/* image + caption */
.lb-img-wrap{ max-width:min(1200px,96vw); max-height:92vh; text-align:center; }
.lb-img{
  display:block; width:auto; height:auto;
  max-width:96vw; max-height:86vh; object-fit:contain;
  border-radius:12px; box-shadow:0 20px 60px rgba(0,0,0,.5);
  margin:0 auto;
}
.lb-caption{
  margin-top:10px; text-align:center; color:#fff; opacity:.92;
  font: 600 14px/1.5 'Inter',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  letter-spacing:.2px;
}

/* controls */
.lb-close{
  position:fixed; top:14px; right:14px;
  border:1px solid rgba(255,255,255,.25);
  background:rgba(255,255,255,.12);
  color:#fff; border-radius:10px;
  padding:8px 10px; cursor:pointer;
}
.lb-close:hover{ background:rgba(255,255,255,.18); }
.lb-close:focus-visible{ outline:2px solid #fff; }

.lb-nav{
  position:fixed; inset:0; pointer-events:none;
  display:flex; align-items:center; justify-content:space-between;
}
.lb-arrow{
  pointer-events:auto;
  border:1px solid rgba(255,255,255,.25);
  background:rgba(255,255,255,.12);
  color:#fff; border-radius:12px;
  width:44px; height:44px;
  display:grid; place-items:center;
  cursor:pointer; user-select:none;
  margin:0 10px;
}
.lb-arrow:hover{ background:rgba(255,255,255,.18); }
.lb-arrow:focus-visible{ outline:2px solid #fff; }

/* Make sure the inner photo-window outline is gone everywhere */
.care-card::after{
  content:none !important;
  display:none !important;
}

/* ===== Mobile-friendly polaroids & lightbox ===== */
@media (max-width:640px){
  /* 1-up grid, centered, comfy spacing */
  .care-grid{
    grid-template-columns: 1fr !important;
    gap:14px !important;
    justify-items:center;
    margin-left:auto;
    margin-right:auto;
  }

  /* Polaroid card: slimmer sides, centered, gentle shadow */
  .care-card{
    max-width: 300px;              /* prevents edge-to-edge sprawl */
    margin: 0 auto;
    padding: 8px 10px 22px;        /* thinner sides, thicker bottom lip */
    border-radius:16px;
    box-shadow:0 12px 28px rgba(232,92,115,.16);
    -webkit-tap-highlight-color: transparent;
  }

  /* Image window: corrected clamp (min ≤ max), never cropped */
  .care-card img{
    height: clamp(350px, 64vw, 300px);
    object-fit: contain;
  }

  /* Caption: slightly smaller & tighter */
  .care-card figcaption.care-date{
    font-size:13px;
    letter-spacing:.2px;
    margin-top:10px;
    min-height:auto;               /* let it wrap naturally on small screens */
  }

  /* Lightbox: bigger touch targets, safer viewport fit */
  .lightbox{ overscroll-behavior: contain; }
  .lb-img{ max-width:100vw; max-height:80vh; }
  .lb-arrow{ width:52px; height:52px; }
  .lb-close{ padding:12px 14px; }
}

/* ===== Instagram Preview ===== */
.insta-preview { padding-top: 34px; padding-bottom: 8px; }
.insta-preview .ig-header { display:flex; align-items:center; justify-content:space-between; gap:12px; }
.insta-preview h2 { margin:0; font-family:'Playfair Display', serif; }
.insta-preview .ig-sub { margin:8px 0 16px; color:var(--muted); }

.ig-follow{
  display:inline-block; font-weight:700; text-decoration:none;
  border:1px solid rgba(58,47,40,.22); color:var(--ink);
  padding:8px 12px; border-radius:12px;
}
.ig-follow:hover{ transform:translateY(-1px); }

.ig-grid{
  display:grid; gap:12px;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
}
.ig-tile{
  position:relative; display:block; border-radius:16px; overflow:hidden;
  box-shadow: 0 2px 8px var(--shadow); border:1px solid var(--shadow);
  aspect-ratio: 1 / 1; /* perfect squares */
}
.ig-tile img{
  width:100%; height:100%; object-fit:cover; display:block;
  transition: transform .25s ease;
}
.ig-tile:hover img{ transform: scale(1.03); }

.ig-badge{
  position:absolute; right:8px; bottom:8px;
  display:inline-flex; align-items:center; justify-content:center;
  width:32px; height:32px; border-radius:999px;
  background: rgba(255,255,255,.9); color:var(--ink);
  box-shadow: 0 1px 4px var(--shadow);
}

.ig-cta{ text-align:center; margin-top:16px; }
.btn.btn-dark{
  display:inline-block; background:var(--ink); color:#fff;
  padding:12px 16px; border-radius:12px; text-decoration:none; font-weight:700;
}
.btn.btn-dark:hover{ filter:brightness(.95); }

/* Small screens spacing tweak */
@media (max-width: 520px){
  .insta-preview { padding-top: 28px; }
}

/* =========================================================
   === Plaque images: consistent size across every page ===
   ========================================================= */
.plaque-img{
  display:block;
  width: var(--plaque-w-mobile);
  height:auto !important;
  aspect-ratio: var(--plaque-aspect);
  object-fit: contain;
  margin-inline:auto;
}

/* Ensure hero plaque follows same sizing (can customize later) */
.center-plaque{
  display:block;
  width: var(--plaque-w-mobile) !important;
  height:auto !important;
  aspect-ratio: var(--plaque-aspect);
  object-fit: contain;
  margin-inline:auto;
  border-radius:0; box-shadow:none;
}

/* Optional wrapper if you use <figure class="plaque"> */
.plaque{ max-width: var(--plaque-w-mobile); margin-inline:auto; }

/* Scale up with viewport */
@media (min-width:600px){
  .plaque-img,
  .center-plaque{ width: var(--plaque-w-tablet) !important; }
  .plaque{ max-width: var(--plaque-w-tablet); }
}
@media (min-width:960px){
  .plaque-img,
  .center-plaque{ width: var(--plaque-w-desktop) !important; }
  .plaque{ max-width: var(--plaque-w-desktop); }
}

/* Neutralize conflicting page-specific rules */
.card .plaque-img,
.grid .plaque-img,
.section .plaque-img,
.card .center-plaque,
.grid .center-plaque,
.section .center-plaque{
  max-width:none !important;
}

/* Fallback: auto-target plaques even if class not added yet */
img[alt*="plaque" i],
img[src*="plaque" i]{
  display:block;
  width: var(--plaque-w-mobile) !important;
  height:auto !important;
  aspect-ratio: var(--plaque-aspect);
  object-fit: contain;
  margin-inline:auto;
}
@media (min-width:600px){
  img[alt*="plaque" i], img[src*="plaque" i]{ width: var(--plaque-w-tablet) !important; }
}
@media (min-width:960px){
  img[alt*="plaque" i], img[src*="plaque" i]{ width: var(--plaque-w-desktop) !important; }
}

/* Optional: unified frame look if you want a border/shadow */
.plaque-frame{
  border:1px solid rgba(0,0,0,.08);
  border-radius: 12px;
  padding: 10px;
  background:#fff;
  box-shadow: 0 4px 16px rgba(0,0,0,.06);
}

