/* ================================================================
   ToGoBeirut — Stylesheet
   Brand: #FFF42C (yellow) · #000 (black) · #fff (white)
   ================================================================ */

:root {
  --yellow: #FFF42C;
  --black:  #000000;
  --white:  #ffffff;
  --dark1:  #050505;
  --dark2:  #0a0a0a;
  --dark3:  #111111;
  --dark4:  #1a1a1a;
  --border: rgba(255,244,44,0.18);
  --border-strong: rgba(255,244,44,0.4);
  --muted:  rgba(255,255,255,0.55);
  --light-bg: #f8f8f8;
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Poppins',sans-serif;background:var(--dark1);color:var(--white);overflow-x:hidden;}
img{display:block;}
a{text-decoration:none;}

/* ── SHARED ─────────────────────────────────────────────────── */
.inner{max-width:1180px;margin:0 auto;padding:0 6%;}
.tag{display:inline-block;font-size:0.68rem;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;color:var(--yellow);margin-bottom:0.9rem;}
.tag--dark{color:var(--black);}
section{padding:90px 6%;}

.section-header{text-align:center;margin-bottom:56px;}
.section-header h2{font-size:clamp(1.8rem,4vw,3rem);font-weight:900;line-height:1.15;}
.section-header h2 span{color:var(--yellow);}
.section-header--dark h2{color:var(--black);}
.section-header--dark h2 span{color:var(--black);border-bottom:4px solid var(--yellow);}
.title-dark{color:var(--black)!important;}
.sub-dark{color:rgba(0,0,0,0.55);margin-top:0.75rem;font-size:0.95rem;}
.section-sub{color:var(--muted);margin-top:0.75rem;font-size:0.9rem;}
.req{color:var(--yellow);}

.btn-primary{display:inline-block;background:var(--yellow);color:var(--black);padding:0.85rem 2.2rem;font-family:Poppins,sans-serif;font-weight:800;font-size:0.88rem;letter-spacing:0.08em;text-transform:uppercase;border:none;cursor:pointer;transition:all 0.2s;}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(255,244,44,0.35);}
.btn-outline{display:inline-block;background:transparent;color:var(--white);padding:0.85rem 2.2rem;font-family:Poppins,sans-serif;font-weight:700;font-size:0.88rem;letter-spacing:0.08em;text-transform:uppercase;border:1.5px solid rgba(255,255,255,0.45);cursor:pointer;transition:all 0.2s;}
.btn-outline:hover{border-color:var(--yellow);color:var(--yellow);}
.btn-full{width:100%;text-align:center;display:block;}

/* ── NAV ─────────────────────────────────────────────────────── */
#main-nav{
  position:fixed;top:0;left:0;right:0;z-index:500;
  padding:0.8rem 6%;display:flex;align-items:center;gap:2rem;
  background:rgba(0,0,0,0.88);backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);transition:all 0.3s;
}
.nav-brand{display:flex;flex-direction:column;align-items:flex-start;gap:1px;}
.nav-logo{height:40px;object-fit:contain;}
.nav-slogan{font-size:0.6rem;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;color:var(--yellow);opacity:0.85;}
.nav-links{display:flex;gap:2.2rem;list-style:none;align-items:center;flex:1;justify-content:center;}
.nav-links a{color:var(--white);font-size:0.72rem;font-weight:500;letter-spacing:0.13em;text-transform:uppercase;opacity:0.6;transition:opacity 0.2s,color 0.2s;}
.nav-links a:hover{opacity:1;color:var(--yellow);}
.nav-cta{background:var(--yellow);color:var(--black);padding:0.62rem 1.4rem;font-size:0.72rem;font-weight:800;letter-spacing:0.1em;text-transform:uppercase;white-space:nowrap;transition:all 0.2s;}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(255,244,44,0.35);}
.nav-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;margin-left:auto;}
.nav-toggle span{width:22px;height:1.5px;background:var(--white);display:block;transition:all 0.3s;}
.nav-toggle.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px);}
.nav-toggle.open span:nth-child(2){opacity:0;}
.nav-toggle.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px);}

