/*
Theme Name: AZ Cloud Solutions
Theme URI: https://azcloudsolutions.com.au
Author: AZ Cloud Solutions
Description: Custom multi-page theme for AZ Cloud Solutions - managed Microsoft IT. Pages are auto-created on activation.
Version: 1.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: azcloudsolutions
*/

/* ===================================================================
   azcloudsolutions — shared design system
   Used by index.html, about.html, faq.html
   =================================================================== */
:root{
  --ink:#080D19;
  --ink-2:#0B1322;
  --panel:#111B2E;
  --panel-2:#0E1727;
  --line:rgba(150,172,214,.12);
  --line-strong:rgba(150,172,214,.24);
  --blue:#3E78FF;
  --blue-soft:#7AA1FF;
  --signal:#2DD58A;
  --signal-dim:rgba(45,213,138,.14);
  --paper:#EFF3FB;
  --text:#E8EDF8;
  --muted:#94A3C0;
  --muted-2:#6E7C99;
  --radius:16px;
  --radius-sm:11px;
  --maxw:1180px;
  --pad:clamp(20px,5vw,40px);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter',system-ui,sans-serif;
  background:var(--ink);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:'Space Grotesk',sans-serif;font-weight:600;line-height:1.08;letter-spacing:-.02em}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.mono{font-family:'JetBrains Mono',monospace}

.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad)}
.section{padding-block:clamp(70px,9vw,120px)}
.eyebrow{
  font-family:'JetBrains Mono',monospace;font-size:.72rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--blue-soft);display:inline-flex;align-items:center;gap:9px;
}
.eyebrow::before{content:"";width:22px;height:1px;background:var(--blue);display:inline-block}
.lead{color:var(--muted);font-size:1.06rem;max-width:60ch}

.btn{
  display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:.95rem;
  padding:13px 22px;border-radius:999px;cursor:pointer;border:1px solid transparent;
  transition:transform .18s ease,background .2s ease,border-color .2s ease,box-shadow .2s ease;
  font-family:'Space Grotesk',sans-serif;
}
.btn-primary{background:var(--blue);color:#fff;box-shadow:0 10px 30px -12px rgba(62,120,255,.7)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 36px -12px rgba(62,120,255,.85)}
.btn-ghost{background:rgba(255,255,255,.03);color:var(--text);border-color:var(--line-strong)}
.btn-ghost:hover{border-color:var(--blue-soft);background:rgba(62,120,255,.08);transform:translateY(-2px)}
.btn svg{width:16px;height:16px}

:focus-visible{outline:2px solid var(--blue-soft);outline-offset:3px;border-radius:6px}

/* ============ HEADER ============ */
header{
  position:sticky;top:0;z-index:50;
  background:rgba(8,13,25,.72);backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;transition:border-color .3s ease,background .3s ease;
}
header.scrolled{border-bottom-color:var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:11px;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:1.12rem;letter-spacing:-.01em}
.brand .b1{color:var(--blue-soft)}
.logo{width:34px;height:34px;border-radius:10px;flex:none;position:relative;display:grid;place-items:center;overflow:hidden;background:linear-gradient(135deg,#5C8CFF,#2456d6);box-shadow:0 6px 18px -6px rgba(62,120,255,.7)}
.logo svg{width:34px;height:34px;display:block}
.nav-links{display:flex;align-items:center;gap:30px;list-style:none}
.nav-links a{font-size:.92rem;color:var(--muted);transition:color .2s ease;position:relative}
.nav-links a:hover,.nav-links a[aria-current="page"]{color:var(--text)}
.nav-links a[aria-current="page"]::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--blue);border-radius:2px}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-phone{font-size:.9rem;color:var(--muted);font-family:'JetBrains Mono',monospace}
.nav-phone:hover{color:var(--text)}
.menu-btn{display:none;background:none;border:1px solid var(--line-strong);border-radius:9px;width:42px;height:42px;color:var(--text);cursor:pointer}

/* ============ HERO (home) ============ */
.hero{position:relative;padding-top:clamp(48px,7vw,86px);padding-bottom:clamp(60px,8vw,104px);overflow:hidden}
.hero-bg{
  position:absolute;inset:0;z-index:0;
  background-image:
    radial-gradient(120% 90% at 78% -10%,rgba(62,120,255,.22),transparent 55%),
    linear-gradient(180deg,rgba(8,13,25,.72),rgba(8,13,25,.94) 60%,var(--ink)),
    url("https://images.unsplash.com/photo-1558494949-ef010cbdcc31?auto=format&fit=crop&w=1700&q=80");
  background-size:cover;background-position:center;
}
.hero-bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,var(--ink) 8%,transparent 55%);}
.grid-lines{position:absolute;inset:0;z-index:0;opacity:.5;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:64px 64px;mask-image:radial-gradient(circle at 70% 30%,#000,transparent 70%)}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,5vw,72px);align-items:center}
.hero h1{font-size:clamp(2.3rem,5.4vw,4rem);margin:22px 0 0}
.hero h1 .hl{color:var(--blue-soft)}
.hero .lead{margin-top:22px;font-size:clamp(1rem,1.3vw,1.14rem)}
.hero-actions{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap}
.trust-row{display:flex;align-items:center;gap:22px;margin-top:38px;flex-wrap:wrap;color:var(--muted-2);font-size:.82rem}
.trust-row .ms{display:flex;align-items:center;gap:9px;color:var(--muted)}
.ms-tiles{width:18px;height:18px;display:grid;grid-template-columns:1fr 1fr;gap:2px}
.ms-tiles i{display:block;border-radius:1px}
.ms-tiles i:nth-child(1){background:#F25022}.ms-tiles i:nth-child(2){background:#7FBA00}
.ms-tiles i:nth-child(3){background:#00A4EF}.ms-tiles i:nth-child(4){background:#FFB900}

/* ops console */
.console{
  position:relative;border:1px solid var(--line-strong);border-radius:var(--radius);
  background:linear-gradient(180deg,rgba(17,27,46,.92),rgba(11,19,34,.92));
  box-shadow:0 40px 80px -40px rgba(0,0,0,.8),inset 0 1px 0 rgba(255,255,255,.04);
  overflow:hidden;
}
.console-top{display:flex;align-items:center;gap:12px;padding:14px 18px;border-bottom:1px solid var(--line)}
.dots{display:flex;gap:6px}.dots i{width:10px;height:10px;border-radius:50%;background:#2a3958;display:block}
.console-title{font-family:'JetBrains Mono',monospace;font-size:.74rem;color:var(--muted);letter-spacing:.05em}
.console-status{margin-left:auto;display:flex;align-items:center;gap:8px;font-family:'JetBrains Mono',monospace;font-size:.72rem;color:var(--signal)}
.pulse{width:9px;height:9px;border-radius:50%;background:var(--signal);box-shadow:0 0 0 0 rgba(45,213,138,.6);animation:pulse 2.2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(45,213,138,.55)}70%{box-shadow:0 0 0 10px rgba(45,213,138,0)}100%{box-shadow:0 0 0 0 rgba(45,213,138,0)}}
.console-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line)}
.metric{background:var(--panel-2);padding:20px 18px}
.metric .k{font-family:'JetBrains Mono',monospace;font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2)}
.metric .v{font-family:'Space Grotesk',sans-serif;font-size:1.85rem;font-weight:600;margin-top:7px;letter-spacing:-.02em}
.metric .v.green{color:var(--signal)}
.metric .sub{font-size:.74rem;color:var(--muted);margin-top:3px}
.spark{display:flex;align-items:flex-end;gap:3px;height:26px;margin-top:10px}
.spark i{flex:1;background:linear-gradient(180deg,var(--blue),rgba(62,120,255,.25));border-radius:2px;display:block;animation:rise .9s ease both}
@keyframes rise{from{transform:scaleY(.15);opacity:0}to{transform:scaleY(1);opacity:1}}
.console-foot{padding:13px 18px;border-top:1px solid var(--line);display:flex;align-items:center;gap:10px;font-family:'JetBrains Mono',monospace;font-size:.72rem;color:var(--muted)}
.tick{color:var(--signal)}

/* ============ PAGE HERO (inner pages) ============ */
.page-hero{position:relative;padding-block:clamp(64px,9vw,108px) clamp(36px,5vw,60px);overflow:hidden;border-bottom:1px solid var(--line)}
.page-hero-bg{position:absolute;inset:0;z-index:0;
  background:radial-gradient(85% 120% at 82% -20%,rgba(62,120,255,.20),transparent 55%),linear-gradient(180deg,var(--ink-2),var(--ink))}
.page-hero .wrap{position:relative;z-index:2;max-width:820px}
.page-hero h1{font-size:clamp(2.1rem,5vw,3.5rem);margin:18px 0 16px}
.page-hero .lead{font-size:clamp(1.02rem,1.4vw,1.18rem)}
.crumb{font-family:'JetBrains Mono',monospace;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2)}
.crumb a:hover{color:var(--text)}
.crumb span{color:var(--blue-soft)}

