/*
Theme Name: Exodus Tech Solutions
Theme URI: https://exodustechsolutions.com.au
Author: Exodus Tech Solutions
Description: Final production theme for Exodus Tech Solutions Brisbane. Fully responsive, SEO-optimised, all pages working.
Version: 5.1.0
Requires at least: 5.8
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: exodus-tech
*/

/* =====================================================
   TOKENS
===================================================== */
:root {
  --a:    #29abe2;
  --a2:   #1a6fb5;
  --ad:   #0f4a8a;
  --ag:   rgba(41,171,226,.10);
  --bg:   #f4f6fb;
  --bg2:  #eaeff7;
  --w:    #ffffff;
  --t:    #18273d;
  --t2:   #2d3e55;
  --mu:   #6278a0;
  --br:   #d8e2ef;
  --brb:  rgba(41,171,226,.25);
  --ft:   #18273d;
  --gr:   linear-gradient(135deg,#29abe2 0%,#1a6fb5 55%,#0f4a8a 100%);
  --s0:   0 1px 4px rgba(18,39,61,.06);
  --s1:   0 2px 10px rgba(18,39,61,.08);
  --s2:   0 6px 24px rgba(18,39,61,.10);
  --s3:   0 16px 48px rgba(18,39,61,.13);
  --s4:   0 24px 64px rgba(18,39,61,.16);
  --r:    10px;
  --rl:   16px;
  --nh:   68px;
  --mw:   1200px;
  --px:   clamp(1rem,5vw,4rem);
  --fh:   'Barlow',sans-serif;
  --fs:   'Barlow Condensed',sans-serif;
  --fb:   'Inter',sans-serif;
}

/* =====================================================
   RESET
===================================================== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{background:var(--bg);color:var(--t);font-family:var(--fb);font-size:16px;line-height:1.7;overflow-x:hidden;-webkit-font-smoothing:antialiased}
body::before{content:'';position:fixed;inset:0;background-image:radial-gradient(circle,rgba(41,171,226,.06) 1px,transparent 1px);background-size:32px 32px;pointer-events:none;z-index:0}
img,video{max-width:100%;height:auto;display:block}
a{color:var(--a2);text-decoration:none;transition:color .2s}
a:hover{color:var(--a)}
ul{list-style:none}
button,input,textarea,select{font-family:var(--fb)}
h1,h2,h3,h4,h5,h6{font-family:var(--fh);font-weight:800;line-height:1.15;letter-spacing:-.01em;color:var(--t)}
h1{font-size:clamp(2rem,5vw,3.4rem)}
h2{font-size:clamp(1.6rem,3.5vw,2.5rem)}
h3{font-size:clamp(1rem,2vw,1.2rem)}
h4{font-size:.97rem}
p{margin-bottom:1rem;color:var(--t2)}
p:last-child{margin-bottom:0}

/* =====================================================
   LAYOUT
===================================================== */
.site-content{position:relative;z-index:1}
.container{max-width:var(--mw);margin:0 auto;padding:0 var(--px)}
.sec{padding:clamp(3rem,8vw,6rem) var(--px)}
.sec-t{padding:clamp(2rem,5vw,3.5rem) var(--px)}

.lbl{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--a2);margin-bottom:14px}
.ttl{font-family:var(--fh);font-size:clamp(1.8rem,4vw,2.5rem);font-weight:800;margin-bottom:16px;color:var(--t)}
.sub{color:var(--mu);font-size:1.05rem;max-width:580px;margin-bottom:48px;line-height:1.75}

