/*
Theme Name: JSRCC Royal Saffron
Theme URI: https://jsrcc.example
Author: Sandeep / JSRCC
Description: Custom royal saffron theme for Jai Shri Ram Cultural & Community Center (JSRCC). Devotional design with hero slider, founders, gatherings, gallery, seva forms and contact form.
Version: 1.0.2
Requires PHP: 8.0
License: GNU General Public License v2 or later
Text Domain: jsrcc
*/

:root{
  --saffron:#E97E12;
  --saffron-rich:#D26A05;
  --saffron-deep:#A14E03;
  --amber-glow:#F9A93E;
  --maroon:#5A0F1E;
  --maroon-deep:#430A16;
  --gold:#D4AF37;
  --gold-deep:#B08A1E;
  --gold-pale:#F2DFA9;
  --cream:#FFF8EA;
  --ink:#3A2410;
  --ink-soft:#7A5A38;
  --white:#FFFDF6;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
}
body{
  font-family:'Mukta',sans-serif;
  background:var(--cream);
  color:var(--ink);
  font-size:17px;
  line-height:1.65;
}
h1,h2,h3,h4{font-family:'Eczar',serif;line-height:1.15}
img{max-width:100%;height:auto;display:block}
a{color:var(--maroon)}
.container{max-width:1140px;margin:0 auto;padding:0 24px}

/* ===== scalloped temple borders ===== */
.temple-border{
  height:18px;
  background:radial-gradient(circle at 10px -4px, transparent 11px, var(--maroon) 12px) repeat-x;
  background-size:20px 18px;
  background-color:var(--saffron);
}
.ribbon{
  background:var(--maroon);color:var(--gold-pale);text-align:center;
  font-size:13.5px;letter-spacing:.18em;padding:8px 16px;text-transform:uppercase;
}

/* ===== header ===== */
.site-header{
  background:linear-gradient(180deg, var(--saffron) 0%, var(--saffron-rich) 100%);
  border-bottom:3px solid var(--gold);
  position:sticky;top:0;z-index:50;
  box-shadow:0 4px 18px rgba(90,15,30,.25);
}
.nav{display:flex;align-items:center;justify-content:space-between;padding:12px 0;gap:18px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;min-width:0}
.brand img.brand-logo{height:56px;width:auto}
.brand-mark{
  width:48px;height:48px;border-radius:50%;flex:none;
  background:radial-gradient(circle at 45% 35%, var(--gold-pale), var(--gold) 55%, var(--gold-deep));
  display:flex;align-items:center;justify-content:center;
  color:var(--maroon);font-family:'Eczar',serif;font-weight:800;font-size:22px;
  border:2px solid var(--maroon);
  box-shadow:0 0 0 3px rgba(212,175,55,.4);
}
.brand-name{font-family:'Eczar',serif;font-weight:700;color:var(--white);font-size:21px;line-height:1.05;text-shadow:0 1px 3px rgba(90,15,30,.4)}
.brand-name small{display:block;font-family:'Mukta',sans-serif;font-weight:600;font-size:10.5px;letter-spacing:.22em;color:var(--gold-pale);text-transform:uppercase}
nav.links{display:flex;gap:22px;align-items:center;flex-wrap:wrap}
nav.links a{
  text-decoration:none;color:var(--white);font-weight:600;font-size:15px;
  padding-bottom:2px;border-bottom:2px solid transparent;
  text-shadow:0 1px 2px rgba(90,15,30,.3);white-space:nowrap;
}
nav.links a:hover{color:var(--gold-pale);border-bottom-color:var(--gold-pale)}
.btn{
  display:inline-block;text-decoration:none;font-weight:700;
  padding:12px 30px;border-radius:50px;font-size:15px;
  transition:transform .15s ease;letter-spacing:.02em;border:none;cursor:pointer;
  font-family:'Mukta',sans-serif;
}
.btn:hover{transform:translateY(-1px)}
.btn-maroon{background:var(--maroon);color:var(--gold-pale)!important;box-shadow:0 4px 14px rgba(67,10,22,.45);border:1.5px solid var(--gold)}
.btn-maroon:hover{background:var(--maroon-deep)}
.btn-gold{
  background:linear-gradient(160deg, var(--gold-pale), var(--gold) 60%, var(--gold-deep));
  color:var(--maroon-deep)!important;border:1.5px solid var(--gold-deep);
  box-shadow:0 4px 16px rgba(176,138,30,.45);
}
.btn-ghost{border:1.5px solid rgba(255,253,246,.65);color:var(--white)!important;background:transparent}
.btn-ghost:hover{border-color:var(--gold-pale);color:var(--gold-pale)!important}
.menu-toggle{display:none;background:none;border:none;font-size:28px;color:var(--white);cursor:pointer;line-height:1}