/* ============ STACK STRIP ============ */
.stack{border-block:1px solid var(--line);background:var(--ink-2)}
.stack .wrap{display:flex;align-items:center;gap:clamp(18px,4vw,44px);flex-wrap:wrap;justify-content:center;padding-block:30px}
.stack-label{font-family:'JetBrains Mono',monospace;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2)}
.pill{
  display:inline-flex;align-items:center;gap:8px;font-size:.86rem;color:var(--muted);
  border:1px solid var(--line);padding:8px 14px;border-radius:999px;background:rgba(255,255,255,.02);
  transition:border-color .2s,color .2s;
}
.pill:hover{border-color:var(--blue-soft);color:var(--text)}
.pill .d{width:7px;height:7px;border-radius:50%;background:var(--blue)}

/* ============ SECTION HEAD ============ */
.shead{max-width:680px;margin-bottom:48px}
.shead.center{margin-inline:auto;text-align:center}
.shead h2{font-size:clamp(1.8rem,3.6vw,2.7rem);margin:16px 0 14px}

/* ============ SERVICES / CARD GRID ============ */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card{
  border:1px solid var(--line);border-radius:var(--radius);padding:28px 26px;
  background:linear-gradient(180deg,var(--panel),var(--panel-2));
  position:relative;transition:transform .25s ease,border-color .25s ease;overflow:hidden;
}
.card::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 50% -20%,rgba(62,120,255,.16),transparent 60%);opacity:0;transition:opacity .3s}
.card:hover{transform:translateY(-5px);border-color:var(--line-strong)}
.card:hover::after{opacity:1}
.ic{
  width:48px;height:48px;border-radius:12px;display:grid;place-items:center;margin-bottom:20px;
  background:rgba(62,120,255,.12);border:1px solid rgba(62,120,255,.28);color:var(--blue-soft);
}
.ic svg{width:24px;height:24px}
.card h3{font-size:1.18rem;margin-bottom:9px}
.card p{color:var(--muted);font-size:.94rem}
.card .more{display:inline-flex;align-items:center;gap:7px;margin-top:16px;font-size:.84rem;color:var(--blue-soft);font-family:'JetBrains Mono',monospace}

