/*
Theme Name: Mahfil Site
Theme URI: https://mahfil.site
Author: Mahfil Team
Author URI: https://mahfil.site
Description: A beautiful Islamic events platform theme for Mahfil.site
Version: 3.1.0
Requires at least: 5.8
Tested up to: 6.5
Requires PHP: 7.4
Text Domain: mahfil-site
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Tags: islamic, events, custom-colors, custom-logo, full-width-template
*/

/* ════════════════════════════════════════════
   BASE RESET & ROOT
════════════════════════════════════════════ */
:root {
  --primary: #1a5c3a;
  --primary-light: #2d8a5a;
  --primary-dark: #0f3822;
  --accent: #c9a84c;
  --accent-light: #e8c97a;
  --accent-dark: #9a7a2e;
  --bg: #f5f0e8;
  --cream: #fdf8f0;
  --section-bg: #eef5f0;
  --card-bg: #ffffff;
  --text: #1a1a1a;
  --text-muted: #6b6b6b;
  --body-font: 'Lato', sans-serif;
  --heading-font: 'Amiri', serif;
  --font-size: 16px;
  --hero-title-size: 58px;
  --sec-padding: 60px;
  --card-radius: 16px;
  --btn-radius: 30px;
  --max-width: 1100px;
  --ticker-speed: 28s;
  --hero-height: 580px;
  --hero-overlay: rgba(10,35,20,0.72);
  --hero-pattern: 0.07;
  --transition: 0.25s ease;
  --shadow-sm: 0 2px 8px rgba(0,0,0,0.08);
  --shadow-md: 0 4px 20px rgba(0,0,0,0.12);
  --shadow-lg: 0 8px 40px rgba(0,0,0,0.18);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: var(--font-size); }
body {
  font-family: var(--body-font);
  background: var(--bg);
  color: var(--text);
  line-height: 1.7;
  overflow-x: hidden;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; transition: color var(--transition); }
ul { list-style: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }

/* ════════════════════════════════════════════
   ANIMATIONS
════════════════════════════════════════════ */
@keyframes ticker-scroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@keyframes fade-in-up { from { opacity: 0; transform: translateY(24px); } to { opacity: 1; transform: translateY(0); } }
@keyframes fade-in { from { opacity: 0; } to { opacity: 1; } }
@keyframes pulse-dot { 0%,100%{transform:scale(1);opacity:1} 50%{transform:scale(0.7);opacity:0.4} }
@keyframes spin { to { transform: rotate(360deg); } }

.animate-fade      { animation: fade-in     0.8s ease both; }
.animate-up        { animation: fade-in-up  0.7s ease both 0.2s; }
.animate-up-delay  { animation: fade-in-up  0.7s ease both 0.4s; }
.animate-up-delay2 { animation: fade-in-up  0.7s ease both 0.6s; }

/* ════════════════════════════════════════════
   UTILITY
════════════════════════════════════════════ */
.mf-container { max-width: var(--max-width); margin: 0 auto; padding: 0 24px; }
.mf-section   { padding: var(--sec-padding) 0; }