/* ===== HERO SLIDER ===== */
.hero{position:relative;color:var(--white);text-align:center;overflow:hidden;min-height:620px;display:flex;flex-direction:column;justify-content:center}
.hero-slides{position:absolute;inset:0;z-index:0}
.hero-slide{
  position:absolute;inset:0;background-size:cover;background-position:center;
  opacity:0;transition:opacity 1.2s ease;
}
.hero-slide.active{opacity:1}
.hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg, rgba(90,15,30,.78) 0%, rgba(67,10,22,.62) 45%, rgba(161,78,3,.75) 100%);
}
.hero-rays{
  position:absolute;inset:-40% -20%;z-index:1;pointer-events:none;
  background:repeating-conic-gradient(from 0deg at 50% 40%, rgba(255,248,234,.06) 0deg 4deg, transparent 4deg 12deg);
}
.hero-inner{position:relative;z-index:2;padding:90px 24px 100px}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  font-size:13px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold-pale);font-weight:600;margin-bottom:22px;
}
.hero-eyebrow::before,.hero-eyebrow::after{content:"\2756";color:var(--gold-pale);font-size:11px}
.hero h1{
  font-size:clamp(32px,4.8vw,58px);font-weight:700;color:var(--white);
  text-shadow:0 2px 12px rgba(40,5,12,.55);max-width:22ch;margin:0 auto 12px;
}
.devanagari-badge{
  font-family:'Eczar',serif;font-weight:600;color:var(--maroon-deep);
  background:linear-gradient(160deg,var(--gold-pale),var(--gold));
  display:inline-block;padding:6px 26px;border-radius:50px;
  border:1.5px solid var(--gold-deep);
  font-size:clamp(19px,2.3vw,27px);margin-bottom:24px;
  box-shadow:0 4px 14px rgba(176,138,30,.4);
}
.hero p.lede{
  font-size:19px;color:#FFF3DC;max-width:62ch;margin:0 auto 36px;font-weight:300;
  text-shadow:0 1px 6px rgba(40,5,12,.5);
}
.hero-ctas{display:flex;gap:16px;flex-wrap:wrap;justify-content:center}
.hero-dots{position:absolute;bottom:46px;left:0;right:0;z-index:3;display:flex;gap:10px;justify-content:center}
.hero-dots button{
  width:11px;height:11px;border-radius:50%;border:1.5px solid var(--gold-pale);
  background:transparent;cursor:pointer;padding:0;
}
.hero-dots button.active{background:var(--gold-pale)}
.hero-scallop{
  position:relative;z-index:4;height:22px;width:100%;
  background:radial-gradient(circle at 12px 0px, rgba(161,78,3,.95) 11px, transparent 12px) repeat-x;
  background-size:24px 22px;background-color:var(--cream);margin-top:auto;
}

/* ===== shared section bits ===== */
.section{padding:84px 0}
.section-head{text-align:center;margin-bottom:14px}
.eyebrow{
  font-size:13px;letter-spacing:.26em;text-transform:uppercase;
  color:var(--saffron-deep);font-weight:700;display:block;margin-bottom:12px;
}
h2.section-title{font-size:clamp(28px,3.4vw,44px);font-weight:700;color:var(--maroon);margin-bottom:14px}
.section-lede{max-width:66ch;margin:0 auto;color:var(--ink-soft);font-size:18px;text-align:center}
.divider{display:flex;align-items:center;justify-content:center;gap:16px;margin:0 auto 18px;max-width:420px}
.divider::before,.divider::after{content:"";flex:1;height:2px;background:linear-gradient(90deg, transparent, var(--gold))}
.divider::after{background:linear-gradient(90deg, var(--gold), transparent)}
.divider span{font-family:'Eczar',serif;color:var(--gold-deep);font-size:22px;line-height:1}