/* ── HERO ─────────────────────────────────────────────────────── */
#hero{
  min-height:100vh;position:relative;
  display:flex;align-items:center;justify-content:center;
  text-align:center;overflow:hidden;padding:120px 2rem 80px;
}
#hero-slides{position:absolute;inset:0;z-index:0;}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 0.8s ease;}
.hero-slide.active{opacity:1;}
.hero-slide-bg{position:absolute;inset:0;background-size:cover;background-position:center;}
.hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(170deg,rgba(0,0,0,0.08) 0%,rgba(0,0,0,0.55) 55%,rgba(0,0,0,0.88) 100%);}
.hero-content{position:relative;z-index:2;max-width:820px;width:100%;display:flex;flex-direction:column;align-items:center;}
.hero-logo{height:min(120px,22vw);width:auto;object-fit:contain;margin-bottom:1.2rem;filter:drop-shadow(0 0 24px rgba(255,244,44,0.2));}
.hero-tagline{font-size:0.72rem;font-weight:800;letter-spacing:0.28em;text-transform:uppercase;color:var(--yellow);margin-bottom:1rem;opacity:0.9;}
.hero-title{font-size:clamp(1.8rem,5.5vw,4rem);font-weight:900;color:var(--white);line-height:1.08;margin-bottom:0.8rem;text-shadow:0 2px 20px rgba(0,0,0,0.5);}
.hero-title.dark-text{color:var(--black);text-shadow:none;}
.hero-sub{font-size:clamp(0.9rem,1.8vw,1.1rem);color:rgba(255,255,255,0.82);margin-bottom:2.4rem;line-height:1.65;max-width:540px;text-shadow:0 1px 10px rgba(0,0,0,0.4);}
.hero-sub.dark-text{color:rgba(0,0,0,0.65);text-shadow:none;}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;}
.slide-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:3;background:rgba(0,0,0,0.45);border:1.5px solid var(--yellow);color:var(--yellow);width:44px;height:44px;border-radius:50%;font-size:1.4rem;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;transition:all 0.2s;}
.slide-arrow:hover{background:var(--yellow);color:var(--black);}
.slide-prev{left:3%;}
.slide-next{right:3%;}
.slide-dots{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;gap:7px;z-index:3;}
.slide-dot{width:8px;height:8px;border-radius:4px;background:rgba(255,255,255,0.35);border:none;cursor:pointer;padding:0;transition:all 0.3s;}
.slide-dot.active{width:28px;background:var(--yellow);}