/* ============ SPLIT (image + content) ============ */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,64px);align-items:center}
.split.rev .split-media{order:2}
.split-media{
  border-radius:var(--radius);overflow:hidden;border:1px solid var(--line-strong);position:relative;
  min-height:380px;background-size:cover;background-position:center;
}
.media-servers{background-image:linear-gradient(150deg,rgba(8,13,25,.35),rgba(62,120,255,.18)),url("https://images.unsplash.com/photo-1521737711867-ee1b5a2dbd4f?auto=format&fit=crop&w=1100&q=80")}
.media-office{background-image:linear-gradient(150deg,rgba(8,13,25,.4),rgba(62,120,255,.16)),url("https://images.unsplash.com/photo-1497366754035-f200968a6e72?auto=format&fit=crop&w=1100&q=80")}
.media-cloud{background-image:linear-gradient(150deg,rgba(8,13,25,.4),rgba(62,120,255,.2)),url("https://images.unsplash.com/photo-1451187580459-43490279c0fa?auto=format&fit=crop&w=1100&q=80")}
.split-media .badge{
  position:absolute;left:18px;bottom:18px;right:18px;
  background:rgba(8,13,25,.82);backdrop-filter:blur(8px);border:1px solid var(--line-strong);
  border-radius:var(--radius-sm);padding:16px 18px;display:flex;align-items:center;gap:14px;
}
.split-media .badge .v{font-family:'Space Grotesk';font-size:1.5rem;font-weight:600}
.split-media .badge .t{font-size:.8rem;color:var(--muted)}
.split-media .badge .bar{width:1px;height:34px;background:var(--line-strong)}
.feats{list-style:none;margin-top:26px;display:grid;gap:16px}
.feats li{display:flex;gap:14px;align-items:flex-start}
.feats .ck{flex:none;width:26px;height:26px;border-radius:8px;background:var(--signal-dim);color:var(--signal);display:grid;place-items:center;margin-top:2px}
.feats .ck svg{width:15px;height:15px}
.feats h4{font-size:1rem;margin-bottom:3px}
.feats p{color:var(--muted);font-size:.9rem}

/* ============ PROSE ============ */
.prose{max-width:680px}
.prose p{color:var(--muted);margin-bottom:18px;font-size:1.04rem}
.prose p strong{color:var(--text);font-weight:600}
.prose p:last-child{margin-bottom:0}

/* ============ VALUES ============ */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.value{border:1px solid var(--line);border-radius:var(--radius);padding:28px 26px;background:var(--panel-2)}
.value .ic{margin-bottom:18px}
.value h3{font-size:1.1rem;margin-bottom:8px}
.value p{color:var(--muted);font-size:.93rem}

/* ============ TIMELINE (company story — real sequence) ============ */
.timeline{position:relative;margin-top:10px;padding-left:30px}
.timeline::before{content:"";position:absolute;left:7px;top:6px;bottom:6px;width:2px;background:linear-gradient(180deg,var(--blue),var(--line))}
.tl{position:relative;padding-bottom:34px}
.tl:last-child{padding-bottom:0}
.tl::before{content:"";position:absolute;left:-30px;top:4px;width:16px;height:16px;border-radius:50%;background:var(--ink);border:2px solid var(--blue);box-shadow:0 0 0 4px rgba(62,120,255,.12)}
.tl .yr{font-family:'JetBrains Mono',monospace;font-size:.78rem;letter-spacing:.06em;color:var(--blue-soft)}
.tl h4{font-size:1.08rem;margin:6px 0 6px}
.tl p{color:var(--muted);font-size:.94rem;max-width:52ch}