/* ===== welcome (arch + text) ===== */
.welcome-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:60px;align-items:center;margin-top:30px}
.arch{position:relative;width:min(330px,80vw);margin:0 auto;filter:drop-shadow(0 24px 40px rgba(67,10,22,.35))}
.arch-frame{
  border-radius:160px 160px 16px 16px;
  border:4px solid var(--gold);
  outline:2px solid var(--gold-pale);outline-offset:7px;
  overflow:hidden;background:linear-gradient(180deg, var(--cream), var(--gold-pale));
  aspect-ratio:3/4;
}
.arch-frame img{width:100%;height:100%;object-fit:cover}
.arch::before{
  content:"";position:absolute;top:-26px;left:50%;transform:translateX(-50%);
  width:18px;height:18px;border-radius:50%;
  background:radial-gradient(circle at 40% 35%, var(--gold-pale), var(--gold) 60%, var(--gold-deep));
  border:2px solid var(--maroon);z-index:2;
}
.arch::after{content:"";position:absolute;top:-10px;left:50%;transform:translateX(-50%);width:4px;height:14px;background:var(--gold-deep);z-index:1}
.welcome-text p{margin-bottom:16px}
.mv-cards{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:26px}
.mv-card{
  background:var(--white);border:1.5px solid var(--gold);border-left:5px solid var(--saffron);
  border-radius:12px;padding:20px 22px;
}
.mv-card h3{color:var(--maroon);font-size:19px;font-weight:700;margin-bottom:6px}
.mv-card p{color:var(--ink-soft);font-size:15px;margin:0}

/* ===== what we do ===== */
.bg-warm{background:linear-gradient(180deg, var(--cream), #FBEFD6)}
.do-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:46px}
.do-card{
  background:var(--white);border:1.5px solid var(--gold);border-radius:14px;
  padding:30px 26px;text-align:center;position:relative;
  box-shadow:0 10px 28px rgba(176,138,30,.12);
}
.do-card .ic{
  width:54px;height:54px;margin:0 auto 14px;border-radius:50%;
  background:radial-gradient(circle at 40% 32%, var(--amber-glow), var(--saffron) 55%, var(--saffron-deep));
  display:flex;align-items:center;justify-content:center;font-size:24px;border:2px solid var(--gold);
}
.do-card h3{font-size:20px;font-weight:700;color:var(--maroon);margin-bottom:8px}
.do-card p{color:var(--ink-soft);font-size:15px;margin:0}

/* ===== founders ===== */
.founders-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:50px}
.founder{
  background:var(--white);border:2px solid var(--gold);border-radius:18px;
  padding:34px 26px 28px;text-align:center;
  box-shadow:0 14px 34px rgba(176,138,30,.16);
}
.founder .f-arch{
  width:170px;margin:0 auto 18px;border-radius:90px 90px 10px 10px;overflow:hidden;
  border:3px solid var(--gold);outline:1.5px solid var(--gold-pale);outline-offset:5px;
  aspect-ratio:3/4;background:linear-gradient(180deg,var(--cream),var(--gold-pale));
  display:flex;align-items:center;justify-content:center;
}
.founder .f-arch img{width:100%;height:100%;object-fit:cover;object-position:center 15%}
.founder .f-arch .ph{font-size:44px;color:var(--gold-deep);font-family:'Eczar',serif}
.founder h3{font-size:23px;font-weight:700;color:var(--maroon)}
.founder .role{color:var(--saffron-deep);font-weight:700;font-size:13px;letter-spacing:.18em;text-transform:uppercase;margin:4px 0 12px}
.founder p{color:var(--ink-soft);font-size:15px}
.founder .quote{
  margin-top:14px;font-family:'Eczar',serif;color:var(--maroon);font-size:15.5px;
  border-top:1px solid var(--gold-pale);padding-top:12px;font-style:italic;
}
.founders-note{text-align:center;max-width:74ch;margin:34px auto 0;color:var(--ink-soft)}

