/* ==================================================================
   Handyman Services Dubai — shared stylesheet
   Used by: index.html, pricing.html, services/*, areas/*, blog
   Brand: bold blue trade brand, friendly & approachable
   ================================================================== */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --blue:#2563EB;
  --blue-dark:#1D4ED8;
  --blue-deep:#1E3A8A;
  --blue-soft:#EFF4FF;
  --blue-tint:#F5F8FF;
  --yellow:#FBBF24;
  --yellow-dark:#F59E0B;
  --ink:#0F172A;
  --ink-2:#1E293B;
  --grey:#475569;
  --grey-2:#64748B;
  --grey-light:#94A3B8;
  --line:#E2E8F0;
  --line-soft:#EEF2F7;
  --bg:#FFFFFF;
  --surface:#F8FAFC;
  --wa:#25D366;
  --wa-dark:#1FB855;
  --max:1240px;
  --radius:18px;
  --radius-lg:24px;
  --radius-sm:12px;
  --shadow:0 4px 24px rgba(37,99,235,.08);
  --shadow-lg:0 16px 48px rgba(37,99,235,.14);
  --shadow-blue:0 12px 28px rgba(37,99,235,.25);
}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Plus Jakarta Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  color:var(--ink);background:var(--bg);font-size:16px;line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font-family:inherit;border:0;background:0;color:inherit}
.wrap{width:100%;max-width:var(--max);margin:0 auto;padding:0 24px}

