/*
Theme Name: Onset Business Consulting
Theme URI: https://onsetconsulting.com
Author: Onset Business Consulting
Author URI: https://onsetconsulting.com
Description: Custom Lean Six Sigma consulting theme with DMAIC branding.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: onset
*/

/* ─── RESET & ROOT ─── */
:root {
  --navy:   #08142A;
  --navy2:  #0F2040;
  --steel:  #1A3358;
  --orange: #E8600A;
  --org2:   #FF7A2B;
  --slate:  #94A7BF;
  --light:  #D4E2F0;
  --white:  #F5F9FF;
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: 'Barlow', sans-serif; background: var(--navy); color: var(--white); overflow-x: hidden; }

/* ─── NAV ─── */
nav.site-nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 500;
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.25rem 5vw;
  background: rgba(8,20,42,0.92); backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(232,96,10,0.2);
}
.logo { display: flex; align-items: center; gap: 0.75rem; text-decoration: none; }
.logo-mark { width: 42px; height: 42px; flex-shrink: 0; }
.logo-mark svg { width: 100%; height: 100%; }
.logo-text { display: flex; flex-direction: column; line-height: 1; }
.logo-text .logo-name { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 1.35rem; letter-spacing: 0.06em; color: var(--white); text-transform: uppercase; }
.logo-text .logo-sub  { font-family: 'Barlow Condensed', sans-serif; font-weight: 400; font-size: 0.7rem; letter-spacing: 0.2em; color: var(--orange); text-transform: uppercase; }
.nav-menu { display: flex; gap: 2.5rem; list-style: none; }
.nav-menu a { font-family: 'Barlow Condensed', sans-serif; font-weight: 600; font-size: 0.85rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--slate); text-decoration: none; transition: color 0.2s; }
.nav-menu a:hover { color: var(--org2); }
.nav-menu .nav-cta > a { background: var(--orange); color: var(--white) !important; padding: 0.5rem 1.25rem; clip-path: polygon(8px 0%,100% 0%,calc(100% - 8px) 100%,0% 100%); }
.nav-menu .nav-cta > a:hover { background: var(--org2) !important; }

/* ─── HERO ─── */
#hero { min-height: 100vh; display: grid; grid-template-columns: 1fr 1fr; overflow: hidden; }
.hero-left { display: flex; flex-direction: column; justify-content: center; padding: 10rem 5vw 6rem 8vw; z-index: 2; }
.hero-eyebrow { font-family: 'Barlow Condensed', sans-serif; font-weight: 600; font-size: 0.78rem; letter-spacing: 0.3em; color: var(--orange); text-transform: uppercase; margin-bottom: 1.5rem; display: flex; align-items: center; gap: 0.75rem; }
.hero-eyebrow::before { content: ''; width: 32px; height: 2px; background: var(--orange); display: inline-block; }
.hero-left h1 { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: clamp(3.5rem,6vw,5.5rem); line-height: 0.95; letter-spacing: -0.01em; text-transform: uppercase; margin-bottom: 1.75rem; }
.hero-left h1 em { font-style: normal; color: var(--orange); display: block; }
.hero-sub { font-size: 1.05rem; font-weight: 300; line-height: 1.75; color: var(--slate); max-width: 480px; margin-bottom: 2.75rem; }
.hero-ctas { display: flex; gap: 1rem; flex-wrap: wrap; }
.btn-primary { display: inline-flex; align-items: center; gap: 0.6rem; background: var(--orange); color: var(--white); padding: 1rem 2rem; font-family: 'Barlow Condensed', sans-serif; font-weight: 700; font-size: 0.9rem; letter-spacing: 0.1em; text-transform: uppercase; text-decoration: none; clip-path: polygon(10px 0%,100% 0%,calc(100% - 10px) 100%,0% 100%); transition: background 0.2s, transform 0.2s; border: none; cursor: pointer; }
.btn-primary:hover { background: var(--org2); transform: translateY(-2px); }
.btn-secondary { display: inline-flex; align-items: center; gap: 0.6rem; border: 1px solid var(--steel); color: var(--light); padding: 1rem 2rem; font-family: 'Barlow Condensed', sans-serif; font-weight: 600; font-size: 0.9rem; letter-spacing: 0.1em; text-transform: uppercase; text-decoration: none; transition: border-color 0.2s, color 0.2s, transform 0.2s; }
.btn-secondary:hover { border-color: var(--orange); color: var(--orange); transform: translateY(-2px); }
.hero-stats { display: flex; gap: 2.5rem; margin-top: 3.5rem; padding-top: 2.5rem; border-top: 1px solid var(--steel); }
.stat-num { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 2.5rem; color: var(--orange); line-height: 1; }
.stat-label { font-size: 0.78rem; letter-spacing: 0.1em; color: var(--slate); text-transform: uppercase; margin-top: 0.25rem; }
.hero-right { position: relative; overflow: hidden; }
.hero-right::before { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg,var(--navy2),var(--steel)); opacity: 0.4; }
.grid-overlay { position: absolute; inset: 0; background-image: linear-gradient(rgba(232,96,10,0.08) 1px,transparent 1px),linear-gradient(90deg,rgba(232,96,10,0.08) 1px,transparent 1px); background-size: 48px 48px; animation: gridDrift 20s linear infinite; }
@keyframes gridDrift { 0%{background-position:0 0} 100%{background-position:48px 48px} }
.hero-diagram { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; }
.dmaic-ring { width: min(400px,88%); filter: drop-shadow(0 0 40px rgba(232,96,10,0.3)); animation: floatRing 6s ease-in-out infinite; }
@keyframes floatRing { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-12px)} }
.brand-stripe { position: absolute; right: 0; top: 0; bottom: 0; width: 4px; background: var(--orange); }

