/*
Theme Name: GeekServices Pro
Theme URI: https://geekservices.com.au
Author: GeekServices
Author URI: https://geekservices.com.au
Description: A clean, image-led one-page theme for an on-site computer repair / tech support business serving Western Sydney. Features an editable hero image slider, services, an about section, service areas, reviews, FAQ and a callback form. Edit slider images, phone, email and ABN under Appearance > Customize.
Version: 2.3.2
Requires at least: 6.0
Tested up to: 6.9
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: geekservices
Tags: business, one-page, slider, custom-logo, custom-menu, responsive, featured-images
*/

/* ============================================================
   Base / reset  — defensive so the layout never breaks or
   drifts off-centre on a live WordPress install.
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body.geekservices{
  margin:0;
  width:100%;
  max-width:100%;
  overflow-x:hidden;
  background:#ffffff;
  color:#33425A;
  font-family:"Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
.geekservices img{max-width:100%;height:auto;display:block;}
.geekservices a{text-decoration:none;}
.geekservices a:not(.gs-btn){color:inherit;}
.geekservices h1,.geekservices h2,.geekservices h3,.geekservices h4{
  font-family:"Plus Jakarta Sans", system-ui, sans-serif;
  color:#16233B;line-height:1.15;margin:0;font-weight:700;letter-spacing:-.01em;
}
.geekservices p{margin:0;}
.geekservices ul{margin:0;padding:0;list-style:none;}

:root{
  --gs-accent:#4F46E5;
  --gs-accent-dark:#4338CA;
  --gs-accent-soft:#EEF0FE;
  --gs-ink:#16233B;
  --gs-body:#33425A;
  --gs-muted:#6B7A90;
  --gs-line:#E4E8F0;
  --gs-soft:#F5F7FC;
  --gs-green:#12996A;
  --gs-dark:#0F1A2C;
  --gs-radius:16px;
  --gs-shadow:0 1px 2px rgba(16,26,44,.05), 0 18px 40px -20px rgba(16,26,44,.22);
}

/* ============================================================
   Layout container — guarantees centred content
   ============================================================ */
.gs-container{
  width:100%;
  max-width:1180px;
  margin-left:auto;
  margin-right:auto;
  padding-left:22px;
  padding-right:22px;
}
.gs-section{padding:78px 0;}
.gs-soft-bg{background:var(--gs-soft);}

.gs-eyebrow{
  display:inline-block;font-size:13px;font-weight:700;letter-spacing:.13em;
  text-transform:uppercase;color:var(--gs-accent);margin-bottom:14px;
}
.gs-head{max-width:680px;margin:0 auto 8px;text-align:center;}
.gs-head h2{font-size:clamp(28px,3.6vw,40px);}
.gs-head p{color:var(--gs-muted);font-size:18px;margin-top:14px;}

