/* ============================================================
   TGM Core — front-end styles for shortcode output.
   Inherits brand variables from the Divi child theme (tgm.css);
   falls back to brand values if the theme is not present.
   ============================================================ */
:root{
  --cyan:#00BCD4; --cyan-dark:#0097a7; --cyan-soft:#e2f7fa;
  --charcoal:#2B2B2B; --ink:#2B2B2B; --ink-60:#5e5e5e; --ink-40:#8a8a8a;
  --offwhite:#FAFAFA; --sand:#F5F0E1; --clay:#D9C4A3; --line:#e7e2d6;
  --serif:'Playfair Display',Georgia,serif; --sans:'Lato',system-ui,sans-serif;
  --radius:14px; --shadow:0 6px 22px rgba(43,43,43,.09);
}

/* ---------- directory filters ---------- */
.tgm-dir .tgm-filters{display:flex;flex-wrap:wrap;gap:12px;margin:0 0 28px}
.tgm-dir .tgm-filters input[type=search],
.tgm-dir .tgm-filters select{
  padding:11px 14px;border:1px solid var(--line);border-radius:10px;
  font-family:var(--sans);font-size:.95rem;background:#fff;color:var(--ink);min-width:200px;flex:1
}

/* ---------- grids & cards ---------- */
.tgm-grid{display:grid;gap:24px}
.tgm-grid-3{grid-template-columns:repeat(3,1fr)}
.tgm-grid-4{grid-template-columns:repeat(4,1fr)}
.tgm-card{
  display:block;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow);transition:transform .18s ease,box-shadow .18s ease;color:inherit
}
.tgm-card:hover{transform:translateY(-4px);box-shadow:0 18px 50px rgba(43,43,43,.16)}
.tgm-card-media{aspect-ratio:16/10;background:var(--sand);display:flex;align-items:center;justify-content:center;overflow:hidden}
.tgm-card-media img{width:100%;height:100%;object-fit:cover}
.tgm-card-sm .tgm-card-media{aspect-ratio:1/1;padding:18px}
.tgm-card-sm .tgm-card-media img{object-fit:contain}
.tgm-card-body{padding:18px 20px}
.tgm-card-body h3{font-family:var(--serif);font-size:1.25rem;margin:0 0 8px;color:var(--charcoal)}
.tgm-card-body h4{font-family:var(--serif);font-size:1.05rem;margin:0 0 6px;color:var(--charcoal)}
.tgm-card-body p{color:var(--ink-60);font-size:.93rem;margin:0 0 10px}
.tgm-price{color:var(--cyan-dark);font-weight:700}
.tgm-link{color:var(--cyan-dark);font-weight:700;font-size:.9rem}
.tgm-eyebrow{display:block;text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;font-weight:800;color:var(--cyan-dark);margin-bottom:6px}
.tgm-empty{color:var(--ink-40);font-style:italic;padding:30px 0}

/* ---------- product cause chips ---------- */
.tgm-product-nfps{margin:20px 0;padding:16px 18px;background:var(--cyan-soft);border-radius:12px}
.tgm-nfp-chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.tgm-chip{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:40px;padding:5px 14px 5px 5px;font-weight:700;font-size:.85rem;color:var(--charcoal)}
.tgm-chip img{width:28px;height:28px !important;border-radius:50%;object-fit:cover}

/* ---------- NFP profile ---------- */
.nfp-hero{position:relative;min-height:460px;display:flex;align-items:flex-end;background:var(--charcoal)}
.nfp-hero .hero-inner{position:relative;z-index:3;color:#fff;width:100%;padding-bottom:42px}
.nfp-hero .wrap{max-width:1180px;margin:0 auto;padding:0 28px}
.nfp-hero .h-logo{width:92px;height:92px;border-radius:18px;border:4px solid #fff;overflow:hidden;margin-bottom:16px;box-shadow:var(--shadow)}
.nfp-hero .h-logo img{width:100%;height:100%;object-fit:cover}
.nfp-hero h1{color:#fff;font-family:var(--serif);font-size:clamp(2.2rem,4vw,3.2rem);margin:6px 0}
.nfp-hero .eyebrow{color:var(--cyan)}
.nfp-hero .lead{color:rgba(255,255,255,.85);max-width:640px}
.section{padding:72px 0}
.section .wrap{max-width:1180px;margin:0 auto;padding:0 28px}
.wrap-narrow{max-width:760px;margin:0 auto;padding:0 28px}
.section-head{max-width:660px;margin:0 0 36px}
.section-head.center{margin:0 auto 36px;text-align:center}
.bg-white{background:#fff}.bg-offwhite{background:var(--offwhite)}.bg-sand{background:var(--sand)}.bg-clay{background:var(--clay)}
.about-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:44px;align-items:center}
.about-visual img{border-radius:var(--radius);box-shadow:var(--shadow)}
.tgm-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.tgm-stat{background:#fff;border-radius:var(--radius);padding:26px;text-align:center;box-shadow:var(--shadow)}
.tgm-stat-v{font-family:var(--serif);font-size:2rem;color:var(--cyan-dark);font-weight:700}
.tgm-stat-l{color:var(--ink-60);font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;margin-top:6px}
.tgm-quote{font-family:var(--serif);font-size:1.6rem;font-style:italic;color:var(--charcoal);line-height:1.45}
.tgm-quote-by{font-weight:700;margin-top:14px}

/* ---------- buttons & forms ---------- */
.tgm-btn{display:inline-block;background:var(--cyan);color:#fff;font-weight:800;padding:13px 28px;border-radius:10px;border:0;cursor:pointer;font-family:var(--sans);font-size:1rem;text-decoration:none;margin-top:14px}
.tgm-btn:hover{background:var(--cyan-dark)}
.tgm-form{max-width:620px}
.tgm-form label{display:block;font-weight:700;margin:0 0 16px;color:var(--charcoal)}
.tgm-form input,.tgm-form textarea{display:block;width:100%;margin-top:6px;padding:12px 14px;border:1px solid var(--line);border-radius:10px;font-family:var(--sans);font-size:1rem}
.tgm-form-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.tgm-alert{padding:14px 18px;border-radius:10px;margin:0 0 22px;font-weight:600}
.tgm-alert-ok{background:#e7f4ec;color:#2f7d52}
.tgm-alert-err{background:#f8e7e2;color:#b1402f}

/* ---------- responsive ---------- */
@media(max-width:1024px){.tgm-grid-4{grid-template-columns:repeat(2,1fr)}.tgm-stats{grid-template-columns:repeat(2,1fr)}}
@media(max-width:760px){
  .tgm-grid-3,.tgm-grid-4{grid-template-columns:1fr}
  .about-grid{grid-template-columns:1fr;gap:26px}
  .tgm-stats{grid-template-columns:1fr 1fr}
  .tgm-form-2{grid-template-columns:1fr}
  .tgm-dir .tgm-filters input,.tgm-dir .tgm-filters select{min-width:100%;flex:1 1 100%}
}
