:root{
  --bg:#f8fbff; --card:#ffffff; --muted:#6b7280; --accent:#f97316; --accent-2:#2563eb; --shadow:0 10px 30px rgba(2,6,23,0.06);
}
*{box-sizing:border-box}
html,body{height:100%;margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial;color:#0b1220}
body{background:linear-gradient(180deg,#fff,var(--bg));}
.container{max-width:1100px;margin:28px auto;padding:0 18px}
.site-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid #eef6ff;background:#fff}
.brand h1{margin:0;color:var(--accent-2);letter-spacing:1px}
.subtitle{margin:0;color:var(--muted);font-size:13px}
.top-nav a{margin-left:16px;color:#0b1220;text-decoration:none;font-weight:600}

.hero{display:flex;gap:18px;align-items:center;padding:22px;background:linear-gradient(90deg,#fff9f2,#ffffff);border-radius:12px;box-shadow:var(--shadow)}
.hero-left{flex:1}
.hero h2{margin:0;font-size:26px;color:#0b2540}
.lead{margin-top:8px;color:var(--muted)}
.cta-row{margin-top:14px}
.btn{display:inline-block;padding:10px 16px;border-radius:999px;background:var(--accent);color:#fff;text-decoration:none;font-weight:700;box-shadow:0 6px 18px rgba(249,115,22,0.12)}
.btn.ghost{background:transparent;color:var(--accent-2);border:1px solid rgba(37,99,235,0.08)}

.panel{margin-top:20px;padding:18px;background:var(--card);border-radius:12px;box-shadow:var(--shadow)}
.panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.controls{display:flex;gap:10px;align-items:center}
.controls select,.controls input{padding:8px 12px;border-radius:10px;border:1px solid #e9f0fb}
.view-toggle button{padding:8px 12px;border-radius:8px;border:1px solid #e9f0fb;background:#fff}
.view-toggle .active{background:var(--accent-2);color:#fff}

#festivalsContainer.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-top:14px}
.card{
  background:var(--card);
  border-radius:12px;
  padding:12px;
  box-shadow:0 10px 24px rgba(2,6,23,0.04);
  min-height:170px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
}
.card img{
  width:100%;
  height:200px;            /* fixed uniform height */
  object-fit:cover;        /* ensures crop & fit */
  border-radius:8px;
  display:block;
  flex-shrink:0;
}

.card h3{margin:10px 0 6px}
.card p{margin:0;color:var(--muted)}

.map-area{display:flex;gap:18px;margin-top:12px;align-items:flex-start}
#map-wrapper{flex:1;border-radius:12px;padding:12px;background:linear-gradient(180deg,#fff,#fbfcff);box-shadow:var(--shadow)}
.state-panel{width:340px;background:var(--card);border-radius:12px;padding:12px;box-shadow:var(--shadow);position:relative}
.state-panel.hidden{display:none}
.state-panel .close{position:absolute;right:10px;top:10px;border:0;background:transparent;font-size:18px;cursor:pointer}
.festival-card{
  display:flex;
  gap:12px;
  align-items:flex-start;
  padding:10px;
  border-radius:10px;
  border:1px solid #f2f6fb;
  background:linear-gradient(180deg,#fff,#fff);
  overflow:hidden;
}
.festival-card img {
  width:100px;
  height:100px;           /* make it square */
  object-fit:cover;       /* crop nicely */
  border-radius:8px;
  flex-shrink:0;
  display:block;
} 

.festival-cards{display:grid;gap:10px}

.culture-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px}
.card .small{color:var(--muted);font-size:13px}

.site-footer{text-align:center;padding:16px;color:var(--muted);margin-top:18px}

@media (max-width:900px){
  .hero{flex-direction:column}
  .map-area{flex-direction:column}
  .state-panel{width:100%}
  .card img{height:180px;}                   /* responsive adjustment */
  .festival-card img{width:80px;height:80px;}/* responsive adjustment */
}
#leafletMap {
  height: 500px;
  width: 100%;
  margin-top: 20px;
}
