/*
Theme Name: BigO Services Strategy
Theme URI: https://bigoservices.net/
Author: BigO Services
Description: A custom Gutenberg-native block theme for BigO Services focused on Managed IT Services, technology strategy, cybersecurity, cloud support, and on-demand support for small businesses.
Version: 1.0.11
Requires at least: 6.3
Tested up to: 6.6
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: bigoservices-strategy-v2
*/

:root {
  --bigo-bg: #f3f5f1;
  --bigo-bg-soft: #eef2ea;
  --bigo-card: #ffffff;
  --bigo-text: #121714;
  --bigo-muted: #5f6d64;
  --bigo-dark: #07100c;
  --bigo-dark-2: #0b1510;
  --bigo-green: #168845;
  --bigo-green-bright: #28a85b;
  --bigo-green-soft: #dceee2;
  --bigo-border: rgba(18, 23, 20, 0.12);
  --bigo-shadow: 0 18px 45px rgba(7, 16, 12, 0.08);
  --bigo-shadow-strong: 0 28px 70px rgba(7, 16, 12, 0.18);
  --bigo-radius: 26px;
  --bigo-max: 1220px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--bigo-bg);
  color: var(--bigo-text);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
body .is-layout-constrained > :where(:not(.alignleft):not(.alignright):not(.alignfull)) { max-width: none; }
.wp-site-blocks { padding: 0; overflow-x: hidden; }
.wp-site-blocks > * + * { margin-block-start: 0; }
a { color: inherit; text-decoration: none; }
a:hover { color: var(--bigo-green-bright); }
img { max-width: 100%; height: auto; }
h1, h2, h3, h4 { font-family: Georgia, "Times New Roman", serif; line-height: 1.05; letter-spacing: -0.035em; margin: 0; }
p { margin: 0; }

.bigo-container { width: min(var(--bigo-max), calc(100% - 48px)); margin-inline: auto; }
.bigo-section { padding: 78px 0; }
.bigo-section-tight { padding: 58px 0; }
.bigo-centered { text-align: center; max-width: 790px; margin-inline: auto; }
.bigo-accent-line { width: 64px; height: 4px; border-radius: 999px; background: var(--bigo-green); margin: 18px auto 0; }
.bigo-green { color: var(--bigo-green-bright); }
.bigo-muted { color: var(--bigo-muted); }
.bigo-lead { font-size: 1.125rem; line-height: 1.8; color: var(--bigo-muted); }

