/*
Theme Name: EzeeVolt
Theme URI: https://ezeevolt.com
Author: Zeeshan Ali
Author URI: https://ezeevolt.com
Description: Custom engineering-services theme for EzeeVolt — electrical installation, solar, HVAC, CCTV, water filtration and estimation services. Fully responsive for phone, tablet and desktop.
Version: 1.0.0
Requires at least: 6.0
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: ezeevolt
Tags: custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready
*/

/* ════════════════════════════════════════════════════════
   TOKENS
   ════════════════════════════════════════════════════════ */
:root{
  --navy:    #0B1E3D;
  --navy2:   #1C2E4A;
  --amber:   #F5A623;
  --amber2:  #FFB84D;
  --green:   #00C896;
  --white:   #F0F4FA;
  --muted:   #8FA3C0;
  --card-bg: #162338;
  --border:  rgba(245,166,35,0.18);
  --font-display: 'Rajdhani', sans-serif;
  --font-body:    'Inter', sans-serif;
  --radius: 10px;
  --transition: 0.3s ease;
}

/* ════════════════════════════════════════════════════════
   RESET / BASE
   ════════════════════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{background:var(--navy);color:var(--white);font-family:var(--font-body);line-height:1.65;overflow-x:hidden;font-size:16px;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;height:auto;}
ul,ol{list-style:none;}
button{font-family:inherit;cursor:pointer;}
input,select,textarea{font-family:inherit;}
.skip-link{position:absolute;left:-9999px;}
.skip-link:focus{
  left:10px;top:10px;z-index:9999;background:var(--amber);color:var(--navy);
  padding:10px 16px;border-radius:6px;font-weight:700;
}
:focus-visible{outline:2px solid var(--amber);outline-offset:3px;}

.container{max-width:1280px;margin:0 auto;padding:0 5vw;}

/* ════════════════════════════════════════════════════════
   NAV
   ════════════════════════════════════════════════════════ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:900;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 5vw;height:68px;
  background:rgba(11,30,61,0.92);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--border);
}
.logo{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-size:1.55rem;font-weight:700;letter-spacing:1px;}
.logo img{height:32px;width:auto;}
.logo span.accent{color:var(--amber);}
.logo svg{width:32px;height:32px;}

.main-navigation{display:flex;align-items:center;gap:1.5rem;}
.main-navigation ul{display:flex;gap:2rem;align-items:center;}
.main-navigation ul ul{
  position:absolute;top:100%;left:0;background:var(--navy2);
  min-width:200px;border:1px solid var(--border);border-radius:8px;
  padding:0.5rem;flex-direction:column;gap:0;display:none;
}
.main-navigation li{position:relative;}
.main-navigation li:hover > ul{display:flex;}
.main-navigation ul ul li a{display:block;padding:8px 12px;border-radius:5px;}
.main-navigation ul ul li a:hover{background:rgba(245,166,35,0.08);}
.main-navigation a{color:var(--muted);transition:color var(--transition);font-size:0.9rem;font-weight:500;letter-spacing:0.5px;}
.main-navigation a:hover,.main-navigation .current-menu-item > a{color:var(--amber);}

.nav-cta{
  background:var(--amber);color:var(--navy) !important;
  padding:8px 20px;border-radius:6px;
  font-family:var(--font-display);font-weight:700;font-size:0.95rem;
  transition:background var(--transition),transform var(--transition);
}
.nav-cta:hover{background:var(--amber2);transform:translateY(-1px);}

.menu-toggle{
  display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;
  background:none;border:none;
}
.menu-toggle span{width:24px;height:2px;background:var(--white);border-radius:2px;transition:var(--transition);}
.menu-toggle.is-active span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.menu-toggle.is-active span:nth-child(2){opacity:0;}
.menu-toggle.is-active span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* ════════════════════════════════════════════════════════
   HERO
   ════════════════════════════════════════════════════════ */