/* buttons */
.gs-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:"Inter",sans-serif;font-weight:700;font-size:16px;
  padding:14px 26px;border-radius:10px;border:2px solid transparent;cursor:pointer;
  transition:transform .15s ease, background .2s ease, color .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.gs-btn-primary{background:var(--gs-accent);color:#fff;box-shadow:0 10px 24px -10px rgba(79,70,229,.8);}
.gs-btn-primary:hover{background:var(--gs-accent-dark);transform:translateY(-2px);}
.gs-btn-light{background:#fff;color:var(--gs-accent);}
.gs-btn-light:hover{transform:translateY(-2px);box-shadow:0 12px 24px -12px rgba(0,0,0,.3);}
.gs-btn-outline{background:transparent;border-color:rgba(255,255,255,.55);color:#fff;}
.gs-btn-outline:hover{background:rgba(255,255,255,.12);transform:translateY(-2px);}
.gs-btn svg{width:18px;height:18px;}

/* ============================================================
   Header
   ============================================================ */
.gs-header{position:sticky;top:0;z-index:80;background:#fff;border-bottom:1px solid var(--gs-line);}
.gs-nav{display:flex;align-items:center;gap:30px;height:74px;}
.gs-brand{display:flex;align-items:center;gap:11px;font-family:"Plus Jakarta Sans",sans-serif;font-weight:800;font-size:21px;color:var(--gs-ink);}
.gs-brand .gs-mark{position:relative;width:38px;height:38px;border-radius:10px;background:var(--gs-accent);display:grid;place-items:center;flex:none;}
.gs-brand .gs-mark svg{width:21px;height:21px;}
.gs-brand .gs-mark .gs-dot{position:absolute;top:-3px;right:-3px;width:12px;height:12px;border-radius:50%;background:var(--gs-green);border:2px solid #fff;}
.gs-brand b{color:var(--gs-accent);font-weight:800;}
.gs-menu{display:flex;gap:26px;margin-left:6px;}
.gs-menu a{font-size:15.5px;font-weight:500;color:var(--gs-body);transition:color .15s;}
.gs-menu a:hover{color:var(--gs-accent);}
.gs-nav-right{margin-left:auto;display:flex;align-items:center;gap:18px;}
.gs-nav-phone{text-align:right;line-height:1.15;}
.gs-nav-phone span{display:block;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--gs-muted);}
.gs-nav-phone a{font-family:"Plus Jakarta Sans",sans-serif;font-weight:700;font-size:18px;color:var(--gs-ink);}
.gs-burger{display:none;width:44px;height:44px;border:1.5px solid var(--gs-line);border-radius:10px;background:#fff;cursor:pointer;align-items:center;justify-content:center;}
.gs-burger svg{width:22px;height:22px;color:var(--gs-ink);}
.gs-mobile{display:none;}
.gs-custom-logo,.gs-brand img{max-height:48px;width:auto;}

/* ============================================================
   Hero slider
   ============================================================ */
.gs-hero{position:relative;background:var(--gs-dark);}
.gs-slider{position:relative;min-height:clamp(460px,56vw,600px);}
.gs-slide{
  position:absolute;inset:0;opacity:0;visibility:hidden;
  background-size:cover;background-position:center;
  transition:opacity .8s ease, visibility .8s ease;
  display:flex;align-items:center;
}
.gs-slide.is-active{opacity:1;visibility:visible;}
.gs-slide::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg, rgba(10,16,28,.86) 0%, rgba(10,16,28,.62) 45%, rgba(10,16,28,.15) 100%);
}
.gs-slide-inner{position:relative;z-index:2;width:100%;}
.gs-slide-inner .gs-box{max-width:620px;}
.gs-slide .gs-eyebrow{color:#A9B8FF;margin-bottom:16px;}
.gs-slide h1{color:#fff;font-size:clamp(30px,4.6vw,54px);font-weight:800;}
.gs-slide p{color:#D4DCEA;font-size:clamp(16px,2vw,20px);margin-top:18px;max-width:34em;}
.gs-slide-cta{margin-top:28px;display:flex;gap:13px;flex-wrap:wrap;}

.gs-arrow{
  position:absolute;top:50%;transform:translateY(-50%);z-index:5;
  width:48px;height:48px;border-radius:50%;border:none;cursor:pointer;
  background:rgba(255,255,255,.16);color:#fff;
  display:grid;place-items:center;transition:background .2s;
}
.gs-arrow:hover{background:rgba(255,255,255,.32);}
.gs-arrow svg{width:22px;height:22px;}
.gs-prev{left:18px;}
.gs-next{right:18px;}
.gs-dots{position:absolute;bottom:20px;left:0;right:0;z-index:5;display:flex;justify-content:center;gap:10px;}
.gs-dots button{width:11px;height:11px;border-radius:50%;border:none;background:rgba(255,255,255,.45);cursor:pointer;padding:0;transition:background .2s, transform .2s;}
.gs-dots button.is-active{background:#fff;transform:scale(1.25);}

/* ============================================================
   Trust bar
   ============================================================ */
.gs-trust{background:var(--gs-soft);border-bottom:1px solid var(--gs-line);}
.gs-trust .gs-container{display:flex;flex-wrap:wrap;gap:16px 34px;justify-content:center;padding-top:20px;padding-bottom:20px;}
.gs-trust-item{display:flex;align-items:center;gap:10px;font-weight:600;color:var(--gs-ink);font-size:15.5px;}
.gs-trust-item svg{width:20px;height:20px;color:var(--gs-green);flex:none;}

/* ============================================================
   Services
   ============================================================ */
.gs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:48px;}
.gs-card{background:#fff;border:1px solid var(--gs-line);border-radius:var(--gs-radius);padding:28px;transition:transform .18s, box-shadow .18s, border-color .18s;}
.gs-card:hover{transform:translateY(-5px);box-shadow:var(--gs-shadow);border-color:transparent;}
.gs-card .gs-ico{width:52px;height:52px;border-radius:13px;background:var(--gs-accent-soft);color:var(--gs-accent);display:grid;place-items:center;margin-bottom:18px;}
.gs-card .gs-ico svg{width:26px;height:26px;}
.gs-card h3{font-size:19px;}
.gs-card p{color:var(--gs-muted);font-size:15px;margin-top:9px;}

/* ============================================================
   About (image + text)
   ============================================================ */
.gs-about .gs-container{display:grid;grid-template-columns:1fr 1fr;gap:52px;align-items:center;}
.gs-about-img{border-radius:var(--gs-radius);overflow:hidden;box-shadow:var(--gs-shadow);}
.gs-about-img img{width:100%;display:block;}
.gs-about h2{font-size:clamp(26px,3.4vw,38px);}
.gs-about .gs-lead{color:var(--gs-muted);font-size:18px;margin-top:16px;}
.gs-checklist{margin-top:24px;display:grid;gap:14px;}
.gs-checklist li{display:flex;gap:13px;align-items:flex-start;}
.gs-checklist .gs-tick{flex:none;width:26px;height:26px;border-radius:50%;background:rgba(18,153,106,.12);color:var(--gs-green);display:grid;place-items:center;margin-top:2px;}
.gs-checklist .gs-tick svg{width:15px;height:15px;}
.gs-checklist b{color:var(--gs-ink);}
.gs-checklist span{color:var(--gs-muted);font-size:15px;}
.gs-about .gs-btn{margin-top:28px;}

/* ============================================================
   Guarantee band
   ============================================================ */
.gs-guarantee{background:var(--gs-accent);}
.gs-guarantee .gs-container{display:flex;align-items:center;gap:32px;flex-wrap:wrap;justify-content:center;text-align:center;padding-top:54px;padding-bottom:54px;}
.gs-seal{width:104px;height:104px;border-radius:50%;border:3px dashed rgba(255,255,255,.55);display:grid;place-items:center;color:#fff;font-family:"Plus Jakarta Sans",sans-serif;font-weight:800;font-size:14px;line-height:1.2;text-transform:uppercase;flex:none;}
.gs-guarantee-text{max-width:560px;}
.gs-guarantee-text h2{color:#fff;font-size:30px;}
.gs-guarantee-text p{color:rgba(255,255,255,.9);margin-top:10px;}

/* ============================================================
   Service areas
   ============================================================ */
.gs-areas .gs-container{display:grid;grid-template-columns:1.5fr 1fr;gap:48px;align-items:start;}
.gs-suburbs{display:grid;grid-template-columns:repeat(3,1fr);gap:10px 20px;margin-top:8px;}
.gs-suburbs li{display:flex;align-items:center;gap:9px;color:var(--gs-body);font-size:15.5px;}
.gs-suburbs li::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--gs-accent);flex:none;}
.gs-areas-note{background:var(--gs-dark);color:#fff;border-radius:var(--gs-radius);padding:30px;}
.gs-areas-note h3{color:#fff;font-size:21px;}
.gs-areas-note p{color:#AEBCD0;font-size:15px;margin-top:12px;}
.gs-areas-note .gs-btn{margin-top:20px;}
.gs-areas-head{text-align:left;margin:0 0 6px;}

/* ============================================================
   Reviews
   ============================================================ */
.gs-reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:48px;}
.gs-review{background:#fff;border:1px solid var(--gs-line);border-radius:var(--gs-radius);padding:26px;box-shadow:var(--gs-shadow);}
.gs-stars{color:#F5A623;letter-spacing:2px;font-size:16px;}
.gs-review p{margin-top:12px;color:var(--gs-body);font-size:15.5px;}
.gs-review .gs-who{margin-top:16px;font-weight:700;color:var(--gs-ink);font-size:14.5px;}
.gs-review .gs-where{color:var(--gs-muted);font-weight:500;}

/* ============================================================
   FAQ
   ============================================================ */
.gs-faq{max-width:820px;margin:44px auto 0;border-top:1px solid var(--gs-line);}
.gs-faq-item{border-bottom:1px solid var(--gs-line);}
.gs-faq-q{width:100%;background:none;border:none;text-align:left;cursor:pointer;padding:22px 0;display:flex;justify-content:space-between;align-items:center;gap:18px;font-family:"Plus Jakarta Sans",sans-serif;font-weight:700;font-size:18px;color:var(--gs-ink);}
.gs-faq-q .gs-plus{flex:none;width:28px;height:28px;border-radius:50%;border:1.5px solid var(--gs-line);display:grid;place-items:center;color:var(--gs-accent);transition:transform .25s, background .2s, color .2s;}
.gs-faq-q[aria-expanded="true"] .gs-plus{background:var(--gs-accent);border-color:var(--gs-accent);color:#fff;transform:rotate(45deg);}
.gs-faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease;}
.gs-faq-a p{color:var(--gs-muted);font-size:16px;padding-bottom:22px;}

/* ============================================================
   Contact
   ============================================================ */
.gs-contact .gs-container{display:grid;grid-template-columns:1fr 1.05fr;gap:50px;align-items:start;}
.gs-contact-left h2{font-size:clamp(26px,3.4vw,38px);}
.gs-contact-left .gs-lead{color:var(--gs-muted);font-size:18px;margin-top:14px;}
.gs-cinfo{margin-top:28px;display:grid;gap:18px;}
.gs-ci{display:flex;gap:14px;align-items:flex-start;}
.gs-ci .gs-ico{flex:none;width:46px;height:46px;border-radius:12px;background:var(--gs-accent-soft);color:var(--gs-accent);display:grid;place-items:center;}
.gs-ci .gs-ico svg{width:21px;height:21px;}
.gs-ci h4{font-size:15px;}
.gs-ci a,.gs-ci p{color:var(--gs-muted);font-size:15.5px;margin-top:2px;}
.gs-ci a:hover{color:var(--gs-accent);}
.gs-form{background:#fff;border:1px solid var(--gs-line);border-radius:var(--gs-radius);padding:30px;box-shadow:var(--gs-shadow);}
.gs-form h3{font-size:22px;}
.gs-form .gs-sub{color:var(--gs-muted);font-size:15px;margin-top:6px;}
.gs-field{margin-top:16px;}
.gs-field label{display:block;font-size:13px;font-weight:600;color:var(--gs-ink);margin-bottom:6px;}
.gs-field input,.gs-field select,.gs-field textarea{width:100%;font-family:inherit;font-size:16px;padding:13px 15px;border:1.5px solid var(--gs-line);border-radius:10px;background:#fff;color:var(--gs-ink);transition:border-color .15s, box-shadow .15s;}
.gs-field input:focus,.gs-field select:focus,.gs-field textarea:focus{outline:none;border-color:var(--gs-accent);box-shadow:0 0 0 3px rgba(79,70,229,.15);}
.gs-form .gs-btn{width:100%;margin-top:22px;}
.gs-form .gs-legal{font-size:12.5px;color:var(--gs-muted);text-align:center;margin-top:12px;}
.gs-form-done{display:none;text-align:center;padding:26px 8px;}
.gs-form-done.is-on{display:block;}
.gs-form-done .gs-big{width:60px;height:60px;border-radius:50%;background:rgba(18,153,106,.12);color:var(--gs-green);display:grid;place-items:center;margin:0 auto 16px;}
.gs-form-done h3{font-size:21px;}
.gs-form-done p{color:var(--gs-muted);margin-top:8px;}
.gs-hp{position:absolute !important;left:-9999px !important;width:1px;height:1px;overflow:hidden;}
.gs-form-error{background:#FDECEC;color:#B42318;border:1px solid #F3C2C2;padding:11px 14px;border-radius:9px;font-size:14.5px;margin-top:14px;}

/* ---- Contact Form 7 styled to match the theme ---- */
.gs-form .wpcf7-form p{margin:0 0 16px;}
.gs-form .wpcf7-form label{display:block;font-size:13px;font-weight:600;color:var(--gs-ink);margin-bottom:6px;}
.gs-form .wpcf7-form-control-wrap{display:block;margin-top:4px;}
.gs-form .wpcf7-form input[type=text],
.gs-form .wpcf7-form input[type=tel],
.gs-form .wpcf7-form input[type=email],
.gs-form .wpcf7-form input[type=number],
.gs-form .wpcf7-form select,
.gs-form .wpcf7-form textarea{
  width:100%;font-family:inherit;font-size:16px;padding:13px 15px;border:1.5px solid var(--gs-line);
  border-radius:10px;background:#fff;color:var(--gs-ink);transition:border-color .15s, box-shadow .15s;
}
.gs-form .wpcf7-form input:focus,
.gs-form .wpcf7-form select:focus,
.gs-form .wpcf7-form textarea:focus{outline:none;border-color:var(--gs-accent);box-shadow:0 0 0 3px rgba(79,70,229,.15);}
.gs-form .wpcf7-form input[type=submit]{
  width:100%;margin-top:8px;background:var(--gs-accent);color:#fff;border:none;cursor:pointer;
  font-family:"Inter",sans-serif;font-weight:700;font-size:16px;padding:15px 26px;border-radius:10px;
  box-shadow:0 10px 24px -10px rgba(79,70,229,.8);transition:background .2s, transform .15s;
}
.gs-form .wpcf7-form input[type=submit]:hover{background:var(--gs-accent-dark);transform:translateY(-2px);}
.gs-form .wpcf7-spinner{margin:14px auto 0;display:block;}
.gs-form .wpcf7-response-output{margin:16px 0 0 !important;border-radius:9px;font-size:14.5px;padding:11px 14px !important;}
.gs-form .wpcf7-not-valid-tip{color:#B42318;font-size:13px;font-weight:500;}
.gs-form .wpcf7 form.invalid .wpcf7-response-output,
.gs-form .wpcf7 form.unaccepted .wpcf7-response-output{border-color:#F3C2C2;background:#FDECEC;color:#B42318;}
.gs-form .wpcf7 form.sent .wpcf7-response-output{border-color:#BfE6D5;background:#EAF7F1;color:#0F7A53;}

/* ============================================================
   Footer
   ============================================================ */
.gs-footer{background:var(--gs-dark);color:#9FB0C6;padding:64px 0 28px;}
.gs-foot-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:34px;}
.gs-footer .gs-brand{color:#fff;}
.gs-footer .gs-brand b{color:#fff;}
.gs-foot-about{font-size:14.5px;margin-top:16px;max-width:26em;color:#9FB0C6;}
.gs-foot-col h5{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:#62758F;margin:0 0 16px;font-weight:700;}
.gs-foot-col a{display:block;font-size:14.5px;padding:5px 0;color:#9FB0C6;transition:color .15s;}
.gs-foot-col a:hover{color:#fff;}
.gs-socials{display:flex;gap:10px;margin-top:18px;}
.gs-socials a{width:38px;height:38px;border-radius:10px;border:1px solid rgba(255,255,255,.14);display:grid;place-items:center;color:#9FB0C6;transition:all .15s;}
.gs-socials a:hover{border-color:var(--gs-accent);color:#fff;}
.gs-socials svg{width:18px;height:18px;}
.gs-acknow{margin-top:44px;padding-top:24px;border-top:1px solid rgba(255,255,255,.08);font-size:13px;color:#7388A1;max-width:62em;}
.gs-foot-bottom{margin-top:22px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:13px;color:#62758F;}

/* admin bar offset */
.admin-bar .gs-header{top:32px;}
@media screen and (max-width:782px){.admin-bar .gs-header{top:46px;}}

/* ============================================================
   Reveal animation
   ============================================================ */
.gs-reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease, transform .6s ease;}
.gs-reveal.is-in{opacity:1;transform:none;}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:960px){
  .gs-grid,.gs-reviews-grid{grid-template-columns:1fr 1fr;}
  .gs-about .gs-container,.gs-areas .gs-container,.gs-contact .gs-container{grid-template-columns:1fr;gap:34px;}
  .gs-about-img{order:-1;}
  .gs-foot-top{grid-template-columns:1fr 1fr;gap:28px;}
}
@media (max-width:760px){
  .gs-menu,.gs-nav-phone{display:none;}
  .gs-burger{display:flex;}
  .gs-section{padding:56px 0;}
  .gs-grid,.gs-reviews-grid{grid-template-columns:1fr;}
  .gs-suburbs{grid-template-columns:1fr 1fr;}
  .gs-foot-top{grid-template-columns:1fr;}
  .gs-arrow{width:40px;height:40px;}
  .gs-prev{left:8px;}.gs-next{right:8px;}
  .gs-mobile.is-open{display:flex;flex-direction:column;padding:8px 22px 20px;border-top:1px solid var(--gs-line);background:#fff;}
  .gs-mobile a{padding:12px 0;font-weight:500;border-bottom:1px solid var(--gs-line);color:var(--gs-ink);}
  .gs-mobile .gs-btn{margin-top:14px;}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;}
  .gs-reveal{opacity:1;transform:none;}
}
.geekservices :focus-visible{outline:3px solid var(--gs-accent);outline-offset:2px;border-radius:6px;}