/* =====================================================
   BUTTONS
===================================================== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:600;font-size:.93rem;padding:13px 26px;border-radius:8px;border:none;cursor:pointer;transition:all .22s;text-decoration:none;line-height:1;white-space:nowrap;-webkit-tap-highlight-color:transparent;min-height:48px}
.btn-p{background:var(--a2);color:#fff!important}
.btn-p:hover{background:var(--a);transform:translateY(-2px);box-shadow:0 8px 24px rgba(41,171,226,.3);color:#fff!important}
.btn-o{background:transparent;color:var(--t2)!important;border:1.5px solid var(--br)}
.btn-o:hover{border-color:var(--a);color:var(--a2)!important;background:var(--ag);transform:translateY(-2px)}
.btn-w{background:#fff;color:var(--a2)!important}
.btn-w:hover{background:#eef7ff;box-shadow:0 8px 24px rgba(0,0,0,.15);transform:translateY(-2px)}
.btn-g{background:transparent;color:#fff!important;border:1.5px solid rgba(255,255,255,.55)}
.btn-g:hover{background:rgba(255,255,255,.12);border-color:#fff}
.btn-f{width:100%;justify-content:center}
.brow{display:flex;gap:12px;flex-wrap:wrap}
.brow-c{justify-content:center}

/* =====================================================
   NAVIGATION — Clean white bar (MyGeeks style)
===================================================== */
#masthead{position:sticky;top:0;z-index:9999;background:#fff;border-bottom:1px solid #e8edf4;box-shadow:none}
.admin-bar #masthead{top:32px}
@media screen and (max-width:782px){.admin-bar #masthead{top:46px}}
.nav-wrap{max-width:var(--mw);margin:0 auto;padding:0 var(--px);display:flex;align-items:center;gap:2rem;height:var(--nh)}
.site-branding{flex-shrink:0}
.site-branding a{display:flex;align-items:center;text-decoration:none}
.et-logo-img{height:48px;width:auto;max-width:220px;display:block;object-fit:contain}
@media(max-width:768px){.et-logo-img{height:38px;max-width:180px}}
.logo-txt{display:flex;flex-direction:column;line-height:1}
.logo-n{font-family:var(--fh);font-size:clamp(.95rem,2.5vw,1.3rem);font-weight:800;letter-spacing:.05em;color:var(--t);line-height:1.1}
.logo-t{font-family:var(--fs);font-size:.58rem;font-weight:600;letter-spacing:.16em;color:var(--mu);margin-top:2px}

/* Desktop nav links */
#sitenav{display:flex;align-items:center;flex:1}
#sitenav ul{display:flex;align-items:center;gap:0;margin:0;padding:0;height:var(--nh)}
#sitenav ul li{position:relative;height:100%;display:flex;align-items:center}
#sitenav ul li a{display:flex;align-items:center;height:100%;font-size:.9rem;font-weight:500;color:#333;padding:0 14px;white-space:nowrap;text-decoration:none;position:relative;transition:color .2s;border-bottom:3px solid transparent;box-sizing:border-box}
#sitenav ul li a:hover{color:var(--a2)}
#sitenav ul li.current-menu-item>a,#sitenav ul li.current-page-ancestor>a{color:var(--a2);border-bottom:3px solid var(--a2)}

/* CTA Get Started button — far right */
#sitenav ul li.menu-cta{margin-left:auto}
#sitenav ul li.menu-cta>a{background:var(--a2)!important;color:#fff!important;font-weight:600!important;padding:10px 22px!important;border-radius:6px!important;border-bottom:none!important;height:auto!important;font-size:.9rem!important;transition:background .2s,transform .15s!important}
#sitenav ul li.menu-cta>a:hover{background:var(--a)!important;transform:translateY(-1px)!important}

/* Dropdown menus */
#sitenav ul ul{display:none;position:absolute;top:100%;left:0;min-width:210px;background:#fff;border:1px solid #e8edf4;border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,.1);padding:6px 0;z-index:1000}
#sitenav ul li:hover>ul{display:block}
#sitenav ul ul li{height:auto;display:block}
#sitenav ul ul li a{display:block;height:auto;padding:10px 18px;border-radius:0;border-bottom:none!important;font-size:.875rem;color:#333;transition:background .15s,color .15s}
#sitenav ul ul li a:hover{background:#f4f6fb;color:var(--a2)}
/* Dropdown arrow indicator */
#sitenav ul li:has(>ul)>a::after{content:'▾';font-size:.7rem;margin-left:4px;opacity:.6}

/* Hamburger */
.ham{display:none;align-items:center;justify-content:center;width:44px;height:44px;background:var(--a2);border:none;border-radius:8px;cursor:pointer;flex-direction:column;gap:5px;padding:10px;-webkit-tap-highlight-color:transparent;flex-shrink:0;margin-left:auto}
.ham span{display:block;width:20px;height:2px;background:#fff;border-radius:2px;transition:transform .3s,opacity .3s}
.ham.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.ham.open span:nth-child(2){opacity:0}
.ham.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* MOBILE SLIDE MENU */
.mob-overlay{display:none!important}
.mob-overlay.open{display:block}

/* =====================================================
   PAGE HEADER
===================================================== */
.pg-hd{padding:clamp(3rem,8vw,5rem) var(--px) clamp(2rem,5vw,3.5rem);background:linear-gradient(150deg,#eaf2fb,#f4f6fb);border-bottom:1px solid var(--br)}
.pg-hd .container{max-width:var(--mw);margin:0 auto}
.pg-hd h1{margin-bottom:14px}
.pg-hd p{color:var(--mu);font-size:clamp(1rem,2vw,1.05rem);max-width:600px;margin:0}
.pg-hd a{color:var(--a2);font-weight:600}

/* =====================================================
   HERO
===================================================== */
.hero{position:relative;overflow:hidden;background:linear-gradient(135deg,#0d1b35 0%,#112244 50%,#1a3560 100%);padding:clamp(3rem,8vw,6rem) var(--px);min-height:calc(100vh - var(--nh));display:flex;align-items:center}
.blob1{position:absolute;top:-200px;right:-200px;width:min(640px,90vw);height:min(640px,90vw);border-radius:50%;background:radial-gradient(circle,rgba(41,171,226,.14) 0%,transparent 68%);pointer-events:none}
.blob2{position:absolute;bottom:-150px;left:-150px;width:min(500px,80vw);height:min(500px,80vw);border-radius:50%;background:radial-gradient(circle,rgba(26,111,181,.09) 0%,transparent 68%);pointer-events:none}
.hero-in{max-width:var(--mw);margin:0 auto;width:100%;display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,6vw,5rem);align-items:center;position:relative;z-index:1}
.badge{display:inline-flex;align-items:center;gap:8px;background:rgba(41,171,226,.1);border:1px solid rgba(41,171,226,.28);color:#fff;font-size:.75rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;padding:6px 14px;border-radius:100px;margin-bottom:20px;background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.25)}
.badge::before{content:'';width:6px;height:6px;background:var(--a);border-radius:50%;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.4)}}
.hero h1{font-size:clamp(1.6rem,3.5vw,2.4rem);margin-bottom:20px;line-height:1.2;color:#fff}
.hero h1 em{font-style:normal;color:var(--a)}
.hero-desc{font-size:clamp(1rem,2vw,1.1rem);color:rgba(255,255,255,.75);margin-bottom:32px;max-width:500px;line-height:1.8}
.trust-row{display:flex;gap:clamp(.75rem,2vw,1.5rem);flex-wrap:wrap;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.15)}
.trust-i{display:flex;align-items:center;gap:7px;font-size:.82rem;font-weight:600;color:rgba(255,255,255,.85)}

/* Hero card */
.hero-vis{display:flex;justify-content:center;align-items:center}
.cstack{position:relative;width:clamp(240px,28vw,320px);height:clamp(260px,33vw,360px)}
.hc{position:absolute;background:#fff;border-radius:var(--rl);padding:clamp(16px,3vw,22px);border:1px solid var(--br)}
.hc.b2{width:90%;top:0;right:0;opacity:.3;transform:rotate(6deg);box-shadow:var(--s1)}
.hc.b1{width:95%;top:12px;right:2%;opacity:.6;transform:rotate(3deg);box-shadow:var(--s1)}
.hc.fr{width:100%;top:26px;right:0;z-index:3;border-color:var(--brb);box-shadow:var(--s4)}
.hc-ic{width:44px;height:44px;background:var(--gr);border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:12px}
.hc h3{font-size:clamp(.9rem,2vw,1.05rem);margin-bottom:6px}
.hc p{font-size:.82rem;color:var(--mu)}
.hst{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:16px;padding-top:14px;border-top:1px solid rgba(255,255,255,.15)}
.hst-n{font-family:var(--fh);font-size:1.05rem;font-weight:800;color:var(--a2)}
.hst-l{font-size:.65rem;color:var(--mu)}

/* =====================================================
   CATEGORY LABEL
===================================================== */
.cat-lbl{font-family:var(--fh);font-size:.95rem;font-weight:700;color:var(--t);padding:10px 18px;background:var(--bg2);border-left:4px solid var(--a2);border-radius:0 8px 8px 0;display:inline-block;margin-bottom:22px;margin-top:8px}

/* =====================================================
   SERVICE CARDS
===================================================== */
.sg{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,270px),1fr));gap:18px}
.sc{background:var(--w);border:1.5px solid var(--br);border-radius:var(--r);padding:clamp(18px,3.5vw,26px);cursor:pointer;transition:all .28s;position:relative;overflow:hidden;box-shadow:var(--s0);display:block;text-decoration:none}
.sc::before{content:'';position:absolute;top:0;left:0;width:100%;height:3px;background:var(--gr);transform:scaleX(0);transform-origin:left;transition:transform .28s}
.sc:hover{border-color:var(--brb);transform:translateY(-4px);box-shadow:var(--s3)}
.sc:hover::before{transform:scaleX(1)}
.si{width:46px;height:46px;background:rgba(41,171,226,.08);border:1px solid rgba(41,171,226,.18);border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:21px;margin-bottom:14px}
.sc h3{font-size:clamp(.93rem,2vw,1.05rem);margin-bottom:9px;color:var(--t)}
.sc p{color:var(--mu);font-size:.87rem;line-height:1.7;margin:0}
.sm{display:inline-flex;align-items:center;gap:6px;font-size:.82rem;color:var(--a2);font-weight:600;margin-top:12px;transition:gap .2s}
.sc:hover .sm{gap:10px}

/* Service detail grid */
.sdg{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,280px),1fr));gap:20px}
.sdc{background:var(--w);border:1.5px solid var(--br);border-radius:var(--rl);padding:clamp(20px,3.5vw,28px);transition:all .28s;box-shadow:var(--s0)}
.sdc:hover{border-color:var(--brb);transform:translateY(-3px);box-shadow:var(--s3)}
.sdc h3{font-size:clamp(.93rem,2vw,1.1rem);margin-bottom:14px;color:var(--t)}
.sdc ul{padding:0}
.sdc ul li{padding:7px 0;color:var(--mu);font-size:.875rem;border-bottom:1px solid var(--br);display:flex;align-items:flex-start;gap:10px}
.sdc ul li:last-child{border-bottom:none}
.sdc ul li::before{content:'→';color:var(--a2);font-weight:700;flex-shrink:0;margin-top:1px}

