/*
Theme Name: Tech World
Theme URI: https://techworld.capsley.site
Author: Tech World
Description: Premium industrial WordPress theme for Tech World — precision CNC engineering. Navy + mustard branding, no page builder required. Built from the live React site.
Version: 1.0.0
License: GPL-2.0-or-later
Text Domain: techworld
Tags: business, industrial, manufacturing, custom-menu, custom-logo, featured-images, threaded-comments
*/

/* ====== Tokens ====== */
:root{
  --navy:#0A1F44;
  --navy-2:#13274d;
  --mustard:#E0A800;
  --mustard-2:#f0c33c;
  --bg:#fafaf7;
  --fg:#0c1631;
  --muted:#5b6680;
  --border:#e3e6ee;
  --card:#ffffff;
  --shadow: 0 20px 60px -20px rgba(10,31,68,.25);
  --radius: 14px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; background:var(--bg); color:var(--fg);
  font-family:'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  -webkit-font-smoothing:antialiased; line-height:1.55;
}
img{max-width:100%; height:auto; display:block}
a{color:var(--navy); text-decoration:none}
a:hover{color:var(--mustard)}
h1,h2,h3,h4{font-family:'Space Grotesk','Inter',sans-serif; letter-spacing:-0.02em; color:var(--navy); margin:0 0 .5em}
h1{font-size:clamp(2rem,4.6vw,3.6rem); line-height:1.05}
h2{font-size:clamp(1.6rem,3vw,2.4rem)}
.container{max-width:1180px; margin:0 auto; padding:0 24px}

