/* =========================================================================
   FixItFast — Core stylesheet
   Modern UAE home-services theme. Navy + orange (action) + teal (technical).
   ========================================================================= */

:root{
  /* Brand */
  --ink:        #0A2540;
  --ink-2:      #0F3257;
  --ink-soft:   #15406b;
  --brand:      #FF6B1A;   /* action orange — "fast" */
  --brand-dark: #E2570B;
  --brand-soft: #FFF1E8;
  --accent:     #0FB5A8;   /* technical teal */
  --accent-dark:#0A8C82;

  /* Surfaces & text */
  --bg:         #F4F7FA;
  --surface:    #FFFFFF;
  --surface-2:  #F8FAFC;
  --text:       #1E2A33;
  --muted:      #5E7283;
  --line:       #E5ECF3;
  --line-2:     #D8E2EC;

  /* Effects */
  --shadow-sm:  0 1px 2px rgba(10,37,64,.06), 0 1px 3px rgba(10,37,64,.05);
  --shadow:     0 6px 24px -8px rgba(10,37,64,.18);
  --shadow-lg:  0 24px 60px -20px rgba(10,37,64,.32);
  --radius:     16px;
  --radius-sm:  10px;
  --radius-lg:  24px;

  /* Type */
  --font-display: "Plus Jakarta Sans", system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-body:    "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;

  --maxw: 1200px;
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--text);
  background:var(--bg);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; height:auto; display:block; }