.hero{
  min-height:100vh;display:flex;align-items:center;
  padding:100px 5vw 60px;
  position:relative;overflow:hidden;
}
.circuit-bg{
  position:absolute;inset:0;opacity:0.07;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80'%3E%3Crect width='80' height='80' fill='none'/%3E%3Cpath d='M0 40h20m20 0h20m20 0h20M40 0v20m0 20v20m0 20v20' stroke='%23F5A623' stroke-width='1' fill='none'/%3E%3Ccircle cx='40' cy='40' r='3' fill='%23F5A623'/%3E%3Ccircle cx='0' cy='40' r='2' fill='%23F5A623'/%3E%3Ccircle cx='80' cy='40' r='2' fill='%23F5A623'/%3E%3Ccircle cx='40' cy='0' r='2' fill='%23F5A623'/%3E%3Ccircle cx='40' cy='80' r='2' fill='%23F5A623'/%3E%3C/svg%3E");
}
.circuit-anim{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;}
.circuit-path{stroke-dasharray:2000;stroke-dashoffset:2000;animation:trace 4s ease forwards 0.5s;}
@keyframes trace{to{stroke-dashoffset:0;}}

.hero-inner{position:relative;max-width:700px;z-index:2;}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:0.78rem;font-weight:600;letter-spacing:2px;text-transform:uppercase;
  color:var(--green);margin-bottom:1.4rem;
}
.eyebrow::before{content:'';width:32px;height:2px;background:var(--green);}
.hero h1{
  font-family:var(--font-display);font-size:clamp(2.2rem,6vw,4.2rem);
  font-weight:700;line-height:1.08;letter-spacing:0.5px;margin-bottom:1.5rem;
}
.hero h1 .line-amber{color:var(--amber);}
.hero h1 .line-dim{color:var(--muted);font-weight:400;}
.hero-sub{font-size:1.05rem;color:var(--muted);max-width:560px;margin-bottom:2.4rem;line-height:1.75;}
.hero-sub strong{color:var(--white);}
.hero-btns{display:flex;flex-wrap:wrap;gap:14px;}
.btn-primary{
  background:var(--amber);color:var(--navy);
  padding:14px 32px;border-radius:8px;
  font-family:var(--font-display);font-weight:700;font-size:1.05rem;
  display:inline-block;transition:all var(--transition);
}
.btn-primary:hover{background:var(--amber2);transform:translateY(-2px);box-shadow:0 8px 24px rgba(245,166,35,0.35);}
.btn-outline{
  border:1.5px solid var(--border);color:var(--white);
  padding:14px 32px;border-radius:8px;display:inline-block;
  font-family:var(--font-display);font-weight:600;font-size:1.05rem;
  transition:all var(--transition);
}
.btn-outline:hover{border-color:var(--amber);color:var(--amber);}
.hero-stats{display:flex;gap:2.5rem;margin-top:3.5rem;padding-top:2rem;border-top:1px solid var(--border);flex-wrap:wrap;}
.stat-val{font-family:var(--font-display);font-size:2rem;font-weight:700;color:var(--amber);}
.stat-label{font-size:0.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px;}

/* ════════════════════════════════════════════════════════
   SECTIONS SHARED
   ════════════════════════════════════════════════════════ */
.section-tag{display:inline-block;font-size:0.72rem;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--amber);margin-bottom:0.7rem;}
.section-title{font-family:var(--font-display);font-size:clamp(1.7rem,4vw,2.6rem);font-weight:700;line-height:1.15;margin-bottom:1rem;}
.section-sub{color:var(--muted);font-size:0.97rem;max-width:580px;margin-bottom:3rem;}
section{padding:90px 5vw;}
section.has-bg-navy2{background:var(--navy2);}
section.has-bg-navy{background:var(--navy);}

/* SERVICES */
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.5rem;}
.service-card{
  background:var(--card-bg);border:1px solid var(--border);
  border-radius:var(--radius);padding:2rem 1.75rem;
  position:relative;overflow:hidden;
  transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition);
}
.service-card::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--amber),var(--green));
  transform:scaleX(0);transform-origin:left;transition:transform var(--transition);
}
.service-card:hover{transform:translateY(-5px);box-shadow:0 16px 40px rgba(0,0,0,0.4);border-color:rgba(245,166,35,0.4);}
.service-card:hover::after{transform:scaleX(1);}
.svc-icon{
  width:50px;height:50px;border-radius:10px;
  background:rgba(245,166,35,0.1);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:1.2rem;font-size:1.5rem;
}
.svc-title{font-family:var(--font-display);font-size:1.15rem;font-weight:700;margin-bottom:0.6rem;}
.svc-desc{font-size:0.88rem;color:var(--muted);line-height:1.65;}

