/* Festival Nerede - Main CSS */
:root {
  --red: #e63946;
  --red-dark: #c1121f;
  --red-light: #ff6b6b;
  --black: #1a1a2e;
  --dark: #16213e;
  --gray-100: #f8f9fa;
  --gray-200: #e9ecef;
  --gray-300: #dee2e6;
  --gray-500: #adb5bd;
  --gray-700: #495057;
  --gray-900: #212529;
  --white: #ffffff;
  --radius: 10px;
  --radius-sm: 6px;
  --radius-lg: 16px;
  --shadow: 0 2px 12px rgba(0,0,0,.08);
  --shadow-md: 0 4px 24px rgba(0,0,0,.12);
  --shadow-lg: 0 8px 40px rgba(0,0,0,.16);
  --transition: .2s ease;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Segoe UI',system-ui,-apple-system,sans-serif;color:var(--gray-900);background:var(--gray-100);line-height:1.6;font-size:16px}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{cursor:pointer;font-family:inherit}
input,select,textarea{font-family:inherit}

/* Container */
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 20px}
.container-fluid{width:100%;padding:0 20px}

/* ===== HEADER ===== */
.site-header{background:#fff;box-shadow:0 2px 8px rgba(0,0,0,.06);position:sticky;top:0;z-index:1000}
.header-inner{display:flex;align-items:center;height:70px;gap:20px}
.site-logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:22px;color:var(--red);flex-shrink:0;white-space:nowrap}
.site-logo img{height:44px;width:auto}
.site-logo span{color:var(--gray-900)}
.main-nav{display:flex;align-items:center;gap:4px;margin-left:auto}
.main-nav a{padding:8px 14px;border-radius:var(--radius-sm);font-size:14px;font-weight:500;color:var(--gray-700);transition:all var(--transition);white-space:nowrap}
.main-nav a:hover,.main-nav a.active{background:var(--gray-100);color:var(--red)}
.header-search{display:flex;align-items:center}
.header-search-btn{background:none;border:none;padding:8px;color:var(--gray-700);font-size:20px;transition:color var(--transition);display:flex;align-items:center}
.header-search-btn:hover{color:var(--red)}
.menu-toggle{display:none;background:none;border:none;padding:8px;flex-direction:column;gap:5px}
.menu-toggle span{display:block;width:24px;height:2px;background:var(--gray-900);transition:all .3s;border-radius:2px}
.menu-toggle.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle.active span:nth-child(2){opacity:0}
.menu-toggle.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Search dropdown */
.search-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:2000;align-items:flex-start;justify-content:center;padding-top:80px}
.search-overlay.open{display:flex}
.search-box-wrap{background:#fff;border-radius:var(--radius-lg);padding:24px;width:100%;max-width:600px;margin:0 20px;box-shadow:var(--shadow-lg)}
.search-input-big{display:flex;gap:12px}
.search-input-big input{flex:1;padding:14px 16px;border:2px solid var(--gray-200);border-radius:var(--radius);font-size:16px;outline:none;transition:border var(--transition)}
.search-input-big input:focus{border-color:var(--red)}
.search-input-big button{padding:14px 24px;background:var(--red);color:#fff;border:none;border-radius:var(--radius);font-size:15px;font-weight:600;transition:background var(--transition)}
.search-input-big button:hover{background:var(--red-dark)}
.search-close{float:right;background:none;border:none;font-size:24px;color:var(--gray-500);margin-bottom:12px}

/* ===== HERO ===== */
.hero{position:relative;min-height:500px;display:flex;align-items:center;overflow:hidden;background:#111}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;background-image:url('/assets/images/hero-default.jpg')}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.5) 0%,rgba(0,0,0,.65) 100%)}
.hero-content{position:relative;z-index:1;color:#fff;text-align:center;width:100%}
.hero-title{font-size:clamp(36px,7vw,72px);font-weight:900;letter-spacing:-1px;text-shadow:0 2px 16px rgba(0,0,0,.4);color:#fff;line-height:1.1}
.hero-title span{color:var(--red)}
.hero-subtitle{font-size:clamp(15px,2vw,18px);margin-top:12px;opacity:.9;text-shadow:0 1px 4px rgba(0,0,0,.4)}
.hero-search{margin-top:32px;background:rgba(255,255,255,.12);backdrop-filter:blur(12px);border-radius:var(--radius-lg);padding:20px;max-width:720px;margin-left:auto;margin-right:auto}
.hero-search-form{display:flex;gap:10px;flex-wrap:wrap}
.hero-search-form input,.hero-search-form select{flex:1;min-width:160px;padding:13px 16px;border:none;border-radius:var(--radius);font-size:15px;outline:none;background:#fff}
.hero-search-form select{cursor:pointer}
.hero-search-form .btn-search{padding:13px 28px;background:var(--red);color:#fff;border:none;border-radius:var(--radius);font-size:15px;font-weight:700;transition:background var(--transition);white-space:nowrap;display:flex;align-items:center;gap:8px}
.hero-search-form .btn-search:hover{background:var(--red-dark)}

/* ===== CATEGORY BAR ===== */
.category-bar{background:#fff;padding:20px 0;box-shadow:0 2px 8px rgba(0,0,0,.04)}
.category-list{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}
.category-list::-webkit-scrollbar{display:none}
.cat-item{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px 16px;border-radius:var(--radius);border:2px solid transparent;cursor:pointer;transition:all var(--transition);min-width:80px;text-decoration:none;color:var(--gray-700);background:var(--gray-100);flex-shrink:0}
.cat-item:hover,.cat-item.active{background:var(--red);color:#fff;border-color:var(--red);transform:translateY(-2px);box-shadow:0 4px 12px rgba(230,57,70,.3)}
.cat-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center}
.cat-icon svg{width:28px;height:28px;stroke:currentColor}
.cat-icon img{width:28px;height:28px;object-fit:contain;filter:invert(0)}
.cat-item:hover .cat-icon img,.cat-item.active .cat-icon img{filter:brightness(0) invert(1)}
.cat-name{font-size:12px;font-weight:600;white-space:nowrap;text-align:center}

/* ===== SECTIONS ===== */
.section{padding:56px 0}
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px;flex-wrap:wrap;gap:12px}
.section-title{font-size:clamp(22px,3vw,28px);font-weight:800;color:var(--gray-900)}
.section-title span{color:var(--red)}
.section-link{font-size:14px;font-weight:600;color:var(--red);display:flex;align-items:center;gap:4px}
.section-link:hover{text-decoration:underline}

/* ===== FESTIVAL CARDS ===== */
.festivals-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}
.festival-card{background:#fff;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);transition:all var(--transition);border:1px solid var(--gray-200)}
.festival-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.card-image{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--gray-200)}
.card-image img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease;loading:lazy}
.festival-card:hover .card-image img{transform:scale(1.05)}
.card-image .no-img{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f5f5f5 0%,#e0e0e0 100%);color:var(--gray-500);font-size:48px}
.card-badges{position:absolute;top:12px;left:12px;display:flex;flex-wrap:wrap;gap:6px}
.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.3px}
.badge-red{background:var(--red);color:#fff}
.badge-green{background:#2d6a4f;color:#fff}
.badge-orange{background:#f77f00;color:#fff}
.badge-gray{background:rgba(0,0,0,.55);color:#fff}
.badge-confirmed{background:#2d6a4f;color:#fff}
.badge-estimated{background:#f77f00;color:#fff}
.card-body{padding:16px}
.card-cats{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}
.card-cat{font-size:11px;font-weight:600;color:var(--red);background:#fff0f0;padding:3px 8px;border-radius:20px}
.card-title{font-size:16px;font-weight:700;color:var(--gray-900);margin-bottom:6px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-location{font-size:13px;color:var(--gray-700);display:flex;align-items:center;gap:4px;margin-bottom:8px}
.card-location svg{width:14px;height:14px;flex-shrink:0}
.card-date{font-size:13px;color:var(--red);font-weight:600;display:flex;align-items:center;gap:4px;margin-bottom:10px}
.card-date svg{width:14px;height:14px;flex-shrink:0}
.card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:10px;border-top:1px solid var(--gray-200)}
.card-rating{display:flex;align-items:center;gap:4px;font-size:13px}
.stars{color:#f4a100;letter-spacing:1px;font-size:14px}
.star.empty{color:var(--gray-300)}
.card-attendees{font-size:12px;color:var(--gray-500);display:flex;align-items:center;gap:3px}

/* Festival detail */
.festival-hero{position:relative;height:400px;overflow:hidden;background:#111}
.festival-hero img{width:100%;height:100%;object-fit:cover;opacity:.7}
.festival-hero-content{position:absolute;bottom:0;left:0;right:0;padding:32px;background:linear-gradient(to top,rgba(0,0,0,.85),transparent);color:#fff}
.festival-hero-title{font-size:clamp(24px,5vw,42px);font-weight:900;line-height:1.1}
.festival-hero-meta{display:flex;flex-wrap:wrap;gap:16px;margin-top:12px;font-size:14px;opacity:.9}
.festival-detail-body{display:grid;grid-template-columns:1fr 340px;gap:32px;align-items:start;padding:40px 0}
.festival-main{}
.festival-sidebar{}
.info-card{background:#fff;border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow);border:1px solid var(--gray-200);margin-bottom:20px}
.info-card h3{font-size:16px;font-weight:700;margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid var(--gray-200);color:var(--gray-900)}
.info-row{display:flex;gap:10px;padding:8px 0;border-bottom:1px solid var(--gray-100);font-size:14px}
.info-row:last-child{border-bottom:none}
.info-label{font-weight:600;color:var(--gray-700);flex-shrink:0;min-width:80px}
.info-value{color:var(--gray-900)}
.festival-content{background:#fff;border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow);border:1px solid var(--gray-200);margin-bottom:24px}
.festival-content h2{font-size:20px;font-weight:700;margin-bottom:16px;color:var(--gray-900)}
.festival-content p{color:var(--gray-700);line-height:1.8;margin-bottom:12px}
.festival-content p:last-child{margin-bottom:0}

/* Gallery */
.gallery-grid{columns:3;gap:12px}
.gallery-grid a{display:block;break-inside:avoid;margin-bottom:12px;border-radius:var(--radius);overflow:hidden;transition:transform var(--transition)}
.gallery-grid a:hover{transform:scale(1.02)}
.gallery-grid img{width:100%;height:auto;object-fit:cover}

/* Editions timeline */
.editions-list{display:flex;flex-direction:column;gap:12px}
.edition-item{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:var(--radius);border:1.5px solid var(--gray-200);background:#fff;transition:border-color var(--transition)}
.edition-item.upcoming{border-color:var(--red);background:#fff8f8}
.edition-year{font-size:16px;font-weight:800;color:var(--gray-900);min-width:48px}
.edition-dates{flex:1;font-size:14px;color:var(--gray-700)}
.edition-status{font-size:11px;font-weight:700;padding:3px 8px;border-radius:20px}

/* Rating */
.rating-widget{display:flex;gap:6px;align-items:center}
.rating-star{font-size:28px;cursor:pointer;color:var(--gray-300);transition:color .15s;line-height:1;user-select:none}
.rating-star:hover,.rating-star.active,.rating-star.hovered{color:#f4a100}

/* Attend button */
.btn-attend{display:flex;align-items:center;gap:8px;padding:13px 20px;border-radius:var(--radius);font-size:15px;font-weight:600;transition:all var(--transition);border:2px solid var(--red);color:var(--red);background:#fff;width:100%;justify-content:center}
.btn-attend:hover,.btn-attend.active{background:var(--red);color:#fff}
.btn-attend svg{width:18px;height:18px}

/* Share */
.share-buttons{display:flex;gap:8px;flex-wrap:wrap}
.share-btn{display:flex;align-items:center;gap:6px;padding:9px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;border:none;cursor:pointer;transition:all var(--transition)}
.share-whatsapp{background:#25D366;color:#fff}
.share-twitter{background:#1da1f2;color:#fff}
.share-copy{background:var(--gray-200);color:var(--gray-900)}
.share-btn:hover{filter:brightness(.9)}

/* Comments */
.comments-list{display:flex;flex-direction:column;gap:16px}
.comment-item{background:var(--gray-100);border-radius:var(--radius);padding:16px}
.comment-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.comment-name{font-weight:700;font-size:14px}
.comment-date{font-size:12px;color:var(--gray-500)}
.comment-text{font-size:14px;color:var(--gray-700);line-height:1.7}
.comment-form input,.comment-form textarea{width:100%;padding:12px 14px;border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);font-size:14px;outline:none;transition:border var(--transition);margin-bottom:12px;resize:vertical}
.comment-form input:focus,.comment-form textarea:focus{border-color:var(--red)}

/* Photo upload */
.photo-upload-zone{border:2px dashed var(--gray-300);border-radius:var(--radius);padding:32px;text-align:center;cursor:pointer;transition:all var(--transition);color:var(--gray-500)}
.photo-upload-zone:hover,.photo-upload-zone.drag{border-color:var(--red);background:#fff8f8;color:var(--red)}
.photo-upload-zone input{display:none}
.photo-upload-zone svg{width:36px;height:36px;margin:0 auto 8px;display:block}
.photo-preview{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.photo-preview-item{width:80px;height:80px;border-radius:var(--radius-sm);overflow:hidden;position:relative}
.photo-preview-item img{width:100%;height:100%;object-fit:cover}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 22px;border-radius:var(--radius);font-size:14px;font-weight:600;transition:all var(--transition);border:2px solid transparent;cursor:pointer;text-decoration:none;white-space:nowrap}
.btn-primary{background:var(--red);color:#fff;border-color:var(--red)}
.btn-primary:hover{background:var(--red-dark);border-color:var(--red-dark)}
.btn-outline{background:transparent;color:var(--red);border-color:var(--red)}
.btn-outline:hover{background:var(--red);color:#fff}
.btn-dark{background:var(--dark);color:#fff;border-color:var(--dark)}
.btn-dark:hover{background:#000;border-color:#000}
.btn-sm{padding:7px 14px;font-size:13px}
.btn-lg{padding:14px 28px;font-size:16px}
.btn-block{width:100%}

/* ===== FILTERS ===== */
.filter-bar{background:#fff;border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow);border:1px solid var(--gray-200);margin-bottom:28px}
.filter-form{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end}
.filter-group{display:flex;flex-direction:column;gap:6px;flex:1;min-width:140px}
.filter-group label{font-size:12px;font-weight:700;color:var(--gray-700);text-transform:uppercase;letter-spacing:.3px}
.filter-group select,.filter-group input{padding:10px 12px;border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);font-size:14px;outline:none;background:#fff;transition:border var(--transition);width:100%}
.filter-group select:focus,.filter-group input:focus{border-color:var(--red)}

/* ===== PAGINATION ===== */
.pagination{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:40px;flex-wrap:wrap}
.page-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-sm);border:1.5px solid var(--gray-200);background:#fff;font-size:14px;font-weight:600;color:var(--gray-700);transition:all var(--transition);text-decoration:none}
.page-btn:hover,.page-btn.active{background:var(--red);color:#fff;border-color:var(--red)}
.page-btn.disabled{opacity:.4;pointer-events:none}
.page-btn-prev,.page-btn-next{width:auto;padding:0 14px;gap:4px}

/* ===== BREADCRUMB ===== */
.breadcrumb{padding:12px 0;font-size:13px}
.breadcrumb ol{display:flex;flex-wrap:wrap;gap:6px;align-items:center;list-style:none}
.breadcrumb li{display:flex;align-items:center;gap:6px;color:var(--gray-500)}
.breadcrumb li::after{content:'›';color:var(--gray-300)}
.breadcrumb li:last-child::after{display:none}
.breadcrumb a{color:var(--gray-700);transition:color var(--transition)}
.breadcrumb a:hover{color:var(--red)}
.breadcrumb li:last-child{color:var(--gray-900);font-weight:600}

/* ===== MAP ===== */
.map-container{height:calc(100vh - 140px);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);position:relative}
.map-filters{position:absolute;top:16px;left:16px;z-index:1000;background:#fff;border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow-lg);min-width:220px}

/* ===== BLOG ===== */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}
.blog-card{background:#fff;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--gray-200);transition:all var(--transition)}
.blog-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.blog-card-img{aspect-ratio:16/9;overflow:hidden;background:var(--gray-200)}
.blog-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.blog-card:hover .blog-card-img img{transform:scale(1.04)}
.blog-card-body{padding:20px}
.blog-cat-tag{font-size:11px;font-weight:700;color:var(--red);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}
.blog-card-title{font-size:17px;font-weight:700;color:var(--gray-900);line-height:1.3;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.blog-card-excerpt{font-size:13px;color:var(--gray-700);line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.blog-card-meta{display:flex;align-items:center;gap:12px;margin-top:14px;font-size:12px;color:var(--gray-500)}

/* ===== NEWSLETTER ===== */
.newsletter-section{background:var(--red);padding:60px 0}
.newsletter-inner{text-align:center;max-width:560px;margin:0 auto}
.newsletter-inner h2{font-size:28px;font-weight:800;color:#fff;margin-bottom:8px}
.newsletter-inner p{color:rgba(255,255,255,.85);margin-bottom:24px;font-size:15px}
.newsletter-form{display:flex;gap:10px;max-width:440px;margin:0 auto}
.newsletter-form input{flex:1;padding:13px 16px;border:none;border-radius:var(--radius);font-size:15px;outline:none}
.newsletter-form button{padding:13px 24px;background:#fff;color:var(--red);border:none;border-radius:var(--radius);font-weight:700;font-size:15px;transition:all var(--transition);white-space:nowrap}
.newsletter-form button:hover{background:var(--red-dark);color:#fff}

/* ===== FOOTER ===== */
.site-footer{background:var(--dark);color:rgba(255,255,255,.8);padding:56px 0 0}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px;margin-bottom:40px}
.footer-about .footer-logo{font-size:22px;font-weight:800;color:#fff;display:flex;align-items:center;gap:8px;margin-bottom:14px}
.footer-about p{font-size:14px;line-height:1.7;color:rgba(255,255,255,.65)}
.footer-social{display:flex;gap:10px;margin-top:16px}
.social-btn{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;transition:background var(--transition);color:#fff;font-size:16px;border:none}
.social-btn:hover{background:var(--red)}
.footer-col h4{font-size:14px;font-weight:700;color:#fff;margin-bottom:16px;text-transform:uppercase;letter-spacing:.5px}
.footer-col ul li{margin-bottom:8px}
.footer-col ul a{font-size:13px;color:rgba(255,255,255,.6);transition:color var(--transition)}
.footer-col ul a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:20px 0;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:13px;color:rgba(255,255,255,.4)}

/* ===== ADS ===== */
.ad-slot{text-align:center;margin:16px auto;max-width:100%;overflow:hidden}

/* ===== FORMS ===== */
.form-group{margin-bottom:18px}
.form-group label{display:block;font-size:13px;font-weight:600;color:var(--gray-700);margin-bottom:6px}
.form-control{width:100%;padding:11px 14px;border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);font-size:14px;outline:none;background:#fff;transition:border var(--transition);color:var(--gray-900)}
.form-control:focus{border-color:var(--red)}
textarea.form-control{resize:vertical;min-height:100px}
.form-error{font-size:12px;color:var(--red);margin-top:4px}
.alert{padding:14px 16px;border-radius:var(--radius-sm);font-size:14px;margin-bottom:16px}
.alert-success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}
.alert-error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}
.alert-info{background:#d1ecf1;color:#0c5460;border:1px solid #bee5eb}
.captcha-box{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.captcha-question{font-size:15px;font-weight:700;background:var(--gray-100);padding:10px 16px;border-radius:var(--radius-sm);color:var(--gray-900);white-space:nowrap}
.captcha-box input{width:80px;text-align:center;font-size:18px;font-weight:700}

/* ===== MISC ===== */
.text-red{color:var(--red)}
.text-muted{color:var(--gray-500)}
.fw-bold{font-weight:700}
.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mb-4{margin-bottom:16px}
.d-flex{display:flex}.align-center{align-items:center}.gap-2{gap:8px}.gap-3{gap:12px}
.loading{text-align:center;padding:48px;color:var(--gray-500)}
.empty-state{text-align:center;padding:64px 24px;color:var(--gray-500)}
.empty-state svg{width:64px;height:64px;margin:0 auto 16px;opacity:.4}
.empty-state h3{font-size:18px;color:var(--gray-700);margin-bottom:8px}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .festival-detail-body{grid-template-columns:1fr}
  .festival-sidebar{order:-1}
  .footer-grid{grid-template-columns:1fr 1fr}
  .gallery-grid{columns:2}
}
@media(max-width:768px){
  .main-nav{display:none;position:absolute;top:70px;left:0;right:0;background:#fff;flex-direction:column;padding:12px;box-shadow:0 8px 24px rgba(0,0,0,.1);align-items:stretch}
  .main-nav.open{display:flex}
  .main-nav a{padding:12px 16px;border-radius:var(--radius-sm);font-size:15px}
  .menu-toggle{display:flex}
  .site-header{position:sticky;top:0}
  .header-inner{position:relative}
  .hero{min-height:380px}
  .hero-search-form{flex-direction:column}
  .hero-search-form input,.hero-search-form select,.hero-search-form .btn-search{width:100%}
  .festival-detail-body{padding:20px 0}
  .newsletter-form{flex-direction:column}
  .footer-grid{grid-template-columns:1fr}
  .festivals-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}
  .filter-form{flex-direction:column}
  .filter-group{min-width:100%}
  .map-container{height:60vh;border-radius:0}
  .map-filters{top:8px;left:8px;min-width:180px;padding:12px}
  .share-buttons{justify-content:center}
  .section{padding:36px 0}
}
@media(max-width:480px){
  .container{padding:0 14px}
  .festivals-grid{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr}
  .gallery-grid{columns:2}
  .hero-title{font-size:30px}
  .category-list{gap:6px}
  .cat-item{min-width:68px;padding:10px 10px}
  .cat-name{font-size:11px}
}
