: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; }
}
/* SIDEBAR HOTFIX (global) */
.container.page-layout{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) 320px !important;
  gap:24px !important;
  align-items:start !important;
}
.container.page-layout .content,
.container.page-layout .sidebar{
  float:none !important;
  width:auto !important;
  clear:none !important;
  min-width:0 !important;
}
@media (max-width:900px){
  .container.page-layout{ grid-template-columns:1fr !important; }
}
/* === Emirate page: two-column with sticky sidebar === */
.container.emirate-layout{
  display:flex;
  gap:24px;
  align-items:flex-start;
  flex-wrap:nowrap;
}
.container.emirate-layout > .content{
  flex:1 1 auto;
  min-width:0;        /* prevent flex overflow */
}
.container.emirate-layout > .sidebar{
  flex:0 0 320px;
  width:320px;
  align-self:flex-start;
  position:sticky;
  top:var(--sticky-top,16px); /* tweak if header becomes fixed */
  max-height:calc(100vh - var(--sticky-top,16px));
  overflow:auto;      /* inner scroll if tall */
  z-index:2;
}

/* Mobile: stack; no sticky */
@media (max-width:900px){
  .container.emirate-layout{ display:block; }
  .container.emirate-layout > .sidebar{
    position:static;
    width:auto;
    max-height:none;
    margin-top:16px;
    overflow:visible;
  }
}

/* Utility: full-width buttons in cards */
.w-100{ display:inline-flex; width:100%; justify-content:center; text-align:center; }

/* Optional: clean list styling in sidebar cards */
.sidebar ul.clean{ list-style:none; padding:0; margin:0; }
.sidebar ul.clean li{ padding:6px 0; }
/* === Pricing components (add to end of your style.css) === */
.price-box, .pricing-breakdown, .pricing-scenarios, .pricing-renewal, .pricing-addons { margin: 24px 0; }
.h-like { font-size: 1.25rem; margin: 0 0 10px; }
.lead { font-size: 1.05rem; }
.tick-list { list-style: none; padding: 0; }
.tick-list li { padding-left: 1.2em; position: relative; margin: 6px 0; }
.tick-list li::before { content: '✓'; position: absolute; left: 0; top: 0; }
.cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 12px; }
.card { border: 1px solid #eee; border-radius: 12px; padding: 14px; }
.card .total { font-weight: 700; margin: 6px 0; }
.card .unit { font-weight: 400; font-size: .9em; color: #666; }
.two-col { columns: 2; column-gap: 20px; }
.two-col li { break-inside: avoid; margin: 4px 0; }
.tiny.muted { color: #777; font-size: .9em; }
.service-fee { background: #fafafa; border: 1px dashed #ddd; border-radius: 10px; padding: 12px; margin: 20px 0; }


/* FAQ accordion icons (site-wide) */
.faqs summary { cursor: pointer; list-style: none; font-weight: 600; position: relative; padding-right: 28px; }
.faqs summary::-webkit-details-marker { display: none; }
.faqs summary::after { content: "+"; position: absolute; right: 8px; top: 50%; transform: translateY(-50%); font-weight: 700; }
.faqs details[open] summary::after { content: "\2212"; }



/* Stack image → title → description */
.page-header--stack {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 24px;
}

/* Hero image */
.page-header--stack .page-hero img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
  border-radius: 16px;
}

/* Title: prevent breaking inside words */
.page-header--stack h1 {
  margin: 0;
  font-size: clamp(28px, 4vw, 40px);
  line-height: 1.15;
  word-break: normal !important;
  overflow-wrap: normal !important;   /* or: break-word if you have very long strings */
  hyphens: manual !important;         /* avoids automatic hyphenation */
}

/* Direct-answer paragraph */
.page-header--stack .lead {
  font-size: clamp(16px, 2.2vw, 18px);
  line-height: 1.6;
  color: var(--text, #111);
  margin: 0;
}