/* ===== events ===== */
.section-maroon{
  background:radial-gradient(ellipse 90% 70% at 50% 0%, rgba(212,175,55,.14), transparent 60%),
  linear-gradient(180deg, var(--maroon) 0%, var(--maroon-deep) 100%);
  color:var(--cream);
}
.section-maroon .eyebrow{color:var(--gold-pale)}
.section-maroon h2.section-title{color:var(--white)}
.section-maroon .section-lede{color:#EAD8B8}
.section-maroon .divider span{color:var(--gold-pale)}
.event-list{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:46px}
.event{
  background:var(--cream);border:2px solid var(--gold);border-radius:16px;overflow:hidden;
  display:flex;flex-direction:column;color:var(--ink);box-shadow:0 14px 34px rgba(0,0,0,.3);
}
.event-date{
  background:linear-gradient(160deg,var(--saffron),var(--saffron-rich));color:var(--white);
  padding:12px 20px;font-size:13px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;
}
.event-body{padding:22px 22px 26px;flex:1;display:flex;flex-direction:column}
.event-body h3{font-size:21px;font-weight:700;color:var(--maroon);margin-bottom:8px}
.event-body p{color:var(--ink-soft);font-size:15px;flex:1}
.event-meta{margin-top:16px;font-size:14px;font-weight:600}
.event-meta span{color:var(--saffron-deep)}
.note-soft{margin-top:30px;font-size:14.5px;color:#D9BE94;text-align:center}

/* ===== gallery ===== */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:46px}
.gallery-grid a{
  display:block;border-radius:12px;overflow:hidden;border:2px solid var(--gold);
  aspect-ratio:1/1;box-shadow:0 8px 20px rgba(176,138,30,.15);
}
.gallery-grid img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}
.gallery-grid a:hover img{transform:scale(1.05)}
.center-cta{text-align:center;margin-top:38px}

/* ===== values band ===== */
.values-band{
  background:radial-gradient(ellipse 100% 80% at 50% 110%, rgba(212,175,55,.22), transparent 55%),
  linear-gradient(180deg, var(--saffron) 0%, var(--saffron-deep) 100%);
  color:var(--white);
}
.values-band .eyebrow{color:var(--gold-pale)}
.values-band h2.section-title{color:var(--white);text-shadow:0 2px 8px rgba(90,15,30,.3)}
.values-list{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:34px}
.value-chip{
  background:rgba(255,253,246,.14);border:1.5px solid var(--gold-pale);
  color:var(--white);border-radius:50px;padding:10px 24px;font-weight:600;font-size:15px;
  backdrop-filter:blur(2px);
}
.values-band .why{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 34px;max-width:840px;margin:38px auto 0}
.values-band .why li{list-style:none;color:#FFF1D8;font-size:16px;padding-left:30px;position:relative}
.values-band .why li::before{content:"\1FA94";position:absolute;left:0}

/* ===== forms ===== */
.form-wrap{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start;margin-top:24px}
.form-card{
  background:var(--white);border:2px solid var(--gold);border-radius:18px;
  padding:38px 32px 32px;color:var(--ink);
  box-shadow:0 22px 60px rgba(67,10,22,.18);position:relative;
}
.form-card::before{
  content:"\0950";position:absolute;top:-21px;left:50%;transform:translateX(-50%);
  width:42px;height:42px;border-radius:50%;
  background:radial-gradient(circle at 40% 35%, var(--gold-pale), var(--gold) 60%, var(--gold-deep));
  border:2px solid var(--maroon);display:flex;align-items:center;justify-content:center;
  font-family:'Eczar',serif;font-weight:700;color:var(--maroon);font-size:20px;
}
.form-card h3{color:var(--maroon);font-weight:700;font-size:24px;margin:6px 0 18px;text-align:center}
.field{margin-bottom:16px}
.field label{display:block;font-size:14px;font-weight:700;margin-bottom:6px}
.field input,.field select,.field textarea{
  width:100%;padding:11px 14px;border:1.5px solid var(--gold);
  border-radius:10px;font-family:'Mukta',sans-serif;font-size:15px;
  background:var(--cream);color:var(--ink);
}
.field textarea{min-height:110px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--saffron);outline-offset:1px}
.form-note{font-size:13px;color:var(--ink-soft);margin-top:12px;text-align:center}
.form-msg{
  background:#E8F6E8;border:1.5px solid #2E7D32;color:#1B5E20;
  border-radius:10px;padding:14px 18px;margin-bottom:20px;font-weight:600;
}
.hp-field{position:absolute;left:-9999px;opacity:0;height:0;overflow:hidden}