/* ====== Header ====== */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.9); backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border);
}
.site-header .inner{display:flex; align-items:center; justify-content:space-between; height:68px}
.brand{display:flex; align-items:center; gap:10px; font-weight:700; color:var(--navy)}
.brand .logo{height:40px; width:64px; background:var(--navy); border-radius:8px; display:grid; place-items:center; overflow:hidden}
.brand .logo img{height:100%; width:100%; object-fit:cover}
.main-nav ul{list-style:none; display:flex; gap:22px; margin:0; padding:0}
.main-nav a{font-size:14px; color:#4a5170}
.main-nav a:hover, .main-nav .current-menu-item a{color:var(--navy); font-weight:600}
.cta-btn{
  display:inline-flex; align-items:center; gap:8px;
  background:var(--navy); color:#fff !important; padding:10px 18px;
  border-radius:999px; font-weight:600; font-size:14px;
  transition: background .25s ease, transform .25s ease;
}
.cta-btn:hover{background:var(--navy-2); transform:translateY(-1px)}
.cta-btn.accent{background:var(--mustard); color:var(--navy) !important}
.cta-btn.accent:hover{background:var(--mustard-2)}
.menu-toggle{display:none; background:none; border:0; font-size:24px; color:var(--navy); cursor:pointer}

@media (max-width: 960px){
  .main-nav{display:none; position:absolute; top:68px; left:0; right:0; background:#fff; border-bottom:1px solid var(--border); padding:16px 24px}
  .main-nav.open{display:block}
  .main-nav ul{flex-direction:column; gap:14px}
  .menu-toggle{display:block}
  .header-cta{display:none}
}

/* ====== Hero ====== */
.hero{position:relative; color:#fff; overflow:hidden; min-height:78vh; display:grid; align-items:center}
.hero .bg{position:absolute; inset:0; z-index:0}
.hero .bg img{width:100%; height:100%; object-fit:cover; transform:scale(1.06)}
.hero .overlay{position:absolute; inset:0; background:linear-gradient(120deg, rgba(10,31,68,.92) 0%, rgba(19,39,77,.65) 50%, rgba(10,31,68,.95) 100%); z-index:1}
.hero .container{position:relative; z-index:2; padding:90px 24px}
.hero h1{color:#fff; max-width:820px}
.hero p.lead{color:rgba(255,255,255,.85); font-size:1.15rem; max-width:680px; margin:18px 0 28px}
.hero .actions{display:flex; gap:14px; flex-wrap:wrap}
.eyebrow{display:inline-block; padding:6px 12px; border:1px solid rgba(224,168,0,.5); color:var(--mustard); border-radius:999px; font-size:12px; letter-spacing:.18em; text-transform:uppercase; margin-bottom:18px}

/* ====== Sections ====== */
section{padding:80px 0}
.section-head{max-width:760px; margin-bottom:44px}
.section-head .eyebrow{color:var(--mustard); border-color:rgba(224,168,0,.4)}
.section-head h2{color:var(--navy)}
.section-head p{color:var(--muted); font-size:1.05rem}

/* ====== Grids / cards ====== */
.grid{display:grid; gap:24px}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-4{grid-template-columns:repeat(4,1fr)}
.grid.cols-2{grid-template-columns:repeat(2,1fr)}
@media (max-width:900px){.grid.cols-3,.grid.cols-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.grid.cols-3,.grid.cols-4,.grid.cols-2{grid-template-columns:1fr}}

.card{
  background:var(--card); border:1px solid var(--border); border-radius:var(--radius);
  overflow:hidden; transition: transform .35s ease, box-shadow .35s ease, border-color .3s;
}
.card:hover{transform:translateY(-6px); box-shadow:var(--shadow); border-color:rgba(10,31,68,.15)}
.card .body{padding:22px}
.card h3{font-size:1.15rem}
.card .img{aspect-ratio:4/3; overflow:hidden}
.card .img img{width:100%; height:100%; object-fit:cover; transition:transform .8s ease}
.card:hover .img img{transform:scale(1.06)}

.feature{padding:28px; border:1px solid var(--border); border-radius:var(--radius); background:#fff}
.feature .icon{width:46px; height:46px; border-radius:10px; background:var(--mustard); color:var(--navy); display:grid; place-items:center; font-weight:800; margin-bottom:14px}

/* ====== Stats ====== */
.stats{background:var(--navy); color:#fff}
.stats .grid{grid-template-columns:repeat(4,1fr); text-align:center}
.stat .num{font-family:'Space Grotesk',sans-serif; font-size:2.6rem; color:var(--mustard); font-weight:700}
.stat .label{color:rgba(255,255,255,.75); font-size:.9rem; letter-spacing:.1em; text-transform:uppercase}
@media (max-width:700px){.stats .grid{grid-template-columns:repeat(2,1fr)}}

/* ====== CTA strip ====== */
.cta-strip{background:linear-gradient(135deg, var(--mustard) 0%, #f0c33c 100%); color:var(--navy); border-radius:var(--radius); padding:40px; display:flex; gap:24px; align-items:center; justify-content:space-between; flex-wrap:wrap}
.cta-strip h3{margin:0; font-size:1.6rem}

/* ====== Footer ====== */
.site-footer{background:var(--navy); color:rgba(255,255,255,.8); margin-top:60px}
.site-footer .top{padding:60px 0 40px; display:grid; grid-template-columns:1.5fr 1fr 1fr 1.2fr; gap:36px}
@media (max-width:900px){.site-footer .top{grid-template-columns:1fr 1fr} }
@media (max-width:560px){.site-footer .top{grid-template-columns:1fr} }
.site-footer h4{color:var(--mustard); font-size:.85rem; letter-spacing:.12em; text-transform:uppercase}
.site-footer ul{list-style:none; padding:0; margin:0}
.site-footer ul li{margin:8px 0}
.site-footer a{color:rgba(255,255,255,.8)}
.site-footer a:hover{color:var(--mustard)}
.site-footer .bottom{border-top:1px solid rgba(255,255,255,.1); text-align:center; padding:18px 0; font-size:.8rem; color:rgba(255,255,255,.55)}

/* ====== Forms ====== */
.form-wrap{background:#fff; border:1px solid var(--border); border-radius:var(--radius); padding:32px}
.form-wrap label{display:block; font-size:.85rem; font-weight:600; margin-bottom:6px; color:var(--navy)}
.form-wrap input, .form-wrap textarea, .form-wrap select{
  width:100%; padding:12px 14px; border:1px solid var(--border); border-radius:10px; font:inherit; background:#fafbff; color:var(--fg);
}
.form-wrap input:focus, .form-wrap textarea:focus{outline:2px solid var(--mustard); outline-offset:1px}
.form-row{margin-bottom:14px}
.form-grid{display:grid; grid-template-columns:1fr 1fr; gap:14px}
@media (max-width:600px){.form-grid{grid-template-columns:1fr}}

/* Page header for inner pages */
.page-hero{background:var(--navy); color:#fff; padding:80px 0 60px}
.page-hero h1{color:#fff}
.page-hero p{color:rgba(255,255,255,.75); max-width:680px}

.prose{max-width:780px}
.prose p{margin:0 0 1em; color:#2b3350}
.prose h2{margin-top:1.6em}

.badge{display:inline-block; background:rgba(224,168,0,.15); color:#806008; padding:4px 10px; border-radius:999px; font-size:.75rem; font-weight:600; letter-spacing:.06em; text-transform:uppercase}
