/* =====================================================
   NGOMitra — style.css
   Warm editorial aesthetic — Instrument Serif + Outfit
   ===================================================== */

:root {
  --ink:        #1a1a18;
  --ink-mid:    #3d3d38;
  --ink-soft:   #6b6b64;
  --ink-ghost:  #9b9b92;
  --paper:      #faf9f6;
  --paper-warm: #f3f1eb;
  --paper-deep: #ebe8e0;
  --white:      #ffffff;
  --sage:       #3d6b52;
  --sage-mid:   #5a9070;
  --sage-light: #e6f0ea;
  --amber:      #c97c2b;
  --amber-light:#fdf3e6;
  --gold:       #b8860b;
  --gold-light: #fdf8e6;
  --red-soft:   #c0392b;
  --border:     #e2dfd7;
  --shadow-sm:  0 1px 4px rgba(26,26,24,0.07);
  --shadow-md:  0 4px 16px rgba(26,26,24,0.10);
  --shadow-lg:  0 12px 40px rgba(26,26,24,0.13);
  --r-sm: 8px; --r-md: 12px; --r-lg: 18px; --r-xl: 24px;
  --font-display: 'Instrument Serif', Georgia, serif;
  --font-body:    'Outfit', sans-serif;
  --nav-h: 62px;
  --filter-h: 52px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--font-body);background:var(--paper);color:var(--ink);-webkit-font-smoothing:antialiased;min-height:100vh;}
a{text-decoration:none;color:inherit;}
button{cursor:pointer;font-family:var(--font-body);border:none;background:none;}
img{display:block;max-width:100%;object-fit:cover;}

/* ── NAV ── */
.nav{
  position:sticky;top:0;z-index:300;
  height:var(--nav-h);
  background:var(--ink);
  display:flex;align-items:center;
  padding:0 24px;gap:20px;
  box-shadow:0 2px 20px rgba(0,0,0,0.25);
}
.nav__brand{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.nav__logo{
  width:34px;height:34px;border-radius:9px;
  background:var(--amber);
  display:flex;align-items:center;justify-content:center;
  color:white;
}
.nav__name{
  font-family:var(--font-display);
  font-size:1.45rem;color:#fff;letter-spacing:-0.3px;
  font-style:normal;
}
.nav__name em{color:var(--amber);font-style:italic;}
.nav__search-wrap{
  flex:1;max-width:400px;position:relative;
}
.nav__search-icon{
  position:absolute;left:12px;top:50%;transform:translateY(-50%);
  color:rgba(255,255,255,0.35);pointer-events:none;
}
#searchInput{
  width:100%;height:38px;
  padding:0 14px 0 38px;
  background:rgba(255,255,255,0.1);
  border:1.5px solid rgba(255,255,255,0.15);
  border-radius:999px;
  font-family:var(--font-body);font-size:0.875rem;
  color:#fff;outline:none;
  transition:background 0.18s,border-color 0.18s;
}
#searchInput::placeholder{color:rgba(255,255,255,0.35);}
#searchInput:focus{background:rgba(255,255,255,0.15);border-color:rgba(255,255,255,0.35);}
.nav__actions{margin-left:auto;flex-shrink:0;}
.nav__list-btn{
  display:inline-flex;align-items:center;gap:4px;
  background:var(--amber);color:#fff;
  font-size:0.85rem;font-weight:600;
  padding:8px 18px;border-radius:999px;
  transition:opacity 0.15s,transform 0.15s;
  white-space:nowrap;
}
.nav__list-btn:hover{opacity:0.88;transform:translateY(-1px);}