/* ===== page hero (inner pages) ===== */
.page-hero{
  background:radial-gradient(ellipse 120% 90% at 50% -10%, var(--amber-glow) 0%, var(--saffron) 40%, var(--saffron-deep) 100%);
  color:var(--white);text-align:center;padding:64px 24px 56px;position:relative;overflow:hidden;
}
.page-hero::before{
  content:"";position:absolute;inset:-40% -20%;
  background:repeating-conic-gradient(from 0deg at 50% 30%, rgba(255,248,234,.07) 0deg 4deg, transparent 4deg 12deg);
  pointer-events:none;
}
.page-hero h1{font-size:clamp(30px,4vw,48px);font-weight:700;position:relative;text-shadow:0 2px 10px rgba(90,15,30,.35)}
.page-hero .devanagari-badge{margin-top:16px;margin-bottom:0;position:relative}
.entry-content{max-width:820px;margin:0 auto}
.entry-content p{margin-bottom:18px}
.entry-content h2{color:var(--maroon);font-size:30px;margin:34px 0 14px}
.entry-content h3{color:var(--maroon);font-size:23px;margin:28px 0 10px}
.entry-content ul{margin:0 0 18px 22px}
.entry-content li{margin-bottom:8px}

/* ===== footer ===== */
.site-footer{background:var(--maroon-deep);color:#E2CBA6;padding:0 0 26px}
.footer-border{
  height:18px;
  background:radial-gradient(circle at 10px 22px, transparent 11px, var(--maroon-deep) 12px) repeat-x;
  background-size:20px 18px;background-color:var(--saffron-deep);
}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.1fr;gap:40px;margin:52px 0 38px}
.site-footer h3{font-size:19px;font-weight:700;color:var(--gold-pale);margin-bottom:14px}
.site-footer a{color:#E2CBA6;text-decoration:none}
.site-footer a:hover{color:var(--gold-pale)}
.site-footer ul{list-style:none}
.site-footer li{margin-bottom:9px;font-size:15px}
.footer-about p{font-size:15px;max-width:42ch}
.socials{display:flex;gap:12px;margin-top:16px}
.socials a{
  width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:rgba(212,175,55,.14);border:1.5px solid var(--gold);transition:background .2s ease;
}
.socials a:hover{background:var(--gold)}
.socials svg{width:20px;height:20px;fill:var(--gold-pale)}
.socials a:hover svg{fill:var(--maroon-deep)}
.footer-bottom{
  border-top:1px solid rgba(212,175,55,.3);padding-top:20px;text-align:center;
  font-size:14px;color:#BCA078;
}
.footer-bottom .jsr{font-family:'Eczar',serif;font-weight:600;color:var(--gold-pale);font-size:18px;display:block;margin-bottom:6px}

/* ===== responsive ===== */
@media (max-width:980px){
  .welcome-grid{grid-template-columns:1fr;gap:44px}
  .do-grid,.founders-grid{grid-template-columns:1fr 1fr}
  .event-list{grid-template-columns:1fr 1fr}
  .gallery-grid{grid-template-columns:repeat(3,1fr)}
  .form-wrap{grid-template-columns:1fr;gap:44px}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:680px){
  nav.links{
    display:none;position:absolute;top:100%;left:0;right:0;
    background:var(--saffron-rich);flex-direction:column;gap:0;
    border-bottom:3px solid var(--gold);
  }
  nav.links.open{display:flex}
  nav.links a{padding:14px 24px;border-bottom:1px solid rgba(255,253,246,.18);width:100%}
  .menu-toggle{display:block}
  .do-grid,.founders-grid,.event-list{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .mv-cards,.values-band .why{grid-template-columns:1fr}
  .section{padding:62px 0}
  .hero{min-height:560px}
}