/* HOW IT WORKS */
.steps-row{display:flex;flex-wrap:wrap;gap:2rem;}
.step{flex:1;min-width:220px;position:relative;}
.step-num{font-family:var(--font-display);font-size:3rem;font-weight:700;color:rgba(245,166,35,0.12);line-height:1;margin-bottom:0.4rem;}
.step-title{font-family:var(--font-display);font-size:1.1rem;font-weight:700;margin-bottom:0.5rem;color:var(--white);}
.step-desc{font-size:0.88rem;color:var(--muted);}

/* CALCULATORS */
.calc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:1.2rem;}
.calc-card{
  background:var(--navy);border:1px solid var(--border);
  border-radius:var(--radius);padding:1.5rem;
  display:flex;align-items:flex-start;gap:1rem;
  transition:border-color var(--transition),transform var(--transition);
  cursor:pointer;
}
.calc-card:hover{border-color:var(--green);transform:translateY(-3px);}
.calc-icon{
  font-size:1.4rem;width:44px;height:44px;flex-shrink:0;
  background:rgba(0,200,150,0.08);border:1px solid rgba(0,200,150,0.2);
  border-radius:8px;display:flex;align-items:center;justify-content:center;
}
.calc-title{font-family:var(--font-display);font-size:0.97rem;font-weight:700;margin-bottom:0.3rem;}
.calc-desc{font-size:0.8rem;color:var(--muted);}
.calc-badge{
  font-size:0.65rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;
  background:rgba(0,200,150,0.12);color:var(--green);
  padding:2px 8px;border-radius:4px;margin-top:6px;display:inline-block;
}

