/*
Theme Name: TheAppliance.Repair
Theme URI: https://theappliance.repair
Author: TheAppliance.Repair
Author URI: https://theappliance.repair
Description: A clean, fast, conversion-focused theme for domestic appliance repair businesses. Includes a hero with a call-to-action, services grid, brands strip, "why choose us", coverage area, testimonials and a booking/contact section. Inspired by classic appliance-repair service sites.
Version: 1.9.0
Requires at least: 6.0
Tested up to: 6.5
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: theappliance-repair
Tags: business, services, one-column, custom-logo, custom-menu, featured-images, full-width-template, footer-widgets, theme-options
*/

/* ==========================================================================
   Design tokens
   ========================================================================== */
:root{
  /* Bluehost Blueprint ocean palette */
  --tar-primary:#16425B;       /* Indigo Dye – primary / buttons */
  --tar-primary-dark:#0e2d3f;  /* deeper, for hover */
  --tar-accent:#30A2C5;        /* Pacific Cyan – ocean pop */
  --tar-accent-dark:#2386a3;
  --tar-green:#235E70;         /* Midnight Green */
  --tar-blue:#2F6690;          /* Lapis Lazuli */
  --tar-dark:#0f2c3d;          /* deep ocean navy */
  --tar-text:#16242e;
  --tar-muted:#516573;
  --tar-light:#eef5f9;         /* Columbia Blue tint */
  --tar-border:#d2e3ec;
  --tar-white:#ffffff;
  --tar-radius:6px;
  --tar-btn-radius:4px;        /* near-square, Blueprint-style buttons */
  --tar-shadow:0 10px 30px rgba(15,44,61,.08);
  --tar-shadow-lg:0 20px 50px rgba(15,44,61,.16);
  --tar-max:1180px;
  --tar-font:'Roboto Flex',system-ui,-apple-system,'Segoe UI',Roboto,Arial,sans-serif;
}

/* ==========================================================================
   Reset-ish base
   ========================================================================== */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--tar-font);
  color:var(--tar-text);
  line-height:1.65;
  background:var(--tar-white);
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--tar-primary);text-decoration:none}
a:hover{color:var(--tar-primary-dark)}
h1,h2,h3,h4{color:var(--tar-dark);line-height:1.2;margin:0 0 .5em}
h1{font-size:clamp(2rem,5vw,3.25rem);font-weight:800;letter-spacing:-.02em}
h2{font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:800;letter-spacing:-.01em}
h3{font-size:1.25rem;font-weight:700}
p{margin:0 0 1rem}
.tar-container{max-width:var(--tar-max);margin:0 auto;padding:0 20px}
.tar-section{padding:80px 0}
.tar-section--alt{background:var(--tar-light)}
.tar-center{text-align:center}
.tar-lead{font-size:1.15rem;color:var(--tar-muted);max-width:680px;margin:0 auto 2.5rem}
.tar-eyebrow{
  display:inline-block;text-transform:uppercase;letter-spacing:.12em;
  font-size:.78rem;font-weight:700;color:var(--tar-primary);margin-bottom:.6rem;
}

/* ==========================================================================
   Icons (inline SVG)
   ========================================================================== */
.tar-ic{flex:none;vertical-align:middle}
.tar-topbar__item .tar-ic{opacity:.85}
.tar-stars{display:inline-flex;gap:3px;color:var(--tar-accent)}
.tar-areas span{display:inline-flex;align-items:center;gap:7px}
.tar-card__icon .tar-ic{width:28px;height:28px}
.tar-footer p .tar-ic{margin-right:3px;opacity:.85}

/* ==========================================================================
   Buttons
   ========================================================================== */