/* DMAIC NODES */
.dmaic-node { cursor: pointer; }
.dmaic-node-circle { fill: #0F2040; stroke: #E8600A; stroke-width: 2.5; transition: fill 0.2s; }
.dmaic-node:hover .dmaic-node-circle { fill: #1A3358; filter: drop-shadow(0 0 6px rgba(232,96,10,0.9)); }
.dmaic-node-label { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 18px; fill: #F5F9FF; pointer-events: none; user-select: none; }

/* TOOLTIP */
#dmaic-tooltip { position: fixed; z-index: 9999; pointer-events: none; opacity: 0; transform: translateY(6px); transition: opacity 0.18s, transform 0.18s; max-width: 275px; }
#dmaic-tooltip.visible { opacity: 1; transform: translateY(0); }
.tt-inner { background: #0F2040; border: 1px solid #E8600A; padding: 1rem 1.25rem; clip-path: polygon(10px 0%,100% 0%,calc(100% - 10px) 100%,0% 100%); }
.tt-header { display: flex; align-items: baseline; gap: 0.6rem; margin-bottom: 0.4rem; }
.tt-letter { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 2rem; color: #E8600A; line-height: 1; }
.tt-title { font-family: 'Barlow Condensed', sans-serif; font-weight: 700; font-size: 0.9rem; letter-spacing: 0.1em; text-transform: uppercase; color: #F5F9FF; }
.tt-desc { font-size: 0.81rem; font-weight: 300; color: #94A7BF; line-height: 1.65; }

/* ─── SECTIONS ─── */
.site-section { padding: 7rem 8vw; position: relative; }
.section-label { font-family: 'Barlow Condensed', sans-serif; font-weight: 600; font-size: 0.75rem; letter-spacing: 0.35em; color: var(--orange); text-transform: uppercase; margin-bottom: 1rem; display: flex; align-items: center; gap: 0.75rem; }
.section-label::before { content: ''; width: 24px; height: 2px; background: var(--orange); display: inline-block; }
.site-section h2 { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: clamp(2.5rem,4vw,3.75rem); line-height: 1; text-transform: uppercase; letter-spacing: -0.01em; margin-bottom: 1.25rem; }
.site-section h2 span { color: var(--orange); }
.section-intro { font-size: 1.05rem; font-weight: 300; color: var(--slate); line-height: 1.8; max-width: 600px; margin-bottom: 4rem; }

/* ─── TICKER ─── */
.ticker-wrap { background: var(--orange); padding: 0.9rem 0; overflow: hidden; white-space: nowrap; }
.ticker-inner { display: inline-flex; animation: ticker 30s linear infinite; }
.ticker-inner span { font-family: 'Barlow Condensed', sans-serif; font-weight: 700; font-size: 0.85rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--white); padding: 0 2.5rem; }
.ticker-inner .dot { color: rgba(255,255,255,0.5); padding: 0; }
@keyframes ticker { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

/* ─── SERVICES ─── */
#services { background: var(--navy2); }
.services-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5px; background: var(--steel); }
.service-card { background: var(--navy2); padding: 2.75rem 2.25rem; position: relative; overflow: hidden; transition: background 0.3s; }
.service-card::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 3px; background: var(--orange); transform: scaleX(0); transition: transform 0.3s; transform-origin: left; }
.service-card:hover { background: var(--navy); }
.service-card:hover::after { transform: scaleX(1); }
.service-icon { width: 48px; height: 48px; margin-bottom: 1.5rem; color: var(--orange); }
.service-card h3 { font-family: 'Barlow Condensed', sans-serif; font-weight: 700; font-size: 1.35rem; text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 0.85rem; color: var(--white); }
.service-card p { font-size: 0.92rem; font-weight: 300; line-height: 1.75; color: var(--slate); }

/* ─── DMAIC PROCESS ─── */
#process { background: var(--navy); }
.process-row { display: flex; position: relative; }
.process-row::before { content: ''; position: absolute; top: 48px; left: 0; right: 0; height: 2px; background: linear-gradient(90deg,transparent,var(--orange),transparent); z-index: 0; }
.process-step { flex: 1; text-align: center; padding: 0 1.5rem; position: relative; z-index: 1; }
.step-circle { width: 96px; height: 96px; border-radius: 50%; border: 2px solid var(--steel); background: var(--navy2); display: flex; align-items: center; justify-content: center; margin: 0 auto 1.75rem; transition: border-color 0.3s, background 0.3s; }
.process-step:hover .step-circle { border-color: var(--orange); background: rgba(232,96,10,0.08); }
.step-letter { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 2.25rem; color: var(--orange); line-height: 1; }
.step-title { font-family: 'Barlow Condensed', sans-serif; font-weight: 700; font-size: 1rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--white); margin-bottom: 0.6rem; }
.step-desc { font-size: 0.85rem; font-weight: 300; color: var(--slate); line-height: 1.65; }

/* ─── SLOGANS ─── */
#slogans { background: var(--orange); padding: 5rem 8vw; text-align: center; }
#slogans .section-label { justify-content: center; color: rgba(255,255,255,0.7); }
#slogans .section-label::before { background: rgba(255,255,255,0.5); }
.slogan-hero { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: clamp(3rem,6vw,5rem); text-transform: uppercase; letter-spacing: -0.01em; color: var(--white); line-height: 1; margin-bottom: 1.5rem; }
.slogan-alts { display: flex; justify-content: center; gap: 3rem; margin-top: 2.5rem; flex-wrap: wrap; }
.slogan-alt { font-family: 'Barlow Condensed', sans-serif; font-weight: 600; font-size: 1.05rem; letter-spacing: 0.15em; text-transform: uppercase; color: rgba(255,255,255,0.65); padding: 0.6rem 1.5rem; border: 1px solid rgba(255,255,255,0.3); }

/* ─── WHY US ─── */
#why { background: var(--navy2); display: grid; grid-template-columns: 1fr 1fr; gap: 6rem; align-items: center; padding: 7rem 8vw; }
.why-visual { position: relative; }
.why-visual-box { background: var(--steel); padding: 3rem; clip-path: polygon(0 0,calc(100% - 24px) 0,100% 24px,100% 100%,24px 100%,0 calc(100% - 24px)); }
.why-accent-bar { position: absolute; left: -4px; top: 2rem; bottom: 2rem; width: 4px; background: var(--orange); }
.why-quote { font-family: 'Barlow Condensed', sans-serif; font-weight: 700; font-size: 1.75rem; line-height: 1.3; text-transform: uppercase; letter-spacing: 0.02em; margin-bottom: 1.5rem; }
.why-quote em { font-style: normal; color: var(--orange); }
.why-visual-box p { font-size: 0.95rem; font-weight: 300; color: var(--slate); line-height: 1.75; }
.why-list { display: flex; flex-direction: column; gap: 1.75rem; }
.why-item { display: flex; gap: 1.25rem; align-items: flex-start; }
.why-icon { width: 44px; height: 44px; background: rgba(232,96,10,0.1); border: 1px solid rgba(232,96,10,0.3); display: flex; align-items: center; justify-content: center; flex-shrink: 0; color: var(--orange); }
.why-item h4 { font-family: 'Barlow Condensed', sans-serif; font-weight: 700; font-size: 1.05rem; text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 0.35rem; color: var(--white); }
.why-item p { font-size: 0.88rem; font-weight: 300; color: var(--slate); line-height: 1.65; }

/* ─── ABOUT ─── */
#about { background: var(--navy); display: grid; grid-template-columns: 1fr 1fr; gap: 6rem; align-items: center; padding: 7rem 8vw; }
.cert-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-top: 2.5rem; }
.cert-chip { background: var(--navy2); border: 1px solid var(--steel); padding: 0.85rem 1.1rem; display: flex; align-items: center; gap: 0.65rem; font-family: 'Barlow Condensed', sans-serif; font-weight: 600; font-size: 0.82rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--light); }
.cert-chip svg { color: var(--orange); flex-shrink: 0; width: 16px; height: 16px; }
.about-visual { display: flex; flex-direction: column; gap: 1.5rem; }
.about-card { background: var(--navy2); border-left: 3px solid var(--orange); padding: 1.75rem 2rem; }
.about-card h4 { font-family: 'Barlow Condensed', sans-serif; font-weight: 700; font-size: 1.1rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--white); margin-bottom: 0.5rem; }
.about-card p { font-size: 0.88rem; font-weight: 300; color: var(--slate); line-height: 1.65; }

/* ─── CONTACT ─── */
#contact { background: var(--navy2); text-align: center; padding: 7rem 8vw; }
.contact-inner { max-width: 700px; margin: 0 auto; }
.contact-box { background: var(--navy); border: 1px solid var(--steel); padding: 3.5rem; margin-top: 3rem; clip-path: polygon(0 0,calc(100% - 20px) 0,100% 20px,100% 100%,20px 100%,0 calc(100% - 20px)); text-align: left; }
.contact-box .form-group { margin-bottom: 1.5rem; }
.contact-box label { display: block; font-family: 'Barlow Condensed', sans-serif; font-weight: 600; font-size: 0.78rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--slate); margin-bottom: 0.5rem; }
.contact-box input,
.contact-box textarea,
.contact-box select { width: 100%; background: var(--navy2); border: 1px solid var(--steel); color: var(--white); padding: 0.9rem 1.1rem; font-family: 'Barlow', sans-serif; font-size: 0.95rem; font-weight: 300; outline: none; transition: border-color 0.2s; -webkit-appearance: none; }
.contact-box input:focus,
.contact-box textarea:focus,
.contact-box select:focus { border-color: var(--orange); }
.contact-box textarea { min-height: 140px; resize: vertical; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; }
.contact-box select option { background: var(--navy2); color: var(--white); }