/* =====================================================
   WHY CARDS
===================================================== */
.wg{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,220px),1fr));gap:16px}
.wc{background:var(--w);border:1.5px solid var(--br);border-radius:var(--r);padding:clamp(16px,3vw,22px);display:flex;gap:14px;align-items:flex-start;transition:all .25s;box-shadow:var(--s0)}
.wc:hover{border-color:var(--brb);box-shadow:var(--s2)}
.wi{font-size:1.4rem;flex-shrink:0;margin-top:2px}
.wc h4{font-size:.93rem;margin-bottom:5px;color:var(--t)}
.wc p{color:var(--mu);font-size:.83rem;margin:0}

/* =====================================================
   CTA BAND
===================================================== */
.cta{background:var(--gr);padding:clamp(3rem,7vw,5rem) var(--px);text-align:center;position:relative;overflow:hidden}
.cta::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:min(700px,90vw);height:350px;background:radial-gradient(ellipse,rgba(255,255,255,.09) 0%,transparent 70%);pointer-events:none}
.cta h2{color:#fff;margin-bottom:14px}
.cta p{color:rgba(255,255,255,.85);font-size:clamp(1rem,2vw,1.1rem);margin-bottom:30px}

/* =====================================================
   GOOGLE REVIEWS
===================================================== */
.reviews{background:var(--bg2);padding:clamp(3rem,7vw,5rem) var(--px)}
.rev-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,280px),1fr));gap:20px;margin-top:40px}
.rev-card{background:var(--w);border:1.5px solid var(--br);border-radius:var(--rl);padding:clamp(20px,3vw,28px);box-shadow:var(--s0);transition:all .25s}
.rev-card:hover{box-shadow:var(--s2);transform:translateY(-2px)}
.rev-head{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.rev-av{width:46px;height:46px;border-radius:50%;background:var(--gr);display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:#fff;font-weight:700;font-family:var(--fh);flex-shrink:0}
.rev-info h4{font-size:.95rem;font-weight:700;color:var(--t);margin-bottom:2px}
.rev-info span{font-size:.78rem;color:var(--mu)}
.rev-stars{color:#f59e0b;font-size:1rem;margin-bottom:12px;letter-spacing:2px}
.rev-text{font-size:.88rem;color:var(--t2);line-height:1.7;font-style:italic}
.rev-badge{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--br);border-radius:8px;padding:10px 16px;margin-top:30px;box-shadow:var(--s0);font-size:.85rem;font-weight:600;color:var(--t2)}

/* =====================================================
   SUBURBS / AREAS
===================================================== */
.areas{background:var(--t);padding:clamp(2.5rem,6vw,4rem) var(--px);text-align:center}
.areas h2{color:#fff;margin-bottom:12px;font-size:clamp(1.4rem,3vw,1.9rem)}
.areas p{color:rgba(255,255,255,.65);margin-bottom:24px;font-size:.95rem}
.area-tags{display:flex;flex-wrap:wrap;justify-content:center;gap:8px}
.area-tag{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.8);padding:6px 14px;border-radius:100px;font-size:.82rem;font-weight:500;transition:all .2s;cursor:default}
.area-tag:hover{background:var(--a2);border-color:var(--a2);color:#fff}

/* =====================================================
   ABOUT PAGE
===================================================== */
.about-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:clamp(2rem,6vw,5rem);align-items:start}
.avis{background:linear-gradient(145deg,#eaf2fb,#dde9f7);border:1.5px solid var(--br);border-radius:20px;padding:clamp(22px,4vw,36px);position:relative;overflow:hidden;box-shadow:var(--s2)}
.avis::before{content:'';position:absolute;top:-60px;right:-60px;width:250px;height:250px;background:radial-gradient(circle,rgba(41,171,226,.15),transparent 70%)}
.about-tag{color:var(--mu);font-size:.9rem;margin-bottom:22px}
.astats{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}
.ast{background:#fff;border:1.5px solid var(--br);border-radius:var(--r);padding:14px;text-align:center;box-shadow:var(--s0)}
.astn{font-family:var(--fh);font-size:1.5rem;font-weight:800;color:var(--a2);line-height:1.1}
.astl{font-size:.72rem;color:var(--mu);margin-top:3px}
.contact-box{background:#fff;border:1.5px solid var(--brb);border-radius:var(--r);padding:20px;box-shadow:var(--s1);margin-top:16px}
.contact-box h4{margin-bottom:12px;font-size:.95rem;color:var(--t)}
.contact-box a{color:var(--a2);font-weight:600}
/* Roy profile */
.roy-profile{background:var(--w);border:1.5px solid var(--br);border-radius:var(--rl);padding:clamp(20px,4vw,32px);box-shadow:var(--s1);margin-bottom:28px}
.roy-head{display:flex;align-items:center;gap:18px;margin-bottom:20px}
.roy-av{width:72px;height:72px;border-radius:50%;background:var(--gr);display:flex;align-items:center;justify-content:center;font-size:1.8rem;color:#fff;font-weight:800;font-family:var(--fh);flex-shrink:0}
.roy-info h3{font-size:1.2rem;margin-bottom:4px;color:var(--t)}
.roy-info p{font-size:.85rem;color:var(--mu);margin:0}
.roy-badges{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.roy-badge{background:var(--bg2);border:1px solid var(--br);color:var(--t2);padding:4px 12px;border-radius:100px;font-size:.78rem;font-weight:600}
.skills-list{display:grid;grid-template-columns:1fr 1fr;gap:6px 16px;margin-top:12px}
.skill-item{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--t2)}
.skill-item::before{content:'✓';color:var(--a2);font-weight:700;flex-shrink:0}
.mv-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:24px}
.mvc{background:var(--w);border:1.5px solid var(--br);border-radius:var(--rl);padding:clamp(14px,3vw,20px);box-shadow:var(--s0)}
.mvc h4{font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--a2);margin-bottom:8px}
.mvc p{color:var(--mu);font-size:.87rem;margin:0}

/* =====================================================
   PRICING
===================================================== */
.pg{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,270px),1fr));gap:20px}
.pc{background:var(--w);border:1.5px solid var(--br);border-radius:var(--rl);padding:clamp(22px,4vw,32px);position:relative;transition:all .28s;box-shadow:var(--s1)}
.pc:hover{transform:translateY(-4px);box-shadow:var(--s4)}
.pc.feat{border-color:var(--a2);background:linear-gradient(160deg,rgba(41,171,226,.05),rgba(26,111,181,.02));box-shadow:0 0 0 1px var(--a2),var(--s3)}
.pbadge{position:absolute;top:-14px;right:20px;background:var(--gr);color:#fff;font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:4px 14px;border-radius:100px}
.ptier{font-size:.74rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--a2);margin-bottom:10px}
.pnum{font-family:var(--fh);font-size:clamp(2rem,4vw,2.7rem);font-weight:800;line-height:1;margin-bottom:4px;color:var(--t)}
.pnum sup{font-size:1.1rem;vertical-align:top;margin-top:8px;display:inline-block}
.pnum sub{font-size:.9rem;vertical-align:bottom;color:var(--mu);font-weight:400}
.pdesc{color:var(--mu);font-size:.87rem;margin-bottom:22px}
.pfeats{padding:0;margin-bottom:26px}
.pfeats li{padding:8px 0;border-bottom:1px solid var(--br);font-size:.87rem;display:flex;align-items:center;gap:10px;color:var(--t2)}
.pfeats li:last-child{border-bottom:none}
.pfeats li::before{content:'✓';color:var(--a2);font-weight:700;flex-shrink:0}
.hbox{text-align:center;margin-top:40px;padding:clamp(18px,4vw,28px);background:var(--bg2);border:1.5px solid var(--br);border-radius:var(--rl)}
.hbox h3{margin-bottom:8px}
.hbox p{color:var(--mu);margin-bottom:18px}

/* =====================================================
   CONTACT / FORM
===================================================== */
.cg{display:grid;grid-template-columns:1fr 1.5fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.cdets{display:flex;flex-direction:column;gap:14px;margin-top:24px}
.ci{display:flex;gap:14px;align-items:flex-start;background:var(--w);border:1.5px solid var(--br);border-radius:var(--r);padding:15px 18px;box-shadow:var(--s0)}
.ci-ic{font-size:1.2rem;flex-shrink:0}
.ci h4{font-weight:600;font-size:.87rem;margin-bottom:3px;color:var(--t)}
.ci p,.ci a{color:var(--mu);font-size:.87rem;margin:0}
.ci a{color:var(--a2);font-weight:600}
.cf{background:var(--w);border:1.5px solid var(--br);border-radius:var(--rl);padding:clamp(20px,4vw,36px);box-shadow:var(--s2)}
.cf h3{margin-bottom:22px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.fg{margin-bottom:14px}
.fg label{display:block;font-size:.82rem;font-weight:600;color:var(--t2);margin-bottom:7px}
.fg input,.fg textarea,.fg select,
.wpcf7-form input[type=text],.wpcf7-form input[type=email],.wpcf7-form input[type=tel],.wpcf7-form textarea,.wpcf7-form select{
  width:100%;background:var(--bg);border:1.5px solid var(--br);border-radius:8px;padding:12px 14px;color:var(--t);font-family:var(--fb);font-size:16px;transition:border-color .2s,box-shadow .2s;outline:none;-webkit-appearance:none;appearance:none}
.fg input:focus,.fg textarea:focus,.fg select:focus,
.wpcf7-form input:focus,.wpcf7-form textarea:focus,.wpcf7-form select:focus{border-color:var(--a);box-shadow:0 0 0 3px rgba(41,171,226,.12)}
.fg textarea,.wpcf7-form textarea{resize:vertical;min-height:120px}
.wpcf7-form input[type=submit]{width:100%;background:var(--a2);color:#fff;font-family:var(--fb);font-size:.93rem;font-weight:600;padding:14px;border-radius:8px;border:none;cursor:pointer;transition:background .22s;min-height:48px}
.wpcf7-form input[type=submit]:hover{background:var(--a)}
.form-ok{display:none;background:rgba(41,171,226,.08);border:1px solid rgba(41,171,226,.3);border-radius:8px;padding:14px 18px;color:var(--a2);font-weight:600;margin-top:14px;text-align:center}

/* =====================================================
   BLOG
===================================================== */
.blg{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,280px),1fr));gap:20px}
.bc{background:var(--w);border:1.5px solid var(--br);border-radius:var(--rl);overflow:hidden;transition:all .28s;box-shadow:var(--s0)}
.bc:hover{border-color:var(--brb);transform:translateY(-4px);box-shadow:var(--s3)}
.bth{height:clamp(140px,18vw,180px);background:linear-gradient(135deg,#ddeef8,#c8e3f4);overflow:hidden}
.bth img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.bc:hover .bth img{transform:scale(1.05)}
.bph{height:100%;display:flex;align-items:center;justify-content:center;font-size:2.8rem}
.bb{padding:clamp(14px,3vw,20px)}
.bcat{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--a2);margin-bottom:8px}
.bc h3{font-size:clamp(.9rem,2vw,.97rem);margin-bottom:8px;line-height:1.4}
.bc h3 a{color:var(--t)}
.bc h3 a:hover{color:var(--a2)}
.bex{color:var(--mu);font-size:.83rem}
.bmet{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px;padding-top:12px;border-top:1px solid var(--br);font-size:.76rem;color:var(--mu)}

/* Entry */
.entry-content{max-width:760px;margin:clamp(2rem,5vw,4rem) auto;padding:0 var(--px)}
.entry-content h2,.entry-content h3{margin:2rem 0 1rem}
.entry-content p{color:var(--t2);margin-bottom:1.2rem}
.entry-content ul,.entry-content ol{padding-left:1.5rem;margin-bottom:1.2rem;color:var(--t2)}
.entry-content li{margin-bottom:.4rem}

/* =====================================================
   FOOTER
===================================================== */
#colophon{background:var(--ft);padding:clamp(3rem,7vw,5rem) var(--px) clamp(1.5rem,3vw,2rem)}
.ft-in{max-width:var(--mw);margin:0 auto}
.ft-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:clamp(1.5rem,4vw,3rem);margin-bottom:clamp(2rem,4vw,3rem)}
.ft-brand p{color:rgba(255,255,255,.5);font-size:.87rem;margin-top:14px;max-width:280px;line-height:1.7}
.ft-ln{font-family:var(--fh);font-size:1.2rem;font-weight:800;letter-spacing:.05em;color:#fff;line-height:1.1}
.ft-lt{font-family:var(--fs);font-size:.58rem;letter-spacing:.16em;color:rgba(255,255,255,.4)}
.ft-col h4{font-family:var(--fh);font-size:.87rem;font-weight:700;margin-bottom:14px;color:#fff}
.ft-col ul{padding:0}
.ft-col ul li{margin-bottom:9px}
.ft-col ul li a{color:rgba(255,255,255,.5);font-size:.84rem;transition:color .2s}
.ft-col ul li a:hover{color:var(--a)}
.ft-bot{padding-top:22px;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;font-size:.8rem;color:rgba(255,255,255,.35)}
.seo-text{font-size:.75rem;color:rgba(255,255,255,.2);margin-top:8px;line-height:1.6}

/* =====================================================
   ACCESSIBILITY & WP
===================================================== */
.screen-reader-text{clip:rect(1px,1px,1px,1px);position:absolute!important;height:1px;width:1px;overflow:hidden}
:focus-visible{outline:2px solid var(--a);outline-offset:3px}
.wpcf7-not-valid-tip{color:#e53e3e;font-size:.8rem;margin-top:4px;display:block}
.wpcf7-mail-sent-ok{background:rgba(41,171,226,.08);border:1px solid var(--a2);padding:10px;border-radius:6px;margin-top:10px;color:var(--a2)}

/* =====================================================
   RESPONSIVE
===================================================== */
@media(max-width:1100px){
  .ft-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .ft-brand{grid-column:1/-1}
  .hero-in{gap:2rem}
}
@media(max-width:1024px){
  .about-grid{gap:2.5rem}
  .cg{gap:2.5rem}
  #sitenav ul li a{padding:0 10px;font-size:.85rem}
}
@media(max-width:900px){
  .hero-in{grid-template-columns:1fr}
  .hero-vis{display:none}
  .hero-placeholder{display:none}
  .hero{min-height:auto;padding:clamp(2.5rem,6vw,4rem) var(--px)}
  .hero h1{font-size:clamp(1.5rem,4vw,2.1rem)}
  .hero-tags{gap:8px}
  .hero-tag{font-size:.78rem;padding:6px 12px}
  .brow{flex-direction:column!important;align-items:stretch!important;max-width:100%!important}
  .brow .btn{width:100%!important;justify-content:center!important}
  .about-grid{grid-template-columns:1fr}
  .cg{grid-template-columns:1fr}
  .mv-grid{grid-template-columns:1fr 1fr}
  .pg{grid-template-columns:1fr 1fr}
  .astats{grid-template-columns:repeat(4,1fr)}
  .skills-list{grid-template-columns:1fr}
  /* iPad nav — keep desktop menu but tighter */
  #sitenav ul li a{padding:0 8px;font-size:.82rem}
}

/* ── TABLET (iPad portrait ~768px) ── */
@media(max-width:768px){
  :root{--nh:62px}
  .ham{display:flex}

  /* ── FULL SCREEN MOBILE MENU — iOS + Android ── */
  #sitenav{
    visibility:hidden;
    opacity:0;
    pointer-events:none;
    position:fixed!important;
    top:0!important;
    left:0!important;
    right:0!important;
    bottom:0!important;
    margin:0!important;
    padding:64px 0 24px!important;
    width:100vw!important;
    max-width:100vw!important;
    height:100vh!important;
    height:calc(var(--vh,1vh)*100)!important;
    background:#18273d!important;
    display:flex!important;
    flex-direction:column!important;
    align-items:stretch!important;
    justify-content:flex-start!important;
    z-index:99999!important;
    overflow-y:auto!important;
    overflow-x:hidden!important;
    -webkit-overflow-scrolling:touch;
    transform:translateY(-100%)!important;
    transition:transform .3s ease,opacity .3s ease,visibility 0s linear .3s;
    box-sizing:border-box!important;
  }
  #sitenav.open{
    visibility:visible!important;
    opacity:1!important;
    pointer-events:auto!important;
    transform:translateY(0)!important;
    transition:transform .3s ease,opacity .3s ease,visibility 0s linear 0s;
  }
  #sitenav ul{
    flex-direction:column!important;
    width:100%!important;
    gap:0!important;
    padding:0 16px!important;
    margin:0!important;
    list-style:none!important;
  }
  #sitenav ul li{
    border-bottom:1px solid rgba(255,255,255,.08)!important;
    width:100%!important;
    height:auto!important;
  }
  #sitenav ul li:first-child{
    border-top:1px solid rgba(255,255,255,.08)!important;
  }
  #sitenav ul li a{
    display:flex!important;
    align-items:center!important;
    padding:14px 14px!important;
    border-radius:0!important;
    font-size:1rem!important;
    font-weight:600!important;
    width:100%!important;
    height:auto!important;
    color:#ffffff!important;
    border-bottom:none!important;
    letter-spacing:.01em!important;
    transition:background .2s,padding-left .2s!important;
    white-space:normal!important;
  }
  #sitenav ul li a:hover,
  #sitenav ul li.current-menu-item>a{
    color:#29abe2!important;
    background:rgba(41,171,226,.12)!important;
    padding-left:20px!important;
  }
  #sitenav ul li.menu-cta{
    border-bottom:none!important;
    margin-top:12px!important;
    padding:0 14px!important;
  }
  #sitenav ul li.menu-cta>a{
    background:var(--a2)!important;
    color:#fff!important;
    border-radius:10px!important;
    justify-content:center!important;
    font-size:1rem!important;
    padding:14px 24px!important;
    margin-top:0!important;
  }
  #sitenav ul li.menu-cta>a:hover{background:var(--a)!important}
  #sitenav ul ul{
    display:none!important;
    position:static!important;
    box-shadow:none!important;
    border:none!important;
    background:rgba(255,255,255,.04)!important;
    border-radius:0!important;
    margin:0!important;
    padding:0 0 6px 14px!important;
  }
  #sitenav ul li.sub-open>ul{display:block!important}
  #sitenav ul ul li{border-bottom:1px solid rgba(255,255,255,.05)!important}
  #sitenav ul ul li a{
    padding:11px 14px!important;
    font-size:.9rem!important;
    color:rgba(255,255,255,.8)!important;
    font-weight:400!important;
  }
  #sitenav::before{
    content:'✕'!important;
    position:fixed!important;
    top:14px!important;right:18px!important;
    color:rgba(255,255,255,.7)!important;
    font-size:1.2rem!important;
    z-index:100000!important;
    cursor:pointer!important;
    width:38px!important;height:38px!important;
    display:flex!important;align-items:center!important;justify-content:center!important;
    background:rgba(255,255,255,.1)!important;
    border-radius:50%!important;
  }
  #sitenav::after{
    content:'MENU'!important;
    position:fixed!important;
    top:20px!important;left:50%!important;
    transform:translateX(-50%)!important;
    color:rgba(255,255,255,.5)!important;
    font-size:.72rem!important;font-weight:700!important;
    letter-spacing:.2em!important;z-index:100000!important;
  }
  .frow{grid-template-columns:1fr!important;gap:0!important}
  .wg{grid-template-columns:1fr 1fr}
  .mv-grid{grid-template-columns:1fr}
  .pg{grid-template-columns:1fr}
  .ft-grid{grid-template-columns:1fr 1fr}
  .ft-brand{grid-column:1/-1}
  .ft-bot{flex-direction:column;text-align:center;gap:6px}
  .skills-list{grid-template-columns:1fr}
  .sec{padding:clamp(2rem,6vw,4rem) var(--px)}
  .pricing-how{grid-template-columns:1fr!important}
}