.tar-btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:15px 28px;border-radius:var(--tar-btn-radius);font-weight:600;font-size:1rem;letter-spacing:.01em;
  cursor:pointer;border:none;transition:transform .15s ease,box-shadow .2s ease,background .2s;
}
.tar-btn:hover{transform:translateY(-2px)}
.tar-btn--primary{background:var(--tar-primary);color:#fff;box-shadow:0 8px 20px rgba(22,66,91,.30)}
.tar-btn--primary:hover{background:var(--tar-primary-dark);color:#fff}
.tar-btn--ghost{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.6)}
.tar-btn--ghost:hover{background:rgba(255,255,255,.12);color:#fff}
.tar-btn--solid{background:var(--tar-primary);color:#fff}
.tar-btn--solid:hover{background:var(--tar-primary-dark);color:#fff}

/* ==========================================================================
   Top bar + header
   ========================================================================== */
.tar-topbar{
  background:var(--tar-dark);color:#cfe0ff;font-size:.88rem;
}
.tar-topbar .tar-container{display:flex;justify-content:space-between;align-items:center;padding-top:8px;padding-bottom:8px;gap:12px;flex-wrap:wrap}
.tar-topbar a{color:#fff}
.tar-topbar__item{display:inline-flex;align-items:center;gap:6px}

.tar-header{
  position:sticky;top:0;z-index:50;background:rgba(255,255,255,.96);
  backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid var(--tar-border);
}
.tar-header .tar-container{display:flex;align-items:center;justify-content:space-between;padding-top:14px;padding-bottom:14px}
.tar-brand{display:flex;align-items:center;gap:12px;font-weight:800;font-size:1.3rem;color:var(--tar-dark)}
.tar-brand .tar-logo-mark{
  width:40px;height:40px;border-radius:var(--tar-radius);display:grid;place-items:center;
  background:linear-gradient(135deg,var(--tar-primary),var(--tar-primary-dark));color:#fff;
  font-size:.95rem;font-weight:800;letter-spacing:.03em;
}
.tar-brand span b{color:var(--tar-primary)}
.tar-nav{display:flex;align-items:center;gap:26px}
.tar-nav ul{display:flex;gap:24px;list-style:none;margin:0;padding:0}
.tar-nav a{color:var(--tar-text);font-weight:600;font-size:.98rem}
.tar-nav a:hover{color:var(--tar-primary)}
.tar-header__cta{display:flex;align-items:center;gap:16px}
.tar-phone{display:inline-flex;align-items:center;gap:6px;font-weight:800;color:var(--tar-dark);white-space:nowrap}
.tar-phone:hover{color:var(--tar-primary)}
.tar-burger{display:none;background:none;border:none;font-size:1.6rem;cursor:pointer;color:var(--tar-dark)}

/* ==========================================================================
   Hero
   ========================================================================== */
.tar-hero{
  position:relative;color:#fff;
  background:
    linear-gradient(120deg,rgba(15,44,61,.95),rgba(47,102,144,.82)),
    url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="80" height="20"><path d="M0 10 Q20 0 40 10 T80 10" fill="none" stroke="%23ffffff" stroke-opacity="0.06" stroke-width="2"/></svg>') var(--tar-primary-dark);
}
.tar-hero{overflow:hidden}
.tar-hero__video{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;
}
.tar-hero__overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(120deg,rgba(15,44,61,.90),rgba(47,102,144,.74));
}
.tar-hero__inner{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;padding:84px 0;position:relative;z-index:2}
.tar-hero h1{color:#fff}
.tar-hero p{font-size:1.2rem;color:#dbe7ff;margin-bottom:1.8rem}
.tar-hero__btns{display:flex;gap:14px;flex-wrap:wrap}
.tar-hero__badges{display:flex;gap:24px;margin-top:2rem;flex-wrap:wrap}
.tar-hero__badge{display:flex;align-items:center;gap:10px;font-weight:600;color:#fff}
.tar-hero__badge svg{flex:none}

/* Quick booking card */
.tar-bookcard{
  background:#fff;color:var(--tar-text);border-radius:var(--tar-radius);
  padding:28px;box-shadow:var(--tar-shadow-lg);
}
.tar-bookcard h3{margin-bottom:.25rem}
.tar-bookcard p{color:var(--tar-muted);font-size:.95rem}
.tar-field{margin-bottom:14px}
.tar-field label{display:block;font-weight:600;font-size:.85rem;margin-bottom:6px;color:var(--tar-dark)}
.tar-field input,.tar-field select,.tar-field textarea{
  width:100%;padding:12px 14px;border:1px solid var(--tar-border);border-radius:var(--tar-radius);
  font-family:inherit;font-size:1rem;background:#fbfcfe;
}
.tar-field input:focus,.tar-field select:focus,.tar-field textarea:focus{
  outline:none;border-color:var(--tar-primary);box-shadow:0 0 0 3px rgba(11,108,240,.15);
}
.tar-bookcard .tar-btn{width:100%;justify-content:center;margin-top:6px}

/* ==========================================================================
   Brands strip
   ========================================================================== */
.tar-brands{background:#fff;border-bottom:1px solid var(--tar-border)}
.tar-brands .tar-container{display:flex;align-items:center;justify-content:center;gap:42px;flex-wrap:wrap;padding:28px 20px}
.tar-brands span{font-weight:800;font-size:1.3rem;color:#9aa7b8;letter-spacing:.02em;transition:color .2s}
.tar-brands span:hover{color:var(--tar-dark)}

/* ==========================================================================
   Services grid
   ========================================================================== */
.tar-grid{display:grid;gap:26px}
.tar-grid--3{grid-template-columns:repeat(3,1fr)}
.tar-grid--4{grid-template-columns:repeat(4,1fr)}
.tar-card{
  background:#fff;border:1px solid var(--tar-border);border-radius:var(--tar-radius);
  padding:30px 26px;box-shadow:var(--tar-shadow);transition:transform .2s ease,box-shadow .2s ease;
}
.tar-card:hover{transform:translateY(-6px);box-shadow:var(--tar-shadow-lg)}
.tar-card__icon{
  width:58px;height:58px;border-radius:var(--tar-radius);display:grid;place-items:center;margin-bottom:16px;
  background:linear-gradient(135deg,rgba(22,66,91,.12),rgba(48,162,197,.14));color:var(--tar-primary);
}
.tar-card h3{margin-bottom:.4rem}
.tar-card p{color:var(--tar-muted);font-size:.97rem;margin:0}

/* ==========================================================================
   Why choose / features
   ========================================================================== */
.tar-why{display:block}
.tar-why__features{display:grid;grid-template-columns:1fr 1fr;gap:26px 40px;margin-top:10px}
.tar-feature{display:flex;gap:16px;margin-bottom:0}
.tar-feature__icon{
  flex:none;width:46px;height:46px;border-radius:var(--tar-radius);display:grid;place-items:center;
  background:var(--tar-accent);color:#fff;font-weight:800;
}
.tar-feature h3{margin-bottom:.25rem;font-size:1.1rem}
.tar-feature p{color:var(--tar-muted);margin:0;font-size:.96rem}

/* ==========================================================================
   Steps
   ========================================================================== */
.tar-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;counter-reset:step}
.tar-step{text-align:center;position:relative}
.tar-step__num{
  width:64px;height:64px;margin:0 auto 16px;border-radius:var(--tar-radius);display:grid;place-items:center;
  background:#fff;border:2px solid var(--tar-primary);color:var(--tar-primary);font-size:1.5rem;font-weight:800;
}

/* ==========================================================================
   Coverage / areas
   ========================================================================== */
.tar-areas{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:30px}
.tar-areas span{
  background:#fff;border:1px solid var(--tar-border);border-radius:var(--tar-radius);padding:8px 18px;
  font-weight:600;font-size:.92rem;color:var(--tar-text);
}

/* ==========================================================================
   Testimonials
   ========================================================================== */
.tar-quote{background:#fff;border:1px solid var(--tar-border);border-radius:var(--tar-radius);padding:28px;box-shadow:var(--tar-shadow)}
.tar-stars{color:var(--tar-accent);font-size:1.1rem;letter-spacing:2px;margin-bottom:10px}
.tar-quote p{font-style:italic;color:var(--tar-text)}
.tar-quote__author{display:flex;align-items:center;gap:12px;margin-top:16px}
.tar-quote__avatar{width:44px;height:44px;border-radius:var(--tar-radius);background:var(--tar-primary);color:#fff;display:grid;place-items:center;font-weight:700}
.tar-quote__author b{display:block}
.tar-quote__author small{color:var(--tar-muted)}

/* ==========================================================================
   CTA band
   ========================================================================== */
.tar-cta{
  background:linear-gradient(120deg,var(--tar-primary),var(--tar-green));color:#fff;text-align:center;
}
.tar-cta h2{color:#fff}
.tar-cta p{font-size:1.15rem;color:#d9eef4;max-width:620px;margin:0 auto 1.6rem}
.tar-cta .tar-btn--solid{background:#fff;color:var(--tar-primary)}
.tar-cta .tar-btn--solid:hover{background:#fff;color:var(--tar-dark)}

/* ==========================================================================
   Footer
   ========================================================================== */
.tar-footer{background:var(--tar-dark);color:#aebcce;padding:64px 0 0}
.tar-footer a{color:#cfe0ff}
.tar-footer a:hover{color:#fff}
.tar-footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:36px}
.tar-footer h4{color:#fff;margin-bottom:1rem;font-size:1.05rem}
.tar-footer ul{list-style:none;margin:0;padding:0}
.tar-footer li{margin-bottom:10px}
.tar-footer__brand{display:flex;align-items:center;gap:12px;color:#fff;font-weight:800;font-size:1.25rem;margin-bottom:14px}
.tar-footer__bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:48px;padding:22px 0;text-align:center;font-size:.9rem}

/* ==========================================================================
   Generic content (posts/pages)
   ========================================================================== */
.tar-content{max-width:760px;margin:0 auto;padding:60px 20px}
.tar-content img{border-radius:var(--tar-radius);margin:1.5rem 0}
.tar-post-meta{color:var(--tar-muted);font-size:.9rem;margin-bottom:1.5rem}
.tar-pagination{display:flex;gap:10px;justify-content:center;margin:40px 0}
.tar-pagination a,.tar-pagination span{padding:8px 14px;border:1px solid var(--tar-border);border-radius:var(--tar-radius)}

/* Sticky mobile call/book bar — hidden on desktop, shown under 760px */
.tar-mobilebar{display:none}

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width:980px){
  .tar-hero__inner{grid-template-columns:1fr;gap:36px;padding:56px 0}
  .tar-why__features{grid-template-columns:1fr}
  .tar-grid--4{grid-template-columns:repeat(2,1fr)}
  .tar-footer__grid{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .tar-nav,.tar-header__cta .tar-phone{display:none}
  .tar-burger{display:block}
  .tar-nav.is-open{
    display:flex;position:absolute;top:100%;left:0;right:0;background:#fff;
    flex-direction:column;align-items:flex-start;padding:18px 20px;border-bottom:1px solid var(--tar-border);
  }
  .tar-nav.is-open ul{flex-direction:column;gap:14px;width:100%}
  .tar-grid--3,.tar-grid--4,.tar-steps{grid-template-columns:1fr}
  .tar-section{padding:56px 0}
  .tar-footer__grid{grid-template-columns:1fr}

  /* Larger, easy-to-tap buttons that stack full width */
  .tar-hero__btns{flex-direction:column}
  .tar-hero__btns .tar-btn,.tar-cta .tar-btn{width:100%;justify-content:center}
  .tar-header__cta .tar-btn--primary{padding:10px 16px;font-size:.92rem}
  .tar-brand{font-size:1.12rem}
  .tar-brand .tar-logo-mark{width:34px;height:34px}

  /* Drop the background video on phones to save data/battery */
  .tar-hero__video{display:none}

  /* Sticky bottom call/book bar (mobile only) */
  body{padding-bottom:72px}
  .tar-mobilebar{
    display:grid;grid-template-columns:1fr 1fr;gap:8px;
    position:fixed;left:0;right:0;bottom:0;z-index:60;
    padding:8px;background:#fff;border-top:1px solid var(--tar-border);
    box-shadow:0 -6px 20px rgba(15,44,61,.12);
  }
  .tar-mobilebar .tar-btn{width:100%;justify-content:center;padding:13px 10px;font-size:.98rem}
}

/* Phone-only refinements */
@media (max-width:600px){
  .tar-topbar{font-size:.8rem}
  .tar-topbar .tar-container{justify-content:center;gap:10px}
  .tar-topbar__email{display:none}
  .tar-hero__inner{padding:40px 0}
  .tar-hero__badges{gap:14px}
  .tar-bookcard{padding:22px}
}
@media (max-width:430px){
  .tar-header__cta .tar-btn--primary{display:none}
}