a{ color:var(--brand-dark); text-decoration:none; }
a:hover{ text-decoration:underline; }
h1,h2,h3,h4,h5{ font-family:var(--font-display); color:var(--ink); line-height:1.15; margin:0 0 .5em; font-weight:700; letter-spacing:-.02em; }
h1{ font-size:clamp(2.1rem,4.6vw,3.6rem); font-weight:800; }
h2{ font-size:clamp(1.7rem,3.4vw,2.6rem); }
h3{ font-size:clamp(1.25rem,2vw,1.6rem); }
p{ margin:0 0 1.1em; }
ul,ol{ margin:0 0 1.1em; padding-left:1.25em; }
.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:22px; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.5em; justify-content:center;
  font-family:var(--font-display); font-weight:700; font-size:1rem;
  padding:.85em 1.5em; border-radius:999px; border:2px solid transparent;
  cursor:pointer; transition:transform .15s ease, box-shadow .2s ease, background .2s ease;
  text-decoration:none; line-height:1; white-space:nowrap;
}
.btn:hover{ text-decoration:none; transform:translateY(-2px); }
.btn svg{ width:18px; height:18px; flex:none; }
.nav-book{ display:none; }
.btn-primary{ background:var(--brand); color:#fff; box-shadow:0 10px 24px -10px rgba(255,107,26,.7); }
.btn-primary:hover{ background:var(--brand-dark); color:#fff; }
.btn-ghost{ background:transparent; color:var(--ink); border-color:var(--line-2); }
.btn-ghost:hover{ border-color:var(--ink); }
.btn-light{ background:#fff; color:var(--ink); }
.btn-accent{ background:var(--accent); color:#fff; }
.btn-accent:hover{ background:var(--accent-dark); color:#fff; }
.btn-lg{ padding:1.05em 2em; font-size:1.08rem; }
.btn-block{ width:100%; }

/* ---------- Eyebrow / section heading ---------- */
.eyebrow{
  display:inline-flex; align-items:center; gap:.5em;
  font-family:var(--font-display); font-weight:700; font-size:.8rem;
  letter-spacing:.14em; text-transform:uppercase; color:var(--brand-dark);
  margin-bottom:.7em;
}
.eyebrow::before{ content:""; width:26px; height:2px; background:var(--brand); border-radius:2px; }
.section{ padding:clamp(56px,8vw,104px) 0; }
.section-head{ max-width:720px; margin:0 auto clamp(36px,5vw,56px); text-align:center; }
.section-head.left{ margin-inline:0; text-align:left; }
.section-head p{ color:var(--muted); font-size:1.1rem; margin-bottom:0; }
.text-center{ text-align:center; }

/* ---------- Header ---------- */
.site-header{
  position:sticky; top:0; z-index:90; background:rgba(255,255,255,.92);
  backdrop-filter:saturate(140%) blur(12px); border-bottom:1px solid var(--line);
}
.topbar{ background:var(--ink); color:#cfe0ee; font-size:.85rem; }
.topbar .container{ display:flex; gap:18px; align-items:center; justify-content:space-between; min-height:40px; flex-wrap:wrap; }
.topbar a{ color:#fff; font-weight:600; }
.topbar .tb-left{ display:flex; gap:20px; flex-wrap:wrap; align-items:center; }
.topbar .tb-badge{ display:inline-flex; align-items:center; gap:.45em; }
.topbar .tb-badge svg{ width:15px; height:15px; }
.header-main .container{ display:flex; align-items:center; justify-content:space-between; gap:18px; min-height:74px; }
.brand{ display:flex; align-items:center; gap:11px; font-family:var(--font-display); font-weight:800; font-size:1.4rem; color:var(--ink); letter-spacing:-.03em; }
.brand:hover{ text-decoration:none; }
.brand .logo-mark{ width:42px; height:42px; flex:none; }
.brand span b{ color:var(--brand); }
.brand .tag{ display:block; font-family:var(--font-body); font-weight:500; font-size:.62rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); margin-top:2px; }

.primary-nav{ display:flex; align-items:center; gap:4px; }
.primary-nav ul{ display:flex; gap:2px; list-style:none; margin:0; padding:0; align-items:center; }
.primary-nav a{ display:block; padding:.6em .85em; color:var(--ink); font-weight:600; font-size:.97rem; border-radius:8px; }
.primary-nav a:hover{ background:var(--surface-2); text-decoration:none; color:var(--brand-dark); }
.primary-nav .menu-item-has-children{ position:relative; }
.primary-nav .menu-item-has-children > a{ display:flex; align-items:center; gap:.35em; }
.primary-nav .menu-item-has-children > a::after{
  content:""; width:6px; height:6px; flex:none; margin-left:.1em; opacity:.55;
  border-right:2px solid currentColor; border-bottom:2px solid currentColor; transform:rotate(45deg) translateY(-1px);
}
.primary-nav .sub-menu{
  position:absolute; top:calc(100% + 6px); left:0; min-width:262px; background:#fff;
  border:1px solid var(--line); border-radius:14px; box-shadow:var(--shadow-lg);
  padding:8px; flex-direction:column; gap:1px; opacity:0; visibility:hidden;
  transform:translateY(8px); transition:opacity .16s ease, transform .16s ease; z-index:50;
}
/* invisible bridge so the cursor can cross the gap without closing the menu */
.primary-nav .sub-menu::before{ content:""; position:absolute; top:-8px; left:0; right:0; height:8px; }
.primary-nav .menu-item-has-children:hover > .sub-menu{ opacity:1; visibility:visible; transform:translateY(0); }
.primary-nav .sub-menu li{ position:relative; }
.primary-nav .sub-menu a{ font-size:.92rem; font-weight:500; padding:.55em .7em; border-radius:8px; white-space:nowrap; }
.primary-nav .sub-menu a:hover{ background:var(--brand-soft); color:var(--brand-dark); }
/* nested fly-out (sub-services) */
.primary-nav .sub-menu .menu-item-has-children > a::after{ transform:rotate(-45deg); margin-left:auto; }
.primary-nav .sub-menu .sub-menu{ top:-9px; left:calc(100% + 4px); }
.primary-nav .sub-menu .sub-menu::before{ top:0; left:-8px; right:auto; width:8px; height:100%; }
.header-cta{ display:flex; align-items:center; gap:10px; }
.nav-toggle{ display:none; background:none; border:0; cursor:pointer; padding:8px; }
.nav-toggle svg{ width:28px; height:28px; color:var(--ink); }

/* ---------- Hero ---------- */
.hero{ position:relative; background:linear-gradient(160deg,#082038 0%,#0A2540 45%,#103a63 100%); color:#fff; overflow:hidden; }
.hero::after{ /* diagonal speed cut — the signature */
  content:""; position:absolute; right:-8%; bottom:-30%; width:60%; height:160%;
  background:linear-gradient(135deg,rgba(255,107,26,.22),rgba(15,181,168,.12));
  transform:rotate(12deg); filter:blur(8px); pointer-events:none;
}
.hero-grid-bg{ position:absolute; inset:0; opacity:.5;
  background-image:radial-gradient(rgba(255,255,255,.08) 1px,transparent 1px);
  background-size:26px 26px; mask-image:linear-gradient(to bottom,#000,transparent 80%); }
.hero .container{ position:relative; z-index:2; display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:center; padding-top:clamp(48px,6vw,86px); padding-bottom:clamp(56px,7vw,96px); }
.hero h1{ color:#fff; }
.hero h1 .hl{ color:var(--brand); }
.hero .lead{ font-size:1.18rem; color:#cdddec; max-width:540px; }
.hero .eyebrow{ color:#ffd9bf; }
.hero .eyebrow::before{ background:var(--brand); }
.hero-cta{ display:flex; gap:14px; flex-wrap:wrap; margin-top:8px; }
.hero-trust{ display:flex; gap:26px; margin-top:30px; flex-wrap:wrap; }
.hero-trust .ht{ }
.hero-trust .num{ font-family:var(--font-display); font-weight:800; font-size:1.7rem; color:#fff; }
.hero-trust .lbl{ font-size:.84rem; color:#9fb6cb; }

/* hero card stack */
.hero-card{ background:#fff; color:var(--text); border-radius:var(--radius-lg); padding:26px; box-shadow:var(--shadow-lg); }
.hero-card h3{ margin-bottom:6px; }
.hero-card .muted{ color:var(--muted); font-size:.95rem; margin-bottom:18px; }
.hero-card .mini-list{ list-style:none; padding:0; margin:0 0 20px; display:grid; gap:12px; }
.hero-card .mini-list li{ display:flex; align-items:center; gap:12px; font-weight:600; font-size:.97rem; }
.hero-card .mini-list .ic{ width:38px; height:38px; border-radius:10px; flex:none; display:grid; place-items:center; background:var(--brand-soft); color:var(--brand-dark); }
.hero-card .mini-list .ic svg{ width:20px; height:20px; }
.hero-card .accent-strip{ display:flex; align-items:center; gap:10px; background:var(--surface-2); border:1px solid var(--line); border-radius:12px; padding:12px 14px; font-size:.9rem; color:var(--muted); }
.hero-card .accent-strip svg{ width:20px; height:20px; flex:none; color:var(--brand); }

/* ---------- Trust bar ---------- */
.trustbar{ background:var(--ink-2); color:#fff; }
.trustbar .container{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; padding-block:30px; }
.trustbar .tb{ display:flex; gap:14px; align-items:flex-start; }
.trustbar .tb .ic{ width:44px; height:44px; flex:none; display:grid; place-items:center; border-radius:12px; background:rgba(255,255,255,.08); color:var(--brand); }
.trustbar .tb .ic svg{ width:24px; height:24px; }
.trustbar .tb h4{ color:#fff; margin:0 0 2px; font-size:1.02rem; }
.trustbar .tb p{ margin:0; color:#a9c0d4; font-size:.88rem; }

/* ---------- Service grid ---------- */
.svc-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:22px; }
.svc-card{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--radius);
  padding:26px; transition:transform .18s ease, box-shadow .2s ease, border-color .2s ease;
  position:relative; overflow:hidden; display:flex; flex-direction:column;
}
.svc-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow); border-color:transparent; }
.svc-card::before{ content:""; position:absolute; inset:0 0 auto 0; height:4px; background:linear-gradient(90deg,var(--brand),var(--accent)); transform:scaleX(0); transform-origin:left; transition:transform .25s ease; }
.svc-card:hover::before{ transform:scaleX(1); }
.svc-ic{ width:58px; height:58px; border-radius:14px; display:grid; place-items:center; background:var(--brand-soft); color:var(--brand-dark); margin-bottom:16px; }
.svc-ic svg{ width:30px; height:30px; }
.svc-card h3{ font-size:1.22rem; margin-bottom:8px; }
.svc-card p{ color:var(--muted); font-size:.96rem; margin-bottom:16px; flex:1; }
.svc-card .svc-sub{ list-style:none; padding:0; margin:0 0 16px; display:flex; flex-wrap:wrap; gap:6px; }
.svc-card .svc-sub li{ font-size:.78rem; background:var(--surface-2); border:1px solid var(--line); color:var(--muted); padding:3px 9px; border-radius:999px; }
.svc-card .more{ font-family:var(--font-display); font-weight:700; color:var(--brand-dark); font-size:.95rem; display:inline-flex; align-items:center; gap:.4em; margin-top:auto; }
.svc-card .more svg{ width:16px; height:16px; transition:transform .2s; }
.svc-card:hover .more svg{ transform:translateX(4px); }

/* ---------- Process / steps ---------- */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; counter-reset:step; }
.step{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:28px 24px; position:relative; }
.step .n{ font-family:var(--font-display); font-weight:800; font-size:2.4rem; color:var(--brand); opacity:.25; line-height:1; }
.step h4{ margin:10px 0 6px; font-size:1.12rem; }
.step p{ color:var(--muted); font-size:.93rem; margin:0; }

/* ---------- CTA band ---------- */
.cta-band{ background:linear-gradient(120deg,var(--brand) 0%,#ff8a45 100%); color:#fff; border-radius:var(--radius-lg); padding:clamp(34px,5vw,56px); text-align:center; position:relative; overflow:hidden; }
.cta-band::after{ content:""; position:absolute; inset:0; background:radial-gradient(circle at 80% 20%,rgba(255,255,255,.25),transparent 50%); }
.cta-band > *{ position:relative; z-index:1; }
.cta-band h2{ color:#fff; }
.cta-band p{ color:#fff; opacity:.95; max-width:560px; margin:0 auto 24px; font-size:1.12rem; }
.cta-band .btn-light{ color:var(--brand-dark); }

/* ---------- Areas / coverage ---------- */
.area-chips{ display:flex; flex-wrap:wrap; gap:10px; justify-content:center; }
.area-chips span{ display:inline-flex; align-items:center; gap:.45em; background:var(--surface); border:1px solid var(--line); border-radius:999px; padding:8px 16px; font-weight:600; font-size:.92rem; color:var(--ink); }
.area-chips span svg{ width:16px; height:16px; flex:none; color:var(--brand); }

/* ---------- Reviews ---------- */
.reviews{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.review{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:26px; }
.review .stars{ color:#FFB020; letter-spacing:2px; margin-bottom:10px; font-size:1.05rem; }
.review p{ font-size:.98rem; }
.review .who{ display:flex; align-items:center; gap:12px; margin-top:14px; }
.review .who .av{ width:42px; height:42px; border-radius:50%; background:var(--ink-2); color:#fff; display:grid; place-items:center; font-family:var(--font-display); font-weight:700; }
.review .who b{ display:block; font-size:.95rem; color:var(--ink); }
.review .who small{ color:var(--muted); }

/* ---------- FAQ ---------- */
.faq{ max-width:820px; margin:0 auto; }
.faq details{ background:var(--surface); border:1px solid var(--line); border-radius:14px; padding:6px 22px; margin-bottom:12px; }
.faq summary{ font-family:var(--font-display); font-weight:700; color:var(--ink); cursor:pointer; padding:16px 0; list-style:none; display:flex; justify-content:space-between; align-items:center; gap:12px; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:"+"; font-size:1.5rem; color:var(--brand); font-weight:400; transition:transform .2s; }
.faq details[open] summary::after{ transform:rotate(45deg); }
.faq details p{ color:var(--muted); padding-bottom:18px; margin:0; }

/* ---------- Page header (interior) ---------- */
.page-hero{ background:linear-gradient(160deg,#0A2540,#103a63); color:#fff; padding:clamp(46px,6vw,80px) 0 clamp(40px,5vw,64px); position:relative; overflow:hidden; }
.page-hero::after{ content:""; position:absolute; right:-6%; bottom:-40%; width:50%; height:180%; background:linear-gradient(135deg,rgba(255,107,26,.18),transparent); transform:rotate(12deg); }
.page-hero .container{ position:relative; z-index:1; }
.page-hero h1{ color:#fff; }
.page-hero p{ color:#cdddec; font-size:1.12rem; max-width:640px; margin-bottom:0; }
.breadcrumbs{ font-size:.85rem; color:#9fb6cb; margin-bottom:14px; }
.breadcrumbs a{ color:#cdddec; } .breadcrumbs a:hover{ color:#fff; }
.breadcrumbs .sep{ margin:0 8px; opacity:.5; }

/* ---------- Content / single ---------- */
.content-wrap{ display:grid; grid-template-columns:1fr 320px; gap:48px; align-items:start; }
.content-main{ min-width:0; }
.card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:22px; }
.entry-content{ font-size:1.05rem; }
.entry-content h2{ margin-top:1.4em; }
.entry-content h3{ margin-top:1.2em; }
.entry-content img{ border-radius:var(--radius); margin:1.4em 0; }
.entry-content ul li,.entry-content ol li{ margin-bottom:.4em; }
.entry-content blockquote{ border-left:4px solid var(--brand); margin:1.4em 0; padding:.4em 0 .4em 1.2em; color:var(--muted); font-style:italic; }
.entry-content .wp-block-table table,.entry-content table{ width:100%; border-collapse:collapse; }
.entry-content table th,.entry-content table td{ border:1px solid var(--line); padding:10px 12px; text-align:left; }
.entry-content table th{ background:var(--surface-2); }

.svc-feature-list{ list-style:none; padding:0; margin:1.2em 0; display:grid; grid-template-columns:repeat(2,1fr); gap:12px; }
.svc-feature-list li{ display:flex; gap:10px; align-items:flex-start; background:var(--surface); border:1px solid var(--line); border-radius:12px; padding:12px 14px; font-size:.95rem; }
.svc-feature-list li::before{ content:"✓"; color:#fff; background:var(--accent); width:22px; height:22px; border-radius:50%; display:grid; place-items:center; font-size:.8rem; flex:none; margin-top:1px; }

/* sidebar */
.sidebar > *{ margin-bottom:24px; }
.widget{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:22px; }
.widget-title,.widget h3{ font-size:1.1rem; margin-bottom:14px; }
.sidebar ul{ list-style:none; padding:0; margin:0; }
.sidebar li{ padding:7px 0; border-bottom:1px solid var(--line); }
.sidebar li:last-child{ border-bottom:0; }
.sidebar a{ color:var(--ink); font-weight:500; }
.book-widget{ background:linear-gradient(160deg,var(--ink),var(--ink-2)); color:#fff; text-align:center; }
.book-widget h3{ color:#fff; }
.book-widget p{ color:#bcd2e5; font-size:.92rem; }

/* sub-service quick links */
.subsvc-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(230px,1fr)); gap:14px; margin:1.4em 0; }
.subsvc-grid a{ display:flex; align-items:center; gap:12px; background:var(--surface); border:1px solid var(--line); border-radius:12px; padding:14px 16px; color:var(--ink); font-weight:600; font-size:.95rem; transition:.15s; }
.subsvc-grid a:hover{ border-color:var(--brand); text-decoration:none; transform:translateX(3px); }
.subsvc-grid a .ic{ width:34px; height:34px; border-radius:9px; background:var(--brand-soft); color:var(--brand-dark); display:grid; place-items:center; flex:none; }
.subsvc-grid a .ic svg{ width:18px; height:18px; }

/* ---------- Blog cards ---------- */
.post-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(320px,1fr)); gap:26px; }
.post-card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; transition:.18s; display:flex; flex-direction:column; }
.post-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.post-card .thumb{ aspect-ratio:16/9; background:linear-gradient(135deg,var(--ink-2),var(--accent)); overflow:hidden; }
.post-card .thumb img{ width:100%; height:100%; object-fit:cover; }
.post-card .pc-body{ padding:22px; display:flex; flex-direction:column; flex:1; }
.post-card .pc-meta{ font-size:.82rem; color:var(--muted); margin-bottom:8px; }
.post-card h3{ font-size:1.18rem; margin-bottom:8px; }
.post-card h3 a{ color:var(--ink); }
.post-card p{ color:var(--muted); font-size:.94rem; flex:1; }

/* ---------- Footer ---------- */
.site-footer{ background:var(--ink); color:#bcd2e5; padding:clamp(48px,6vw,76px) 0 0; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:36px; }
.site-footer h4{ color:#fff; font-size:1.05rem; margin-bottom:16px; }
.site-footer a{ color:#bcd2e5; }
.site-footer a:hover{ color:#fff; }
.site-footer ul{ list-style:none; padding:0; margin:0; }
.site-footer li{ margin-bottom:9px; font-size:.94rem; }
.footer-brand .brand{ color:#fff; margin-bottom:14px; }
.footer-brand .brand span{ color:#fff; }
.footer-brand p{ font-size:.94rem; color:#9fb6cb; max-width:320px; }
.footer-contact .fc{ display:flex; gap:12px; align-items:flex-start; margin-bottom:14px; font-size:.95rem; }
.footer-contact .fc .ic{ width:38px; height:38px; flex:none; border-radius:10px; background:rgba(255,255,255,.08); color:var(--brand); display:grid; place-items:center; }
.footer-contact .fc .ic svg{ width:19px; height:19px; }
.footer-contact .fc b{ color:#fff; display:block; }
.footer-247{ display:inline-flex; align-items:center; gap:.5em; background:rgba(15,181,168,.15); color:#5fe0d4; border:1px solid rgba(15,181,168,.3); padding:7px 14px; border-radius:999px; font-weight:700; font-size:.85rem; margin-top:6px; }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.1); margin-top:44px; padding:22px 0; font-size:.86rem; color:#80a0bb; }
.footer-bottom .container{ display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; }

/* ---------- Floating action buttons ---------- */
.fab-stack{ position:fixed; right:18px; bottom:18px; z-index:80; display:flex; flex-direction:column; gap:12px; }
.fab{ width:56px; height:56px; border-radius:50%; display:grid; place-items:center; box-shadow:var(--shadow-lg); color:#fff; cursor:pointer; border:0; transition:transform .15s; }
.fab:hover{ transform:scale(1.08); }
.fab svg{ width:28px; height:28px; }
.fab-whatsapp{ background:#25D366; }
.fab-call{ background:var(--ink-2); }
.fab-book{ background:var(--brand); width:auto; border-radius:999px; padding:0 22px; gap:.5em; font-family:var(--font-display); font-weight:700; }
.fab-book svg{ width:20px; height:20px; }

/* ---------- Utility ---------- */
.bg-surface{ background:var(--surface); }
.bg-soft{ background:var(--surface-2); }
.muted{ color:var(--muted); }
.mt-0{ margin-top:0; } .mb-0{ margin-bottom:0; }
.skip-link{ position:absolute; left:-9999px; }
.skip-link:focus{ left:8px; top:8px; background:#fff; padding:10px 16px; border-radius:8px; z-index:999; }

/* accessibility focus */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,summary:focus-visible{
  outline:3px solid var(--brand); outline-offset:2px; border-radius:4px;
}

/* ---------- Pagination ---------- */
.pagination{ margin-top:42px; }
.pagination .nav-links{ display:flex; flex-wrap:wrap; gap:8px; justify-content:center; }
.pagination .page-numbers{ display:inline-grid; place-items:center; min-width:44px; height:44px; padding:0 12px; border:1px solid var(--line); border-radius:10px; color:var(--ink); font-weight:600; background:var(--surface); }
.pagination .page-numbers:hover{ border-color:var(--brand); text-decoration:none; }
.pagination .page-numbers.current{ background:var(--brand); color:#fff; border-color:var(--brand); }
.pagination .page-numbers.dots{ border:0; background:transparent; }

/* ---------- Search form ---------- */
.search-form{ display:flex; gap:10px; }
.search-form label{ flex:1; }
.search-field{ width:100%; padding:.85em 1.1em; border:1px solid var(--line-2); border-radius:12px; font:inherit; background:var(--surface); }
.search-submit{ padding:.85em 1.5em; border:0; border-radius:12px; background:var(--brand); color:#fff; font-weight:700; cursor:pointer; }
.search-submit:hover{ background:var(--brand-dark); }

/* ---------- Comments ---------- */
.comments-area{ margin-top:48px; padding-top:32px; border-top:1px solid var(--line); }
.comments-area .comment-list{ list-style:none; padding:0; margin:0 0 32px; }
.comments-area .comment-list li{ padding:18px 0; border-bottom:1px solid var(--line); }
.comments-area .comment-meta{ font-size:.85rem; color:var(--muted); margin-bottom:6px; }
.comment-form input[type=text],.comment-form input[type=email],.comment-form input[type=url],.comment-form textarea{
  width:100%; padding:.85em 1.1em; border:1px solid var(--line-2); border-radius:12px; font:inherit; margin-bottom:14px; background:var(--surface);
}
.comment-form .submit{ padding:.85em 1.8em; border:0; border-radius:999px; background:var(--brand); color:#fff; font-weight:700; cursor:pointer; }

/* ---------- Contact ---------- */
.contact-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:20px; margin:0 0 40px; }
.contact-card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:26px; text-align:center; }
.contact-card .ic{ width:54px; height:54px; border-radius:14px; display:grid; place-items:center; background:var(--brand-soft); color:var(--brand-dark); margin:0 auto 14px; }
.contact-card h3{ font-size:1.1rem; margin-bottom:6px; }
.contact-card a{ font-weight:600; }
.map-embed{ border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); aspect-ratio:16/7; background:var(--surface-2); }
.map-embed iframe{ width:100%; height:100%; border:0; display:block; }

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .hero .container{ grid-template-columns:1fr; }
  .hero-card{ order:-1; }
  .trustbar .container{ grid-template-columns:repeat(2,1fr); }
  .steps{ grid-template-columns:repeat(2,1fr); }
  .reviews{ grid-template-columns:1fr; }
  .content-wrap{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:860px){
  .nav-toggle{ display:block; }
  .primary-nav{ position:fixed; inset:0 0 0 auto; width:min(86vw,340px); background:#fff; flex-direction:column; align-items:stretch; padding:80px 18px 24px; box-shadow:var(--shadow-lg); transform:translateX(100%); transition:transform .25s ease; overflow-y:auto; }
  .primary-nav.open{ transform:translateX(0); }
  .primary-nav ul{ flex-direction:column; align-items:stretch; gap:2px; width:100%; }
  .primary-nav .sub-menu{ position:static; opacity:1; visibility:visible; transform:none; box-shadow:none; border:0; border-left:2px solid var(--line); border-radius:0; padding-left:12px; display:none; }
  .primary-nav .menu-item-has-children.open > .sub-menu{ display:flex; }
  .primary-nav .menu-item-has-children > a::after{ margin-left:auto; }
  .primary-nav .sub-menu::before,.primary-nav .sub-menu .sub-menu::before{ display:none; }
  .primary-nav .sub-menu .sub-menu{ position:static; left:auto; top:auto; }
  .primary-nav a{ text-align:left; }
  .nav-book{ display:block; margin-top:16px; }
  .header-cta{ display:none; }
  .nav-open-backdrop{ position:fixed; inset:0; background:rgba(10,37,64,.45); z-index:89; }
}
@media (max-width:560px){
  body{ font-size:16px; }
  .trustbar .container,.steps,.svc-feature-list{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr; }
  .topbar .tb-left{ font-size:.78rem; gap:14px; }
  .fab-book span{ display:none; }
  .fab-book{ width:56px; padding:0; border-radius:50%; }
}

@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; scroll-behavior:auto !important; }
}