/* ── STORY ───────────────────────────────────────────────────── */
#story{background:var(--black);padding:90px 6%;}
.story-text{max-width:820px;margin:0 auto;}
.story-text h2{font-size:clamp(1.8rem,4vw,3rem);font-weight:900;line-height:1.15;margin-bottom:1.6rem;}
.story-text h2 span{color:var(--yellow);}
.story-text p{color:var(--muted);line-height:1.9;font-size:0.95rem;margin-bottom:1.1rem;}
.mv-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.2rem;margin-top:2.4rem;}
.mv-card{background:var(--yellow);padding:2rem 2.2rem;border-radius:2px;}
.mv-card h4{font-size:1.1rem;font-weight:800;color:var(--black);margin-bottom:0.75rem;}
.mv-card p{font-size:0.9rem;color:#222;line-height:1.75;font-weight:500;}
.mv-card--outline{background:transparent;border:2px solid var(--border-strong);}
.mv-card--outline h4{color:var(--yellow);}
.mv-card--outline p{color:var(--muted);}

/* ── STATS STRIP ─────────────────────────────────────────────── */
.stats-strip{background:var(--yellow);padding:2.4rem 6%;}
.stats-inner{max-width:900px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;text-align:center;}
.stat h3{font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:900;color:var(--black);}
.stat p{font-size:0.78rem;font-weight:600;color:rgba(0,0,0,0.6);letter-spacing:0.1em;text-transform:uppercase;margin-top:0.25rem;}

/* ── SERVICES ────────────────────────────────────────────────── */
#services{background:var(--dark2);padding:90px 6%;}
#services .section-header h2{color:var(--white);}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.2rem;max-width:900px;margin:0 auto;}
.svc-card{padding:3rem 2.4rem;position:relative;overflow:hidden;}
.svc-express{background:var(--yellow);}
.svc-standard{background:var(--dark4);border:1.5px solid var(--border);}
.svc-pop{position:absolute;top:0;right:0;background:var(--black);color:var(--yellow);font-size:0.6rem;font-weight:800;letter-spacing:0.15em;padding:0.5rem 1rem;}
.svc-icon{font-size:2.8rem;margin-bottom:1rem;}
.svc-badge{display:inline-block;background:var(--black);color:var(--yellow);font-size:0.6rem;font-weight:800;letter-spacing:0.18em;padding:0.28rem 0.8rem;margin-bottom:1rem;}
.svc-badge--std{background:rgba(255,244,44,0.12);color:var(--yellow);}
.svc-express h3{color:var(--black);font-size:1.4rem;font-weight:900;margin-bottom:0.8rem;}
.svc-standard h3{color:var(--white);font-size:1.4rem;font-weight:900;margin-bottom:0.8rem;}
.svc-express p{color:#333;font-size:0.88rem;line-height:1.7;margin-bottom:1.2rem;}
.svc-standard p{color:var(--muted);font-size:0.88rem;line-height:1.7;margin-bottom:1.2rem;}
.svc-express ul,.svc-standard ul{list-style:none;display:flex;flex-direction:column;gap:0.6rem;}
.svc-express ul li{font-size:0.85rem;color:#222;display:flex;align-items:center;gap:0.5rem;}
.svc-express ul li span:first-child{font-weight:800;color:var(--black);}
.svc-standard ul li{font-size:0.85rem;color:rgba(255,255,255,0.75);display:flex;align-items:center;gap:0.5rem;}
.svc-standard ul li span:first-child{font-weight:800;color:var(--yellow);}

/* ── COVERAGE MAP ────────────────────────────────────────────── */
#coverage{background:var(--light-bg);padding:90px 6%;}
.map-legend{display:flex;gap:1.8rem;margin-bottom:1.4rem;flex-wrap:wrap;justify-content:center;}
.legend-item{display:flex;align-items:center;gap:0.5rem;font-size:0.8rem;font-weight:600;color:#333;}
.legend-dot{width:13px;height:13px;border-radius:50%;flex-shrink:0;}
.legend-dot--fast{background:var(--yellow);border:2px solid var(--black);}
.legend-dot--std{background:#222;border:1.5px solid var(--yellow);}

/* Centered map */
.map-centered-wrap{max-width:720px;margin:0 auto 2rem;position:relative;border-radius:4px;overflow:hidden;box-shadow:0 4px 24px rgba(0,0,0,0.15);}
#tgb-map{height:500px;width:100%;}
.map-info{position:absolute;top:12px;left:12px;z-index:1000;background:var(--black);color:var(--white);border:2px solid var(--yellow);border-radius:4px;padding:1rem 1.2rem;min-width:190px;box-shadow:0 4px 20px rgba(0,0,0,0.4);}
.map-info-close{position:absolute;top:6px;right:10px;background:none;border:none;color:#888;font-size:1rem;cursor:pointer;}
.map-info-name{font-weight:800;font-size:1rem;margin-bottom:2px;}
.map-info-region{font-size:0.72rem;color:#888;margin-bottom:0.7rem;}
.map-info-type{font-size:0.82rem;font-weight:700;color:var(--yellow);margin-bottom:3px;}
.map-info-date{font-size:0.82rem;color:rgba(255,255,255,0.88);}

/* Desktop table */
.city-table{width:100%;border-collapse:collapse;display:table;}
.city-table thead tr{background:var(--black);}
.city-table thead th{color:var(--yellow);font-size:0.68rem;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;padding:0.9rem 1.1rem;text-align:left;white-space:nowrap;}
.city-table tbody tr{border-bottom:1px solid #eee;cursor:pointer;transition:background 0.15s;}
.city-table tbody tr:last-child{border-bottom:none;}
.city-table tbody tr:hover{background:#f0f0f0;}
.city-table tbody tr.active{background:var(--black);}
.city-table tbody td{padding:0.82rem 1.1rem;font-size:0.88rem;color:#222;}
.city-table tbody tr.active td{color:var(--white);}
.ct-name{font-weight:700;}
.ct-region{color:#888;font-size:0.8rem;}
.city-table tbody tr.active .ct-region{color:rgba(255,255,255,0.45);}
.ct-fast{color:#cc9900;font-weight:700;font-size:0.82rem;}
.city-table tbody tr.active .ct-fast{color:var(--yellow);}
.ct-std{color:#999;font-size:0.82rem;}
.ct-date{color:#666;font-size:0.82rem;}
.city-table tbody tr.active .ct-date{color:rgba(255,255,255,0.55);}

/* Mobile cards — hidden on desktop */
.city-cards{display:none;}
.city-btn{background:var(--white);border:2px solid transparent;padding:0.85rem 1rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-family:Poppins,sans-serif;text-align:left;transition:all 0.15s;border-radius:2px;width:100%;}
.city-btn:hover,.city-btn.active{border-color:var(--yellow);}
.city-btn.active{background:var(--black);}
.city-btn-left .city-name{font-weight:700;font-size:0.88rem;color:#111;}
.city-btn.active .city-name{color:var(--white);}
.city-btn-left .city-region{font-size:0.72rem;color:#888;margin-top:2px;}
.city-btn-right{text-align:right;}
.city-type{font-size:0.7rem;font-weight:700;}
.city-type--fast{color:var(--yellow);}
.city-type--std{color:#999;}
.city-date{font-size:0.68rem;color:#bbb;margin-top:2px;}
.city-btn.active .city-date{color:rgba(255,255,255,0.55);}

/* Leaflet popup */
.leaflet-popup-content-wrapper{background:var(--black);border:1.5px solid var(--yellow);border-radius:4px;color:var(--white);font-family:Poppins,sans-serif;box-shadow:0 4px 16px rgba(0,0,0,0.5);}
.leaflet-popup-tip{background:var(--yellow);}
.leaflet-popup-content{margin:12px 16px;font-size:0.82rem;}
.lp-name{font-weight:800;font-size:0.95rem;margin-bottom:4px;}
.lp-region{font-size:0.7rem;color:#888;margin-bottom:8px;}
.lp-type{color:var(--yellow);font-weight:700;margin-bottom:3px;}
.lp-date{color:rgba(255,255,255,0.85);}

/* ── REQUEST FORM ─────────────────────────────────────────────── */
#request{background:var(--black);padding:90px 6%;}
#request .section-header h2{color:var(--white);}
.form-card{background:rgba(255,255,255,0.04);border:1px solid var(--border);padding:2.4rem;max-width:680px;margin:0 auto;display:flex;flex-direction:column;gap:1rem;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.form-field label{display:block;font-size:0.68rem;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--yellow);margin-bottom:0.4rem;}
.form-field input,.form-field select,.form-field textarea{
  width:100%;background:#111;border:1px solid rgba(255,244,44,0.22);
  color:var(--white);padding:0.78rem 1rem;font-family:Poppins,sans-serif;
  font-size:0.88rem;outline:none;transition:border-color 0.2s;
}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--yellow);}
.form-field textarea{resize:vertical;}
.form-field select option{background:#111;color:var(--white);}
.form-hint{text-align:center;font-size:0.72rem;color:rgba(255,255,255,0.3);margin-top:0.4rem;}
.form-success{text-align:center;padding:3.5rem 1rem;max-width:480px;margin:0 auto;}
.success-icon{font-size:4rem;margin-bottom:1rem;}
.form-success h3{font-size:1.6rem;font-weight:800;color:var(--yellow);margin-bottom:0.75rem;}
.form-success p{color:var(--muted);margin-bottom:2rem;line-height:1.7;}

/* ── REVIEWS ─────────────────────────────────────────────────── */
#reviews{background:var(--light-bg);padding:90px 6%;}
.avg-bar{display:flex;align-items:center;justify-content:center;gap:0.9rem;margin-bottom:2.6rem;flex-wrap:wrap;}
.avg-stars{color:var(--yellow);font-size:1.6rem;letter-spacing:0.05em;}
.avg-score{font-size:1.8rem;font-weight:900;color:var(--black);}
.avg-score span{font-size:1rem;font-weight:500;color:#aaa;}
.avg-count{font-size:0.85rem;color:#999;}
.reviews-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.2rem;margin-bottom:3rem;}
.rv-card{background:var(--white);padding:1.6rem;border-radius:2px;box-shadow:0 2px 14px rgba(0,0,0,0.07);transition:transform 0.2s;}
.rv-card:hover{transform:translateY(-3px);}
.rv-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:0.9rem;}
.rv-author{font-weight:700;font-size:0.92rem;color:var(--black);}
.rv-date{font-size:0.72rem;color:#aaa;margin-top:2px;}
.rv-stars{color:var(--yellow);font-size:0.88rem;}
.rv-title{font-weight:700;font-size:0.92rem;color:var(--black);margin-bottom:0.5rem;}
.rv-body{font-size:0.85rem;color:#666;line-height:1.7;}
.review-form-wrap{background:var(--white);border-radius:2px;max-width:560px;margin:0 auto;box-shadow:0 2px 14px rgba(0,0,0,0.07);}
.review-form-inner{padding:2.4rem;}
.review-form-inner h3{font-size:1.3rem;font-weight:800;color:var(--black);margin-bottom:0.35rem;}
.review-form-inner h3 span{color:var(--yellow);}
.review-form-sub{font-size:0.8rem;color:#aaa;margin-bottom:1.4rem;}
.star-picker{margin-bottom:1.2rem;}
.sp-label{font-size:0.7rem;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;color:#555;display:block;margin-bottom:0.5rem;}
.sp-stars{display:flex;gap:0.2rem;}
.sp-star{font-size:1.9rem;cursor:pointer;color:#ddd;transition:color 0.1s,transform 0.1s;line-height:1;}
.sp-star.active,.sp-star.hover{color:var(--yellow);}
.rf-input{width:100%;padding:0.78rem 1rem;border:1px solid #e0e0e0;background:var(--white);color:var(--black);font-family:Poppins,sans-serif;font-size:0.88rem;outline:none;margin-bottom:0.8rem;transition:border-color 0.2s;display:block;resize:vertical;}
.rf-input:focus{border-color:var(--yellow);}

/* ── FOOTER ──────────────────────────────────────────────────── */
footer{background:var(--dark1);padding:4rem 6% 2.2rem;border-top:1px solid var(--border);}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:2.8rem;margin-bottom:2.8rem;}
.footer-brand .footer-logo{height:52px;object-fit:contain;margin-bottom:1rem;}
.footer-brand p{font-size:0.82rem;color:var(--muted);line-height:1.75;}
.footer-phone{font-size:0.82rem;color:var(--yellow);font-weight:700;margin-top:0.9rem;}
.footer-heading{font-size:0.72rem;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--white);margin-bottom:1.1rem;}
.footer-links{display:flex;flex-direction:column;gap:0.6rem;}
.footer-links a{font-size:0.82rem;color:var(--muted);transition:color 0.2s;}
.footer-links a:hover{color:var(--yellow);}
.social-buttons{display:flex;flex-direction:column;gap:0.55rem;}
.social-btn{display:flex;align-items:center;gap:0.65rem;background:rgba(255,255,255,0.04);border:1px solid var(--border);padding:0.65rem 0.9rem;font-family:Poppins,sans-serif;font-size:0.8rem;font-weight:600;color:var(--white);cursor:pointer;transition:all 0.2s;}
.social-btn:hover{background:rgba(255,244,44,0.1);border-color:var(--border-strong);}
.social-btn svg{width:16px;height:16px;fill:currentColor;flex-shrink:0;}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.08);padding-top:1.4rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:0.75rem;}
.footer-bottom p{font-size:0.75rem;color:rgba(255,255,255,0.28);}
.footer-admin-link{font-size:0.68rem;color:rgba(255,255,255,0.12);transition:color 0.2s;}
.footer-admin-link:hover{color:rgba(255,255,255,0.35);}

/* ── ADMIN LOGIN ─────────────────────────────────────────────── */
#admin-login-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.94);z-index:9000;align-items:center;justify-content:center;}
.admin-login-box{background:#111;border:2px solid var(--yellow);padding:2.6rem 2.2rem;width:100%;max-width:400px;}
.al-input{width:100%;background:#0a0a0a;border:1px solid rgba(255,244,44,0.25);color:var(--white);padding:0.78rem 1rem;font-family:Poppins,sans-serif;font-size:0.88rem;outline:none;display:block;margin-bottom:0.75rem;transition:border-color 0.2s;}
.al-input:focus{border-color:var(--yellow);}

/* ── ADMIN PANEL ─────────────────────────────────────────────── */
#admin-panel{display:none;position:fixed;inset:0;z-index:8000;background:var(--dark2);overflow-y:auto;}
.admin-bar{position:sticky;top:0;z-index:10;background:var(--black);padding:0 5%;height:60px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);}
.a-logout{background:rgba(255,100,100,0.12);border:1px solid rgba(255,100,100,0.3);color:#ff6b6b;padding:0.5rem 1rem;font-family:Poppins,sans-serif;font-size:0.75rem;font-weight:700;cursor:pointer;letter-spacing:0.08em;}
.admin-body{padding:2rem 5%;max-width:1000px;margin:0 auto;}
.asec{background:var(--dark4);border:1px solid rgba(255,244,44,0.1);padding:1.8rem;margin-bottom:1.4rem;}
.asec h2{font-size:1.05rem;font-weight:800;color:var(--white);margin-bottom:0.5rem;}
.asec-sub{font-size:0.78rem;color:var(--muted);margin-bottom:1.4rem;}
.asave{background:var(--yellow);color:var(--black);border:none;padding:0.62rem 1.2rem;font-family:Poppins,sans-serif;font-weight:800;font-size:0.75rem;letter-spacing:0.1em;text-transform:uppercase;cursor:pointer;transition:all 0.2s;}
.asave:hover{transform:translateY(-1px);}
.abadge{background:rgba(255,100,100,0.2);color:#ff8888;border-radius:10px;padding:1px 7px;font-size:0.7rem;margin-left:5px;}
.review-tab{transition:all 0.2s;}
.review-tab.active{background:var(--yellow);color:var(--black);}
.review-tab:not(.active){background:var(--dark3);border:1px solid var(--border);color:var(--white);}

/* Slideshow admin grid */
.slideshow-admin-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0.75rem;}
.slide-admin-slot{position:relative;cursor:pointer;aspect-ratio:2.4;overflow:hidden;border:2px solid var(--border);transition:border-color 0.2s;}
.slide-admin-slot:hover{border-color:var(--yellow);}
.slide-admin-slot-bg{position:absolute;inset:0;background-size:cover;background-position:center;}
.slide-admin-slot-label{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,0.75);color:var(--yellow);text-align:center;padding:0.4rem;font-size:0.68rem;letter-spacing:0.12em;text-transform:uppercase;font-weight:700;}

/* Admin review cards */
.arv-card{background:var(--dark3);border:1px solid rgba(255,255,255,0.07);padding:1.1rem 1.2rem;margin-bottom:0.6rem;display:flex;gap:1rem;align-items:flex-start;flex-wrap:wrap;}
.arv-info{flex:1;min-width:200px;}
.arv-meta{display:flex;align-items:center;gap:0.6rem;margin-bottom:0.4rem;flex-wrap:wrap;}
.arv-author{color:var(--white);font-weight:700;font-size:0.88rem;}
.arv-stars{color:var(--yellow);font-size:0.82rem;}
.arv-live{background:rgba(76,175,80,0.15);color:#4caf50;font-size:0.62rem;font-weight:800;padding:1px 7px;letter-spacing:0.1em;}
.arv-title{color:rgba(255,255,255,0.8);font-size:0.85rem;font-weight:600;margin-bottom:3px;}
.arv-desc{color:#888;font-size:0.8rem;line-height:1.55;}
.arv-date{color:#555;font-size:0.72rem;margin-top:5px;}
.arv-actions{display:flex;gap:0.5rem;flex-shrink:0;align-items:flex-start;}
.a-approve{background:rgba(76,175,80,0.15);border:1px solid #4caf50;color:#4caf50;padding:0.48rem 0.9rem;font-family:Poppins,sans-serif;font-weight:700;font-size:0.72rem;cursor:pointer;}
.a-reject{background:rgba(255,100,100,0.12);border:1px solid rgba(255,100,100,0.4);color:#ff6b6b;padding:0.48rem 0.9rem;font-family:Poppins,sans-serif;font-weight:700;font-size:0.72rem;cursor:pointer;}

/* Admin requests */
.areq-card{background:var(--dark3);border:1px solid rgba(255,255,255,0.07);padding:1.1rem 1.2rem;margin-bottom:0.6rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:0.75rem;}
.areq-f label{font-size:0.6rem;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;color:var(--yellow);display:block;margin-bottom:3px;}
.areq-f span{font-size:0.85rem;color:var(--white);}
.areq-f a{color:var(--yellow);font-size:0.85rem;font-weight:600;}
.admin-empty{color:#555;font-size:0.88rem;padding:2rem 0;text-align:center;}

/* Toast */
/* ── GALLERY SLIDESHOW ───────────────────────────────────────── */
#gallery{background:var(--dark2);padding:90px 6%;}
#gallery .section-header h2{color:var(--white);}
.gallery-slideshow{position:relative;width:100%;max-width:960px;margin:0 auto;border-radius:2px;overflow:hidden;background:#111;}
.gallery-slides-wrap{position:relative;width:100%;height:500px;}
.gallery-slide{position:absolute;inset:0;opacity:0;transition:opacity 0.7s ease;}
.gallery-slide.active{opacity:1;}
.gallery-slide img{width:100%;height:100%;object-fit:cover;display:block;}
.gallery-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:3;background:rgba(0,0,0,0.55);border:1.5px solid var(--yellow);color:var(--yellow);width:44px;height:44px;border-radius:50%;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;transition:all 0.2s;}
.gallery-arrow:hover{background:var(--yellow);color:var(--black);}
.gallery-prev{left:14px;}
.gallery-next{right:14px;}
.gallery-dots{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);display:flex;gap:6px;z-index:3;}
.gallery-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,0.35);border:none;cursor:pointer;padding:0;transition:all 0.25s;}
.gallery-dot.active{background:var(--yellow);width:22px;border-radius:4px;}
.gallery-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:260px;color:rgba(255,255,255,0.35);font-size:0.9rem;}
.gallery-upload-btn{display:inline-block;background:var(--yellow);color:var(--black);padding:0.62rem 1.4rem;font-family:Poppins,sans-serif;font-weight:800;font-size:0.75rem;letter-spacing:0.12em;text-transform:uppercase;cursor:pointer;margin-bottom:1.2rem;transition:all 0.2s;}
.gallery-upload-btn:hover{transform:translateY(-1px);}
.gallery-admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:0.6rem;}
.gal-admin-item{position:relative;aspect-ratio:1.6;overflow:hidden;border:1.5px solid rgba(255,255,255,0.08);}
.gal-admin-item img{width:100%;height:100%;object-fit:cover;display:block;}
.gal-admin-del{position:absolute;top:5px;right:5px;background:rgba(0,0,0,0.75);border:1px solid rgba(255,100,100,0.5);color:#ff8888;width:26px;height:26px;border-radius:50%;font-size:0.7rem;cursor:pointer;display:flex;align-items:center;justify-content:center;font-weight:700;}
.gal-admin-del:hover{background:rgba(255,100,100,0.3);}
@media(max-width:768px){.gallery-slides-wrap{height:220px;}.gallery-arrow{display:none;}}

.save-toast{position:fixed;bottom:2rem;left:50%;transform:translateX(-50%) translateY(80px);background:var(--yellow);color:var(--black);padding:0.75rem 1.6rem;font-family:Poppins,sans-serif;font-weight:700;font-size:0.82rem;z-index:99000;transition:transform 0.3s ease;border-radius:2px;pointer-events:none;}
.save-toast.show{transform:translateX(-50%) translateY(0);}

/* ── RESPONSIVE ──────────────────────────────────────────────── */
@media(max-width:768px){
  section{padding:64px 5%;}
  .nav-links{display:none;position:fixed;top:68px;left:0;right:0;background:rgba(0,0,0,0.97);flex-direction:column;gap:0;padding:1rem 0;border-bottom:1px solid var(--border);z-index:499;}
  .nav-links.open{display:flex;}
  .nav-links li a{padding:0.9rem 6%;display:block;}
  .nav-cta{display:none;}
  .nav-toggle{display:flex;}
  .hero-logo{height:80px;}
  .form-row{grid-template-columns:1fr;}
  .stats-inner{grid-template-columns:repeat(2,1fr);}
  .map-centered-wrap{width:100%;max-width:100%;}
  #tgb-map{height:340px;}
  .city-table{display:none;}
  .city-cards{display:flex;flex-direction:column;gap:6px;}
  .city-list{flex:none;width:100%;}
  .slideshow-admin-grid{grid-template-columns:1fr;}
  .slide-arrow{display:none;}
}
