/*
Theme Name: Swarnim Bharat Manch
Theme URI:  https://example.com/
Author: Vaibhav (generated)
Description: Responsive starter theme inspired by narayanseva.org
Version: 1.0
License: GPL-2.0+
Text Domain: narayanseva-lite
*/

/* ================= ROOT VARS ================= */

:root{
  --accent:#d32f2f;
  --accent-dark:#b22a28;
  --bg:#ffffff;
  --muted:#667085;
  --dark:#0f1724;
  --container:1100px;
  --radius:10px;
  --gap:18px;
  --header-height:80px;
  --transition:0.25s;
  font-family: Inter, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
}

/* ================= BASE ================= */

*{box-sizing:border-box;}
html,body{height:100%;}
body{
  margin:0;
  color:var(--dark);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none;transition:all var(--transition);}

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

/* ================= HEADER ================= */

.site-header{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  z-index:9999;
  background:transparent;
  border-bottom:none;
}

.site-header .container{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:10px 0;
}

/* logo */
.site-branding img{
  max-height:56px;
  width:auto;
  display:block;
}

/* Desktop menu */
.main-nav{
  flex:1;
  display:flex;
  justify-content:center;
}
.primary-nav{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  gap:22px;
  align-items:center;
}
.primary-nav li{position:relative;}
.primary-nav > li > a{
  font-weight:600;
  font-size:15px;
  padding:6px 4px;
}

/* Desktop dropdown */
.primary-nav li ul.sub-menu{
  list-style:none;
  margin:0;
  padding:6px 0;
  position:absolute;
  left:0;
  top:100%;
  min-width:190px;
  background:#fff;
  border:1px solid #ddd;
  border-radius:6px;
  box-shadow:0 10px 30px rgba(15,23,42,0.12);
  display:none;
  z-index:9999;
}
.primary-nav li:hover > ul.sub-menu{display:block;}
.primary-nav li ul.sub-menu li a{
  display:block;
  padding:8px 12px;
  font-size:14px;
  color:#222;
}

/* Donate button */
.cta-donate{
  background:var(--accent);
  color:#fff;
  padding:10px 16px;
  border-radius:8px;
  display:inline-block;
  font-weight:600;
  box-shadow:0 6px 18px rgba(210,50,50,0.18);
}

/* Right side (Donate + Hamburger) */
.header-actions{
  display:flex;
  align-items:center;
  gap:10px;
}

/* Language links */
.lang-link{
  position:absolute;
  right:18px;
  top:76px;
  font-size:14px;
  color:var(--muted);
}

/* Hamburger Icon */
.nav-toggle{
  display:none;
  border:0;
  background:transparent;
  font-size:26px;
  cursor:pointer;
}

/* MOBILE MENU HIDE BY DEFAULT */
.mobile-nav{
  display:none;
}

/* MOBILE MENU OPEN STATE */
.mobile-nav.is-open{
  display:block !important;
  background:#fff;
  margin-top:10px;
  padding:12px;
  border-radius:10px;
  box-shadow:0 12px 30px rgba(15,23,42,0.18);
}
.mobile-nav .primary-nav{
  flex-direction:column;
  gap:0;
}
.mobile-nav .primary-nav li{width:100%;}
.mobile-nav .primary-nav li a{
  display:block;
  padding:10px 0;
}

/* ================= HERO SECTION ================= */

.hero{
  position:relative;
  width:100%;
  min-height:90vh;
  background-image:url('assets/img/background.jpg');
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  padding-top:calc(var(--header-height) + 40px);
}

.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(
    rgba(0,87,161,0.20),
    rgba(242,140,40,0.20)
  );
  z-index:1;
}

.hero .container{
  position:relative;
  z-index:2;
}

.slides{display:flex;transition:transform 0.6s ease;}
.slide{
  min-height:320px;
  display:flex;
  gap:24px;
  align-items:center;
  padding:40px 0;
  width:100%;
  flex-shrink:0;
}
.slide .content{flex:1;}
.slide .media{flex:1;text-align:right;}
.slide h1{font-size:30px;margin:0 0 12px;}
.slide p{color:var(--muted);margin:0 0 16px;}
.slide img{
  max-width:100%;
  border-radius:12px;
  box-shadow:0 8px 30px rgba(15,23,36,0.06);
}

/* ================= SECTIONS ================= */

.section{padding:48px 0;}
.section-title{font-size:20px;margin-bottom:18px;color:var(--dark);}

.grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:var(--gap);
}
.card{
  background:#fff;
  padding:20px;
  border-radius:12px;
  border:1px solid #f0f0f0;
  box-shadow:0 6px 20px rgba(15,23,36,0.03);
}
.card p{margin:0;color:var(--muted);font-size:14px;}
.card a{color:var(--accent);font-weight:600;}

/* Stories */
.stories-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.story .thumb{
  height:160px;
  border-radius:8px;
  overflow:hidden;
}
.story img{
  width:100%;
  height:100%;
  object-fit:cover;
}

/* ================= FOOTER ================= */
.site-footer{
  background:#071425;
  color:#fff;
  padding:40px 0;
}
.site-footer .container{
  display:flex;
  gap:32px;
  flex-wrap:wrap;
}

/* ================= RESPONSIVE ================= */

@media(max-width:1100px){
  .grid{grid-template-columns:repeat(3,1fr);}
  .stories-grid{grid-template-columns:repeat(2,1fr);}
}

@media(max-width:880px){
  .slide{
    flex-direction:column;
    text-align:left;
    padding:28px 0;
  }
  .grid{grid-template-columns:repeat(2,1fr);}
}

/* ================= MOBILE (<=640px) ================= */

@media(max-width:640px){

  :root{
    --container:100%;
    --header-height:72px;
  }

  /* hide desktop menu */
  .primary-nav,
  .main-nav{
    display:none !important;
  }

  /* show hamburger */
  .nav-toggle{
    display:block !important;
  }

  /* mobile layout */
  .site-header .container{
    padding:8px 12px;
  }
  .site-branding img{max-height:48px;}

  .header-actions{gap:6px;}
  .cta-donate{padding:8px 10px;font-size:14px;}

  .slide h1{font-size:22px;}
  .slide p{font-size:14px;}

  .grid,
  .stories-grid{
    grid-template-columns:1fr;
  }

  /* language links adjust */
  .lang-link{
    position:static;
    margin-top:4px;
    text-align:right;
  }
}

/* JS helper */
#mobile-menu.is-open{display:block !important;}

@media (min-width: 641px){
  #mobile-menu,
  .mobile-nav{
    display:none !important;
  }
}
/* FIX: allow primary-nav inside mobile menu */
#mobile-menu .primary-nav {
  display: flex !important;
  flex-direction: column;
  gap: 0;
}

#mobile-menu .primary-nav li a {
  display: block;
  padding: 12px 0;
  border-bottom: 1px solid #eee;
}

#mobile-menu.is-open {
  display: block !important;
  background: #fff;
  padding: 15px;
  border-radius: 8px;
}


.footer-nav {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer-nav li {
  margin: 6px 0;
}

.footer-nav a {
  color: rgba(255,255,255,0.7);
  text-decoration: none;
  transition: 0.3s;
}

.footer-nav a:hover {
  color: #fff;
}

/* Responsive footer fix */
@media(max-width:768px){
  .site-footer .container {
     display: flex;
     flex-direction: column;
     gap: 24px;
     text-align: center;
  }
}