/* ════════════════════════════════════════════
   NAV
════════════════════════════════════════════ */
.mf-nav {
  background: var(--primary-dark);
  height: 64px;
  padding: 0 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: sticky;
  top: 0;
  z-index: 999;
  box-shadow: 0 2px 16px rgba(0,0,0,0.35);
  transition: box-shadow var(--transition);
}
.mf-nav.scrolled { box-shadow: 0 4px 24px rgba(0,0,0,0.5); }
.mf-nav-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--heading-font);
  font-size: 22px;
  color: var(--accent);
  text-decoration: none;
  flex-shrink: 0;
}
.mf-logo-ar {
  font-family: var(--heading-font);
  font-size: 20px;
  color: var(--accent-light);
  opacity: 0.85;
}
.mf-nav-links {
  display: flex;
  gap: 6px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.mf-nav-links a, .mf-nav-links li a {
  color: rgba(255,255,255,0.82);
  font-size: 14px;
  font-weight: 600;
  padding: 6px 14px;
  border-radius: 6px;
  transition: all var(--transition);
}
.mf-nav-links a:hover, .mf-nav-links li a:hover {
  color: var(--accent);
  background: rgba(201,168,76,0.1);
}
.mf-nav-btns { display: flex; align-items: center; gap: 10px; }
.mf-btn-outline {
  border: 1.5px solid var(--accent);
  color: var(--accent);
  background: transparent;
  padding: 7px 18px;
  border-radius: var(--btn-radius);
  font-size: 13px;
  font-weight: 700;
  text-decoration: none;
  display: inline-block;
  transition: all var(--transition);
}
.mf-btn-outline:hover { background: var(--accent); color: #fff; }
.mf-btn-solid {
  background: var(--accent);
  color: var(--primary-dark);
  border: none;
  padding: 8px 20px;
  border-radius: var(--btn-radius);
  font-size: 13px;
  font-weight: 700;
  text-decoration: none;
  display: inline-block;
  transition: all var(--transition);
}
.mf-btn-solid:hover { opacity: 0.88; transform: translateY(-1px); }
.mf-hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  padding: 6px;
  cursor: pointer;
  background: none;
  border: none;
}
.mf-hamburger span { width: 22px; height: 2px; background: rgba(255,255,255,0.8); border-radius: 1px; transition: all 0.3s; display: block; }
.mf-hamburger.open span:nth-child(1) { transform: rotate(45deg) translate(5px, 5px); }
.mf-hamburger.open span:nth-child(2) { opacity: 0; }
.mf-hamburger.open span:nth-child(3) { transform: rotate(-45deg) translate(5px, -5px); }

/* ════════════════════════════════════════════
   TICKER
════════════════════════════════════════════ */
.mf-ticker-wrap {
  background: var(--primary);
  height: 38px;
  display: flex;
  align-items: center;
  overflow: hidden;
  gap: 0;
}
.mf-ticker-badge {
  background: var(--accent);
  color: var(--primary-dark);
  font-size: 11px;
  font-weight: 700;
  padding: 4px 14px;
  white-space: nowrap;
  flex-shrink: 0;
  height: 100%;
  display: flex;
  align-items: center;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
.mf-ticker-track { overflow: hidden; flex: 1; height: 100%; display: flex; align-items: center; }
.mf-ticker-inner {
  display: flex;
  align-items: center;
  white-space: nowrap;
  animation: ticker-scroll var(--ticker-speed) linear infinite;
}
.mf-ticker-item { font-size: 13px; color: rgba(255,255,255,0.85); padding: 0 20px; }
.mf-ticker-sep  { color: var(--accent); font-size: 11px; opacity: 0.7; }

/* ════════════════════════════════════════════
   HERO
════════════════════════════════════════════ */
.mf-hero {
  min-height: var(--hero-height);
  background: var(--primary-dark);
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background-size: cover;
  background-position: center;
}
.mf-hero-overlay {
  position: absolute;
  inset: 0;
  background: var(--hero-overlay);
  z-index: 1;
}
.mf-hero-pattern {
  position: absolute;
  inset: 0;
  z-index: 2;
  opacity: var(--hero-pattern);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80' viewBox='0 0 80 80'%3E%3Cg fill='none' stroke='%23c9a84c' stroke-width='0.8'%3E%3Cpolygon points='40,4 76,22 76,58 40,76 4,58 4,22'/%3E%3Cpolygon points='40,14 66,28 66,52 40,66 14,52 14,28'/%3E%3Cpolygon points='40,24 56,34 56,46 40,56 24,46 24,34'/%3E%3C/g%3E%3C/svg%3E");
  background-size: 80px 80px;
}
.mf-hero-inner {
  position: relative;
  z-index: 3;
  text-align: center;
  max-width: 780px;
  padding: 60px 24px;
}
.mf-hero-bismillah {
  font-family: var(--heading-font);
  font-size: 2.2rem;
  color: var(--accent-light);
  margin-bottom: 16px;
  text-shadow: 0 0 30px rgba(201,168,76,0.3);
  line-height: 1.4;
}
.mf-hero-ornament {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin-bottom: 20px;
}
.mf-orn-line  { width: 60px; height: 1px; background: linear-gradient(90deg, transparent, var(--accent)); }
.mf-orn-line:last-child { background: linear-gradient(270deg, transparent, var(--accent)); }
.mf-orn-star  { color: var(--accent); font-size: 1rem; }
.mf-hero-title {
  font-family: var(--heading-font);
  font-size: var(--hero-title-size);
  font-weight: 700;
  color: #fff;
  line-height: 1.15;
  margin-bottom: 18px;
  text-shadow: 0 2px 20px rgba(0,0,0,0.4);
}
.mf-hero-highlight { color: var(--accent); display: block; }
.mf-hero-sub {
  font-size: 1.15rem;
  color: rgba(255,255,255,0.72);
  margin-bottom: 32px;
  max-width: 540px;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.75;
}
.mf-hero-btns { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; margin-bottom: 40px; }
.mf-btn-primary {
  background: var(--primary);
  color: #fff;
  padding: 14px 34px;
  border-radius: var(--btn-radius);
  font-weight: 700;
  font-size: 15px;
  border: 2px solid var(--primary-light);
  transition: all var(--transition);
  display: inline-block;
}
.mf-btn-primary:hover { background: var(--primary-light); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.mf-btn-gold {
  background: linear-gradient(135deg, var(--accent-dark), var(--accent), var(--accent-light));
  color: var(--primary-dark);
  padding: 14px 34px;
  border-radius: var(--btn-radius);
  font-weight: 700;
  font-size: 15px;
  border: none;
  transition: all var(--transition);
  display: inline-block;
  box-shadow: 0 4px 18px rgba(201,168,76,0.35);
}
.mf-btn-gold:hover { transform: translateY(-2px); box-shadow: 0 8px 28px rgba(201,168,76,0.5); opacity: 0.92; }
.mf-hero-stats { display: flex; align-items: center; justify-content: center; gap: 24px; flex-wrap: wrap; }
.mf-stat { text-align: center; }
.mf-stat-num { display: block; font-family: var(--heading-font); font-size: 2rem; font-weight: 700; color: var(--accent); line-height: 1; }
.mf-stat-label { font-size: 12px; color: rgba(255,255,255,0.55); letter-spacing: 0.07em; text-transform: uppercase; margin-top: 4px; }
.mf-stat-div { width: 1px; height: 36px; background: rgba(201,168,76,0.3); }

/* ════════════════════════════════════════════
   NAAT PLAYER
════════════════════════════════════════════ */
.mf-naat-player {
  position: absolute;
  bottom: 24px;
  right: 24px;
  z-index: 4;
  background: rgba(10,35,20,0.88);
  border: 1px solid rgba(201,168,76,0.35);
  border-radius: 14px;
  padding: 14px 18px;
  display: flex;
  align-items: center;
  gap: 14px;
  backdrop-filter: blur(10px);
  min-width: 280px;
  box-shadow: var(--shadow-lg);
}
.mf-naat-info { display: flex; align-items: center; gap: 10px; flex: 1; }
.mf-naat-icon { font-size: 1.4rem; }
.mf-naat-title { font-family: var(--heading-font); font-size: 14px; color: var(--accent-light); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 150px; }
.mf-naat-sub   { font-size: 11px; color: rgba(255,255,255,0.45); }
.mf-naat-controls { display: flex; align-items: center; gap: 10px; }
.mf-play-btn {
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--accent);
  color: var(--primary-dark);
  border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; flex-shrink: 0;
  transition: all var(--transition);
}
.mf-play-btn:hover { opacity: 0.85; transform: scale(1.08); }
.mf-naat-progress-wrap { display: flex; flex-direction: column; gap: 4px; }
.mf-naat-progress { width: 90px; height: 4px; background: rgba(255,255,255,0.15); border-radius: 2px; cursor: pointer; overflow: hidden; }
.mf-naat-fill { height: 100%; background: var(--accent); border-radius: 2px; width: 0%; transition: width 0.5s linear; }
.mf-naat-time { font-size: 11px; color: rgba(255,255,255,0.45); }

/* ════════════════════════════════════════════
   SECTION HEAD
════════════════════════════════════════════ */
.mf-section-head { text-align: center; margin-bottom: 40px; }
.mf-badge {
  display: inline-block;
  background: rgba(26,92,58,0.1);
  border: 1px solid rgba(26,92,58,0.25);
  color: var(--primary);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 5px 16px;
  border-radius: 20px;
  margin-bottom: 14px;
}
.mf-badge-gold    { background: rgba(201,168,76,0.12); border-color: rgba(201,168,76,0.3); color: var(--accent-dark); }
.mf-badge-outline { background: transparent; border-color: rgba(201,168,76,0.4); color: var(--accent); }
.mf-section-title {
  font-family: var(--heading-font);
  font-size: 2.4rem;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 12px;
  line-height: 1.25;
}
.mf-title-light { color: #fff; }
.mf-section-sub  { font-size: 1.05rem; color: var(--text-muted); max-width: 500px; margin: 0 auto; }

/* ════════════════════════════════════════════
   EVENTS GRID
════════════════════════════════════════════ */
.mf-events-section { background: var(--bg); }

/* ══ HOMEPAGE FILTER BAR ══ */
.mf-hp-filter { margin: 0 0 32px; }
.mf-hp-filter-label { display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:16px; }
.mf-hp-filter-label-line { flex:1;max-width:56px;height:1px;background:linear-gradient(90deg,transparent,rgba(201,168,76,.4)); }
.mf-hp-filter-label-line.right { background:linear-gradient(90deg,rgba(201,168,76,.4),transparent); }
.mf-hp-filter-label-text { font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent,#c9a84c); }
.mf-hp-filter-inner { background:var(--card-bg,#fff);border-radius:20px;box-shadow:0 2px 0 rgba(201,168,76,.3),0 8px 32px rgba(15,56,34,.1);border:1.5px solid rgba(201,168,76,.28);overflow:hidden; }
.mf-hp-sel-row { display:flex;align-items:stretch; }
.mf-hp-sel-wrap { flex:1;display:flex;align-items:center;position:relative;border-right:1px solid rgba(201,168,76,.15);transition:background .15s; }
.mf-hp-sel-wrap:last-child { border-right:none; }
.mf-hp-sel-wrap:hover { background:rgba(201,168,76,.04); }
.mf-hp-sel-meta { display:flex;flex-direction:column;align-items:center;padding:0 0 0 14px;pointer-events:none;flex-shrink:0; }
.mf-hp-sel-icon { font-size:18px;line-height:1;margin-bottom:2px; }
.mf-hp-sel-sublabel { font-size:8.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent,#c9a84c); }
.mf-hp-sel { flex:1;padding:18px 30px 18px 10px;border:none;outline:none;cursor:pointer;font-size:13.5px;font-weight:600;background:transparent;color:var(--text,#1a1a1a);-webkit-appearance:none;appearance:none; }
.mf-hp-sel-arrow { position:absolute;right:12px;top:50%;transform:translateY(-50%);pointer-events:none;width:10px;height:7px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='7'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23c9a84c' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center; }
.mf-hp-filter-btn-row { border-top:1.5px solid rgba(201,168,76,.15);background:linear-gradient(135deg,#0f3822,#1a5c3a); }
.mf-hp-filter-btn { display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:16px 24px;background:transparent;color:#fff;font-size:14.5px;font-weight:700;letter-spacing:.04em;border:none;cursor:pointer;font-family:inherit; }
.mf-hp-filter-btn:hover { opacity:.88; }
.mf-hp-filter-btn-text { flex:1;text-align:center; }
.mf-hp-filter-btn-arrow { font-size:16px;opacity:.7; }
.mf-hp-active-chips { display:flex;gap:6px;flex-wrap:wrap;margin-top:10px; }
.mf-hp-chip { display:inline-flex;align-items:center;background:rgba(26,92,58,.08);border:1px solid rgba(26,92,58,.2);color:var(--primary,#1a5c3a);font-size:12px;font-weight:700;padding:4px 12px;border-radius:20px; }
/* Timer */
.mf-tu{display:flex;flex-direction:column;align-items:center;background:linear-gradient(135deg,#0f3822,#1a5c3a);border-radius:7px;padding:5px 8px;min-width:36px;box-shadow:0 2px 6px rgba(15,56,34,.2)}
.mf-tn{font-family:Georgia,serif;font-size:16px;font-weight:700;color:#c9a84c;line-height:1.1}
.mf-tl{font-size:8px;font-weight:600;color:rgba(255,255,255,.45);text-transform:uppercase;letter-spacing:.07em}
.mf-tsep{font-size:15px;font-weight:700;color:rgba(201,168,76,.45);margin-bottom:7px;line-height:1}
.mf-timer-pill-label{font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:#888;padding:3px 9px;background:rgba(201,168,76,.1);border:1px solid rgba(201,168,76,.22);border-radius:20px;white-space:nowrap}
.mf-timer-happening{font-size:10px;font-weight:700;color:var(--primary,#1a5c3a);letter-spacing:.05em;text-transform:uppercase}
@media(max-width:700px){.mf-hp-sel-row{flex-direction:column}.mf-hp-sel-wrap{border-right:none;border-bottom:1px solid rgba(201,168,76,.15)}.mf-hp-sel-wrap:last-child{border-bottom:none}.mf-hp-sel{padding:15px 30px 15px 10px}.mf-hp-filter-btn{padding:15px}}
.mf-events-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 24px;
  margin-bottom: 36px;
}
.mf-event-card {
  background: var(--card-bg);
  border-radius: var(--card-radius);
  border: 1px solid rgba(201,168,76,0.18);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.mf-event-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: rgba(201,168,76,0.45); }
.mf-event-thumb { position: relative; height: 190px; overflow: hidden; }
.mf-event-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s ease; }
.mf-event-card:hover .mf-event-thumb img { transform: scale(1.04); }
.mf-event-thumb-placeholder { width: 100%; height: 100%; background: linear-gradient(135deg, var(--primary-dark), var(--primary)); display: flex; align-items: center; justify-content: center; font-size: 3rem; }
.mf-event-type-badge {
  position: absolute; top: 12px; left: 12px;
  background: rgba(15,56,34,0.88); color: var(--accent-light);
  font-size: 11px; font-weight: 700; padding: 4px 10px; border-radius: 20px;
  backdrop-filter: blur(4px); letter-spacing: 0.05em;
}
.mf-event-fee-badge {
  position: absolute; top: 12px; right: 12px;
  font-size: 11px; font-weight: 700; padding: 4px 10px; border-radius: 20px;
}
.mf-event-fee-badge.free { background: rgba(29,158,117,0.85); color: #fff; }
.mf-event-fee-badge.paid { background: rgba(201,168,76,0.9); color: var(--primary-dark); }
.mf-event-body { padding: 18px; flex: 1; }
.mf-event-title { font-family: var(--heading-font); font-size: 1.2rem; font-weight: 700; color: var(--text); margin-bottom: 8px; line-height: 1.35; }
.mf-event-title a { color: inherit; }
.mf-event-title a:hover { color: var(--primary); }
.mf-event-excerpt { font-size: 0.85rem; color: var(--text-muted); line-height: 1.65; margin-bottom: 14px; }
.mf-event-meta { display: flex; flex-direction: column; gap: 6px; }
.mf-event-meta-row { display: flex; align-items: center; gap: 7px; font-size: 13px; color: var(--text-muted); }
.mf-meta-icon { font-size: 0.9rem; flex-shrink: 0; }
.mf-event-footer { padding: 14px 18px; border-top: 1px solid rgba(201,168,76,0.12); }
.mf-event-btn {
  display: inline-flex; align-items: center;
  color: var(--primary); font-size: 13px; font-weight: 700;
  padding: 7px 16px; border: 1.5px solid rgba(26,92,58,0.3);
  border-radius: var(--btn-radius); transition: all var(--transition);
}
.mf-event-btn:hover { background: var(--primary); color: #fff; border-color: var(--primary); }
.mf-view-all-wrap { text-align: center; }
.mf-btn-view-all {
  display: inline-block;
  border: 2px solid var(--primary);
  color: var(--primary);
  padding: 12px 34px;
  border-radius: var(--btn-radius);
  font-weight: 700;
  font-size: 14px;
  transition: all var(--transition);
}
.mf-btn-view-all:hover { background: var(--primary); color: #fff; transform: translateY(-2px); }
.mf-no-events { text-align: center; padding: 60px 24px; }
.mf-no-events-icon { font-size: 3.5rem; margin-bottom: 16px; }
.mf-no-events h3 { font-family: var(--heading-font); font-size: 1.6rem; margin-bottom: 10px; color: var(--text); }
.mf-no-events p  { color: var(--text-muted); margin-bottom: 24px; }

/* ════════════════════════════════════════════
   FEATURES
════════════════════════════════════════════ */
.mf-features-section { background: var(--primary-dark); }
.mf-features-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 20px;
}
.mf-feature-card {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(201,168,76,0.18);
  border-radius: var(--card-radius);
  padding: 28px 22px;
  text-align: center;
  transition: all var(--transition);
}
.mf-feature-card:hover { background: rgba(255,255,255,0.08); border-color: rgba(201,168,76,0.42); transform: translateY(-3px); }
.mf-feature-icon  { font-size: 2.4rem; margin-bottom: 14px; }
.mf-feature-title { font-family: var(--heading-font); font-size: 1.15rem; font-weight: 700; color: var(--accent-light); margin-bottom: 8px; }
.mf-feature-desc  { font-size: 0.85rem; color: rgba(255,255,255,0.55); line-height: 1.7; }

/* ════════════════════════════════════════════
   SUBMIT CTA
════════════════════════════════════════════ */
.mf-submit-cta { background: var(--section-bg); }
.mf-cta-card {
  background: linear-gradient(135deg, var(--primary-dark), #1a4a2a);
  border: 1px solid rgba(201,168,76,0.25);
  border-radius: 20px;
  padding: 56px 40px;
  text-align: center;
  position: relative;
  overflow: hidden;
  box-shadow: var(--shadow-lg);
}
.mf-cta-deco { position: absolute; top: -20px; right: 40px; font-size: 8rem; color: rgba(201,168,76,0.06); pointer-events: none; }
.mf-cta-title { font-family: var(--heading-font); font-size: 2.4rem; font-weight: 700; color: #fff; margin: 12px 0; }
.mf-cta-sub   { color: rgba(255,255,255,0.6); font-size: 1.05rem; max-width: 520px; margin: 0 auto 32px; line-height: 1.75; }
.mf-cta-steps { display: flex; align-items: center; justify-content: center; gap: 16px; margin-bottom: 32px; flex-wrap: wrap; }
.mf-cta-step  { display: flex; align-items: center; gap: 10px; color: rgba(255,255,255,0.75); font-size: 14px; }
.mf-cta-step-n { width: 32px; height: 32px; border-radius: 50%; background: rgba(201,168,76,0.2); border: 1.5px solid rgba(201,168,76,0.45); color: var(--accent); font-size: 14px; font-weight: 700; display: flex; align-items: center; justify-content: center; }
.mf-cta-arrow { color: rgba(201,168,76,0.45); font-size: 1.2rem; }
.mf-btn-cta {
  display: inline-block;
  background: linear-gradient(135deg, var(--accent-dark), var(--accent), var(--accent-light));
  color: var(--primary-dark);
  padding: 16px 44px;
  border-radius: var(--btn-radius);
  font-weight: 700;
  font-size: 16px;
  box-shadow: 0 6px 24px rgba(201,168,76,0.35);
  transition: all var(--transition);
  margin-bottom: 16px;
}
.mf-btn-cta:hover { transform: translateY(-3px); box-shadow: 0 10px 36px rgba(201,168,76,0.5); }
.mf-cta-note { font-size: 13px; color: rgba(255,255,255,0.4); margin-top: 8px; }

/* ════════════════════════════════════════════
   ADMIN PANEL
════════════════════════════════════════════ */
.mf-admin-section { background: #fff8f0; }
.mf-admin-card { background: #fff; border: 1px solid rgba(201,168,76,0.25); border-radius: 16px; overflow: hidden; box-shadow: var(--shadow-sm); }
.mf-admin-head { padding: 18px 24px; border-bottom: 1px solid rgba(201,168,76,0.15); display: flex; align-items: center; justify-content: space-between; }
.mf-admin-head h2 { font-size: 1.2rem; font-weight: 700; }
.mf-admin-badge { background: var(--primary); color: #fff; font-size: 11px; font-weight: 700; padding: 3px 12px; border-radius: 20px; letter-spacing: 0.06em; }
.mf-admin-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: rgba(201,168,76,0.12); }
.mf-admin-stat { background: #fff; padding: 24px; text-align: center; }
.mf-admin-stat-num { font-family: var(--heading-font); font-size: 2.4rem; color: var(--primary); font-weight: 700; }
.mf-admin-stat-label { font-size: 12px; color: var(--text-muted); margin-top: 4px; text-transform: uppercase; letter-spacing: 0.07em; }
.mf-admin-links { padding: 20px 24px; display: flex; gap: 12px; flex-wrap: wrap; }
.mf-admin-link { display: inline-flex; align-items: center; gap: 6px; padding: 9px 18px; background: var(--section-bg); border: 1px solid rgba(26,92,58,0.2); border-radius: 8px; color: var(--primary-dark); font-size: 13px; font-weight: 600; transition: all var(--transition); }
.mf-admin-link:hover { background: var(--primary); color: #fff; border-color: var(--primary); }

/* ════════════════════════════════════════════
   FOOTER
════════════════════════════════════════════ */
.mf-footer { background: var(--primary-dark); color: rgba(255,255,255,0.8); }
.mf-footer-inner { max-width: var(--max-width); margin: 0 auto; padding: 56px 24px 40px; display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 40px; }
.mf-footer-logo-wrap { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; }
.mf-footer-logo-wrap .mf-footer-logo { height: 40px; width: auto; object-fit: contain; }
.mf-footer-logo-text { font-family: var(--heading-font); font-size: 20px; color: var(--accent); }
.mf-footer-tagline { font-size: 13.5px; color: rgba(255,255,255,0.5); line-height: 1.7; margin-bottom: 16px; max-width: 260px; }
.mf-footer-ar { font-family: var(--heading-font); font-size: 1.4rem; color: var(--accent); margin-bottom: 20px; }
.mf-footer-socials { display: flex; gap: 10px; }
.mf-social-btn { width: 36px; height: 36px; border-radius: 50%; background: rgba(255,255,255,0.08); color: rgba(255,255,255,0.65); display: flex; align-items: center; justify-content: center; transition: all var(--transition); }
.mf-social-btn:hover { background: var(--accent); color: var(--primary-dark); transform: translateY(-2px); }
.mf-footer-col-head { font-size: 12px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent); margin-bottom: 18px; }
.mf-footer-links { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.mf-footer-links li a, .mf-footer-links a { font-size: 13.5px; color: rgba(255,255,255,0.55); transition: color var(--transition); }
.mf-footer-links li a:hover, .mf-footer-links a:hover { color: var(--accent); }
.mf-footer-bottom { border-top: 1px solid rgba(255,255,255,0.07); }
.mf-footer-bottom-inner { max-width: var(--max-width); margin: 0 auto; padding: 18px 24px; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 10px; }
.mf-footer-bottom-inner span { font-size: 12px; color: rgba(255,255,255,0.28); }
.mf-footer-bottom-orn { font-family: var(--heading-font); font-size: 1.2rem; color: rgba(201,168,76,0.45); }

/* ════════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════════ */
@media (max-width: 1024px) {
  .mf-footer-inner { grid-template-columns: 1fr 1fr; gap: 32px; }
  :root { --hero-title-size: 46px; }
}
@media (max-width: 768px) {
  :root { --hero-title-size: 34px; --sec-padding: 40px; }
  .mf-nav { padding: 0 16px; }
  .mf-nav-links { display: none; position: absolute; top: 64px; left: 0; right: 0; background: var(--primary-dark); padding: 16px; flex-direction: column; gap: 4px; box-shadow: var(--shadow-md); }
  .mf-nav-links.open { display: flex; }
  .mf-hamburger { display: flex; }
  .mf-btn-outline, .mf-btn-solid { padding: 6px 14px; font-size: 12px; }
  .mf-footer-inner { grid-template-columns: 1fr; gap: 32px; }
  .mf-naat-player { right: 12px; bottom: 12px; min-width: 240px; }
  .mf-cta-card { padding: 36px 20px; }
  .mf-admin-grid { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  :root { --hero-title-size: 28px; }
  .mf-hero-bismillah { font-size: 1.5rem; }
  .mf-hero-sub { font-size: 0.95rem; }
  .mf-section-title { font-size: 1.9rem; }
  .mf-events-grid { grid-template-columns: 1fr; }
  .mf-features-grid { grid-template-columns: 1fr 1fr; }
  .mf-hero-btns { flex-direction: column; align-items: center; }
  .mf-btn-primary, .mf-btn-gold { width: 100%; text-align: center; }
}

/* ════════════════════════════════════════════
   BLOG SECTION
════════════════════════════════════════════ */
.mf-blog-section { background: var(--cream, #fdf8f0); }

.mf-blog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 28px;
}

.mf-blog-card {
  background: var(--card-bg, #fff);
  border-radius: var(--card-radius, 16px);
  border: 1px solid rgba(201,168,76,.15);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.mf-blog-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 12px 36px rgba(0,0,0,.12);
  border-color: rgba(201,168,76,.38);
}

.mf-blog-thumb-link { display: block; }
.mf-blog-thumb {
  height: 210px;
  overflow: hidden;
  position: relative;
  background: var(--primary-dark, #0f3822);
}
.mf-blog-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.45s ease;
  /* Sharper rendering */
  image-rendering: -webkit-optimize-contrast;
  image-rendering: crisp-edges;
}
.mf-blog-card:hover .mf-blog-thumb img { transform: scale(1.05); }
.mf-blog-thumb-placeholder {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  font-size: 3.5rem;
  background: linear-gradient(135deg, var(--primary-dark,#0f3822), var(--primary,#1a5c3a));
}
.mf-blog-cat-badge {
  position: absolute;
  top: 12px; left: 12px;
  background: rgba(15,56,34,.88);
  color: var(--accent-light, #e8c97a);
  font-size: 11px; font-weight: 700;
  padding: 4px 12px; border-radius: 20px;
  backdrop-filter: blur(4px);
  letter-spacing: .05em;
}

.mf-blog-body { padding: 20px; flex: 1; display: flex; flex-direction: column; }
.mf-blog-meta {
  display: flex; align-items: center; gap: 8px;
  font-size: 12px; color: var(--text-muted, #6b6b6b);
  margin-bottom: 10px;
}
.mf-blog-dot { opacity: .4; }
.mf-blog-title {
  font-family: var(--heading-font, 'Amiri', serif);
  font-size: 1.2rem; font-weight: 700;
  color: var(--text, #1a1a1a);
  line-height: 1.35; margin-bottom: 10px;
}
.mf-blog-title a { color: inherit; }
.mf-blog-title a:hover { color: var(--primary, #1a5c3a); }
.mf-blog-excerpt {
  font-size: 13.5px; color: var(--text-muted, #6b6b6b);
  line-height: 1.7; flex: 1; margin-bottom: 16px;
}
.mf-blog-read-more {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 13px; font-weight: 700;
  color: var(--primary, #1a5c3a);
  padding: 7px 16px;
  border: 1.5px solid rgba(26,92,58,.25);
  border-radius: 20px;
  align-self: flex-start;
  transition: all var(--transition);
}
.mf-blog-read-more:hover {
  background: var(--primary, #1a5c3a);
  color: #fff; border-color: var(--primary, #1a5c3a);
}

/* ════════════════════════════════════════════
   IMAGE QUALITY GLOBAL FIXES
════════════════════════════════════════════ */
img {
  /* Prevent blurry scaling on retina displays */
  image-rendering: auto;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -ms-interpolation-mode: bicubic;
}

/* Preload hint for event card images */
.mf-event-thumb img,
.mf-blog-thumb img {
  will-change: transform;
  transform: translateZ(0); /* GPU layer for smooth hover */
}

/* ════════════════════════════════════════════
   HEADER NAV — BLOG HIGHLIGHT
════════════════════════════════════════════ */
.mf-nav-links li a[href*="blog"] {
  position: relative;
}
.mf-nav-links li a[href*="blog"]::after {
  content: '✦';
  font-size: 8px;
  color: var(--accent, #c9a84c);
  position: absolute;
  top: 2px;
  right: 2px;
  line-height: 1;
}
/* Submit event nav link — gold highlight */
.mf-nav-links li a[href*="submit"] {
  color: var(--accent, #c9a84c) !important;
  font-weight: 700;
  border: 1px solid rgba(201,168,76,.3);
  border-radius: 8px;
}
.mf-nav-links li a[href*="submit"]:hover {
  background: rgba(201,168,76,.12) !important;
  border-color: rgba(201,168,76,.6);
}

/* ════════════════════════════════════════════
   PERFORMANCE — CONTENT VISIBILITY
════════════════════════════════════════════ */
.mf-features-section,
.mf-submit-cta,
.mf-blog-section,
.mf-admin-section {
  content-visibility: auto;
  contain-intrinsic-size: 0 500px;
}

@media (max-width: 480px) {
  .mf-blog-grid { grid-template-columns: 1fr; }
  .mf-blog-thumb { height: 180px; }
}

/* Submit nav link gold highlight */
.mf-nav-links li a.mf-nav-submit,
.mf-nav-links li a[href*="submit-event"] {
  color: var(--accent, #c9a84c) !important;
  font-weight: 700 !important;
  border: 1.5px solid rgba(201,168,76,.35);
  border-radius: 8px;
  padding: 5px 13px !important;
}
.mf-nav-links li a.mf-nav-submit:hover,
.mf-nav-links li a[href*="submit-event"]:hover {
  background: rgba(201,168,76,.14) !important;
  border-color: rgba(201,168,76,.65);
}

/* ════════════════════════════════════════════
   HERO QUICK LINKS
════════════════════════════════════════════ */
.mf-hero-quicklinks {
  display: flex;
  gap: 10px;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 28px;
}
.mf-quicklink {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(201,168,76,0.28);
  color: rgba(255,255,255,0.82);
  padding: 9px 18px;
  border-radius: 30px;
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
  transition: all 0.22s ease;
  backdrop-filter: blur(6px);
}
.mf-quicklink:hover {
  background: rgba(201,168,76,0.18);
  border-color: rgba(201,168,76,0.6);
  color: var(--accent-light, #e8c97a);
  transform: translateY(-2px);
}
.mf-quicklink-icon { font-size: 1rem; }

/* ════════════════════════════════════════════
   NAMAZ TIMES PAGE — PRINT STYLES
════════════════════════════════════════════ */
@media print {
  .mf-nav, .mf-ticker-wrap, .mf-footer,
  .nt-filter, .nt-date-strip, .nt-adhan-bar,
  .nt-hero-pat, .ic-hero-pat { display: none !important; }
  .nt-prayers-grid { grid-template-columns: repeat(5,1fr) !important; }
  body { background: #fff !important; color: #000 !important; }
}

/* ════════════════════════════════════════════
   SINGLE POST — READING EXPERIENCE
════════════════════════════════════════════ */
.entry-content {
  font-size: 1.05rem;
  line-height: 1.85;
  color: var(--text, #1a1a1a);
  max-width: 720px;
}
.entry-content h2, .entry-content h3 {
  font-family: var(--heading-font, 'Amiri', serif);
  color: var(--primary-dark, #0f3822);
  margin: 1.5em 0 0.5em;
}
.entry-content p { margin-bottom: 1.2em; }
.entry-content img {
  max-width: 100%;
  border-radius: var(--card-radius, 16px);
  margin: 1.5em 0;
  box-shadow: var(--shadow-md);
}
.entry-content a { color: var(--primary, #1a5c3a); text-decoration: underline; }
.entry-content blockquote {
  border-left: 4px solid var(--accent, #c9a84c);
  padding: 14px 20px;
  background: rgba(201,168,76,0.05);
  border-radius: 0 10px 10px 0;
  font-family: var(--heading-font, 'Amiri', serif);
  font-size: 1.2rem;
  color: var(--primary-dark, #0f3822);
  margin: 1.5em 0;
}

/* ════════════════════════════════════════════
   PAGE TRANSITIONS — SMOOTH LOADING
════════════════════════════════════════════ */
.mf-events-grid,
.mf-blog-grid,
.ep-grid,
.bl-grid {
  animation: grid-appear 0.5s ease both;
}
@keyframes grid-appear {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ════════════════════════════════════════════
   ISLAMIC CALENDAR — MOBILE FIXES
════════════════════════════════════════════ */
@media (max-width: 480px) {
  .ic-wrap { padding: 20px 12px 48px; }
  .ic-today { padding: 18px 16px; }
  .ic-cal { border-radius: 10px; }
  .nt-wrap { padding: 20px 12px 48px; }
  .nt-city-header { padding: 14px 16px; }
  .nt-prayers-grid { grid-template-columns: 1fr 1fr 1fr; gap: 8px; }
  .nt-prayer-card { padding: 12px 8px; }
  .nt-prayer-time { font-size: 1.2rem; }
}

/* ════════════════════════════════════════════
   RESPONSIVE NAV — NAMAZ & CALENDAR
════════════════════════════════════════════ */
@media (max-width: 900px) {
  .mf-nav-links li a[href*="namaz"],
  .mf-nav-links li a[href*="calendar"] {
    display: none;
  }
}
@media (max-width: 768px) {
  .mf-nav-links li { display: block; }
  .mf-nav-links li a[href*="namaz"],
  .mf-nav-links li a[href*="calendar"] {
    display: block;
  }
}

/* ════════════════════════════════════════════
   CLICKABLE EVENT CARDS — full card is a link
════════════════════════════════════════════ */
.mf-event-card {
  position: relative;
  cursor: pointer;
}
/* The card-link overlay covers the whole card */
.mf-card-link-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  border-radius: var(--card-radius, 16px);
}
/* Buttons/links inside card stay clickable above overlay */
.mf-event-card .mf-event-btn,
.mf-event-card a,
.mf-event-card button {
  position: relative;
  z-index: 2;
}
/* Hover state on entire card */
.mf-event-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 14px 40px rgba(0,0,0,.16);
  border-color: rgba(201,168,76,.5);
}

/* ── Page-events clickable cards ── */
.ep-card {
  position: relative;
  cursor: pointer;
}
.ep-card-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  border-radius: var(--card-radius, 16px);
}
.ep-card a, .ep-card button {
  position: relative;
  z-index: 2;
}

/* ── Blog cards clickable ── */
.mf-blog-card {
  position: relative;
  cursor: pointer;
}
.mf-blog-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  border-radius: var(--card-radius, 16px);
}
.mf-blog-card a, .mf-blog-card button {
  position: relative;
  z-index: 2;
}

/* ════════════════════════════════════════════
   LIGHTBOX — Full image on click
════════════════════════════════════════════ */
.mf-lightbox {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 99999;
  background: rgba(0,0,0,.92);
  align-items: center;
  justify-content: center;
  cursor: zoom-out;
  animation: lb-fade-in 0.2s ease;
  backdrop-filter: blur(6px);
}
.mf-lightbox.open { display: flex; }
@keyframes lb-fade-in { from{opacity:0} to{opacity:1} }

.mf-lightbox-inner {
  position: relative;
  max-width: 92vw;
  max-height: 90vh;
  cursor: default;
  animation: lb-scale-in 0.25s cubic-bezier(0.22,1,0.36,1);
}
@keyframes lb-scale-in { from{transform:scale(0.88);opacity:0} to{transform:scale(1);opacity:1} }

.mf-lightbox-img {
  max-width: 92vw;
  max-height: 88vh;
  width: auto;
  height: auto;
  border-radius: 12px;
  box-shadow: 0 24px 80px rgba(0,0,0,.7);
  display: block;
  object-fit: contain;
}

.mf-lightbox-close {
  position: absolute;
  top: -14px;
  right: -14px;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(255,255,255,.15);
  border: 1.5px solid rgba(255,255,255,.3);
  color: #fff;
  font-size: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all .2s;
  backdrop-filter: blur(4px);
  line-height: 1;
}
.mf-lightbox-close:hover {
  background: rgba(255,255,255,.28);
  border-color: rgba(255,255,255,.6);
  transform: scale(1.1);
}

.mf-lightbox-caption {
  position: absolute;
  bottom: -36px;
  left: 0;
  right: 0;
  text-align: center;
  font-size: 13px;
  color: rgba(255,255,255,.55);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.mf-lightbox-nav {
  position: fixed;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: rgba(255,255,255,.12);
  border: 1.5px solid rgba(255,255,255,.2);
  color: #fff;
  font-size: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all .2s;
  z-index: 100000;
}
.mf-lightbox-nav:hover { background: rgba(255,255,255,.25); }
.mf-lightbox-prev { left: 16px; }
.mf-lightbox-next { right: 16px; }

/* Make event images show zoom cursor */
.mf-event-thumb img,
.sv-cover img,
.mf-blog-thumb img,
.ep-card-thumb img,
.bl-feat-thumb img,
.bl-card-thumb img {
  cursor: zoom-in;
}

/* Hijri date display — clickable to show customizer note */
.mf-hijri-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--heading-font,'Amiri',serif);
  font-size: 0.88rem;
  color: rgba(201,168,76,.8);
  border: 1px solid rgba(201,168,76,.2);
  border-radius: 20px;
  padding: 3px 12px;
  cursor: help;
  transition: all .2s;
}
.mf-hijri-badge:hover {
  border-color: rgba(201,168,76,.5);
  color: var(--accent,#c9a84c);
}

@media(max-width:480px){
  .mf-lightbox-nav { width:36px; height:36px; font-size:16px; }
  .mf-lightbox-prev { left:8px; }
  .mf-lightbox-next { right:8px; }
}

/* ════════════════════════════════════════════
   EVENT COUNTDOWN TIMER ON CARDS
════════════════════════════════════════════ */

/* Timer strip at bottom of event card */
.mf-event-timer {
  padding: 8px 14px;
  border-top: 1px solid rgba(201,168,76,.1);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  font-size: 12px;
  min-height: 36px;
}

/* Countdown digits */
.mf-timer-digits {
  display: flex;
  align-items: center;
  gap: 3px;
  font-family: var(--heading-font,'Amiri',serif);
  font-size: 13px;
  color: var(--primary-dark,#0f3822);
  font-weight: 700;
}
.mf-timer-unit {
  display: flex;
  flex-direction: column;
  align-items: center;
  background: rgba(26,92,58,.06);
  border: 1px solid rgba(201,168,76,.18);
  border-radius: 5px;
  padding: 2px 5px;
  min-width: 30px;
}
.mf-timer-num {
  font-size: 13px;
  font-weight: 700;
  color: var(--primary-dark,#0f3822);
  line-height: 1.2;
}
.mf-timer-lbl {
  font-size: 8.5px;
  color: var(--text-muted,#6b6b6b);
  text-transform: uppercase;
  letter-spacing: .06em;
  font-family: var(--body-font,'Lato',sans-serif);
  font-weight: 400;
  line-height: 1;
}
.mf-timer-sep {
  color: rgba(201,168,76,.6);
  font-size: 13px;
  margin-bottom: 8px;
}
.mf-timer-label {
  font-size: 10px;
  color: var(--text-muted,#6b6b6b);
  letter-spacing: .05em;
  text-transform: uppercase;
  white-space: nowrap;
}

/* TODAY badge — event is today */
.mf-timer-today {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: linear-gradient(135deg,rgba(26,92,58,.12),rgba(26,92,58,.06));
  border: 1px solid rgba(26,92,58,.3);
  border-radius: 20px;
  padding: 4px 10px;
  font-size: 11px;
  font-weight: 700;
  color: var(--primary,#1a5c3a);
  letter-spacing: .05em;
}
.mf-timer-today-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--primary,#1a5c3a);
  animation: mf-pulse 1.4s ease-in-out infinite;
}
@keyframes mf-pulse {
  0%,100% { transform:scale(1); opacity:1; }
  50%      { transform:scale(0.6); opacity:.4; }
}

/* COMPLETED / ORGANISED badge — event is past */
.mf-timer-done {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: linear-gradient(135deg,rgba(201,168,76,.1),rgba(201,168,76,.05));
  border: 1px solid rgba(201,168,76,.35);
  border-radius: 20px;
  padding: 5px 12px;
  font-size: 11px;
  font-weight: 700;
  color: var(--accent-dark,#9a7a2e);
  letter-spacing: .05em;
  white-space: nowrap;
}
.mf-timer-done-icon {
  font-size: 13px;
}

/* Upcoming timer — green tint */
.mf-event-timer.timer-upcoming {
  background: rgba(26,92,58,.02);
}
/* Today — gold tint */
.mf-event-timer.timer-today {
  background: rgba(26,92,58,.04);
}
/* Past — muted */
.mf-event-timer.timer-past {
  background: rgba(201,168,76,.04);
  opacity: .85;
}

/* On single event page — large countdown */
.sv-big-timer {
  background: linear-gradient(135deg,var(--primary-dark,#0f3822),#1a4a2a);
  border: 1px solid rgba(201,168,76,.25);
  border-radius: 16px;
  padding: 20px 24px;
  margin-bottom: 24px;
  text-align: center;
}
.sv-big-timer-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(201,168,76,.7);
  margin-bottom: 14px;
}
.sv-big-timer-units {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  flex-wrap: wrap;
}
.sv-big-unit {
  text-align: center;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(201,168,76,.2);
  border-radius: 10px;
  padding: 12px 16px;
  min-width: 64px;
}
.sv-big-num {
  display: block;
  font-family: var(--heading-font,'Amiri',serif);
  font-size: 2rem;
  font-weight: 700;
  color: var(--accent,#c9a84c);
  line-height: 1;
}
.sv-big-lbl {
  display: block;
  font-size: 10px;
  color: rgba(255,255,255,.4);
  text-transform: uppercase;
  letter-spacing: .1em;
  margin-top: 4px;
}
.sv-big-sep {
  font-family: var(--heading-font,'Amiri',serif);
  font-size: 1.8rem;
  color: rgba(201,168,76,.4);
  margin-bottom: 18px;
}

/* ORGANISED banner on single page */
.sv-organised-banner {
  background: linear-gradient(135deg,rgba(201,168,76,.12),rgba(201,168,76,.06));
  border: 2px solid rgba(201,168,76,.4);
  border-radius: 16px;
  padding: 20px 24px;
  margin-bottom: 24px;
  text-align: center;
}
.sv-organised-check {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: linear-gradient(135deg,var(--primary,#1a5c3a),var(--primary-light,#2d8a5a));
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  margin: 0 auto 12px;
  box-shadow: 0 4px 16px rgba(26,92,58,.3);
}
.sv-organised-title {
  font-family: var(--heading-font,'Amiri',serif);
  font-size: 1.3rem;
  color: var(--primary-dark,#0f3822);
  font-weight: 700;
  margin-bottom: 6px;
}
.sv-organised-sub {
  font-size: 13px;
  color: var(--text-muted,#6b6b6b);
}
.sv-organised-ar {
  font-family: var(--heading-font,'Amiri',serif);
  font-size: 1.1rem;
  color: var(--accent-dark,#9a7a2e);
  margin-top: 8px;
}

/* "Organised" ribbon on card thumb */
.mf-organised-ribbon {
  position: absolute;
  top: 12px;
  left: 50%;
  transform: translateX(-50%);
  background: linear-gradient(135deg,var(--primary,#1a5c3a),var(--primary-light,#2d8a5a));
  color: #fff;
  font-size: 10.5px;
  font-weight: 700;
  padding: 4px 14px;
  border-radius: 20px;
  letter-spacing: .06em;
  white-space: nowrap;
  box-shadow: 0 2px 8px rgba(26,92,58,.4);
  z-index: 2;
}

/* Past event card — slight overlay */
.mf-event-card.mf-event-past .mf-event-thumb img {
  filter: grayscale(15%) brightness(0.9);
}

@media(max-width:480px) {
  .sv-big-num { font-size: 1.5rem; }
  .sv-big-unit { min-width: 50px; padding: 10px 12px; }
}