/* WPForms override — keep form styled consistently */
.wpforms-container input,
.wpforms-container textarea,
.wpforms-container select { background: var(--navy2) !important; border: 1px solid var(--steel) !important; color: var(--white) !important; padding: 0.9rem 1.1rem !important; font-family: 'Barlow', sans-serif !important; font-weight: 300 !important; border-radius: 0 !important; }
.wpforms-container input:focus,
.wpforms-container textarea:focus,
.wpforms-container select:focus { border-color: var(--orange) !important; outline: none !important; box-shadow: none !important; }
.wpforms-container .wpforms-submit { background: var(--orange) !important; color: var(--white) !important; font-family: 'Barlow Condensed', sans-serif !important; font-weight: 700 !important; letter-spacing: 0.1em !important; text-transform: uppercase !important; border: none !important; padding: 1rem 2rem !important; border-radius: 0 !important; clip-path: polygon(10px 0%,100% 0%,calc(100% - 10px) 100%,0% 100%); cursor: pointer !important; transition: background 0.2s !important; }
.wpforms-container .wpforms-submit:hover { background: var(--org2) !important; }
.wpforms-field-label { font-family: 'Barlow Condensed', sans-serif !important; font-weight: 600 !important; font-size: 0.78rem !important; letter-spacing: 0.2em !important; text-transform: uppercase !important; color: var(--slate) !important; }