/* ============ TEAM ============ */
.team{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.member{border:1px solid var(--line);border-radius:var(--radius);padding:26px 22px;background:var(--panel-2);text-align:center}
.member .av-lg{width:64px;height:64px;border-radius:50%;margin:0 auto 16px;display:grid;place-items:center;font-family:'Space Grotesk';font-weight:600;font-size:1.2rem;color:#fff;background:linear-gradient(135deg,var(--blue),#2456d6)}
.member h4{font-size:1.04rem}
.member .role{color:var(--blue-soft);font-size:.82rem;font-family:'JetBrains Mono',monospace;margin:4px 0 10px}
.member p{color:var(--muted);font-size:.88rem}

/* ============ STATS BAND ============ */
.band{border-block:1px solid var(--line);background:
  radial-gradient(80% 140% at 50% 0%,rgba(62,120,255,.1),transparent 60%),var(--ink-2)}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.stat .v{font-family:'Space Grotesk';font-size:clamp(2.1rem,4vw,3rem);font-weight:600;letter-spacing:-.03em}
.stat .v .u{color:var(--blue-soft)}
.stat .k{color:var(--muted);font-size:.86rem;margin-top:6px}

/* ============ TESTIMONIALS ============ */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.quote{border:1px solid var(--line);border-radius:var(--radius);padding:28px 26px;background:linear-gradient(180deg,var(--panel),var(--panel-2))}
.quote .stars{color:var(--signal);font-size:.9rem;letter-spacing:2px}
.quote p{margin:16px 0 22px;font-size:.98rem;color:#D5DDEE}
.who{display:flex;align-items:center;gap:12px}
.av{width:42px;height:42px;border-radius:50%;flex:none;display:grid;place-items:center;font-family:'Space Grotesk';font-weight:600;color:#fff;background:linear-gradient(135deg,var(--blue),#2456d6)}
.who .nm{font-size:.9rem;font-weight:600}.who .rl{font-size:.78rem;color:var(--muted)}

/* ============ PRICING ============ */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;align-items:start}
.tier{border:1px solid var(--line);border-radius:var(--radius);padding:30px 28px;background:var(--panel-2);position:relative}
.tier.feat{border-color:rgba(62,120,255,.5);background:linear-gradient(180deg,rgba(62,120,255,.1),var(--panel-2));box-shadow:0 30px 60px -34px rgba(62,120,255,.5)}
.tier .tag{position:absolute;top:-11px;left:28px;background:var(--blue);color:#fff;font-size:.7rem;font-family:'JetBrains Mono',monospace;letter-spacing:.1em;text-transform:uppercase;padding:4px 12px;border-radius:999px}
.tier h3{font-size:1.2rem}
.tier .price{font-family:'Space Grotesk';font-size:2.4rem;font-weight:600;margin:14px 0 2px;letter-spacing:-.02em}
.tier .price small{font-size:.9rem;color:var(--muted);font-weight:400;font-family:'Inter'}
.tier .pdesc{color:var(--muted);font-size:.88rem;min-height:40px}
.tier ul{list-style:none;margin:22px 0 26px;display:grid;gap:11px}
.tier li{display:flex;gap:10px;align-items:flex-start;font-size:.9rem;color:#CBD5E8}
.tier li svg{width:17px;height:17px;color:var(--signal);flex:none;margin-top:3px}
.tier .btn{width:100%;justify-content:center}

/* ============ FAQ ACCORDION ============ */
.faq-layout{display:grid;grid-template-columns:.7fr 2fr;gap:clamp(30px,5vw,56px);align-items:start}
.faq-nav{position:sticky;top:96px;display:grid;gap:6px}
.faq-nav a{font-size:.92rem;color:var(--muted);padding:9px 12px;border-radius:9px;border:1px solid transparent;transition:.2s}
.faq-nav a:hover{color:var(--text);background:rgba(255,255,255,.03)}
.faq-nav a.active{color:var(--text);border-color:var(--line-strong);background:rgba(62,120,255,.08)}
.faq-group{margin-bottom:42px}
.faq-group:last-child{margin-bottom:0}
.faq-group h2{font-size:1.4rem;margin-bottom:18px;scroll-margin-top:90px}
.acc{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--panel-2);margin-bottom:12px;overflow:hidden;transition:border-color .2s}
.acc[open]{border-color:var(--line-strong)}
.acc summary{
  list-style:none;cursor:pointer;padding:19px 22px;display:flex;align-items:center;gap:16px;
  font-family:'Space Grotesk';font-weight:500;font-size:1.02rem;color:var(--text);
}
.acc summary::-webkit-details-marker{display:none}
.acc summary .plus{margin-left:auto;flex:none;width:22px;height:22px;position:relative;transition:transform .3s}
.acc summary .plus::before,.acc summary .plus::after{content:"";position:absolute;background:var(--blue-soft);border-radius:2px}
.acc summary .plus::before{top:10px;left:3px;right:3px;height:2px}
.acc summary .plus::after{left:10px;top:3px;bottom:3px;width:2px;transition:opacity .3s}
.acc[open] summary .plus{transform:rotate(180deg)}
.acc[open] summary .plus::after{opacity:0}
.acc .answer{padding:0 22px 20px;color:var(--muted);font-size:.96rem}
.acc .answer p{margin-bottom:12px}
.acc .answer p:last-child{margin-bottom:0}
.acc .answer a{color:var(--blue-soft);text-decoration:underline;text-underline-offset:2px}

/* ============ CTA BAND ============ */
.cta-band{position:relative;overflow:hidden;border:1px solid var(--line-strong);border-radius:calc(var(--radius) + 4px);
  background:radial-gradient(90% 160% at 80% -30%,rgba(62,120,255,.28),transparent 55%),linear-gradient(180deg,var(--panel),var(--panel-2));
  padding:clamp(38px,6vw,64px);text-align:center}
.cta-band h2{font-size:clamp(1.7rem,3.4vw,2.5rem);margin-bottom:14px}
.cta-band p{color:var(--muted);max-width:54ch;margin:0 auto 28px}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ============ CONTACT ============ */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,60px)}
.cinfo h2{font-size:clamp(1.9rem,3.6vw,2.7rem);margin:16px 0 16px}
.cmeta{display:grid;gap:18px;margin-top:30px}
.cmeta a,.cmeta div{display:flex;align-items:center;gap:14px;color:var(--muted);font-size:.96rem}
.cmeta .ci{width:42px;height:42px;border-radius:11px;flex:none;display:grid;place-items:center;background:rgba(62,120,255,.1);border:1px solid rgba(62,120,255,.26);color:var(--blue-soft)}
.cmeta .ci svg{width:19px;height:19px}
.cmeta a:hover{color:var(--text)}
form{border:1px solid var(--line);border-radius:var(--radius);padding:30px;background:var(--panel-2)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field{margin-bottom:16px}
.field label{display:block;font-size:.8rem;color:var(--muted);margin-bottom:7px;font-family:'JetBrains Mono',monospace;letter-spacing:.04em}
.field input,.field textarea{
  width:100%;background:var(--ink);border:1px solid var(--line-strong);border-radius:10px;
  padding:12px 14px;color:var(--text);font-family:'Inter';font-size:.95rem;transition:border-color .2s;
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--blue)}
.field textarea{resize:vertical;min-height:110px}
form .btn{width:100%;justify-content:center;margin-top:6px}
.fnote{font-size:.78rem;color:var(--muted-2);margin-top:14px;text-align:center}

/* ============ FOOTER ============ */
footer{border-top:1px solid var(--line);background:var(--ink-2);padding-block:54px 30px}
.fgrid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:34px;margin-bottom:40px}
.fcol h5{font-size:.78rem;font-family:'JetBrains Mono',monospace;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-2);margin-bottom:16px}
.fcol a{display:block;color:var(--muted);font-size:.92rem;margin-bottom:11px;transition:color .2s}
.fcol a:hover{color:var(--text)}
.fabout p{color:var(--muted);font-size:.9rem;margin:16px 0;max-width:34ch}
.fbottom{border-top:1px solid var(--line);padding-top:24px;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;align-items:center}
.fbottom p{color:var(--muted-2);font-size:.82rem}
.ack{color:var(--muted-2);font-size:.78rem;max-width:60ch;margin-top:16px;line-height:1.5}