/* ── HERO ── */
.hero{
  background:var(--ink);
  padding:48px 24px 52px;
  display:flex;align-items:center;gap:40px;
  overflow:hidden;position:relative;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 70% 50%, rgba(201,124,43,0.12) 0%, transparent 60%);
}
.hero__left{flex:1;position:relative;z-index:1;}
.hero__tag{
  display:inline-block;
  background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.15);
  color:rgba(255,255,255,0.75);font-size:0.72rem;font-weight:600;
  letter-spacing:0.8px;text-transform:uppercase;
  padding:5px 14px;border-radius:999px;margin-bottom:18px;
}
.hero__title{
  font-family:var(--font-display);
  font-size:clamp(2.2rem,5vw,3.6rem);
  color:#fff;line-height:1.1;letter-spacing:-0.5px;
  margin-bottom:14px;
}
.hero__title em{color:var(--amber);font-style:italic;}
.hero__desc{font-size:0.95rem;color:rgba(255,255,255,0.55);line-height:1.65;margin-bottom:28px;max-width:460px;}
.hero__stats{display:flex;align-items:center;gap:20px;flex-wrap:wrap;}
.stat{text-align:left;}
.stat__num{display:block;font-family:var(--font-display);font-size:1.6rem;color:#fff;line-height:1;}
.stat__label{font-size:0.7rem;color:rgba(255,255,255,0.4);text-transform:uppercase;letter-spacing:0.6px;}
.stat__sep{width:1px;height:30px;background:rgba(255,255,255,0.12);}
.hero__right{flex-shrink:0;width:220px;position:relative;z-index:1;}
.hero__card-preview{position:relative;height:200px;}
.preview-pill{
  position:absolute;
  background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.15);
  color:rgba(255,255,255,0.75);font-size:0.75rem;font-weight:500;
  padding:6px 14px;border-radius:999px;white-space:nowrap;
  animation:floatPill 4s ease-in-out infinite;
}
.preview-pill--1{top:0;left:20px;animation-delay:0s;}
.preview-pill--2{top:30px;right:0;animation-delay:0.5s;}
.preview-pill--3{top:80px;left:0;animation-delay:1s;}
.preview-pill--4{top:110px;right:10px;animation-delay:1.5s;}
.preview-pill--5{top:155px;left:30px;animation-delay:2s;}
.preview-pill--6{top:165px;right:0;animation-delay:2.5s;}
@keyframes floatPill{0%,100%{transform:translateY(0);}50%{transform:translateY(-5px);}}

