/*
Theme Name: Sadaqah Jariyah Modern
Theme URI: https://sadaqahjariyah.org.uk/
Author: Web Craft HQ
Description: A modern donation and campaign-ready WordPress theme for Sadaqah Jariyah Funeral Services.
Version: 1.7.0
Text Domain: sadaqah-jariyah-modern
*/

:root{
  --green:#074d45;
  --green2:#27ad68;
  --deep:#071b18;
  --cream:#fbf7ec;
  --soft:#edf8f1;
  --gold:#caa75c;
  --ink:#102321;
  --muted:#61756f;
  --border:rgba(16,35,33,.12);
  --shadow:0 24px 80px rgba(16,35,33,.12);
  --radius:28px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:var(--ink);background:#fff;line-height:1.65}
img{max-width:100%;height:auto}
a{color:inherit}
.container{width:min(1180px,calc(100% - 40px));margin-inline:auto}
.narrow{width:min(900px,calc(100% - 40px));margin-inline:auto}
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.9);backdrop-filter:blur(18px);border-bottom:1px solid var(--border)}
.header-inner{min-height:86px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.logo img{width:240px;max-height:72px;object-fit:contain}
.nav{display:flex;align-items:center;gap:24px;font-size:15px;font-weight:850}
.nav a{text-decoration:none;color:var(--ink)}
.nav a:hover{color:var(--green)}
.header-ctas{display:flex;gap:10px}
.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:15px 24px;text-decoration:none;font-weight:900;border:1px solid transparent;transition:.2s ease;line-height:1.1}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--green);color:#fff;box-shadow:0 16px 35px rgba(7,77,69,.18)}
.btn-gold{background:var(--gold);color:#1d1607}
.btn-light{background:#fff;color:var(--green);border-color:var(--border)}
.btn-white{background:#fff;color:var(--green)}
.mobile-toggle{display:none;border:0;background:var(--green);color:#fff;border-radius:12px;padding:10px 14px;font-weight:900}
.hero{position:relative;overflow:hidden;padding:76px 0 58px;background:radial-gradient(circle at 90% 10%,rgba(39,173,104,.18),transparent 34%),radial-gradient(circle at 8% 0%,rgba(202,167,92,.16),transparent 34%),linear-gradient(180deg,#fff,var(--cream))}
.hero:before{content:"";position:absolute;inset:0;opacity:.065;background-image:linear-gradient(30deg,var(--green) 12%,transparent 12.5%,transparent 87%,var(--green) 87.5%,var(--green)),linear-gradient(150deg,var(--green) 12%,transparent 12.5%,transparent 87%,var(--green) 87.5%,var(--green));background-size:70px 120px}
.hero-grid{position:relative;display:grid;grid-template-columns:1.08fr .92fr;gap:48px;align-items:center}
.eyebrow{font-size:13px;letter-spacing:.18em;text-transform:uppercase;font-weight:950;color:var(--green);margin-bottom:16px}
h1,h2,h3{line-height:1.03;letter-spacing:-.055em;margin:0 0 20px}
h1{font-size:clamp(3.1rem,7vw,6.6rem)}
h2{font-size:clamp(2.3rem,4.5vw,4.8rem)}
h3{font-size:clamp(1.3rem,2vw,2rem);letter-spacing:-.035em}
.lead{font-size:clamp(1.08rem,1.6vw,1.32rem);color:var(--muted);max-width:760px}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin:30px 0 22px}
.trust-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.pill{background:#fff;border:1px solid var(--border);border-radius:999px;padding:9px 14px;color:var(--green);font-weight:900;font-size:14px}
.urgent-card{background:linear-gradient(135deg,var(--green),#0b6b5f);color:#fff;border-radius:var(--radius);padding:34px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.urgent-card:after{content:"";position:absolute;right:-75px;top:-75px;width:200px;height:200px;border-radius:999px;background:rgba(255,255,255,.08)}
.urgent-card h2{font-size:clamp(2rem,3.8vw,3.8rem)}
.urgent-card p{color:rgba(255,255,255,.82)}
.urgent-phone{font-size:clamp(2rem,4vw,3.5rem);font-weight:950;margin:20px 0;line-height:1}
.urgent-phone a{text-decoration:none}
.section{padding:78px 0}
.section-soft{background:var(--soft)}
.section-dark{background:var(--deep);color:#fff}
.section-head{display:flex;align-items:end;justify-content:space-between;gap:32px;margin-bottom:34px}
.section-head p{color:var(--muted);max-width:650px;margin:0}
.section-dark p,.section-dark .lead{color:rgba(255,255,255,.76)}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.card,.service-card,.campaign-card,.impact-card,.donation-panel{background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 18px 60px rgba(16,35,33,.08);padding:30px}
.service-card p,.campaign-card p,.impact-card p{color:var(--muted)}
.icon{width:56px;height:56px;border-radius:18px;background:var(--soft);display:grid;place-items:center;color:var(--green);font-weight:950;font-size:22px;margin-bottom:18px}
.amount-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:20px 0}
.amount{background:#fff;border:1px solid var(--border);border-radius:18px;padding:16px;text-align:center;text-decoration:none;color:var(--green);font-weight:950}
.amount:hover{background:var(--soft)}
.donation-tabs{display:flex;background:var(--soft);padding:6px;border-radius:999px;margin-bottom:18px}
.donation-tabs button{flex:1;border:0;background:transparent;color:var(--green);font-weight:950;border-radius:999px;padding:12px;cursor:pointer}
.donation-tabs button.active{background:var(--green);color:#fff}
.bank-box{margin-top:18px;border:1px dashed rgba(7,77,69,.28);background:var(--soft);border-radius:20px;padding:18px}
.bank-box p{margin:5px 0;color:var(--ink)}
.progress{height:10px;border-radius:999px;background:#e1eee8;overflow:hidden;margin:18px 0}
.progress span{display:block;height:100%;background:linear-gradient(90deg,var(--green),var(--green2))}
.steps{counter-reset:step;display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:#fff}
.step{padding:26px;border-right:1px solid var(--border)}
.step:last-child{border-right:0}
.step:before{counter-increment:step;content:counter(step, decimal-leading-zero);display:block;color:var(--green2);font-size:2rem;font-weight:950;margin-bottom:8px}
.step strong{display:block;font-size:1.1rem}
.cta-band{background:linear-gradient(135deg,var(--green),#0e7165);border-radius:var(--radius);padding:44px;color:#fff;display:flex;justify-content:space-between;align-items:center;gap:28px;box-shadow:var(--shadow)}
.cta-band h2{font-size:clamp(2rem,4vw,4.2rem);margin-bottom:10px}
.page-hero{background:linear-gradient(180deg,#fff,var(--cream));padding:76px 0 48px}
.page-hero h1{font-size:clamp(3rem,5.5vw,5.8rem)}
.content-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:40px}
.content-card h2{font-size:2.4rem;margin-top:34px}
.content-card h2:first-child{margin-top:0}
.content-card h3{font-size:1.55rem;letter-spacing:-.02em;margin-top:26px}
.content-card p,.content-card li{color:var(--muted)}
.content-card a{color:var(--green);font-weight:900}
.notice{padding:18px 20px;border-radius:20px;background:#fff8e5;border:1px solid rgba(202,167,92,.4);color:#5b430e}
.site-footer{background:#071a18;color:#fff;padding:64px 0 28px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:42px}
.site-footer img{width:220px;filter:brightness(0) invert(1)}
.site-footer p,.site-footer a{color:rgba(255,255,255,.72)}
.site-footer a{text-decoration:none;display:block;margin:8px 0}
.site-footer a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:42px;padding-top:24px;color:rgba(255,255,255,.6)}
.footer-legal{display:flex;gap:12px;flex-wrap:wrap}
.footer-legal a{display:inline;margin:0}
.footer-legal span{color:rgba(255,255,255,.35)}
.reveal{opacity:0;transform:translateY(18px);transition:.65s ease}
.reveal.is-visible{opacity:1;transform:none}
@media(max-width:1000px){
  .hero-grid,.grid-2{grid-template-columns:1fr}
  .grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .nav,.header-ctas{display:none}
  .mobile-toggle{display:block}
  .nav.is-open{display:flex;position:absolute;top:86px;left:20px;right:20px;background:#fff;border:1px solid var(--border);border-radius:22px;box-shadow:var(--shadow);padding:20px;flex-direction:column;align-items:flex-start}
}
@media(max-width:640px){
  .logo img{width:180px}
  .hero{padding:48px 0}
  .grid-3,.grid-4,.steps{grid-template-columns:1fr}
  .amount-row{grid-template-columns:repeat(2,1fr)}
  .section-head,.cta-band{display:block}
  .footer-grid{grid-template-columns:1fr}
  .content-card,.card,.donation-panel{padding:24px}
}

/* v2 image-led hero and real photo sections */
.hero-photo {
  position: relative;
  min-height: 690px;
  display: flex;
  align-items: stretch;
  background: var(--deep);
  color: #fff;
  overflow: hidden;
}
.hero-photo-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  transform: scale(1.02);
  opacity: .46;
}
.hero-photo:before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(7,26,24,.96) 0%, rgba(7,26,24,.82) 42%, rgba(7,26,24,.35) 100%),
    radial-gradient(circle at 80% 20%, rgba(39,173,104,.22), transparent 38%);
  z-index: 1;
}
.hero-photo .container {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 420px;
  gap: 42px;
  align-items: center;
  padding: 82px 0;
}
.hero-photo h1 {
  color: #fff;
  max-width: 900px;
}
.hero-photo .lead {
  color: rgba(255,255,255,.82);
}
.hero-photo .eyebrow {
  color: #d8f6e6;
}
.hero-photo .pill {
  background: rgba(255,255,255,.1);
  color: #fff;
  border-color: rgba(255,255,255,.18);
}
.hero-side-panel {
  background: rgba(255,255,255,.94);
  color: var(--ink);
  border-radius: 30px;
  padding: 28px;
  box-shadow: 0 28px 90px rgba(0,0,0,.28);
  border: 1px solid rgba(255,255,255,.28);
}
.hero-side-panel .urgent-phone a {
  color: var(--green);
}
.hero-side-panel p {
  color: var(--muted);
}
.photo-strip {
  display: grid;
  grid-template-columns: 1.2fr .9fr .9fr;
  gap: 16px;
  margin-top: 26px;
}
.photo-tile {
  position: relative;
  min-height: 260px;
  border-radius: 28px;
  overflow: hidden;
  border: 1px solid var(--border);
  box-shadow: 0 18px 60px rgba(16,35,33,.08);
  background: var(--soft);
}
.photo-tile.large {
  min-height: 420px;
}
.photo-tile img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  inset: 0;
}
.photo-caption {
  position: absolute;
  left: 16px;
  right: 16px;
  bottom: 16px;
  background: rgba(7,26,24,.82);
  color: #fff;
  border-radius: 18px;
  padding: 14px 16px;
  font-weight: 850;
  backdrop-filter: blur(12px);
}
.split-photo-card {
  display: grid;
  grid-template-columns: .95fr 1.05fr;
  gap: 0;
  overflow: hidden;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: #fff;
  box-shadow: var(--shadow);
}
.split-photo-card img {
  width: 100%;
  height: 100%;
  min-height: 460px;
  object-fit: cover;
}
.split-photo-content {
  padding: 42px;
}
@media(max-width:1000px){
  .hero-photo .container{grid-template-columns:1fr}
  .hero-side-panel{max-width:620px}
  .photo-strip{grid-template-columns:1fr}
  .photo-tile,.photo-tile.large{min-height:300px}
  .split-photo-card{grid-template-columns:1fr}
}

/* v4 page expansion updates */
.nav { gap: 18px; }
@media(max-width:1200px){ .nav{gap:14px;font-size:14px}.header-ctas .btn-light{display:none} }


/* v5 button text visibility fix */
.btn,
a.btn,
button.btn {
  text-decoration: none !important;
}

.btn-primary,
a.btn-primary,
button.btn-primary {
  background: var(--green) !important;
  color: #ffffff !important;
}

.btn-gold,
a.btn-gold,
button.btn-gold {
  background: var(--gold) !important;
  color: #1d1607 !important;
}

.btn-light,
a.btn-light,
button.btn-light {
  background: #ffffff !important;
  color: var(--green) !important;
  border-color: var(--border) !important;
}

.btn-white,
a.btn-white,
button.btn-white {
  background: #ffffff !important;
  color: var(--green) !important;
  border-color: rgba(255,255,255,.55) !important;
}

/* Footer was overriding button text colour */
.site-footer a.btn,
.site-footer .btn,
.site-footer a.btn-white,
.site-footer a.btn-light {
  color: var(--green) !important;
}

.site-footer a.btn-primary {
  color: #ffffff !important;
}

.site-footer a.btn-gold {
  color: #1d1607 !important;
}

.site-footer a.btn:hover {
  color: var(--green) !important;
}

/* Header CTA wrapping fix */
.header-ctas .btn {
  white-space: nowrap;
}


/* v6 content and page fixes */
.btn:empty::after,
a.btn:empty::after {
  content: "Donate now";
  color: inherit;
}

.nav { gap: 16px; }

.content-card .grid-3,
.content-card .grid-2 {
  margin: 24px 0;
}

.content-card .split-photo-card {
  margin: 10px 0 34px;
}

.site-footer .btn-white,
.site-footer a.btn-white {
  color: var(--green) !important;
  min-width: 170px;
}

/* v7 page content override fixes */
.content-card > p:only-child {
  font-size: 1.1rem;
}
.content-card .campaign-card a:not(.btn),
.content-card .service-card a:not(.btn) {
  text-decoration: none;
  color: inherit;
}


/* v8 CTA section button spacing */
.cta-band > div:last-child {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
  min-width: 190px;
}

.cta-band > div:last-child .btn {
  width: 100%;
  min-width: 170px;
  text-align: center;
}

@media (max-width: 640px) {
  .cta-band > div:last-child {
    margin-top: 22px;
    width: 100%;
  }

  .cta-band > div:last-child .btn {
    width: 100%;
  }
}