/* Header */
.bigo-header { position: sticky; top: 0; z-index: 999; background: rgba(8,13,11,.97); color: #fff; border-bottom: 1px solid rgba(255,255,255,.1); backdrop-filter: blur(12px); }
.admin-bar .bigo-header { top: 32px; }
.bigo-header-inner { width: min(1320px, calc(100% - 40px)); min-height: 68px; margin-inline: auto; display: flex; align-items: center; justify-content: space-between; gap: 18px; }
.bigo-logo-link { display: block; width: 224px; height: 40px; background: url('assets/logo-white-horizontal.png') left center / contain no-repeat; flex: 0 0 auto; }
.bigo-nav { display: flex; align-items: center; gap: 20px; font-weight: 750; font-size: .88rem; color: #e7eee9; white-space: nowrap; }
.bigo-nav a.active { color: var(--bigo-green-bright); border-bottom: 2px solid var(--bigo-green); padding-bottom: 5px; }
.bigo-header-actions { display: flex; align-items: center; gap: 14px; }
.bigo-mobile-menu { display: none; color: white; font-size: 1.8rem; }
.bigo-header .bigo-button { padding: 12px 17px; font-size: .88rem; }

.bigo-button, .bigo-button-outline, .bigo-button-light { display: inline-flex; align-items: center; justify-content: center; gap: 8px; border-radius: 14px; padding: 14px 22px; font-weight: 850; line-height: 1; transition: transform .18s ease, background .18s ease, border-color .18s ease; }
.bigo-button { background: var(--bigo-green); color: white; box-shadow: 0 16px 36px rgba(22,136,69,.24); }
.bigo-button:hover { color: white; background: #1b9c52; transform: translateY(-1px); }
.bigo-button-outline { background: rgba(255,255,255,.05); color: white; border: 1px solid rgba(255,255,255,.42); }
.bigo-button-outline:hover { color: white; background: rgba(255,255,255,.12); transform: translateY(-1px); }
.bigo-button-light { background: white; color: var(--bigo-dark); }
.bigo-button-light:hover { color: var(--bigo-dark); background: #eff4ee; transform: translateY(-1px); }

/* Hero */
.bigo-hero { position: relative; overflow: hidden; background: radial-gradient(circle at 77% 36%, rgba(22,136,69,.28), transparent 34%), radial-gradient(circle at 30% 0%, rgba(255,255,255,.07), transparent 30%), linear-gradient(135deg, #07100c 0%, #09130f 52%, #061e11 100%); color: white; }
.bigo-hero::after { content: ""; position: absolute; right: clamp(18px, 6vw, 90px); top: 80px; width: clamp(330px, 38vw, 520px); height: clamp(330px, 38vw, 520px); background: url('assets/logo-hero.png') center / contain no-repeat; opacity: .46; filter: drop-shadow(0 0 34px rgba(22,136,69,.24)); pointer-events: none; }
.bigo-hero-inner { position: relative; z-index: 2; min-height: 560px; display: grid; grid-template-columns: minmax(0, .98fr) minmax(300px, .9fr); align-items: center; gap: 40px; padding: 88px 0 96px; }
.bigo-hero-content { max-width: 650px; }
.bigo-eyebrow { display: inline-flex; align-items: center; gap: 9px; border: 1px solid rgba(40,168,91,.35); background: rgba(22,136,69,.12); color: #c7f7d5; padding: 9px 14px; border-radius: 999px; font-weight: 850; font-size: .9rem; margin-bottom: 22px; }
.bigo-hero h1 { font-size: clamp(3.1rem, 5vw, 5.15rem); max-width: 650px; }
.bigo-hero p { margin-top: 25px; max-width: 640px; color: #d7dfd9; font-size: 1.06rem; line-height: 1.78; }
.bigo-hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 32px; }
.bigo-pills { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 32px; }
.bigo-pill { border: 1px solid rgba(255,255,255,.12); background: rgba(0,0,0,.28); color: #e7eee9; border-radius: 13px; padding: 11px 14px; font-weight: 800; font-size: .9rem; }
.bigo-pill::before { content: "●"; color: var(--bigo-green-bright); margin-right: 8px; }

/* Cards and grids */
.bigo-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.bigo-grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
.bigo-card { background: var(--bigo-card); border: 1px solid var(--bigo-border); border-radius: var(--bigo-radius); padding: 28px; box-shadow: var(--bigo-shadow); }
.bigo-card:hover { box-shadow: var(--bigo-shadow-strong); }
.bigo-icon { width: 58px; height: 58px; border-radius: 999px; background: var(--bigo-green-soft); color: var(--bigo-green); display: inline-flex; align-items: center; justify-content: center; font-size: .9rem; line-height: 1; font-weight: 950; flex: 0 0 auto; font-family: Inter, ui-sans-serif, system-ui, sans-serif; letter-spacing: .01em; }
.bigo-card h3 { font-family: Inter, ui-sans-serif, system-ui, sans-serif; letter-spacing: -0.02em; font-size: 1.18rem; margin-top: 20px; }
.bigo-card p { margin-top: 11px; color: var(--bigo-muted); }
.bigo-intro-grid { display: grid; grid-template-columns: .75fr 1.25fr; gap: 44px; align-items: start; }
.bigo-intro-grid h2, .bigo-centered h2 { font-size: clamp(2.15rem, 3.7vw, 3.35rem); }
.bigo-intro-grid .bigo-lead { margin-top: 22px; }
.bigo-service-card { display: flex; gap: 22px; min-height: 186px; transition: transform .18s ease, box-shadow .18s ease; }
.bigo-service-card:hover { transform: translateY(-3px); }
.bigo-service-card.featured { border-color: var(--bigo-green); box-shadow: 0 18px 42px rgba(22,136,69,.09); }
.bigo-service-card h3 { margin-top: 0; }
.bigo-link { display: inline-block; margin-top: 13px; color: var(--bigo-green); font-weight: 900; font-size: .92rem; }

/* Managed strip */
.bigo-managed-strip { background: radial-gradient(circle at 10% 20%, rgba(22,136,69,.28), transparent 26%), linear-gradient(135deg, #07100c, #0b1510 62%, #061b10); color: white; border-radius: 30px; padding: 38px; box-shadow: var(--bigo-shadow-strong); display: grid; grid-template-columns: .95fr 1.05fr; gap: 34px; align-items: center; }
.bigo-managed-title { display: flex; gap: 22px; align-items: flex-start; }
.bigo-managed-title h2 { font-size: clamp(2rem, 3.2vw, 2.85rem); }
.bigo-managed-title p { color: #cad8d0; margin-top: 14px; }
.bigo-managed-subtitle { color: var(--bigo-green-bright) !important; font-weight: 900; font-size: 1.15rem; margin-top: 8px !important; }
.bigo-managed-features { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
.bigo-check { display: flex; align-items: center; gap: 10px; font-weight: 800; color: #eaf1ed; }
.bigo-check::before { content: "✓"; display: inline-flex; align-items: center; justify-content: center; width: 24px; height: 24px; border-radius: 999px; background: var(--bigo-green); color: white; font-size: .8rem; flex: 0 0 auto; }

/* Pricing */
.bigo-price-card { display: flex; gap: 20px; align-items: center; }
.bigo-price { color: var(--bigo-green); font-size: clamp(2.7rem, 5vw, 4rem); font-weight: 950; line-height: 1; letter-spacing: -0.05em; }
.bigo-price small { color: var(--bigo-text); font-size: 1rem; font-weight: 750; letter-spacing: 0; }
.bigo-small-note { color: var(--bigo-muted); text-align: center; margin-top: 18px; }

/* Virtual partner */
.bigo-partner-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: 48px; align-items: center; }
.bigo-tech-panel { background: var(--bigo-dark); border-radius: 32px; padding: 26px; box-shadow: var(--bigo-shadow-strong); }
.bigo-tech-inner { min-height: 330px; border-radius: 24px; border: 1px solid rgba(22,136,69,.32); background: radial-gradient(circle at 80% 25%, rgba(22,136,69,.36), transparent 35%), #0b1510; color: white; padding: 34px; }
.bigo-tech-inner .label { color: var(--bigo-green-bright); font-weight: 900; letter-spacing: .22em; text-transform: uppercase; font-size: .82rem; margin-bottom: 28px; }
.bigo-tech-list { display: grid; gap: 13px; }
.bigo-tech-list div { background: rgba(255,255,255,.08); border-radius: 16px; padding: 16px; font-weight: 850; color: #eaf1ed; }
.bigo-tech-list div::before { content: "✓"; color: var(--bigo-green-bright); margin-right: 10px; }
.bigo-partner-content h2 { font-size: clamp(2.15rem, 3.7vw, 3.35rem); }
.bigo-partner-content p { margin-top: 18px; }
.bigo-benefits { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; margin-top: 26px; }
.bigo-benefits div { font-weight: 850; }
.bigo-benefits div::before { content: "✓"; display: inline-flex; align-items: center; justify-content: center; width: 23px; height: 23px; border-radius: 999px; background: var(--bigo-green); color: white; font-size: .75rem; margin-right: 9px; }

/* Testimonials */
.bigo-testimonial { display: flex; gap: 18px; align-items: flex-start; min-height: 236px; }
.bigo-avatar { width: 64px; height: 64px; border-radius: 999px; background: var(--bigo-green-soft); color: var(--bigo-green); display: inline-flex; align-items: center; justify-content: center; font-weight: 950; flex: 0 0 auto; }
.bigo-testimonial-photo { width: 76px; height: 76px; border-radius: 999px; object-fit: cover; object-position: center; flex: 0 0 auto; box-shadow: 0 10px 24px rgba(8, 18, 13, .14); border: 3px solid #fff; }
.bigo-testimonial blockquote { margin: 0; color: var(--bigo-muted); font-size: .98rem; line-height: 1.65; }
.bigo-testimonial .name { margin-top: 16px; font-weight: 950; color: var(--bigo-text); }
.bigo-testimonial .company { color: var(--bigo-green); font-weight: 850; font-size: .92rem; }
.bigo-stars { color: var(--bigo-green); margin-top: 6px; letter-spacing: .07em; }

/* CTA and footer */
.bigo-cta { background: radial-gradient(circle at 20% 0%, rgba(22,136,69,.32), transparent 34%), linear-gradient(135deg, #07100c, #0b1510 60%, #061b10); color: white; padding: 74px 0; }
.bigo-cta-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: 44px; align-items: center; }
.bigo-cta h2 { font-size: clamp(2.15rem, 3.8vw, 3.55rem); }
.bigo-contact-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.bigo-contact-card { border: 1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.06); border-radius: 24px; padding: 24px 20px; text-align: center; min-height: 184px; }
.bigo-contact-icon { width: 56px; height: 56px; display: inline-flex; align-items: center; justify-content: center; border-radius: 999px; background: var(--bigo-green); font-size: .85rem; font-weight: 950; }
.bigo-contact-card strong { display: block; margin-top: 14px; }
.bigo-contact-card span { display: block; margin-top: 5px; color: #d6dfd9; overflow-wrap: anywhere; font-size: .94rem; line-height: 1.55; }
.bigo-footer { background: #050806; color: white; padding: 28px 0; }
.bigo-footer-inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.bigo-footer-logo { display: block; width: 210px; height: 38px; background: url('assets/logo-white-horizontal.png') left center / contain no-repeat; }
.bigo-footer-nav { display: flex; flex-wrap: wrap; gap: 24px; color: #d7dfd9; font-weight: 750; font-size: .92rem; }
.bigo-copyright { color: #aab5ae; font-size: .9rem; }

/* Inner pages */
.bigo-page-hero { background: radial-gradient(circle at 82% 20%, rgba(22,136,69,.24), transparent 30%), var(--bigo-dark); color: white; padding: 84px 0; position: relative; overflow: hidden; }
.bigo-page-hero::after { content:""; position:absolute; right:40px; top:22px; width:300px; height:300px; background:url('assets/logo-hero.png') center/contain no-repeat; opacity:.24; }
.bigo-page-hero .bigo-container { position: relative; z-index: 2; }
.bigo-page-hero h1 { font-size: clamp(3rem, 5vw, 5rem); }
.bigo-page-hero p { max-width: 760px; margin-top: 22px; color:#d7dfd9; font-size:1.15rem; line-height:1.8; }
.bigo-content-page { padding: 74px 0; }
.bigo-content-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; }
.bigo-list { display:grid; gap: 12px; margin-top: 22px; padding-left: 0; }
.bigo-list li { list-style: none; position: relative; padding-left: 34px; color: var(--bigo-muted); }
.bigo-list li::before { content:"✓"; position:absolute; left:0; top:0; width:22px; height:22px; border-radius:50%; background:var(--bigo-green); color:white; display:inline-flex; align-items:center; justify-content:center; font-size:.75rem; font-weight:900; }

@media (max-width: 1160px) {
  .bigo-nav { gap: 14px; font-size: .82rem; }
  .bigo-logo-link { width: 195px; }
  .bigo-header .bigo-button { padding: 11px 14px; }
}
@media (max-width: 980px) {
  .admin-bar .bigo-header { top: 46px; }
  .bigo-nav, .bigo-header-actions { display: none; }
  .bigo-mobile-menu { display: block; }
  .bigo-logo-link { width: 210px; }
  .bigo-hero::after { opacity: .14; width: 420px; height: 420px; right: -130px; top: 130px; }
  .bigo-hero-inner, .bigo-intro-grid, .bigo-managed-strip, .bigo-partner-grid, .bigo-cta-grid, .bigo-content-grid { grid-template-columns: 1fr; }
  .bigo-hero-inner { min-height: auto; padding: 76px 0 82px; }
  .bigo-hero-content { max-width: 760px; }
  .bigo-grid-3 { grid-template-columns: 1fr; }
  .bigo-grid-2, .bigo-managed-features, .bigo-benefits, .bigo-contact-cards { grid-template-columns: 1fr; }
  .bigo-footer-inner { flex-direction: column; text-align: center; }
}
@media (max-width: 640px) {
  .bigo-container, .bigo-header-inner { width: min(100% - 32px, var(--bigo-max)); }
  .bigo-hero h1 { font-size: 2.75rem; }
  .bigo-section { padding: 60px 0; }
  .bigo-card { padding: 24px; }
  .bigo-service-card, .bigo-managed-title, .bigo-testimonial, .bigo-price-card { flex-direction: column; }
  .bigo-managed-strip { padding: 28px; }
  .bigo-logo-link { width: 185px; }
}









/* v7 precise hero fixes */
.bigo-hero-inner {
  min-height: 440px !important;
  padding-top: 56px !important;
  padding-bottom: 64px !important;
  grid-template-columns: minmax(0, 0.92fr) minmax(260px, 0.82fr) !important;
  align-items: center !important;
}
.bigo-hero-content { max-width: 780px !important; }
.bigo-hero-title,
.bigo-hero h1 {
  max-width: 820px !important;
  font-size: clamp(2.9rem, 4.15vw, 4.55rem) !important;
  line-height: 1.06 !important;
  letter-spacing: -0.035em !important;
  margin: 0 !important;
}
.bigo-title-line { display: block !important; }
.bigo-nowrap { white-space: nowrap !important; }
.bigo-hero p {
  max-width: 700px !important;
  margin-top: 22px !important;
  font-size: 1.03rem !important;
  line-height: 1.68 !important;
}
.bigo-hero-actions {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  flex-wrap: wrap !important;
  margin-top: 28px !important;
}
.bigo-hero-actions .bigo-button,
.bigo-hero-actions .bigo-button-outline,
.bigo-header-actions .bigo-button,
.bigo-cta .bigo-button,
a[href*="outlook.office365.com"] {
  text-decoration: none !important;
}
.bigo-pills,
.bigo-hero-service-row {
  display: grid !important;
  grid-template-columns: repeat(4, max-content) !important;
  justify-content: start !important;
  align-items: center !important;
  gap: 10px !important;
  flex-wrap: nowrap !important;
  margin-top: 24px !important;
}
.bigo-pill,
.bigo-hero-service-row .bigo-pill {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  white-space: nowrap !important;
  min-height: 42px !important;
  padding: 0 13px !important;
  font-size: .83rem !important;
  line-height: 1 !important;
}
.bigo-hero::after {
  width: clamp(270px, 31vw, 420px) !important;
  height: clamp(270px, 31vw, 420px) !important;
  right: clamp(20px, 8vw, 125px) !important;
  top: 72px !important;
  opacity: .34 !important;
}
.bigo-hero-eyebrow,
.bigo-eyebrow,
.bigo-small-business-pill,
.bigo-preheadline { display:none !important; }
@media (max-width: 1120px) {
  .bigo-hero-inner { grid-template-columns: 1fr !important; min-height: auto !important; padding-top: 60px !important; padding-bottom: 68px !important; }
  .bigo-hero::after { opacity: .13 !important; right: -110px !important; top: 118px !important; }
  .bigo-pills, .bigo-hero-service-row { grid-template-columns: repeat(2, max-content) !important; }
}
@media (max-width: 640px) {
  .bigo-hero-title, .bigo-hero h1 { font-size: clamp(2.35rem, 11vw, 3.2rem) !important; }
  .bigo-nowrap { white-space: normal !important; }
  .bigo-pills, .bigo-hero-service-row { grid-template-columns: 1fr !important; }
  .bigo-pill { width: 100% !important; justify-content: flex-start !important; }
}


/* v8 CTA link safety */
a[href*="outlook.office365.com/owa/calendar/BigOServicesSales"] {
  cursor: pointer;
}



/* v9 navigation active-state fixes */
.bigo-nav-link,
.bigo-site-nav a,
header nav a,
.wp-block-navigation a {
  border-bottom: 2px solid transparent;
  color: rgba(255,255,255,.88);
  padding-bottom: .35rem;
  transition: color .18s ease, border-color .18s ease;
}

.bigo-nav-link:hover,
.bigo-site-nav a:hover,
header nav a:hover,
.wp-block-navigation a:hover {
  color: #33b466 !important;
}

.bigo-nav-link.bigo-current,
.bigo-site-nav a.bigo-current,
header nav a.bigo-current,
.wp-block-navigation a.bigo-current,
.current-menu-item > a,
.current_page_item > a,
.wp-block-navigation-item.current-menu-item > a,
.wp-block-navigation-item.current_page_item > a {
  color: #33b466 !important;
  border-bottom-color: #168845 !important;
}

header nav a[aria-current="page"],
.wp-block-navigation a[aria-current="page"] {
  color: #33b466 !important;
  border-bottom-color: #168845 !important;
}


/* v11 mobile navigation toggle fix */
.bigo-mobile-menu {
  appearance: none;
  -webkit-appearance: none;
  background: transparent;
  border: 0;
  cursor: pointer;
  line-height: 1;
  padding: 8px;
  border-radius: 10px;
}
.bigo-mobile-menu:hover,
.bigo-mobile-menu:focus-visible {
  background: rgba(255,255,255,.10);
  color: #fff;
  outline: none;
}

@media (max-width: 980px) {
  .bigo-header-inner { position: relative; }
  .bigo-header.bigo-mobile-nav-open .bigo-nav {
    display: flex;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    z-index: 1000;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding: 14px;
    background: rgba(8,13,11,.99);
    border: 1px solid rgba(255,255,255,.12);
    border-top: 0;
    border-radius: 0 0 18px 18px;
    box-shadow: 0 24px 50px rgba(0,0,0,.28);
    white-space: normal;
  }
  .bigo-header.bigo-mobile-nav-open .bigo-nav a {
    display: block;
    padding: 13px 12px;
    border-radius: 10px;
  }
  .bigo-header.bigo-mobile-nav-open .bigo-nav a:hover,
  .bigo-header.bigo-mobile-nav-open .bigo-nav a.bigo-current,
  .bigo-header.bigo-mobile-nav-open .bigo-nav a[aria-current="page"] {
    background: rgba(22,136,69,.16);
    color: var(--bigo-green-bright);
  }
}