/* REGISTER */
.register-cards{display:grid;grid-template-columns:1fr 1fr;gap:2rem;}
.reg-card{border-radius:var(--radius);padding:2.5rem 2rem;border:1px solid var(--border);position:relative;overflow:hidden;}
.reg-card.client{background:linear-gradient(135deg,#122040,#1a2e50);}
.reg-card.tech{background:linear-gradient(135deg,#0d1f0a,#122040);}
.reg-label{font-family:var(--font-display);font-size:0.7rem;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;padding:4px 12px;border-radius:4px;margin-bottom:1.2rem;display:inline-block;}
.client .reg-label{background:rgba(245,166,35,0.12);color:var(--amber);}
.tech .reg-label{background:rgba(0,200,150,0.12);color:var(--green);}
.reg-title{font-family:var(--font-display);font-size:1.5rem;font-weight:700;margin-bottom:0.7rem;}
.reg-desc{font-size:0.88rem;color:var(--muted);margin-bottom:1.6rem;line-height:1.65;}
.reg-btn{display:inline-block;padding:11px 26px;border-radius:7px;font-family:var(--font-display);font-weight:700;font-size:0.97rem;transition:all var(--transition);}
.client .reg-btn{background:var(--amber);color:var(--navy);}
.tech .reg-btn{background:var(--green);color:var(--navy);}
.reg-btn:hover{transform:translateY(-2px);opacity:0.9;}
.reg-bullets li{font-size:0.85rem;color:var(--muted);padding:4px 0;display:flex;gap:8px;align-items:flex-start;}
.reg-bullets li::before{content:'✦';color:var(--amber);font-size:0.7rem;margin-top:4px;flex-shrink:0;}
.tech .reg-bullets li::before{color:var(--green);}
.reg-bullets{margin:0 0 1.6rem;}

/* COVERAGE */
.coverage{background:linear-gradient(180deg,var(--navy2) 0%,var(--navy) 100%);text-align:center;}
.coverage .section-sub{margin-left:auto;margin-right:auto;text-align:center;}
.countries{display:flex;flex-wrap:wrap;justify-content:center;gap:0.8rem;margin-top:2rem;}
.country-pill{padding:8px 18px;border-radius:40px;border:1px solid var(--border);font-size:0.85rem;color:var(--muted);transition:all var(--transition);background:none;}
.country-pill:hover,.country-pill.active{border-color:var(--amber);color:var(--amber);background:rgba(245,166,35,0.06);}
.lang-row,.units-row{display:flex;justify-content:center;gap:1rem;margin-top:1.5rem;flex-wrap:wrap;align-items:center;}
.lang-pill{padding:6px 16px;border-radius:6px;background:rgba(255,255,255,0.05);font-size:0.82rem;color:var(--muted);}
.unit-tag{padding:5px 14px;border-radius:5px;background:rgba(0,200,150,0.08);border:1px solid rgba(0,200,150,0.18);font-size:0.8rem;color:var(--green);}
.row-label{font-size:0.78rem;color:var(--muted);letter-spacing:1px;text-transform:uppercase;}

/* CONTACT */
.contact-inner{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start;}
.contact-info h3{font-family:var(--font-display);font-size:1.6rem;margin-bottom:1rem;}
.contact-line{display:flex;gap:12px;align-items:center;padding:0.75rem 0;border-bottom:1px solid var(--border);}
.contact-line:last-child{border-bottom:none;}
.c-icon{width:36px;height:36px;border-radius:8px;background:rgba(245,166,35,0.08);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0;}
.c-label{font-size:0.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px;}
.c-val{font-size:0.92rem;color:var(--white);}
.contact-form{display:flex;flex-direction:column;gap:1rem;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.field{display:flex;flex-direction:column;gap:5px;}
.field label{font-size:0.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px;}
.field input,.field select,.field textarea{
  background:var(--navy);border:1px solid var(--border);border-radius:7px;padding:11px 14px;
  color:var(--white);font-family:var(--font-body);font-size:0.92rem;outline:none;
  transition:border-color var(--transition);width:100%;
}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--amber);}
.field select option{background:var(--navy2);}
.field textarea{resize:vertical;min-height:100px;}
.submit-btn{
  background:var(--amber);color:var(--navy);padding:13px 28px;border-radius:8px;border:none;
  font-family:var(--font-display);font-weight:700;font-size:1rem;transition:all var(--transition);
  align-self:flex-start;
}
.submit-btn:hover{background:var(--amber2);transform:translateY(-2px);box-shadow:0 8px 20px rgba(245,166,35,0.3);}

/* ════════════════════════════════════════════════════════
   GENERIC PAGE / BLOG CONTENT (page.php, single.php, archive)
   ════════════════════════════════════════════════════════ */
.site-content{padding-top:68px;}
.page-header-banner{padding:140px 5vw 50px;background:var(--navy2);}
.page-header-banner h1{font-family:var(--font-display);font-size:clamp(1.8rem,4vw,2.6rem);font-weight:700;}
.entry-content{padding:60px 5vw;max-width:800px;margin:0 auto;}
.entry-content p{margin-bottom:1.2rem;color:var(--white);}
.entry-content h2,.entry-content h3{font-family:var(--font-display);margin:1.8rem 0 1rem;color:var(--white);}
.entry-content img{border-radius:var(--radius);margin:1.5rem 0;}
.entry-content a{color:var(--amber);text-decoration:underline;}
.entry-content ul,.entry-content ol{margin:0 0 1.2rem 1.4rem;color:var(--white);}
.entry-content ul{list-style:disc;}
.entry-content ol{list-style:decimal;}
.post-meta{font-size:0.82rem;color:var(--muted);margin-bottom:1rem;}
.comment-list{list-style:none;}
.comment-respond input,.comment-respond textarea{
  background:var(--navy2);border:1px solid var(--border);border-radius:7px;
  padding:10px 14px;color:var(--white);width:100%;margin-bottom:1rem;
}
.comment-respond .form-submit input{
  background:var(--amber);color:var(--navy);font-weight:700;border:none;width:auto;padding:11px 26px;
}
.pagination{display:flex;gap:1rem;justify-content:center;padding:2rem 0;}
.pagination a,.pagination span{
  padding:8px 16px;border:1px solid var(--border);border-radius:6px;color:var(--muted);
}
.pagination .current{color:var(--amber);border-color:var(--amber);}

.widget-area{padding:2rem;background:var(--navy2);border-radius:var(--radius);}
.widget{margin-bottom:2rem;}
.widget-title{font-family:var(--font-display);font-size:1.1rem;margin-bottom:1rem;}
.widget ul li{padding:6px 0;border-bottom:1px solid var(--border);font-size:0.9rem;color:var(--muted);}
.widget a:hover{color:var(--amber);}

/* ════════════════════════════════════════════════════════
   FOOTER
   ════════════════════════════════════════════════════════ */
.site-footer{background:#060F1D;border-top:1px solid var(--border);padding:50px 5vw 24px;}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem;}
.footer-brand .logo{margin-bottom:1rem;}
.footer-brand p{font-size:0.85rem;color:var(--muted);line-height:1.7;max-width:260px;}
.footer-col h5{font-family:var(--font-display);font-weight:700;font-size:0.9rem;letter-spacing:1px;color:var(--white);margin-bottom:1rem;}
.footer-col li{margin-bottom:0.55rem;}
.footer-col a{font-size:0.85rem;color:var(--muted);transition:color var(--transition);}
.footer-col a:hover{color:var(--amber);}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;padding-top:1.5rem;
  border-top:1px solid var(--border);font-size:0.8rem;color:var(--muted);flex-wrap:wrap;gap:0.5rem;
}
.social-row{display:flex;gap:12px;}
.social-btn{width:34px;height:34px;border-radius:7px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:0.9rem;transition:all var(--transition);}
.social-btn:hover{border-color:var(--amber);color:var(--amber);}

/* ════════════════════════════════════════════════════════
   SCROLL REVEAL
   ════════════════════════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 0.65s ease,transform 0.65s ease;}
.reveal.visible{opacity:1;transform:none;}

/* ════════════════════════════════════════════════════════
   RESPONSIVE — TABLET (≤1024px)
   ════════════════════════════════════════════════════════ */
@media(max-width:1024px){
  .footer-top{grid-template-columns:1fr 1fr;}
  .contact-inner{grid-template-columns:1fr;gap:2.5rem;}
}

/* ════════════════════════════════════════════════════════
   RESPONSIVE — SMALL TABLET / LARGE PHONE (≤900px)
   ════════════════════════════════════════════════════════ */
@media(max-width:900px){
  .register-cards{grid-template-columns:1fr;}
  .form-row{grid-template-columns:1fr;}
  section{padding:70px 5vw;}
  .hero{padding:90px 5vw 50px;}
}

/* ════════════════════════════════════════════════════════
   RESPONSIVE — PHONE (≤680px)
   ════════════════════════════════════════════════════════ */
@media(max-width:680px){
  .main-navigation{
    position:fixed;top:68px;left:0;right:0;bottom:0;
    background:var(--navy);flex-direction:column;align-items:flex-start;
    padding:1.5rem 5vw;overflow-y:auto;
    transform:translateX(100%);transition:transform 0.3s ease;
    z-index:899;
  }
  .main-navigation.is-open{transform:translateX(0);}
  .main-navigation ul{flex-direction:column;gap:0;width:100%;align-items:flex-start;}
  .main-navigation ul li{width:100%;}
  .main-navigation ul a{display:block;padding:14px 0;border-bottom:1px solid var(--border);width:100%;}
  .main-navigation ul ul{position:static;border:none;padding:0 0 0 1rem;background:none;}
  .main-navigation .nav-cta{margin-top:1rem;display:inline-block;}
  .menu-toggle{display:flex;}

  .hero-stats{gap:1.5rem;}
  .stat-val{font-size:1.6rem;}
  .hero-btns{flex-direction:column;}
  .hero-btns a{text-align:center;}

  .footer-top{grid-template-columns:1fr;gap:2rem;}
  .footer-bottom{flex-direction:column;text-align:center;}

  section{padding:56px 5vw;}
  .services-grid,.calc-grid{grid-template-columns:1fr;}
}

/* ════════════════════════════════════════════════════════
   RESPONSIVE — SMALL PHONE (≤380px)
   ════════════════════════════════════════════════════════ */
@media(max-width:380px){
  .hero h1{font-size:1.9rem;}
  .logo{font-size:1.25rem;}
}

/* ════════════════════════════════════════════════════════
   ACCESSIBILITY
   ════════════════════════════════════════════════════════ */
@media(prefers-reduced-motion:reduce){
  .circuit-path{animation:none;stroke-dashoffset:0;}
  .reveal{opacity:1;transform:none;}
  html{scroll-behavior:auto;}
}

/* WordPress core alignment helpers */
.alignleft{float:left;margin:0 1.5rem 1rem 0;}
.alignright{float:right;margin:0 0 1rem 1.5rem;}
.aligncenter{display:block;margin:0 auto 1rem;}
.wp-caption-text{font-size:0.8rem;color:var(--muted);text-align:center;}
.screen-reader-text{
  position:absolute !important;clip:rect(1px,1px,1px,1px);width:1px;height:1px;overflow:hidden;
}