/* ============ REVEAL ============ */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ============ RESPONSIVE ============ */
@media(max-width:980px){
  .hero-grid,.split,.contact,.faq-layout{grid-template-columns:1fr}
  .split.rev .split-media{order:0}
  .cards,.quotes,.tiers,.values{grid-template-columns:1fr 1fr}
  .team{grid-template-columns:1fr 1fr}
  .steps,.stats{grid-template-columns:1fr 1fr}
  .fgrid{grid-template-columns:1fr 1fr}
  .hero-bg::after{background:linear-gradient(180deg,transparent,var(--ink))}
  .faq-nav{position:static;grid-auto-flow:column;overflow-x:auto;padding-bottom:6px}
}
@media(max-width:640px){
  .nav-links,.nav-phone{display:none}
  .menu-btn{display:grid;place-items:center}
  .cards,.quotes,.tiers,.values,.team,.stats,.frow,.console-grid{grid-template-columns:1fr}
  .fgrid{grid-template-columns:1fr 1fr}
  .nav.open .nav-links{display:flex;position:absolute;top:72px;left:0;right:0;flex-direction:column;background:var(--ink-2);border-bottom:1px solid var(--line);padding:18px var(--pad);gap:18px}
  .faq-nav{grid-auto-flow:column}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto}
  .reveal{opacity:1;transform:none;transition:none}
}

/* ===================================================================
   v2 — reliable inline imagery + expanded pages
   (these rules come last, so they override earlier photo backgrounds)
   =================================================================== */