/* ── MOBILE (iPhone, small Android) ── */
@media(max-width:480px){
  .hero h1{font-size:clamp(1.3rem,6vw,1.8rem)}
  .hero-tags{gap:6px}
  .hero-tag{font-size:.75rem;padding:5px 10px}
  .sg{grid-template-columns:1fr}
  .sdg{grid-template-columns:1fr}
  .wg{grid-template-columns:1fr}
  .blg{grid-template-columns:1fr}
  .astats{grid-template-columns:1fr 1fr}
  .ft-grid{grid-template-columns:1fr}
  .brow{flex-direction:column}
  .brow .btn{width:100%;justify-content:center}
  .cf{padding:18px}
  .area-tags{gap:6px}
  .rev-grid{grid-template-columns:1fr}
  .roy-head{flex-direction:column;align-items:flex-start;gap:12px}
  .pg{grid-template-columns:1fr}
  .mv-grid{grid-template-columns:1fr}
  .about-grid{grid-template-columns:1fr}
  .cg{grid-template-columns:1fr}
  .hbox{padding:16px}
  .pc{padding:20px}
  .hero{padding:2rem var(--px)}
  .trust-row{gap:.5rem}
  .trust-i{font-size:.76rem}
}

/* ── SMALL PHONES ── */
@media(max-width:360px){
  :root{--px:.875rem}
  .hero h1{font-size:1.3rem}
  .hero-tag{font-size:.7rem;padding:4px 8px}
}
@media print{#masthead,.cta,#colophon{display:none}body{background:#fff;color:#000}}

/* Hero image */
.hero-img-wrap{width:100%;border-radius:16px;overflow:hidden;box-shadow:0 24px 64px rgba(0,0,0,.4);aspect-ratio:4/3}
.hero-img-wrap img{width:100%;height:100%;object-fit:cover;display:block}
.hero-placeholder{width:100%;aspect-ratio:4/3;border-radius:16px;background:rgba(255,255,255,.06);border:1.5px solid rgba(255,255,255,.12);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:rgba(255,255,255,.5);font-size:.9rem;text-align:center;padding:32px}
.hero-placeholder-icon{font-size:4rem;opacity:.5}
.hero-tags{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:28px}
.hero-tag{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:rgba(255,255,255,.9);padding:8px 16px;border-radius:100px;font-size:.83rem;font-weight:500}

/* ── HERO SLIDER ── */
.hero-slider{width:100%;border-radius:16px;overflow:hidden;position:relative}
.hero-slides{display:flex;transition:transform .5s ease}
.hero-slide{min-width:100%;aspect-ratio:16/9}
.hero-slide img{width:100%;height:100%;object-fit:cover;display:block;border-radius:16px}
.slider-dots{display:flex;justify-content:center;gap:8px;margin-top:12px}
.slider-dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.35);cursor:pointer;transition:background .3s;border:none;padding:0}
.slider-dot.active{background:#fff}
@media(max-width:900px){.hero-slider{display:none}}

/* ── PRICING TRUST TICKS — blue highlight ── */
.pricing-trust{display:flex;gap:clamp(1rem,3vw,2.5rem);flex-wrap:wrap;margin-top:20px}
.pricing-trust-item{display:flex;align-items:center;gap:8px;font-size:.95rem;font-weight:600;color:var(--a2)}
.pricing-trust-item::before{content:'✓';background:var(--a2);color:#fff;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0}

/* ── PRICING HOW SECTION MOBILE FIX ── */
@media(max-width:768px){
  .pricing-how-grid{grid-template-columns:1fr!important;gap:2rem!important}
  .pricing-how-wg{grid-template-columns:1fr 1fr!important}
}
@media(max-width:480px){
  .pricing-how-wg{grid-template-columns:1fr!important}
}
