:root{
  --brand:#2f3542; --text:#0f1221; --muted:#6b7280; --bg:#f7f8fb; --card:#ffffff; --border:#e7e9ef;
  --radius:16px; --ring:rgba(47,53,66,.18);
}

*{box-sizing:border-box}
body{
  margin:0;font-family:Roboto,system-ui,-apple-system,Segoe UI,Arial,sans-serif;
  background:var(--bg);color:var(--text);line-height:1.6;
}
.wrap{max-width:1120px;margin:0 auto;padding:16px}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}

header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 0}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:38px;width:auto}
.nav a{color:var(--muted);margin-left:14px;font-weight:600}
.nav a:hover{color:var(--brand)}

.hero{margin:12px 0 20px;background:#fff;border:1px solid var(--border);border-radius:20px;padding:24px}
.hero h1{margin:0 0 10px;font-weight:800;color:var(--brand);font-size:clamp(22px,4.5vw,36px)}
.hero p{margin:0 0 14px;color:var(--muted)}

.search{position:relative}
.search input{
  width:100%;padding:14px 16px 14px 48px;border-radius:14px;border:1px solid var(--border);background:#fff;
  outline:none;font-size:16px;box-shadow:0 2px 10px rgba(0,0,0,.03);
}
.search input:focus{border-color:var(--brand);box-shadow:0 0 0 6px var(--ring)}
.search .icon{position:absolute;left:14px;top:12px;width:22px;height:22px;opacity:.6;color:var(--brand)}
.suggest{margin-top:10px;background:#fff;border:1px solid var(--border);border-radius:14px;overflow:hidden;display:none;box-shadow:0 16px 30px rgba(0,0,0,.08)}
.s-row{display:flex;justify-content:space-between;gap:8px;padding:12px 14px;border-top:1px solid #f0f2f6}
.s-row:first-child{border-top:0}
.s-row a{color:var(--text);font-weight:700}

.cta-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 14px;border-radius:12px;border:2px solid var(--brand);font-weight:800}
.btn.primary{background:var(--brand);color:#fff}
.btn.ghost{background:#fff;color:var(--brand)}

.grid{display:grid;gap:12px;margin-top:18px}
@media(min-width:720px){.grid.three{grid-template-columns:repeat(3,1fr)}}

.card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:16px;box-shadow:0 8px 18px rgba(0,0,0,.05)}
.card h3{margin:0 0 6px;font-size:18px}
.muted{color:var(--muted);font-size:14px}

.facts{display:grid;gap:12px}
@media(min-width:720px){.facts{grid-template-columns:repeat(2,1fr)}}
.fact{padding:12px;border:1px solid var(--border);border-radius:12px;background:#fff}
.fact b{display:block;margin-bottom:4px}

details{border:1px solid var(--border);border-radius:12px;background:#fff;padding:12px}
details+details{margin-top:10px}

footer{margin:26px 0;color:var(--muted);font-size:13px;text-align:center}
.badge{display:inline-block;padding:6px 10px;border-radius:999px;background:#f1f2f6;border:1px solid #e6e8ee;color:#444;font-size:12px}



/* 2-col layout (8/4). Stacks on mobile */
.layout { display: grid; gap: 16px; margin-top: 16px; }
@media (min-width: 900px) {
  .layout { grid-template-columns: 2fr 1fr; } /* 8/4 */
}
.main { min-width: 0; } /* prevent overflow */
.sidebar { min-width: 0; }
@media (min-width: 900px) {
  .sidebar { position: sticky; top: 16px; }
}
.emirate-layout{display:flex;gap:24px;align-items:flex-start}
.emirate-layout .content{flex:1 1 auto;min-width:0}
.emirate-layout .sidebar{flex:0 0 320px;position:sticky;top:16px;align-self:flex-start}
@media(max-width:900px){.emirate-layout{display:block}.emirate-layout .sidebar{position:static;margin-top:16px}}
/* FORCE two-column on emirate pages */
.container.emirate-layout{
  display:flex !important;
  flex-wrap:nowrap !important;
  gap:24px !important;
  align-items:flex-start !important;
}
.container.emirate-layout > .content{
  flex:1 1 auto !important;
  min-width:0 !important;
  width:auto !important;
  float:none !important;
  clear:none !important;
}
.container.emirate-layout > .sidebar{
  flex:0 0 320px !important;
  width:320px !important;
  float:none !important;
  clear:none !important;
  position:sticky !important;
  top:16px !important;
  align-self:flex-start !important;
}
@media (max-width:900px){
  .container.emirate-layout{display:block !important;}
  .container.emirate-layout > .sidebar{
    position:static !important;
    width:auto !important;
    margin-top:16px !important;
  }
}
/* Banner should never overflow */
.page-banner { margin: 0 0 16px; }
.page-banner img {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
  border-radius: 16px;
}

/* Optional: cap banner height on desktop */
@media (min-width: 900px) {
  .page-banner img { max-height: 320px; object-fit: cover; }
}


/* --- Mobile overflow fixes --- */
html, body { max-width: 100%; overflow-x: hidden; }

/* Containers get side padding on phones */
.container { width:100%; max-width:1200px; margin-inline:auto; padding-inline:16px; }
@media (min-width:900px){ .container { padding-inline:24px; } }

/* Images & media never exceed container */
img, video, svg { max-width:100%; height:auto; display:block; }

/* Banner stays inside container and clips safely */
.page-banner { margin:0 0 16px; overflow:hidden; }
.page-banner img { width:100%; max-width:100%; height:auto; border-radius:16px; }

/* Two-column emirate layout (sidebar on right) */
.container.emirate-layout { display:flex !important; gap:24px !important; align-items:flex-start !important; flex-wrap:nowrap !important; }
.container.emirate-layout > .content { flex:1 1 auto !important; min-width:0 !important; width:auto !important; float:none !important; clear:none !important; }
.container.emirate-layout > .sidebar { flex:0 0 320px !important; width:320px !important; float:none !important; clear:none !important; position:sticky !important; top:16px !important; align-self:flex-start !important; }
@media (max-width:900px){
  .container.emirate-layout { display:block !important; }
  .container.emirate-layout > .sidebar { position:static !important; width:auto !important; margin-top:16px !important; }
}

/* Cards/grids collapse on small screens */
.grid.three { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:16px; }
@media (max-width:1024px){ .grid.three { grid-template-columns:repeat(2,minmax(0,1fr)); } }
@media (max-width:600px){ .grid.three { grid-template-columns:1fr; } }

/* Tables & code won’t force sideways scroll */
table { width:100%; max-width:100%; border-collapse:collapse; }
pre, code { white-space:pre-wrap; word-wrap:break-word; }

/* Long words/URLs wrap instead of pushing width */
.content, .card, p, h1, h2, h3, h4 { overflow-wrap:anywhere; word-break:break-word; }
/* ===== Homepage hero (using existing .hero) ===== */
.hero{
  color:#fff;
  background: linear-gradient(120deg,#6a00ff,#0f78ff,#00d4ff,#6a00ff);
  background-size:300% 300%;
  animation: heroGradient 12s ease infinite;
  padding:32px 24px;
  border-radius:20px;
  position:relative;
  overflow:hidden;
  box-shadow:0 20px 50px rgba(15,120,255,.25);
}
.hero h1, .hero p, .hero label{ color:#fff; }

/* soft glow that follows cursor */
.hero::before{
  content:"";
  position:absolute; inset:-2px; pointer-events:none;
  background: radial-gradient(600px circle at var(--x,50%) var(--y,50%), rgba(255,255,255,.18), transparent 40%);
  opacity:.6; transition:opacity .2s ease;
}
.hero:hover::before{ opacity:1; }

/* search box inside hero */
.hero .search{ position:relative; margin-top:16px; }
.hero .search .icon{
  position:absolute; left:14px; top:50%; transform:translateY(-50%);
  color:rgba(255,255,255,.85);
}
.hero .search input[type="search"]{
  width:100%;
  padding:14px 16px 14px 44px;
  background:rgba(255,255,255,.10);
  border:2px solid rgba(255,255,255,.35);
  color:#fff; border-radius:18px; outline:0;
  box-shadow:0 2px 0 rgba(0,0,0,.25) inset, 0 8px 24px rgba(0,0,0,.25);
  backdrop-filter: blur(6px);
}
.hero .search input::placeholder{ color:rgba(255,255,255,.85); }
.hero .search input:focus{
  border-color:#fff;
  box-shadow:0 0 0 3px rgba(255,255,255,.25), 0 12px 28px rgba(0,0,0,.32);
}

/* suggestions panel */
.hero #suggest{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.25);
  border-radius:14px;
  margin-top:10px;
  backdrop-filter: blur(6px);
}
.hero #suggest a{ color:#fff; display:block; padding:10px 14px; }
.hero #suggest a:hover{ background:rgba(255,255,255,.12); }

/* gradient animation */
@keyframes heroGradient{
  0%{background-position:0% 50%}
  50%{background-position:100% 50%}
  100%{background-position:0% 50%}
}

/* mobile spacing */
@media (max-width:600px){
  .hero{ padding:24px 16px; border-radius:16px; }
}