/* Hero background: pure CSS, no external image dependency */
.hero-bg{
  background:
    radial-gradient(120% 90% at 80% -10%,rgba(62,120,255,.28),transparent 55%),
    radial-gradient(80% 70% at 10% 110%,rgba(45,213,138,.10),transparent 60%),
    linear-gradient(180deg,#0a1326,var(--ink) 70%);
}
.hero-bg::after{background:none}

/* Illustration media blocks (replace stock photos) */
.media-servers,.media-office,.media-cloud{
  background-image:
    radial-gradient(90% 90% at 30% 10%,rgba(62,120,255,.22),transparent 60%),
    radial-gradient(80% 80% at 90% 100%,rgba(45,213,138,.12),transparent 60%),
    linear-gradient(160deg,#0f1a30,#0b1424);
}
.figure{
  border-radius:var(--radius);overflow:hidden;border:1px solid var(--line-strong);position:relative;
  min-height:380px;display:grid;place-items:center;padding:34px;
  background-image:
    radial-gradient(90% 90% at 25% 12%,rgba(62,120,255,.20),transparent 60%),
    radial-gradient(80% 80% at 92% 100%,rgba(45,213,138,.12),transparent 60%),
    linear-gradient(160deg,#0f1a30,#0b1424);
}
.figure::before{
  content:"";position:absolute;inset:0;opacity:.5;pointer-events:none;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:38px 38px;
  -webkit-mask-image:radial-gradient(circle at 50% 40%,#000,transparent 75%);
  mask-image:radial-gradient(circle at 50% 40%,#000,transparent 75%);
}
.figure svg{position:relative;width:100%;max-width:380px;height:auto;z-index:1}
.figure.small{min-height:300px}

/* draw-in animation for illustration strokes */
@keyframes dash{to{stroke-dashoffset:0}}
.figure .draw{stroke-dasharray:300;stroke-dashoffset:300;animation:dash 1.6s ease forwards}
@media(prefers-reduced-motion:reduce){.figure .draw{animation:none;stroke-dashoffset:0}}

/* small inline illustration inside cards/hero */
.mini-illus{width:100%;height:auto;display:block}

/* ============ SERVICE DETAIL ROWS ============ */
.svc-row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,64px);align-items:center;padding-block:clamp(40px,6vw,72px);border-bottom:1px solid var(--line)}
.svc-row:last-child{border-bottom:none}
.svc-row.rev .svc-fig{order:2}
.svc-tag{font-family:'JetBrains Mono',monospace;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--blue-soft)}
.svc-row h2{font-size:clamp(1.6rem,3.2vw,2.2rem);margin:14px 0 14px}
.svc-row p.lead{font-size:1.02rem;margin-bottom:18px}
.svc-list{list-style:none;display:grid;gap:11px;margin-top:8px}
.svc-list li{display:flex;gap:11px;align-items:flex-start;color:#CBD5E8;font-size:.95rem}
.svc-list li svg{width:18px;height:18px;color:var(--signal);flex:none;margin-top:3px}

/* ============ INDUSTRIES GRID ============ */
.inds{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.ind{border:1px solid var(--line);border-radius:var(--radius);padding:28px 26px;background:linear-gradient(180deg,var(--panel),var(--panel-2));transition:transform .25s,border-color .25s}
.ind:hover{transform:translateY(-5px);border-color:var(--line-strong)}
.ind .ic{margin-bottom:18px}
.ind h3{font-size:1.12rem;margin-bottom:8px}
.ind p{color:var(--muted);font-size:.93rem}
.ind .tags{margin-top:14px;display:flex;flex-wrap:wrap;gap:7px}
.ind .tags span{font-size:.74rem;color:var(--muted-2);border:1px solid var(--line);border-radius:999px;padding:4px 10px}

/* ============ CERT / PARTNER STRIP ============ */
.certs{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}
.cert{display:flex;align-items:center;gap:11px;border:1px solid var(--line);border-radius:12px;padding:14px 18px;background:rgba(255,255,255,.02)}
.cert .ms-tiles{width:22px;height:22px}
.cert .ci2{width:30px;height:30px;color:var(--blue-soft)}
.cert .ci2 svg{width:30px;height:30px}
.cert b{font-family:'Space Grotesk';font-weight:600;font-size:.95rem;display:block}
.cert small{color:var(--muted);font-size:.76rem}

/* ============ COMPARISON TABLE (pricing) ============ */
.cmp-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius)}
table.cmp{width:100%;border-collapse:collapse;min-width:640px}
table.cmp th,table.cmp td{padding:15px 18px;text-align:left;border-bottom:1px solid var(--line);font-size:.92rem}
table.cmp thead th{font-family:'Space Grotesk';font-size:1rem;background:var(--panel-2)}
table.cmp thead th.feat{color:var(--blue-soft)}
table.cmp td:not(:first-child),table.cmp th:not(:first-child){text-align:center}
table.cmp tbody tr:last-child td{border-bottom:none}
table.cmp .yes{color:var(--signal)}
table.cmp .no{color:var(--muted-2)}
table.cmp .rowlabel{color:#CBD5E8}

/* ============ HOURS / CONTACT EXTRAS ============ */
.hours{border:1px solid var(--line);border-radius:var(--radius);background:var(--panel-2);padding:8px 4px;margin-top:8px}
.hours .row{display:flex;justify-content:space-between;padding:12px 18px;border-bottom:1px solid var(--line);font-size:.93rem}
.hours .row:last-child{border-bottom:none}
.hours .row .d{color:var(--muted)}
.hours .row .t{color:var(--text);font-family:'JetBrains Mono',monospace;font-size:.86rem}
.hours .row.now .t{color:var(--signal)}

.loc-card{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;margin-top:8px}
.loc-map{position:relative;min-height:200px;display:grid;place-items:center;
  background-image:
    radial-gradient(80% 90% at 30% 20%,rgba(62,120,255,.20),transparent 60%),
    linear-gradient(160deg,#0f1a30,#0b1424);}
.loc-map::before{content:"";position:absolute;inset:0;opacity:.5;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:34px 34px}
.loc-map svg{position:relative;width:56px;height:56px;color:var(--blue-soft);z-index:1}
.loc-info{padding:18px;display:flex;align-items:center;gap:14px}
.loc-info .ci{width:42px;height:42px;border-radius:11px;flex:none;display:grid;place-items:center;background:rgba(62,120,255,.1);border:1px solid rgba(62,120,255,.26);color:var(--blue-soft)}
.loc-info .ci svg{width:19px;height:19px}
.loc-info b{display:block;font-size:.95rem}
.loc-info span{color:var(--muted);font-size:.86rem}

/* simple two-column intro for inner pages */
.intro2{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(30px,5vw,56px);align-items:start}

@media(max-width:980px){
  .svc-row,.intro2{grid-template-columns:1fr}
  .svc-row.rev .svc-fig{order:0}
  .inds{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .inds{grid-template-columns:1fr}
}


/* ===== WPForms Lite — match the dark theme ===== */
.wpforms-container{margin:0 !important;}
.wpforms-form .wpforms-field{padding:0 0 16px !important;}
.wpforms-form .wpforms-field-label{color:var(--muted) !important;font-family:'JetBrains Mono',monospace !important;font-size:.8rem !important;font-weight:500 !important;letter-spacing:.04em;margin-bottom:7px !important;}
.wpforms-form input[type=text],.wpforms-form input[type=email],.wpforms-form input[type=tel],.wpforms-form input[type=url],.wpforms-form input[type=number],.wpforms-form textarea,.wpforms-form select{width:100% !important;background:var(--ink) !important;border:1px solid var(--line-strong) !important;border-radius:10px !important;padding:12px 14px !important;color:var(--text) !important;font-family:'Inter',sans-serif !important;font-size:.95rem !important;box-shadow:none !important;}
.wpforms-form input:focus,.wpforms-form textarea:focus,.wpforms-form select:focus{outline:none !important;border-color:var(--blue) !important;}
.wpforms-form textarea{min-height:120px !important;}
.wpforms-form ::placeholder{color:var(--muted-2) !important;}
.wpforms-form .wpforms-field-description,.wpforms-form .wpforms-field-sublabel{color:var(--muted-2) !important;}
.wpforms-form .wpforms-required-label{color:#ff7a7a !important;}
.wpforms-form button[type=submit],.wpforms-form .wpforms-submit{background:var(--blue) !important;color:#fff !important;border:none !important;border-radius:999px !important;padding:13px 24px !important;font-family:'Space Grotesk',sans-serif !important;font-weight:600 !important;font-size:.95rem !important;cursor:pointer;box-shadow:0 10px 30px -12px rgba(62,120,255,.7) !important;transition:transform .18s ease;}
.wpforms-form button[type=submit]:hover,.wpforms-form .wpforms-submit:hover{transform:translateY(-2px);}
.wpforms-confirmation-container-full{background:var(--panel-2) !important;border:1px solid var(--line-strong) !important;color:var(--text) !important;border-radius:12px !important;padding:18px 20px !important;margin:0 !important;}
.wpforms-error{color:#ff7a7a !important;}


/* ===== Contact Form 7 - match the dark theme ===== */
.wpcf7{margin:0 !important;}
.wpcf7 form .wpcf7-form-control-wrap{display:block;}
.wpcf7 label{display:block;color:var(--muted) !important;font-family:'JetBrains Mono',monospace !important;font-size:.8rem !important;letter-spacing:.04em;margin-bottom:14px;}
.wpcf7 input[type=text],.wpcf7 input[type=email],.wpcf7 input[type=tel],.wpcf7 input[type=url],.wpcf7 input[type=number],.wpcf7 textarea,.wpcf7 select{
  width:100% !important;background:var(--ink) !important;border:1px solid var(--line-strong) !important;border-radius:10px !important;
  padding:12px 14px !important;color:var(--text) !important;font-family:'Inter',sans-serif !important;font-size:.95rem !important;margin-top:7px;box-shadow:none !important;}
.wpcf7 input:focus,.wpcf7 textarea:focus,.wpcf7 select:focus{outline:none !important;border-color:var(--blue) !important;}
.wpcf7 textarea{min-height:120px !important;}
.wpcf7 ::placeholder{color:var(--muted-2) !important;}
.wpcf7 .wpcf7-submit{
  background:var(--blue) !important;color:#fff !important;border:none !important;border-radius:999px !important;
  padding:13px 24px !important;font-family:'Space Grotesk',sans-serif !important;font-weight:600 !important;font-size:.95rem !important;
  cursor:pointer;box-shadow:0 10px 30px -12px rgba(62,120,255,.7) !important;transition:transform .18s ease;margin-top:6px;}
.wpcf7 .wpcf7-submit:hover{transform:translateY(-2px);}
.wpcf7-response-output{border-radius:10px !important;border:1px solid var(--line-strong) !important;color:var(--text) !important;
  padding:12px 16px !important;margin:18px 0 0 !important;background:var(--panel-2) !important;}
.wpcf7 .wpcf7-not-valid-tip{color:#ff7a7a !important;font-size:.8rem;}
.wpcf7-spinner{margin-left:10px;}


/* ===== Contact page — sectioned (Get-In-Touch style) layout ===== */
.contact-lead{max-width:780px;margin:0 auto 44px;text-align:center;}
.contact-lead .lead{margin-inline:auto;}
.enquiry-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;max-width:880px;margin:0 auto;}
.enquiry-card{background:var(--panel-2);border:1px solid var(--line);border-radius:var(--radius);padding:28px 26px;}
.enquiry-card h3{font-size:1.08rem;margin:0 0 8px;}
.enquiry-card>p{color:var(--muted);font-size:.92rem;margin:0 0 16px;line-height:1.55;}
.enquiry-card a.ci-line{display:flex;align-items:center;gap:10px;color:var(--blue-soft);font-weight:500;padding:7px 0;text-decoration:none;font-size:.95rem;}
.enquiry-card a.ci-line:hover{color:var(--blue);}
.enquiry-card a.ci-line svg{width:18px;height:18px;flex:none;}
.contact-hours .row{display:flex;justify-content:space-between;gap:14px;padding:8px 0;border-bottom:1px solid var(--line);font-size:.9rem;}
.contact-hours .row:last-child{border-bottom:none;}
.contact-hours .row .d{color:var(--muted);}
.contact-hours .row .t{color:var(--text);font-family:'JetBrains Mono',monospace;}
.form-head{max-width:700px;margin:0 auto 28px;text-align:center;}
.form-head .lead{margin-inline:auto;}
.form-panel{max-width:760px;margin:0 auto;}
.offices{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;max-width:880px;margin:0 auto;}
.office-card{background:var(--panel-2);border:1px solid var(--line);border-radius:var(--radius);padding:26px;}
.office-card .city{font-family:'JetBrains Mono',monospace;font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--blue-soft);margin-bottom:10px;}
.office-card b{display:block;font-size:1.02rem;margin-bottom:6px;}
.office-card span{color:var(--muted);font-size:.9rem;line-height:1.5;}
.office-card a{color:var(--blue-soft);font-size:.85rem;text-decoration:none;display:inline-block;margin-top:14px;}
.office-card a:hover{color:var(--blue);}
@media(max-width:680px){.enquiry-grid{grid-template-columns:1fr;}}


/* ===== Modern contact form (self-contained, no plugin) ===== */
.cform{position:relative;background:linear-gradient(180deg,var(--panel) 0%,var(--panel-2) 100%);border:1px solid var(--line-strong);border-radius:20px;padding:38px 34px;overflow:hidden;box-shadow:0 30px 80px -40px rgba(0,0,0,.65);}
.cform::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--blue),var(--signal));}
.cform-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.cform .cfield{margin-bottom:18px;}
.cform .cfield label{display:block;font-family:'JetBrains Mono',monospace;font-size:.72rem;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);margin-bottom:9px;}
.cinput{position:relative;display:flex;align-items:center;}
.cinput svg{position:absolute;left:14px;width:18px;height:18px;color:var(--muted-2);pointer-events:none;}
.cinput input{width:100%;background:var(--ink);border:1px solid var(--line-strong);border-radius:12px;padding:13px 14px 13px 44px;color:var(--text);font-family:'Inter',sans-serif;font-size:.95rem;transition:border-color .18s,box-shadow .18s;}
.cform textarea{width:100%;background:var(--ink);border:1px solid var(--line-strong);border-radius:12px;padding:13px 16px;color:var(--text);font-family:'Inter',sans-serif;font-size:.95rem;min-height:130px;resize:vertical;transition:border-color .18s,box-shadow .18s;}
.cinput input:focus,.cform textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(62,120,255,.18);}
.cinput input::placeholder,.cform textarea::placeholder{color:var(--muted-2);}
.cinput input:focus + svg{color:var(--blue);}
.cbtn{display:inline-flex;align-items:center;gap:9px;background:linear-gradient(135deg,var(--blue),#2f5fd6);color:#fff;border:none;border-radius:999px;padding:14px 28px;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:.98rem;cursor:pointer;box-shadow:0 16px 40px -16px rgba(62,120,255,.85);transition:transform .18s,box-shadow .18s;margin-top:4px;}
.cbtn:hover{transform:translateY(-2px);box-shadow:0 22px 52px -18px rgba(62,120,255,1);}
.cbtn svg{width:18px;height:18px;}
.cnote{margin:16px 0 0;font-size:.82rem;color:var(--muted-2);}
@media(max-width:680px){.cform-row{grid-template-columns:1fr;}.cform{padding:28px 20px;}}


/* ===== Modern form look — applied to Contact Form 7 (.cform) ===== */
.cform{position:relative;background:linear-gradient(180deg,var(--panel) 0%,var(--panel-2) 100%) !important;border:1px solid var(--line-strong) !important;border-radius:20px !important;padding:38px 34px !important;overflow:hidden;box-shadow:0 30px 80px -40px rgba(0,0,0,.65) !important;}
.cform::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--blue),var(--signal));}
.cform .cform-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.cform .cfield{margin-bottom:18px !important;}
.cform .cfield label{display:block !important;font-family:'JetBrains Mono',monospace !important;font-size:.72rem !important;letter-spacing:.07em;text-transform:uppercase;color:var(--muted) !important;margin-bottom:9px !important;}
.cform .cinput{position:relative;display:flex;align-items:center;}
.cform .cinput svg{position:absolute;left:14px;width:18px;height:18px;color:var(--muted-2);pointer-events:none;z-index:2;}
.cform .wpcf7-form-control-wrap{display:block !important;width:100% !important;}
.cform .cinput input{width:100% !important;background:var(--ink) !important;border:1px solid var(--line-strong) !important;border-radius:12px !important;padding:13px 14px 13px 44px !important;color:var(--text) !important;font-family:'Inter',sans-serif !important;font-size:.95rem !important;margin:0 !important;box-shadow:none !important;}
.cform textarea{width:100% !important;background:var(--ink) !important;border:1px solid var(--line-strong) !important;border-radius:12px !important;padding:13px 16px !important;color:var(--text) !important;font-family:'Inter',sans-serif !important;font-size:.95rem !important;min-height:130px !important;margin:0 !important;box-shadow:none !important;resize:vertical;}
.cform .cinput input:focus,.cform textarea:focus{outline:none !important;border-color:var(--blue) !important;box-shadow:0 0 0 3px rgba(62,120,255,.18) !important;}
.cform ::placeholder{color:var(--muted-2) !important;}
.cform .cbtn,.cform input[type=submit],.cform .wpcf7-submit{display:inline-flex !important;align-items:center;gap:9px;background:linear-gradient(135deg,var(--blue),#2f5fd6) !important;color:#fff !important;border:none !important;border-radius:999px !important;padding:14px 28px !important;font-family:'Space Grotesk',sans-serif !important;font-weight:600 !important;font-size:.98rem !important;cursor:pointer;box-shadow:0 16px 40px -16px rgba(62,120,255,.85) !important;transition:transform .18s,box-shadow .18s;margin-top:4px !important;width:auto !important;}
.cform .cbtn:hover,.cform input[type=submit]:hover,.cform .wpcf7-submit:hover{transform:translateY(-2px);box-shadow:0 22px 52px -18px rgba(62,120,255,1) !important;}
.cform .cnote{margin:16px 0 0 !important;font-size:.82rem;color:var(--muted-2);}
.cform .wpcf7-spinner{margin:10px 0 0 10px;}
.cform .wpcf7-not-valid-tip{color:#ff7a7a !important;font-size:.8rem;margin-top:6px;}
.cform .wpcf7-response-output{border:1px solid var(--line-strong) !important;border-radius:10px !important;color:var(--text) !important;padding:12px 16px !important;margin:18px 0 0 !important;background:var(--panel-2) !important;}
@media(max-width:680px){.cform .cform-row{grid-template-columns:1fr;}.cform{padding:28px 20px !important;}}