/* ─── BLOG / POSTS ─── */
.blog-section { background: var(--navy); padding: 7rem 8vw; }
.posts-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2rem; margin-top: 3rem; }
.post-card { background: var(--navy2); border-top: 3px solid var(--orange); padding: 2rem; }
.post-card .post-date { font-family: 'Barlow Condensed', sans-serif; font-size: 0.75rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--orange); margin-bottom: 0.75rem; }
.post-card h3 { font-family: 'Barlow Condensed', sans-serif; font-weight: 700; font-size: 1.25rem; text-transform: uppercase; color: var(--white); margin-bottom: 0.75rem; line-height: 1.2; }
.post-card p { font-size: 0.88rem; font-weight: 300; color: var(--slate); line-height: 1.7; margin-bottom: 1.25rem; }
.post-card a.read-more { font-family: 'Barlow Condensed', sans-serif; font-weight: 600; font-size: 0.82rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--orange); text-decoration: none; }
.post-card a.read-more:hover { color: var(--org2); }

/* Single post */
.single-post-wrap { max-width: 780px; margin: 0 auto; padding: 9rem 2rem 5rem; }
.single-post-wrap h1 { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: clamp(2rem,4vw,3rem); text-transform: uppercase; line-height: 1.05; margin-bottom: 1rem; }
.post-meta { font-size: 0.8rem; color: var(--slate); letter-spacing: 0.1em; text-transform: uppercase; font-family: 'Barlow Condensed', sans-serif; margin-bottom: 2.5rem; padding-bottom: 1.5rem; border-bottom: 1px solid var(--steel); }
.post-meta span { color: var(--orange); }
.post-content { font-size: 1rem; font-weight: 300; line-height: 1.9; color: var(--light); }
.post-content h2,
.post-content h3 { font-family: 'Barlow Condensed', sans-serif; font-weight: 700; text-transform: uppercase; color: var(--white); margin: 2rem 0 0.75rem; }
.post-content p { margin-bottom: 1.25rem; }
.post-content a { color: var(--orange); }
.post-content ul,
.post-content ol { padding-left: 1.5rem; margin-bottom: 1.25rem; color: var(--slate); }