/* ============ Buttons ============ */
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 24px;border-radius:999px;font-weight:700;font-size:15px;letter-spacing:-.01em;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap;border:2px solid transparent}
.btn:hover{transform:translateY(-2px)}
.btn-blue{background:var(--blue);color:#fff;box-shadow:var(--shadow-blue)}
.btn-blue:hover{background:var(--blue-dark);box-shadow:0 18px 32px rgba(37,99,235,.32)}
.btn-wa{background:var(--wa);color:#fff;box-shadow:0 8px 20px rgba(37,211,102,.32)}
.btn-wa:hover{background:var(--wa-dark)}
.btn-white{background:#fff;color:var(--ink);border-color:var(--line);box-shadow:0 4px 12px rgba(15,23,42,.06)}
.btn-white:hover{border-color:var(--blue);color:var(--blue)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.3)}
.btn-ghost:hover{background:rgba(255,255,255,.1);border-color:#fff}
.btn-lg{padding:18px 30px;font-size:16px}

/* ============ Top bar ============ */
.topbar{background:var(--ink);color:rgba(255,255,255,.85);font-size:13px;padding:9px 0}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.topbar a{color:#fff;transition:color .15s}
.topbar a:hover{color:var(--yellow)}
.topbar .l,.topbar .r{display:flex;gap:20px;align-items:center;flex-wrap:wrap}
.topbar .live{display:inline-flex;align-items:center;gap:8px}
.topbar .dot{width:8px;height:8px;background:#22C55E;border-radius:50%;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.9)}}
@media(max-width:720px){.topbar{display:none}}

/* ============ Header ============ */
.hdr{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.96);backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid var(--line)}
.hdr .wrap{display:flex;align-items:center;justify-content:space-between;padding-top:18px;padding-bottom:18px;gap:24px}
.brand{display:flex;align-items:center;gap:12px}
.brand-mark{width:48px;height:48px;background-image:url('../img/logo.webp'),url('../img/logo.png');background-size:contain;background-position:center;background-repeat:no-repeat;color:transparent;font-size:0;position:relative;flex-shrink:0}
.brand-mark::after{display:none}
footer .brand-mark{filter:none;background-color:#fff;border-radius:10px;padding:4px}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-text strong{font-size:18px;font-weight:800;letter-spacing:-.02em;color:var(--ink)}
.brand-text small{font-size:11px;font-weight:600;color:var(--blue);letter-spacing:.06em}

.nav{display:flex;gap:32px;align-items:center}
.nav > a, .nav .drop > a{font-size:15px;font-weight:600;color:var(--ink-2);transition:color .15s;cursor:pointer}
.nav > a:hover, .nav .drop > a:hover{color:var(--blue)}
.nav .drop{position:relative}
.nav .drop > a::after{content:" ▾";font-size:10px;color:var(--grey-light)}
.nav .menu{position:absolute;top:calc(100% + 14px);left:-16px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:12px;min-width:280px;display:grid;grid-template-columns:1fr 1fr;gap:2px;opacity:0;visibility:hidden;transform:translateY(8px);transition:all .15s;box-shadow:var(--shadow-lg)}
.nav .drop:hover .menu{opacity:1;visibility:visible;transform:translateY(0)}
.nav .menu a{padding:10px 14px;font-size:14px;color:var(--ink-2);font-weight:500;border-radius:10px;transition:background .12s,color .12s}
.nav .menu a:hover{background:var(--blue-soft);color:var(--blue)}

.cta{display:flex;gap:10px;align-items:center}
.cta .phone-pill{display:inline-flex;align-items:center;gap:10px;background:var(--blue-soft);padding:11px 18px 11px 14px;border-radius:999px;font-weight:700;color:var(--blue-dark);font-size:14.5px;transition:background .15s}
.cta .phone-pill:hover{background:#E0EAFF}
.cta .phone-pill .icon{width:30px;height:30px;border-radius:50%;background:var(--blue);color:#fff;display:grid;place-items:center}

.menutoggle{display:none;width:46px;height:46px;border-radius:12px;background:var(--blue-soft);place-items:center;color:var(--blue)}

html, body{overflow-x:hidden}
@media(max-width:1020px){
  .nav{position:fixed;top:0;right:0;width:88%;max-width:380px;height:100vh;background:#fff;flex-direction:column;align-items:stretch;padding:84px 24px 32px;gap:4px;overflow-y:auto;box-shadow:-20px 0 50px rgba(15,23,42,.18);transform:translateX(100%);transition:transform .3s ease;will-change:transform}
  .nav.open{transform:translateX(0)}
  .nav > a, .nav .drop > a{padding:14px 16px;border-radius:12px;font-size:16px}
  .nav > a:hover, .nav .drop > a:hover{background:var(--blue-soft)}
  .nav .menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;padding:0 0 8px 16px;grid-template-columns:1fr;background:transparent;min-width:auto}
  .cta .phone-pill{display:none}
  .menutoggle{display:grid}
}

/* ============ Common section base ============ */
section{padding:90px 0}
.section-head{text-align:center;margin-bottom:56px;max-width:700px;margin-left:auto;margin-right:auto}
.eyebrow{display:inline-block;background:var(--blue-soft);color:var(--blue-dark);padding:6px 16px;border-radius:999px;font-size:12.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin-bottom:16px}
.section-head h2{font-size:clamp(30px,4vw,46px);font-weight:800;letter-spacing:-.025em;line-height:1.15;margin-bottom:14px}
.section-head h2 .accent{color:var(--blue)}
.section-head p{font-size:17.5px;color:var(--grey);line-height:1.6}
@media(max-width:780px){section{padding:64px 0}.section-head{margin-bottom:40px}}

/* ============ Breadcrumbs ============ */
.crumbs{background:var(--surface);border-bottom:1px solid var(--line);padding:14px 0;font-size:13.5px}
.crumbs .wrap{display:flex;align-items:center;gap:8px;flex-wrap:wrap;color:var(--grey-2)}
.crumbs a{color:var(--grey-2);font-weight:500;transition:color .15s}
.crumbs a:hover{color:var(--blue)}
.crumbs .sep{color:var(--grey-light)}
.crumbs strong{color:var(--ink);font-weight:600}

/* ============ Article / inner-page hero ============ */
.page-hero{position:relative;overflow:hidden;background:radial-gradient(800px 500px at 90% 10%,rgba(37,99,235,.08),transparent 60%),radial-gradient(600px 400px at 0% 100%,rgba(251,191,36,.08),transparent 60%),var(--bg);padding:64px 0 56px}
.page-hero .wrap{display:grid;grid-template-columns:1.3fr .7fr;gap:60px;align-items:center}
.page-hero .tag{display:inline-flex;align-items:center;gap:10px;background:var(--blue-soft);color:var(--blue-dark);padding:8px 16px 8px 8px;border-radius:999px;font-size:13px;font-weight:700;margin-bottom:20px}
.page-hero .tag .pill{background:var(--blue);color:#fff;padding:4px 12px;border-radius:999px;font-size:11.5px;letter-spacing:.04em}
.page-hero h1{font-size:clamp(34px,4.6vw,54px);font-weight:800;line-height:1.05;letter-spacing:-.025em;margin-bottom:20px}
.page-hero h1 .accent{color:var(--blue)}
.page-hero .lead{font-size:18px;color:var(--grey);line-height:1.6;max-width:560px;margin-bottom:28px}
.page-hero .actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:28px}
.page-hero .signals{display:flex;gap:12px;flex-wrap:wrap}
.signal-pill{display:inline-flex;align-items:center;gap:7px;background:#fff;border:1px solid var(--line);padding:7px 13px;border-radius:999px;font-size:12.5px;font-weight:600;color:var(--ink-2);box-shadow:0 2px 6px rgba(15,23,42,.04)}
.signal-pill svg{color:var(--blue);width:15px;height:15px}
.signal-pill .star{color:var(--yellow-dark)}

.hero-card-mini{background:#fff;border-radius:20px;border:1px solid var(--line);padding:28px;box-shadow:var(--shadow-lg);position:relative}
.hero-card-mini::before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--blue),var(--blue-dark),var(--yellow));border-radius:20px 20px 0 0}
.hero-card-mini .price-line{display:flex;align-items:baseline;gap:6px;margin-bottom:8px}
.hero-card-mini .price-line .from{font-size:13px;color:var(--grey-2);font-weight:600;letter-spacing:.06em;text-transform:uppercase}
.hero-card-mini .price-line .price{font-size:48px;font-weight:800;color:var(--blue-dark);letter-spacing:-.03em;line-height:1}
.hero-card-mini .price-line .price em{font-style:normal;font-size:22px;color:var(--yellow-dark);vertical-align:8px;margin-right:4px}
.hero-card-mini .sub{font-size:14px;color:var(--grey);margin-bottom:20px}
.hero-card-mini ul{list-style:none;display:grid;gap:10px;margin-bottom:24px}
.hero-card-mini li{display:flex;gap:10px;align-items:flex-start;font-size:14.5px;color:var(--ink-2);font-weight:500}
.hero-card-mini li svg{flex-shrink:0;color:#16A34A;width:18px;height:18px;margin-top:2px}
.hero-card-mini .actions{display:flex;flex-direction:column;gap:8px}
.hero-card-mini .actions .btn{justify-content:center;width:100%}

@media(max-width:980px){
  .page-hero{padding:36px 0 32px}
  .page-hero .wrap{grid-template-columns:1fr;gap:36px}
}

/* ============ Key takeaways box ============ */
.takeaways{background:linear-gradient(135deg,#FFFDF5 0%,#FFFBED 100%);border:1.5px solid #FDE68A;border-radius:18px;padding:28px 32px;margin:0 0 40px}
.takeaways h2, .takeaways h3{font-size:15px;font-weight:800;color:var(--yellow-dark);letter-spacing:.08em;text-transform:uppercase;margin-bottom:16px;display:flex;align-items:center;gap:10px}
.takeaways h2::before, .takeaways h3::before{content:"⚡";font-size:18px}
.takeaways ul{list-style:none;display:grid;gap:10px}
.takeaways li{display:flex;gap:12px;align-items:flex-start;font-size:15.5px;line-height:1.55;color:var(--ink)}
.takeaways li strong{color:var(--ink);font-weight:700}
.takeaways li::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--yellow-dark);margin-top:10px;flex-shrink:0}

/* ============ Article body ============ */
.article{padding:64px 0}
.article-grid{display:grid;grid-template-columns:1fr 280px;gap:64px;align-items:start}
.article-body{font-size:17px;line-height:1.75;color:var(--ink-2);max-width:760px}
.article-body h2{font-size:clamp(26px,3vw,34px);font-weight:800;letter-spacing:-.02em;line-height:1.2;margin:48px 0 18px;color:var(--ink);scroll-margin-top:100px}
.article-body h2:first-child{margin-top:0}
.article-body h2 .accent{color:var(--blue)}
.article-body h3{font-size:21px;font-weight:700;letter-spacing:-.01em;margin:32px 0 12px;color:var(--ink)}
.article-body p{margin-bottom:18px}
.article-body p strong{color:var(--ink);font-weight:700}
.article-body a{color:var(--blue);font-weight:600;border-bottom:1px solid rgba(37,99,235,.25);transition:border-color .15s,color .15s}
.article-body a:hover{color:var(--blue-dark);border-color:var(--blue)}
.article-body ul, .article-body ol{margin:0 0 22px 0;padding-left:0;list-style:none}
.article-body ul li, .article-body ol li{position:relative;padding-left:30px;margin-bottom:10px;line-height:1.7}
.article-body ul li::before{content:"";position:absolute;left:8px;top:11px;width:8px;height:8px;border-radius:50%;background:var(--blue)}
.article-body ol{counter-reset:listcount}
.article-body ol li{counter-increment:listcount;padding-left:36px}
.article-body ol li::before{content:counter(listcount);position:absolute;left:0;top:0;width:26px;height:26px;border-radius:50%;background:var(--blue);color:#fff;font-weight:700;font-size:13px;display:grid;place-items:center}
.article-body blockquote{margin:28px 0;padding:20px 24px;border-left:4px solid var(--blue);background:var(--blue-soft);border-radius:0 12px 12px 0;font-style:italic;color:var(--ink-2);font-size:17px}
.article-body blockquote .by{display:block;margin-top:10px;font-style:normal;font-size:13px;font-weight:600;color:var(--blue-dark)}
.article-body table{width:100%;border-collapse:collapse;margin:24px 0;background:#fff;border:1.5px solid var(--line);border-radius:14px;overflow:hidden;font-size:15px}
.article-body table thead{background:var(--blue-soft)}
.article-body table th{text-align:left;padding:14px 18px;font-weight:700;color:var(--blue-dark);font-size:13.5px;letter-spacing:.04em;text-transform:uppercase;border-bottom:1.5px solid var(--line)}
.article-body table td{padding:14px 18px;border-bottom:1px solid var(--line-soft);color:var(--ink-2)}
.article-body table tr:last-child td{border-bottom:0}
.article-body table tr:hover td{background:var(--surface)}
.article-body table td strong{color:var(--blue-dark);font-weight:700}

/* TOC sidebar */
.toc{position:sticky;top:100px;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:24px;font-size:14px}
.toc h2.toc-h, .toc .toc-h, .toc h4{font-size:11.5px;font-weight:800;color:var(--grey-2);text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.toc h4::before{content:"";width:18px;height:2px;background:var(--blue);border-radius:2px}
.toc ul{list-style:none}
.toc li{margin-bottom:6px}
.toc a{display:block;padding:7px 12px;color:var(--grey);font-weight:500;border-radius:8px;transition:all .15s;border-left:2px solid transparent;line-height:1.4}
.toc a:hover{background:#fff;color:var(--blue);border-left-color:var(--blue)}
@media(max-width:980px){.article-grid{grid-template-columns:1fr;gap:0}.toc{display:none}}

/* Inline CTA box */
.inline-cta{background:linear-gradient(135deg,var(--blue-deep),var(--blue-dark));color:#fff;padding:32px;border-radius:18px;margin:36px 0;display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.inline-cta h3{font-size:22px;font-weight:800;margin-bottom:6px;color:#fff;letter-spacing:-.01em}
.inline-cta p{color:rgba(255,255,255,.85);margin:0;font-size:14.5px}
.inline-cta .actions{display:flex;gap:10px;flex-wrap:wrap}

/* ============ FAQ block (reusable) ============ */
.faq-list{display:grid;gap:12px}
.faq-item{background:#fff;border:1.5px solid var(--line);border-radius:16px;overflow:hidden;transition:all .2s}
.faq-item[open]{border-color:var(--blue);box-shadow:var(--shadow)}
.faq-item summary{list-style:none;cursor:pointer;padding:22px 24px;display:flex;align-items:center;justify-content:space-between;gap:20px;font-weight:700;font-size:16.5px;color:var(--ink)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";width:32px;height:32px;border-radius:50%;background:var(--blue-soft);color:var(--blue);display:grid;place-items:center;font-weight:300;font-size:22px;line-height:1;flex-shrink:0;transition:all .25s}
.faq-item[open] summary::after{transform:rotate(45deg);background:var(--blue);color:#fff}
.faq-item .ans{padding:0 24px 24px;color:var(--grey);font-size:15px;line-height:1.7}
.faq-item .ans p{margin-bottom:12px}
.faq-item .ans p:last-child{margin-bottom:0}

/* ============ Related grid (services / areas) ============ */
.related-section{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:72px 0}
.related-section h2{font-size:clamp(26px,3vw,36px);font-weight:800;letter-spacing:-.02em;line-height:1.2;margin-bottom:32px}
.related-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}
.related-card{background:#fff;border:1.5px solid var(--line);border-radius:14px;padding:20px;transition:all .2s;display:flex;align-items:center;justify-content:space-between;gap:12px}
.related-card:hover{border-color:var(--blue);transform:translateY(-3px);box-shadow:var(--shadow)}
.related-card strong{font-size:15.5px;font-weight:700;color:var(--ink)}
.related-card span{font-size:12.5px;color:var(--grey-2);display:block;margin-top:2px}
.related-card .arr{color:var(--blue);font-weight:800;font-size:18px}

/* ============ Pricing table block ============ */
.price-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px}
.price-tile{background:#fff;border:1.5px solid var(--line);border-radius:16px;padding:26px;transition:all .2s}
.price-tile:hover{border-color:var(--blue);box-shadow:var(--shadow);transform:translateY(-3px)}
.price-tile h3{font-size:18px;font-weight:700;margin-bottom:6px}
.price-tile .range{font-size:24px;font-weight:800;color:var(--blue-dark);letter-spacing:-.02em;margin-bottom:14px;line-height:1}
.price-tile .range em{font-style:normal;font-size:14px;color:var(--grey-2);font-weight:600}
.price-tile p{font-size:14px;color:var(--grey);line-height:1.55;margin-bottom:14px}
.price-tile ul{list-style:none;padding:0;margin:0}
.price-tile li{position:relative;padding-left:22px;font-size:13.5px;color:var(--ink-2);margin-bottom:6px;line-height:1.5}
.price-tile li::before{content:"✓";position:absolute;left:0;color:#16A34A;font-weight:800}

/* ============ End CTA / Footer (shared) ============ */
.endcta{background:linear-gradient(135deg,var(--blue-deep) 0%,var(--blue-dark) 100%);color:#fff;padding:96px 0;text-align:center;position:relative;overflow:hidden}
.endcta::before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(800px 400px at 50% 0%,rgba(251,191,36,.12),transparent 60%)}
.endcta .wrap{position:relative;z-index:1}
.endcta h2{font-size:clamp(32px,5vw,52px);font-weight:800;letter-spacing:-.025em;line-height:1.1;margin-bottom:18px}
.endcta h2 em{font-style:normal;color:var(--yellow)}
.endcta p{font-size:18px;color:rgba(255,255,255,.85);max-width:580px;margin:0 auto 36px}
.endcta-ctas{display:flex;justify-content:center;gap:14px;flex-wrap:wrap}

footer{background:var(--ink);color:rgba(255,255,255,.7);padding:72px 0 28px;font-size:14.5px}
.f-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
footer h5{color:#fff;font-size:15px;font-weight:700;margin-bottom:20px;letter-spacing:-.005em}
footer .f-heading{color:#fff;font-size:15px;font-weight:700;margin-bottom:20px;letter-spacing:-.005em}
footer ul{list-style:none}
footer ul li{margin-bottom:10px}
footer a{transition:color .15s}
footer a:hover{color:var(--yellow)}
.f-brand{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.f-brand .brand-text strong{color:#fff}
.f-about p{line-height:1.7;margin-bottom:20px;max-width:380px}
.f-contact{display:grid;gap:8px}
.f-contact a{color:#fff;font-weight:600;display:block;font-size:15px}
.f-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;padding-top:28px;border-top:1px solid rgba(255,255,255,.1);font-size:13px;color:rgba(255,255,255,.5)}
.f-bottom .badges{display:flex;gap:14px;flex-wrap:wrap}
.f-bottom .badges span{padding:5px 12px;background:rgba(255,255,255,.06);border-radius:8px;font-size:12px}
@media(max-width:780px){.f-grid{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:480px){.f-grid{grid-template-columns:1fr}}

/* ============ Mobile sticky bar ============ */
.mbar{display:none;position:fixed;left:0;right:0;bottom:0;z-index:60;background:#fff;padding:10px 12px calc(10px + env(safe-area-inset-bottom));gap:8px;border-top:1px solid var(--line);box-shadow:0 -8px 24px rgba(15,23,42,.08)}
.mbar .btn{flex:1;justify-content:center;padding:14px 12px;font-size:14.5px}
@media(max-width:720px){.mbar{display:flex}body{padding-bottom:82px}}

/* ============ Reveal animation ============ */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s,transform .7s}
.reveal.in{opacity:1;transform:translateY(0)}

/* ============ Homepage-only sections (kept here for index.html) ============ */
/* Hero */
.hero{position:relative;overflow:hidden;background:radial-gradient(800px 500px at 90% 10%,rgba(37,99,235,.08),transparent 60%),radial-gradient(600px 400px at 0% 100%,rgba(251,191,36,.08),transparent 60%),var(--bg);padding:64px 0 88px}
.hero .wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center}
.hero-tag{display:inline-flex;align-items:center;gap:10px;background:var(--blue-soft);color:var(--blue-dark);padding:8px 16px 8px 8px;border-radius:999px;font-size:13.5px;font-weight:700;margin-bottom:24px}
.hero-tag .pill{background:var(--blue);color:#fff;padding:4px 12px;border-radius:999px;font-size:11.5px;letter-spacing:.04em}
.hero h1{font-size:clamp(38px,5.5vw,64px);font-weight:800;line-height:1.05;letter-spacing:-.025em;margin-bottom:22px;color:var(--ink)}
.hero h1 .accent{background:linear-gradient(135deg,var(--blue) 0%,var(--blue-dark) 100%);-webkit-background-clip:text;background-clip:text;color:transparent;position:relative;display:inline-block}
.hero h1 .wave{position:relative;display:inline-block}
.hero h1 .wave::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:8px;background:var(--yellow);border-radius:4px;z-index:-1}
.hero p.lead{font-size:18.5px;line-height:1.6;color:var(--grey);max-width:540px;margin-bottom:32px}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:36px}
.hero-trust{display:flex;gap:18px;flex-wrap:wrap;align-items:center}
.trust-pill{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);padding:8px 14px;border-radius:999px;font-size:13px;font-weight:600;color:var(--ink-2);box-shadow:0 2px 6px rgba(15,23,42,.04)}
.trust-pill svg{color:var(--blue);width:16px;height:16px}
.trust-pill .star{color:var(--yellow-dark)}

/* WhatsApp phone mockup */
.hero-visual{position:relative;display:flex;justify-content:center;align-items:center}
.hero-img{display:block;position:relative;width:360px;border-radius:28px;overflow:hidden;box-shadow:0 30px 80px rgba(15,23,42,.22),0 0 0 1px rgba(15,23,42,.05);background:linear-gradient(180deg,#EFF4FF 0%,#DBE4FF 100%);aspect-ratio:3/4}
.hero-img img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.phone{width:320px;background:#0B0F1A;border-radius:38px;padding:14px;box-shadow:0 30px 80px rgba(15,23,42,.25),0 0 0 1px rgba(15,23,42,.06);position:relative}
.phone::before{content:"";position:absolute;top:14px;left:50%;transform:translateX(-50%);width:100px;height:24px;background:#0B0F1A;border-radius:0 0 14px 14px;z-index:3}
.phone-screen{background:#E5DDD5;border-radius:26px;overflow:hidden;height:600px;display:flex;flex-direction:column}
.wa-header{background:#075E54;color:#fff;padding:38px 14px 14px;display:flex;align-items:center;gap:10px}
.wa-header .avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--blue-dark));display:grid;place-items:center;font-weight:800;font-size:15px}
.wa-header .who{flex:1}
.wa-header .who strong{display:block;font-size:14.5px;font-weight:600;letter-spacing:-.01em}
.wa-header .who span{font-size:11.5px;opacity:.8;display:flex;align-items:center;gap:5px}
.wa-header .who span::before{content:"";width:6px;height:6px;background:#22C55E;border-radius:50%}
.wa-header .icons{display:flex;gap:14px;opacity:.95}
.wa-header .icons svg{width:18px;height:18px}
.wa-body{flex:1;padding:16px 14px;display:flex;flex-direction:column;gap:8px;overflow:hidden;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.4) 0%,transparent 40%),radial-gradient(circle at 70% 70%,rgba(255,255,255,.3) 0%,transparent 40%),#E5DDD5}
.msg{max-width:80%;padding:8px 11px;border-radius:8px;font-size:13.5px;line-height:1.4;position:relative;font-family:-apple-system,'Segoe UI',sans-serif}
.msg.user{align-self:flex-end;background:#DCF8C6;color:#1F2937;border-radius:8px 0 8px 8px}
.msg.pro{align-self:flex-start;background:#fff;color:#1F2937;border-radius:0 8px 8px 8px}
.msg time{display:block;font-size:9.5px;color:rgba(15,23,42,.45);text-align:right;margin-top:3px;font-weight:500}
.msg .check{color:#34B7F1;font-size:11px;margin-left:3px}
.wa-input{background:#F0F0F0;padding:8px 12px;display:flex;align-items:center;gap:8px}
.wa-input .field{flex:1;background:#fff;border-radius:18px;padding:7px 14px;font-size:12.5px;color:var(--grey-light)}
.wa-input .send{width:34px;height:34px;border-radius:50%;background:#075E54;color:#fff;display:grid;place-items:center}
.wa-input .send svg{width:16px;height:16px}

.hero-float-1{position:absolute;top:30px;left:-10px;background:#fff;border-radius:14px;padding:12px 16px;display:flex;align-items:center;gap:10px;box-shadow:0 12px 32px rgba(15,23,42,.12);border:1px solid var(--line);font-size:13px;font-weight:700}
.hero-float-1 .ic{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#22C55E,#16A34A);color:#fff;display:grid;place-items:center}
.hero-float-1 small{display:block;font-size:11px;color:var(--grey-2);font-weight:500}
.hero-float-2{position:absolute;bottom:60px;right:-20px;background:#fff;border-radius:14px;padding:14px 16px;display:flex;align-items:center;gap:12px;box-shadow:0 12px 32px rgba(15,23,42,.12);border:1px solid var(--line)}
.hero-float-2 .price{font-size:24px;font-weight:800;color:var(--blue-dark);line-height:1;letter-spacing:-.02em}
.hero-float-2 .price small{display:block;font-size:10.5px;color:var(--grey-2);font-weight:600;letter-spacing:.04em;text-transform:uppercase}
.hero-float-2 .from{font-size:13px;color:var(--ink-2);font-weight:600}

@media(max-width:980px){.hero{padding:40px 0 64px}.hero .wrap{grid-template-columns:1fr;gap:48px}.hero-visual{order:-1}.phone{width:280px}.phone-screen{height:520px}.hero-img{width:300px}.hero-float-1{top:10px;left:0}.hero-float-2{bottom:30px;right:0}}

/* Featured in strip */
.featured-in{background:linear-gradient(180deg,#FFFFFF 0%,var(--surface) 100%);border-bottom:1px solid var(--line);padding:48px 0 56px}
.featured-in .eyebrow-row{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:28px}
.featured-in .eyebrow-row::before,.featured-in .eyebrow-row::after{content:"";flex:1;max-width:120px;height:1px;background:var(--line)}
.featured-in .eyebrow-label{font-size:12px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--grey-2);white-space:nowrap}
.featured-row{display:grid;grid-template-columns:repeat(6,1fr);gap:24px;align-items:center}
.featured-logo{display:flex;align-items:center;justify-content:center;height:48px;color:#64748B;filter:grayscale(100%);opacity:.7;transition:opacity .25s,filter .25s,transform .25s;user-select:none}
.featured-logo:hover{opacity:1;filter:grayscale(0);transform:translateY(-2px);color:var(--blue-dark)}
.fl-gulf{font-family:'Plus Jakarta Sans',sans-serif;font-weight:800;font-size:20px;letter-spacing:-.02em;text-transform:uppercase}
.fl-gulf span{color:#C81E1E;transition:color .25s}
.fl-khaleej{font-family:Georgia,'Times New Roman',serif;font-weight:700;font-size:21px;font-style:italic;letter-spacing:-.01em}
.fl-national{font-family:Georgia,serif;font-weight:400;font-size:13px;letter-spacing:.32em;text-transform:uppercase;text-align:center;line-height:1.1}
.fl-national strong{display:block;font-size:18px;font-weight:700;letter-spacing:.18em;margin-top:2px}
.fl-timeout{font-family:'Plus Jakarta Sans',sans-serif;font-weight:900;font-size:13px;letter-spacing:-.01em;text-transform:uppercase;background:#0F172A;color:#fff!important;padding:8px 12px;line-height:1;text-align:center}
.fl-timeout em{font-style:normal;color:#FBBF24;display:block;font-size:11px;margin-top:2px;letter-spacing:.04em}
.featured-logo:hover .fl-timeout{background:var(--blue-dark)}
.fl-arabian{font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:14px;letter-spacing:.16em;text-transform:uppercase;text-align:center;line-height:1.2}
.fl-arabian span{display:block;font-weight:500;font-size:11px;letter-spacing:.28em;margin-top:2px;opacity:.7}
.fl-bayut{font-family:'Plus Jakarta Sans',sans-serif;font-weight:800;font-size:24px;letter-spacing:-.03em;color:#64748B}
.fl-bayut em{font-style:normal;color:#06B6D4;transition:color .25s}
@media(max-width:980px){.featured-row{grid-template-columns:repeat(3,1fr);gap:32px 24px}}
@media(max-width:560px){.featured-row{grid-template-columns:repeat(2,1fr);gap:28px 18px}.featured-in{padding:36px 0 44px}}

/* Trust strip numbers */
.trust-strip{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:32px 0}
.trust-strip .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.trust-item{display:flex;flex-direction:column;align-items:center;gap:6px}
.trust-item .num{font-size:32px;font-weight:800;letter-spacing:-.02em;color:var(--blue-dark);line-height:1}
.trust-item .num em{font-style:normal;color:var(--yellow-dark)}
.trust-item .lbl{font-size:13px;font-weight:600;color:var(--grey)}
@media(max-width:680px){.trust-strip .wrap{grid-template-columns:1fr 1fr;gap:28px}}

/* Service cards grid */
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.svc-card{background:#fff;border:1.5px solid var(--line);border-radius:var(--radius);padding:24px;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;display:block}
.svc-card:hover{transform:translateY(-6px);border-color:var(--blue);box-shadow:var(--shadow-lg)}
.svc-card::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--blue),var(--blue-dark));transform:scaleX(0);transform-origin:left;transition:transform .3s}
.svc-card:hover::before{transform:scaleX(1)}
.svc-icon{width:54px;height:54px;border-radius:14px;background:var(--blue-soft);color:var(--blue);display:grid;place-items:center;margin-bottom:18px;transition:background .2s,color .2s}
.svc-card:hover .svc-icon{background:var(--blue);color:#fff}
.svc-icon svg{width:26px;height:26px}
.svc-card h3{font-size:18px;font-weight:700;letter-spacing:-.01em;margin-bottom:8px}
.svc-card p{font-size:14px;color:var(--grey);line-height:1.55;margin-bottom:18px;min-height:44px}
.svc-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:14px;border-top:1px dashed var(--line)}
.svc-price{display:inline-flex;align-items:center;gap:4px;font-size:13px;color:var(--grey-2);font-weight:600}
.svc-price strong{color:var(--blue-dark);font-size:15px;font-weight:800}
.svc-arrow{width:32px;height:32px;border-radius:50%;background:var(--blue-soft);color:var(--blue);display:grid;place-items:center;transition:all .2s}
.svc-card:hover .svc-arrow{background:var(--blue);color:#fff;transform:translateX(4px)}
@media(max-width:1020px){.svc-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:780px){.svc-grid{grid-template-columns:repeat(2,1fr);gap:14px}.svc-card{padding:20px}}
@media(max-width:440px){.svc-grid{grid-template-columns:1fr}}

/* WhatsApp banner */
.wa-banner{background:linear-gradient(135deg,var(--blue-deep) 0%,var(--blue-dark) 50%,var(--blue) 100%);color:#fff;position:relative;overflow:hidden}
.wa-banner::before{content:"";position:absolute;top:-100px;right:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(251,191,36,.15) 0%,transparent 70%);border-radius:50%}
.wa-banner::after{content:"";position:absolute;bottom:-100px;left:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(37,211,102,.15) 0%,transparent 70%);border-radius:50%}
.wa-banner .wrap{display:grid;grid-template-columns:1.3fr .9fr;gap:60px;align-items:center;position:relative;z-index:1}
.wa-banner .eyebrow{background:rgba(255,255,255,.15);color:#fff}
.wa-banner h2{font-size:clamp(30px,4vw,44px);font-weight:800;letter-spacing:-.025em;line-height:1.1;margin-bottom:20px;color:#fff}
.wa-banner h2 em{font-style:normal;color:var(--yellow);position:relative}
.wa-banner p{font-size:17px;color:rgba(255,255,255,.85);margin-bottom:28px;max-width:520px}
.wa-banner-ctas{display:flex;gap:12px;flex-wrap:wrap}
.wa-banner-stats{display:flex;gap:36px;margin-top:32px;padding-top:32px;border-top:1px solid rgba(255,255,255,.15)}
.wa-banner-stats > div{display:flex;flex-direction:column;gap:4px}
.wa-banner-stats strong{font-size:30px;font-weight:800;color:var(--yellow);line-height:1;letter-spacing:-.02em}
.wa-banner-stats span{font-size:12.5px;color:rgba(255,255,255,.7);font-weight:500}
.wa-banner-img{display:grid;place-items:center;position:relative}
.wa-ic-big{width:200px;height:200px;border-radius:50%;background:var(--wa);display:grid;place-items:center;box-shadow:0 24px 60px rgba(37,211,102,.4),0 0 0 12px rgba(37,211,102,.15);animation:floatY 3s ease-in-out infinite}
.wa-ic-big svg{width:100px;height:100px;color:#fff}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@media(max-width:880px){.wa-banner .wrap{grid-template-columns:1fr;gap:40px}.wa-banner-img{order:-1}.wa-ic-big{width:140px;height:140px}.wa-ic-big svg{width:72px;height:72px}}

/* How it works steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;position:relative}
.step{background:#fff;border:1.5px solid var(--line);border-radius:var(--radius-lg);padding:32px 28px;text-align:left;position:relative;transition:all .25s}
.step:hover{transform:translateY(-4px);border-color:var(--blue);box-shadow:var(--shadow)}
.step-num{position:absolute;top:-18px;left:28px;width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,var(--blue),var(--blue-dark));color:#fff;font-weight:800;font-size:20px;display:grid;place-items:center;box-shadow:var(--shadow-blue)}
.step-icon{width:60px;height:60px;border-radius:16px;background:var(--blue-soft);display:grid;place-items:center;color:var(--blue);margin:20px 0 18px}
.step-icon svg{width:30px;height:30px}
.step h3{font-size:20px;font-weight:700;letter-spacing:-.01em;margin-bottom:8px}
.step p{font-size:15px;color:var(--grey);line-height:1.6}
@media(max-width:880px){.steps{grid-template-columns:1fr;gap:30px}}

/* Areas grid */
.areas-wrap{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.areas-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.area-card{background:#fff;border:1.5px solid var(--line);border-radius:var(--radius-sm);padding:18px 20px;display:flex;align-items:center;gap:12px;transition:all .2s;font-weight:600;color:var(--ink-2)}
.area-card:hover{border-color:var(--blue);background:var(--blue-soft);color:var(--blue-dark);transform:translateX(4px)}
.area-card svg{width:18px;height:18px;color:var(--blue);flex-shrink:0}
@media(max-width:880px){.areas-grid{grid-template-columns:1fr 1fr;gap:10px}.area-card{padding:14px 16px;font-size:14px}}

/* Reviews */
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.review-card{background:#fff;border:1.5px solid var(--line);border-radius:var(--radius);padding:28px;position:relative;transition:all .25s}
.review-card:hover{border-color:var(--blue);box-shadow:var(--shadow)}
.review-card .quote-mark{position:absolute;top:-12px;right:24px;font-size:60px;line-height:1;color:var(--blue);font-family:Georgia,serif;font-weight:700}
.review-stars{color:var(--yellow-dark);letter-spacing:3px;margin-bottom:14px;font-size:16px}
.review-text{font-size:15.5px;color:var(--ink-2);line-height:1.65;margin-bottom:22px}
.review-author{display:flex;align-items:center;gap:12px;padding-top:18px;border-top:1px solid var(--line-soft)}
.review-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--blue-dark));color:#fff;display:grid;place-items:center;font-weight:800;font-size:16px}
.review-author strong{display:block;font-size:15px;font-weight:700;color:var(--ink)}
.review-author span{font-size:12.5px;color:var(--grey-2);font-weight:500}
.review-google{margin-left:auto;display:flex;align-items:center;gap:4px;font-size:11px;color:var(--grey-2);font-weight:600}
.review-google::before{content:"G";display:inline-grid;place-items:center;width:18px;height:18px;border-radius:50%;background:linear-gradient(135deg,#4285F4,#34A853);color:#fff;font-weight:800;font-size:11px}
@media(max-width:880px){.reviews-grid{grid-template-columns:1fr}}

/* Team */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.team-card{background:#fff;border:1.5px solid var(--line);border-radius:var(--radius);padding:24px;text-align:center;transition:all .25s}
.team-card:hover{transform:translateY(-4px);border-color:var(--blue);box-shadow:var(--shadow)}
.team-photo{width:100px;height:100px;border-radius:50%;margin:0 auto 16px;background:linear-gradient(135deg,var(--blue) 0%,var(--blue-dark) 100%);display:grid;place-items:center;font-weight:800;font-size:38px;color:#fff;border:4px solid var(--blue-soft);position:relative}
.team-photo::after{content:"";position:absolute;bottom:4px;right:4px;width:20px;height:20px;background:#22C55E;border:3px solid #fff;border-radius:50%}
.team-card h4{font-size:17px;font-weight:700;margin-bottom:4px}
.team-card h3{font-size:17px;font-weight:700;margin-bottom:4px}
.team-card .role{font-size:13px;color:var(--blue);font-weight:600;margin-bottom:10px}
.team-card .exp{font-size:12.5px;color:var(--grey-2);font-weight:500}
@media(max-width:880px){.team-grid{grid-template-columns:1fr 1fr}}

/* Quote form */
.quote-section{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.quote-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.quote-left h2{font-size:clamp(30px,4vw,42px);font-weight:800;letter-spacing:-.025em;line-height:1.1;margin-bottom:18px}
.quote-left h2 .accent{color:var(--blue)}
.quote-left .lede{font-size:17px;color:var(--grey);line-height:1.6;margin-bottom:32px}
.contact-grid{display:grid;gap:14px}
.contact-row{background:#fff;border:1.5px solid var(--line);border-radius:var(--radius-sm);padding:18px 20px;display:flex;align-items:center;gap:16px;transition:all .2s}
.contact-row:hover{border-color:var(--blue);transform:translateX(4px)}
.contact-row .ic{width:48px;height:48px;border-radius:14px;background:var(--blue-soft);display:grid;place-items:center;color:var(--blue);flex-shrink:0}
.contact-row .ic svg{width:22px;height:22px}
.contact-row .lbl{font-size:11.5px;color:var(--grey-2);font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:2px}
.contact-row .val{font-size:15.5px;color:var(--ink);font-weight:700}
.contact-row.wa .ic{background:rgba(37,211,102,.15);color:var(--wa-dark)}

.qform{background:#fff;border:1.5px solid var(--line);border-radius:var(--radius-lg);padding:34px;box-shadow:var(--shadow);position:relative}
.qform-badge{position:absolute;top:-14px;right:30px;background:var(--yellow);color:var(--ink);padding:7px 16px;border-radius:999px;font-size:12.5px;font-weight:800;letter-spacing:.04em;box-shadow:0 4px 12px rgba(251,191,36,.4)}
.qform h3{font-size:24px;font-weight:800;letter-spacing:-.01em;margin-bottom:6px}
.qform .sub{font-size:14.5px;color:var(--grey);margin-bottom:24px}
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--ink-2);margin-bottom:8px}
.field input, .field select, .field textarea{width:100%;padding:13px 16px;border:1.5px solid var(--line);background:#fff;border-radius:12px;font-family:inherit;font-size:15px;color:var(--ink);transition:border-color .15s,box-shadow .15s}
.field input:focus, .field select:focus, .field textarea:focus{outline:0;border-color:var(--blue);box-shadow:0 0 0 4px rgba(37,99,235,.12)}
.field textarea{min-height:90px;resize:vertical}
.field-2{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}
.field-2 .field{margin-bottom:0}
.qform .btn{width:100%;justify-content:center;margin-top:8px}
.qform .micro{text-align:center;font-size:13px;color:var(--grey-2);margin-top:14px}
.qform .micro span{color:var(--blue);font-weight:600}
@media(max-width:880px){.quote-grid{grid-template-columns:1fr;gap:40px}.qform{padding:24px}}