/* ── FILTER BAR ── */
.filter-bar{
  background:var(--white);border-bottom:1px solid var(--border);
  position:sticky;top:var(--nav-h);z-index:200;
  padding:0 24px;height:var(--filter-h);
  display:flex;align-items:center;gap:12px;
  box-shadow:var(--shadow-sm);
}
.filter-bar__label{font-size:0.7rem;font-weight:600;color:var(--ink-ghost);text-transform:uppercase;letter-spacing:0.7px;white-space:nowrap;}
.tags-row{display:flex;gap:6px;overflow-x:auto;flex:1;padding:4px 0;scrollbar-width:none;}
.tags-row::-webkit-scrollbar{display:none;}
.tag-pill{
  flex-shrink:0;padding:5px 14px;border-radius:999px;
  font-size:0.78rem;font-weight:500;
  border:1.5px solid var(--border);background:var(--white);color:var(--ink-soft);
  transition:all 0.15s;white-space:nowrap;
}
.tag-pill:hover{border-color:var(--sage-mid);color:var(--sage);}
.tag-pill.active{background:var(--sage);color:#fff;border-color:var(--sage);}
.filter-bar__count{font-size:0.75rem;color:var(--ink-ghost);white-space:nowrap;flex-shrink:0;}

/* ── LAYOUT ── */
.layout{
  display:grid;
  grid-template-columns:200px 1fr 200px;
  gap:0;
  min-height:calc(100vh - var(--nav-h) - var(--filter-h));
  align-items:start;
}

/* ── SIDEBAR ── */
.sidebar{
  padding:20px 14px;
  border-right:1px solid var(--border);
  position:sticky;
  top:calc(var(--nav-h) + var(--filter-h));
  height:calc(100vh - var(--nav-h) - var(--filter-h));
  overflow-y:auto;
  display:flex;flex-direction:column;gap:12px;
  background:var(--white);
  scrollbar-width:thin;
  scrollbar-color:var(--border) transparent;
}
.sidebar--right{border-right:none;border-left:1px solid var(--border);}
.sidebar__label{
  font-size:0.6rem;font-weight:700;letter-spacing:1.2px;
  text-transform:uppercase;color:var(--ink-ghost);
  text-align:center;padding-bottom:8px;
  border-bottom:1px solid var(--border);
}
.ad-box{
  background:var(--paper-warm);border:1.5px dashed var(--border);
  border-radius:var(--r-md);padding:14px 10px;text-align:center;
}
.ad-box__icon{font-size:1.4rem;margin-bottom:4px;opacity:0.4;}
.ad-box__title{font-size:0.78rem;font-weight:600;color:var(--ink-mid);margin-bottom:4px;}
.ad-box__desc{font-size:0.68rem;color:var(--ink-ghost);line-height:1.4;margin-bottom:8px;}
.ad-box--sm .ad-box__title{font-size:0.72rem;}
.ad-box__btn{
  display:inline-block;background:var(--ink);color:#fff;
  font-size:0.7rem;font-weight:600;padding:6px 14px;border-radius:var(--r-sm);
  transition:opacity 0.15s;
}
.ad-box__btn:hover{opacity:0.8;}
.aff-box{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-md);padding:12px;
  position:relative;overflow:hidden;
}
.aff-box--dark{background:var(--ink);}
.aff-box__badge{
  position:absolute;top:8px;right:8px;
  background:var(--amber-light);color:var(--amber);
  font-size:0.55rem;font-weight:700;letter-spacing:0.8px;
  text-transform:uppercase;padding:2px 6px;border-radius:4px;
}
.aff-box__emoji{font-size:1.3rem;margin-bottom:6px;}
.aff-box__name{font-size:0.8rem;font-weight:600;color:var(--ink);margin-bottom:4px;}
.aff-box__desc{font-size:0.68rem;color:var(--ink-soft);line-height:1.4;margin-bottom:8px;}
.aff-box__link{font-size:0.72rem;font-weight:600;color:var(--sage);transition:opacity 0.15s;}
.aff-box__link:hover{opacity:0.75;}
.aff-box__link--light{color:var(--amber);}