/* Generic page */
.page-content-wrap { max-width: 900px; margin: 0 auto; padding: 9rem 2rem 5rem; }
.page-content-wrap h1 { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: clamp(2.5rem,4vw,3.75rem); text-transform: uppercase; margin-bottom: 2rem; }
.page-content-wrap .entry-content { font-size: 1rem; font-weight: 300; line-height: 1.9; color: var(--light); }

/* 404 */
.error-404-wrap { min-height: 80vh; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; padding: 4rem; }
.error-404-wrap h1 { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: clamp(5rem,12vw,10rem); color: var(--orange); line-height: 1; }
.error-404-wrap p { font-size: 1.1rem; font-weight: 300; color: var(--slate); margin: 1rem 0 2rem; }

/* ─── FOOTER ─── */
.site-footer { background: var(--navy); border-top: 1px solid var(--steel); padding: 4rem 8vw 2.5rem; }
.footer-top { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 3rem; padding-bottom: 3rem; border-bottom: 1px solid var(--steel); margin-bottom: 2rem; }
.footer-about p { font-size: 0.88rem; font-weight: 300; color: var(--slate); line-height: 1.75; margin-top: 1.25rem; max-width: 300px; }
.footer-col h5 { font-family: 'Barlow Condensed', sans-serif; font-weight: 700; font-size: 0.8rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--white); margin-bottom: 1.25rem; }
.footer-col ul { list-style: none; display: flex; flex-direction: column; gap: 0.65rem; }
.footer-col ul li a { font-size: 0.88rem; font-weight: 300; color: var(--slate); text-decoration: none; transition: color 0.2s; }
.footer-col ul li a:hover { color: var(--orange); }
.footer-bottom { display: flex; justify-content: space-between; align-items: center; }
.footer-bottom p { font-size: 0.8rem; color: var(--slate); font-weight: 300; }
.footer-bottom span { color: var(--orange); }

/* ─── ANIMATIONS ─── */
.fade-up { opacity: 0; transform: translateY(30px); transition: opacity 0.7s ease, transform 0.7s ease; }
.fade-up.visible { opacity: 1; transform: translateY(0); }

/* ─── SCROLLBAR ─── */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--navy); }
::-webkit-scrollbar-thumb { background: var(--orange); }