/* List CTA in sidebar */
.list-cta{
  background:linear-gradient(135deg,var(--sage) 0%,#2a5240 100%);
  border-radius:var(--r-md);padding:16px 12px;text-align:center;
}
.list-cta__icon{font-size:1.6rem;margin-bottom:6px;}
.list-cta__title{font-family:var(--font-display);font-size:1rem;color:#fff;font-style:italic;margin-bottom:4px;}
.list-cta__price{background:var(--amber);color:#fff;font-size:0.85rem;font-weight:700;padding:3px 12px;border-radius:999px;display:inline-block;margin-bottom:8px;}
.list-cta__desc{font-size:0.68rem;color:rgba(255,255,255,0.65);line-height:1.5;margin-bottom:8px;}
.list-cta__upi{background:rgba(255,255,255,0.1);border-radius:6px;padding:6px 8px;font-size:0.65rem;color:rgba(255,255,255,0.7);margin-bottom:10px;}
.list-cta__upi strong{color:#fff;}
.list-cta__btn{
  display:block;background:#25D366;color:#fff;
  font-size:0.75rem;font-weight:600;
  padding:8px;border-radius:var(--r-sm);
  transition:opacity 0.15s;
}
.list-cta__btn:hover{opacity:0.88;}

/* ── MAIN ── */
.main{padding:24px 20px 60px;min-width:0;}

/* ── BENTO GRID ── */
.bento{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:16px;
}
.bento__loading{
  grid-column:1/-1;
  display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:14px;min-height:300px;
  color:var(--ink-ghost);font-size:0.9rem;
}

/* ── NGO CARD ── */
.ngo-card{
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--r-xl);
  overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform 0.22s ease,box-shadow 0.22s ease;
  animation:cardIn 0.4s ease both;
  position:relative;
}
@keyframes cardIn{from{opacity:0;transform:translateY(14px);}to{opacity:1;transform:translateY(0);}}
.ngo-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.ngo-card--featured{
  border:2px solid var(--gold);
  background:var(--gold-light);
  box-shadow:0 0 0 3px rgba(184,134,11,0.1);
}

/* Media */
.card-media{
  width:100%;height:170px;overflow:hidden;
  background:var(--sage-light);flex-shrink:0;position:relative;
}
.card-media img{width:100%;height:100%;object-fit:cover;transition:transform 0.4s ease;}
.ngo-card:hover .card-media img{transform:scale(1.05);}
.card-media iframe{width:100%;height:100%;border:none;}
.card-media__placeholder{
  width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  font-size:2.8rem;background:linear-gradient(135deg,var(--sage-light),#c8dfd0);
}

/* Badges on media */
.card-badges{
  position:absolute;top:10px;left:10px;right:10px;
  display:flex;align-items:center;justify-content:space-between;
  pointer-events:none;
}
.badge-featured{
  background:var(--gold);color:#fff;
  font-size:0.62rem;font-weight:700;letter-spacing:0.5px;text-transform:uppercase;
  padding:3px 9px;border-radius:999px;
}
.badge-listed{
  background:rgba(255,255,255,0.92);color:var(--sage);
  font-size:0.65rem;font-weight:700;
  padding:3px 9px;border-radius:999px;
  display:flex;align-items:center;gap:3px;
}

/* Card body */
.card-body{padding:14px 16px;display:flex;flex-direction:column;gap:9px;flex:1;}
.card-name{font-family:var(--font-display);font-size:1.05rem;color:var(--ink);line-height:1.25;font-style:italic;}
.card-year{font-size:0.68rem;color:var(--ink-ghost);margin-top:1px;}
.card-tags{display:flex;flex-wrap:wrap;gap:4px;}
.card-tag{
  background:var(--sage-light);color:var(--sage);
  font-size:0.65rem;font-weight:600;padding:3px 9px;border-radius:999px;
  border:none;cursor:pointer;font-family:var(--font-body);
  transition:background 0.15s,color 0.15s;
}
.card-tag:hover{background:var(--sage);color:#fff;}
.card-meta{display:flex;flex-direction:column;gap:4px;}
.meta-row{display:flex;align-items:baseline;gap:5px;font-size:0.72rem;color:var(--ink-soft);line-height:1.4;}
.meta-row strong{color:var(--ink);font-weight:600;margin-right:2px;}
.meta-row a{color:var(--sage-mid);}
.meta-row a:hover{text-decoration:underline;}

/* Map */
.card-map{
  border-radius:var(--r-sm);overflow:hidden;
  border:1px solid var(--border);height:95px;flex-shrink:0;
}
.card-map iframe{width:100%;height:100%;border:none;display:block;}

/* Card footer */
.card-footer{
  padding:10px 16px;border-top:1px solid var(--border);
  display:flex;gap:8px;background:var(--paper-warm);
}
.ngo-card--featured .card-footer{background:rgba(184,134,11,0.04);}
.btn-share{
  display:flex;align-items:center;gap:5px;
  font-size:0.72rem;font-weight:600;color:var(--ink-soft);
  background:var(--white);border:1.5px solid var(--border);
  padding:8px 11px;border-radius:var(--r-sm);flex-shrink:0;
  transition:all 0.15s;
}
.btn-share:hover{border-color:var(--sage);color:var(--sage);}
.btn-donate{
  flex:1;display:flex;align-items:center;justify-content:center;
  gap:5px;background:var(--ink);color:#fff;
  font-size:0.8rem;font-weight:700;
  padding:9px 14px;border-radius:var(--r-sm);
  border:none;font-family:var(--font-body);
  transition:opacity 0.15s,transform 0.15s;
}
.btn-donate:hover{opacity:0.85;transform:scale(1.01);}
.ngo-card--featured .btn-donate{background:var(--gold);}

/* ── CTA CARD ── */
.cta-card{
  background:var(--ink);
  border-radius:var(--r-xl);
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  text-align:center;padding:28px 20px;gap:10px;
  min-height:280px;
  border:2px dashed rgba(255,255,255,0.1);
  animation:cardIn 0.4s ease both;
  transition:transform 0.22s;
}
.cta-card:hover{transform:translateY(-4px);}
.cta-plus{
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,0.08);
  border:2px solid rgba(255,255,255,0.15);
  display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;color:rgba(255,255,255,0.5);
}
.cta-title{font-family:var(--font-display);font-size:1.15rem;color:#fff;font-style:italic;line-height:1.25;}
.cta-price{background:var(--amber);color:#fff;font-size:0.85rem;font-weight:700;padding:4px 16px;border-radius:999px;}
.cta-desc{font-size:0.73rem;color:rgba(255,255,255,0.5);line-height:1.6;max-width:180px;}
.cta-upi{
  background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.12);
  border-radius:6px;padding:7px 12px;font-size:0.67rem;
  color:rgba(255,255,255,0.65);width:100%;
}
.cta-upi strong{color:#fff;}
.cta-btn{
  display:flex;align-items:center;gap:6px;
  background:#25D366;color:#fff;font-size:0.78rem;font-weight:700;
  padding:9px 18px;border-radius:var(--r-sm);border:none;
  font-family:var(--font-body);transition:opacity 0.15s;
}
.cta-btn:hover{opacity:0.88;}
.cta-note{font-size:0.62rem;color:rgba(255,255,255,0.3);}

/* ── SPINNER ── */
.spinner{
  width:36px;height:36px;
  border:3px solid var(--border);
  border-top-color:var(--sage-mid);
  border-radius:50%;animation:spin 0.7s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg);}}

/* ── WA FAB ── */
.wa-fab{
  position:fixed;bottom:28px;right:28px;z-index:999;
  width:54px;height:54px;border-radius:50%;
  background:#25D366;color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px rgba(37,211,102,0.45);
  transition:transform 0.15s;
  animation:waPulse 2.5s ease-in-out infinite;
}
.wa-fab:hover{transform:scale(1.1);animation:none;box-shadow:0 6px 28px rgba(37,211,102,0.6);}
@keyframes waPulse{0%,100%{box-shadow:0 4px 20px rgba(37,211,102,0.45);}50%{box-shadow:0 4px 30px rgba(37,211,102,0.7);}}

/* ── FOOTER ── */
.footer{background:var(--ink);padding:28px 24px;margin-top:0;}
.footer__inner{
  max-width:1200px;margin:0 auto;
  display:flex;gap:40px;align-items:flex-start;flex-wrap:wrap;
}
.footer__brand{flex:0 0 auto;}
.footer__logo{font-family:var(--font-display);font-size:1.3rem;color:#fff;font-style:normal;}
.footer__logo em{color:var(--amber);font-style:italic;}
.footer__brand p{font-size:0.75rem;color:rgba(255,255,255,0.35);margin-top:4px;}
.footer__disclaimer{flex:1;font-size:0.72rem;color:rgba(255,255,255,0.3);line-height:1.7;min-width:200px;}
.footer__contact{flex:0 0 auto;font-size:0.75rem;color:rgba(255,255,255,0.4);line-height:1.8;}
.footer__contact strong{color:rgba(255,255,255,0.7);}

/* ── EMPTY / ERROR ── */
.grid-empty{
  grid-column:1/-1;text-align:center;
  padding:60px 20px;color:var(--ink-ghost);font-size:0.9rem;
}

/* ── RESPONSIVE ── */
@media(max-width:1100px){.layout{grid-template-columns:180px 1fr;}.sidebar--right{display:none;}}
@media(max-width:860px){.layout{grid-template-columns:1fr;}.sidebar--left{display:none;}.hero{flex-direction:column;gap:24px;}.hero__right{display:none;}}
@media(max-width:540px){
  .nav{padding:0 14px;gap:10px;}
  .nav__list-btn span{display:none;}
  .bento{grid-template-columns:1fr;}
  .main{padding:16px 12px 48px;}
  .filter-bar{padding:0 12px;}
}
