@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@400;500;600;700&family=Inter:wght@300;400;500;600&display=swap');

/* ── WordPress / Astra overrides ─────────────────────── */
html{scroll-behavior:smooth}
.ast-primary-header-bar,.ast-main-header-bar-wrap,#masthead,.entry-title,
.ast-above-header-bar,.ast-above-header,.ast-below-header-section,
.ast-breadcrumbs-wrapper,.ast-page-header-section,.ast-page-title-wrap,
.page-header,.entry-header,.post-thumbnail,.wp-post-image,
.ast-featured-image-wrap,.ast-article-post-thumbnail,.ast-post-thumbnail,
.ast-site-identity-wrap,.ast-site-identity{display:none!important}
.entry-content,#primary,.ast-article-single,.site-main,.ast-container,#content,#main,#page,#wrapper{
  max-width:100%!important;width:100%!important;padding:0!important;margin:0!important}

/* ── Reset (scoped) ──────────────────────────────────── */
#sg *,#sg *::before,#sg *::after{box-sizing:border-box;margin:0;padding:0}

/* ── Theme variables ─────────────────────────────────── */
#sg{
  --bg:hsl(30,4%,22%);--fg:hsl(0,0%,100%);
  --accent:hsl(220,13%,80%);--accent-fg:hsl(215,25%,31%);
  --primary:hsl(215,25%,31%);--muted:hsl(220,13%,75%);
  --card:hsl(30,4%,19%);--card-bg:hsl(215,25%,28%);
  --border:hsl(215,25%,35%);--header-bg:rgba(58,55,48,.97);
  --shadow:0 4px 20px rgba(0,0,0,.35);--radius:.5rem;
}
#sg[data-theme="light"]{
  --bg:hsl(0,0%,97%);--fg:hsl(215,25%,18%);
  --accent:hsl(215,45%,40%);--accent-fg:hsl(0,0%,100%);
  --primary:hsl(215,35%,92%);--muted:hsl(215,15%,45%);
  --card:hsl(0,0%,94%);--card-bg:hsl(215,30%,88%);
  --border:hsl(215,20%,80%);--header-bg:rgba(250,250,252,.97);
  --shadow:0 4px 20px rgba(0,0,0,.10);
}

/* ── Base ────────────────────────────────────────────── */
#sg{background:var(--bg);color:var(--fg);font-family:'Inter',sans-serif;font-weight:300;line-height:1.6;transition:background .3s,color .3s;width:100%;overflow-x:clip}
#sg a{color:inherit;text-decoration:none}
#sg img{max-width:100%}
#sg h1,#sg h2,#sg h3,#sg h4,#sg h5,#sg h6{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.05em;font-weight:600;line-height:1.2}
#sg .container{max-width:1280px;margin:0 auto!important;padding:0 1.5rem!important;width:100%!important;box-sizing:border-box!important}

/* ── Buttons ─────────────────────────────────────────── */
#sg .btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 2rem;border-radius:var(--radius);font-family:'Inter',sans-serif;font-size:.95rem;font-weight:500;cursor:pointer;border:2px solid transparent;transition:all .2s;text-decoration:none;white-space:nowrap}
#sg .btn-accent{background:var(--accent);color:var(--accent-fg);border-color:var(--accent)}
#sg .btn-accent:hover{opacity:.85}
#sg .btn-outline{background:transparent;color:var(--accent);border-color:var(--accent)}
#sg .btn-outline:hover{background:var(--accent);color:var(--accent-fg)}
#sg .btn-lg{padding:.9rem 2.25rem;font-size:1.05rem}
#sg .btn-full{width:100%}

/* ── Top Banner ──────────────────────────────────────── */
#sg .top-banner{background:var(--accent);color:var(--accent-fg);padding:.5rem 1rem;text-align:center;font-size:.85rem;font-weight:500;display:flex;align-items:center;justify-content:center;gap:.5rem}

/* ── Header ──────────────────────────────────────────── */
#sg .sg-hdr{position:sticky;top:0;z-index:999;background:var(--header-bg);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);transition:background .3s,border-color .3s;display:block!important}
#sg .header-inner{display:flex;align-items:center;justify-content:space-between;height:80px;gap:1.5rem}
#sg .logo-wrap{display:flex;align-items:center;gap:.75rem;flex-shrink:0}
#sg .logo-wrap img{height:48px;width:auto}
#sg .logo-name{font-family:'Oswald',sans-serif;font-size:1.2rem;font-weight:700;color:var(--accent);letter-spacing:.08em}
#sg .main-nav{display:flex;align-items:center;gap:2rem}
#sg .main-nav a{font-size:.9rem;font-weight:500;color:var(--muted);transition:color .2s}
#sg .main-nav a:hover{color:var(--fg)}
#sg .header-right{display:flex;align-items:center;gap:.75rem;flex-shrink:0}
#sg .header-right .btn{height:38px;padding:0 1.25rem;font-size:.85rem}

/* ── Language dropdown ───────────────────────────────── */
#sg .lang-dropdown{position:relative}
#sg .lang-btn{display:flex;align-items:center;gap:.4rem;background:transparent;border:1px solid var(--border);color:var(--muted);border-radius:var(--radius);padding:0 .85rem;height:38px;font-family:'Inter',sans-serif;font-size:.82rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}
#sg .lang-btn:hover{border-color:var(--accent);color:var(--fg)}
#sg .lang-btn svg{width:15px;height:15px;flex-shrink:0;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
#sg .lang-btn .chevron{width:12px;height:12px;transition:transform .2s}
#sg .lang-dropdown.open .chevron{transform:rotate(180deg)}
#sg .lang-menu{display:none;position:absolute;top:calc(100% + 6px);right:0;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;min-width:140px;z-index:100}
#sg .lang-dropdown.open .lang-menu{display:block}
#sg .lang-menu button{display:block;width:100%;text-align:left;padding:.6rem 1rem;background:none;border:none;font-family:'Inter',sans-serif;font-size:.85rem;color:var(--muted);cursor:pointer;transition:all .15s}
#sg .lang-menu button:hover{background:var(--primary);color:var(--fg)}
#sg .lang-menu button.active{color:var(--accent);font-weight:600}

/* ── Theme toggle ────────────────────────────────────── */
#sg .theme-toggle{width:38px;height:38px;border-radius:var(--radius);border:1px solid var(--border);background:transparent;color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}
#sg .theme-toggle:hover{border-color:var(--accent);color:var(--fg)}
#sg .theme-toggle svg{width:17px;height:17px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
#sg .icon-sun{display:none}
#sg .icon-moon{display:block}
#sg[data-theme="light"] .icon-sun{display:block}
#sg[data-theme="light"] .icon-moon{display:none}

/* ── Hamburger ───────────────────────────────────────── */
#sg .hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:.5rem;background:none;border:none}
#sg .hamburger span{display:block;width:24px;height:2px;background:var(--fg);transition:all .3s}

/* ── Mobile menu ─────────────────────────────────────── */
#sg .mobile-menu{display:none;flex-direction:column;gap:.25rem;padding:1.5rem;border-top:1px solid var(--border);background:var(--header-bg)}
#sg .mobile-menu.open{display:flex}
#sg .mobile-menu a{padding:.6rem 0;font-size:.9rem;font-weight:500;color:var(--muted)}
#sg .mobile-menu a:hover{color:var(--fg)}
#sg .mobile-menu-controls{display:flex;align-items:center;gap:.75rem;padding:.75rem 0;border-top:1px solid var(--border)}
#sg .mobile-menu-ctas{display:flex;flex-direction:column;gap:.75rem;margin-top:.5rem;padding-top:1rem;border-top:1px solid var(--border)}
@media(max-width:1023px){#sg .main-nav,#sg .header-right{display:none}#sg .hamburger{display:flex}}

/* ── Sections ────────────────────────────────────────── */
#sg .section{padding:6rem 0}
#sg .section-alt{background:var(--card)}
#sg .section-title{text-align:center;margin-bottom:4rem}
#sg .section-title h2{font-size:clamp(1.8rem,4vw,2.6rem);margin-bottom:1rem}
#sg .section-title p{color:var(--muted);max-width:600px;margin:0 auto;font-size:1.05rem}

/* ── Grids ───────────────────────────────────────────── */
#sg .grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem}
#sg .grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}

/* ── Card icon ───────────────────────────────────────── */
#sg .card-icon{width:56px;height:56px;background:rgba(128,148,180,.18);border-radius:.75rem;display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem}
#sg .card-icon svg{width:28px;height:28px;color:var(--accent);fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* ── Service cards ───────────────────────────────────── */
#sg .service-card{background:var(--card-bg);border:1px solid var(--border);border-radius:1rem;padding:2rem;display:flex;flex-direction:column;transition:border-color .3s,box-shadow .3s}
#sg .service-card:hover{border-color:var(--accent);box-shadow:var(--shadow)}
#sg .service-card h3{font-size:1.1rem;margin-bottom:.6rem}
#sg .service-card p{font-size:.9rem;color:var(--muted);line-height:1.65;flex:1;margin-bottom:1.5rem}
#sg .service-card a{color:var(--accent);font-size:.9rem;font-weight:500;display:inline-flex;align-items:center;gap:.35rem;transition:gap .2s}
#sg .service-card a:hover{gap:.6rem}

/* ── Industry cards ──────────────────────────────────── */
#sg .industry-card{background:var(--card-bg);border:1px solid var(--border);border-radius:1rem;padding:2rem;transition:border-color .3s,box-shadow .3s}
#sg .industry-card:hover{border-color:var(--accent);box-shadow:var(--shadow)}
#sg .industry-card h3{font-size:1.2rem;margin-bottom:.5rem}
#sg .industry-card p{font-size:.9rem;color:var(--muted)}

/* ── About video background ─────────────────────────── */
#sg #sg-about{position:relative;overflow:hidden}
#sg .about-video-bg{position:absolute;inset:0;z-index:0}
#sg .about-video-bg video{width:100%;height:100%;object-fit:cover;display:block}
#sg .about-video-overlay{position:absolute;inset:0;background:rgba(8,20,40,.72);z-index:1}
#sg #sg-about>.container{position:relative;z-index:2}

/* ── Our Story ───────────────────────────────────────── */
#sg .about-story{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:3.5rem;
  align-items:center;
  margin-bottom:3.5rem
}
#sg .about-story-text h2{font-size:clamp(1.8rem,3.5vw,2.4rem);margin-bottom:1.5rem;color:#fff}
#sg .about-story-text p{color:rgba(255,255,255,.75);line-height:1.85;margin-bottom:1rem}

/* ── About Story Slideshow ───────────────────────────── */
#sg .about-story-slider{
  position:relative;
  border-radius:1.25rem;
  overflow:visible
}
#sg .asl-viewport{
  border-radius:1.25rem;
  overflow:hidden;
  box-shadow:0 8px 40px rgba(0,0,0,.45);
  border:1px solid rgba(255,255,255,.12)
}
#sg .asl-track{
  display:flex;
  transition:transform .6s cubic-bezier(.4,0,.2,1)
}
#sg .asl-slide{
  flex:0 0 100%;
  width:100%;
  height:360px;
  object-fit:cover;
  object-position:center center;
  display:block
}
#sg .asl-dots{
  display:flex;
  justify-content:center;
  gap:.5rem;
  margin-top:1rem
}
#sg .asl-dot{
  width:8px;
  height:8px;
  border-radius:50%;
  background:rgba(255,255,255,.3);
  border:none;
  cursor:pointer;
  padding:0;
  transition:background .25s,width .25s
}
#sg .asl-dot.active{
  background:#C7D0DD;
  width:24px;
  border-radius:4px
}
@media(max-width:767px){
  #sg .about-story{grid-template-columns:1fr;gap:2rem}
  #sg .asl-slide{height:240px}
}

/* ── Mission + Vision grid ───────────────────────────── */
#sg .about-mv-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
#sg .mv-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:1.25rem;padding:2.5rem}
#sg .mv-card h3{font-size:1.5rem;margin-bottom:1.25rem;color:#fff}
#sg .mv-card p{color:rgba(255,255,255,.75);line-height:1.8;margin-bottom:1rem}
#sg .mv-card p:last-child{margin-bottom:0}
@media(max-width:767px){#sg .about-mv-grid{grid-template-columns:1fr}}

/* ── Stats ───────────────────────────────────────────── */
#sg .stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;text-align:center}
#sg .stat-card{padding:3rem 1.5rem;border-right:1px solid var(--border);position:relative}
#sg .stat-card:last-child{border-right:none}
#sg .stat-val{font-family:'Oswald',sans-serif;font-size:clamp(2.8rem,5vw,4rem);font-weight:700;color:var(--accent);line-height:1;margin-bottom:.5rem}
#sg .stat-lbl{font-size:.95rem;color:var(--muted);font-weight:500;letter-spacing:.03em}

/* ── Testimonial Carousel ───────────────────────────── */
#sg .testi-carousel-wrap{display:flex;align-items:center;gap:1rem;position:relative}
#sg .testi-carousel-viewport{overflow:hidden;flex:1;border-radius:1.25rem}
#sg .testi-carousel-track{display:flex;transition:transform .45s cubic-bezier(.4,0,.2,1)}
#sg .testi-slide{flex:0 0 33.333%;padding:0 .5rem;box-sizing:border-box}
#sg .testi-arrow{flex-shrink:0;width:48px;height:48px;border-radius:50%;border:1px solid var(--border);background:var(--card-bg);color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .2s,background .2s,color .2s}
#sg .testi-arrow:hover{border-color:var(--accent);background:var(--accent);color:var(--accent-fg)}
#sg .testi-dots{display:flex;justify-content:center;gap:.5rem;margin-top:1.5rem}
#sg .testi-dot{width:8px;height:8px;border-radius:50%;background:var(--border);border:none;cursor:pointer;transition:background .2s,width .2s;padding:0}
#sg .testi-dot.active{background:var(--accent);width:24px;border-radius:4px}
#sg .testi-card{background:var(--card-bg);border:1px solid var(--border);border-radius:1.25rem;padding:1.75rem;display:flex;flex-direction:column;gap:1rem}
#sg .testi-stars{color:#f59e0b;font-size:1rem;letter-spacing:.1em}
#sg .testi-quote{font-size:.92rem;color:var(--muted);line-height:1.7;flex:1;font-style:italic}
#sg .testi-author{display:flex;align-items:center;gap:.75rem;padding-top:.75rem;border-top:1px solid var(--border)}
#sg .testi-avatar{width:44px;height:44px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;color:var(--accent);flex-shrink:0}
#sg .testi-name{font-weight:600;font-size:.9rem;color:var(--fg)}
#sg .testi-role{font-size:.78rem;color:var(--muted)}

/* ── Footer ──────────────────────────────────────────── */
#sg .sg-ftr{background:var(--card);border-top:1px solid var(--border);padding:5rem 0 0}
#sg .footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:3rem;padding-bottom:4rem}
#sg .footer-brand span{font-family:'Oswald',sans-serif;font-size:1.5rem;font-weight:700;color:var(--accent);letter-spacing:.08em}
#sg .footer-brand p{margin-top:1rem;font-size:.875rem;color:var(--muted);line-height:1.7}
#sg .footer-col h4{font-size:.8rem;font-weight:600;letter-spacing:.1em;margin-bottom:1rem}
#sg .footer-col ul{list-style:none}
#sg .footer-col ul li{margin-bottom:.75rem}
#sg .footer-col ul li a{font-size:.875rem;color:var(--muted);transition:color .2s}
#sg .footer-col ul li a:hover{color:var(--accent)}
#sg .social-links{display:flex;gap:1rem;margin-top:.5rem}
#sg .social-links a{width:40px;height:40px;background:rgba(128,148,180,.18);border-radius:.5rem;display:flex;align-items:center;justify-content:center;transition:all .2s}
#sg .social-links a:hover{background:var(--accent);color:var(--accent-fg)}
#sg .social-links a svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
#sg .footer-bottom{border-top:1px solid var(--border);padding:1.75rem 0;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
#sg-legal-strip{background:#0a0a0a;border-top:1px solid rgba(255,255,255,.06);padding:.65rem 2rem;text-align:center}
#sg-legal-strip p{font-size:.72rem;color:rgba(255,255,255,.35);margin:0;line-height:1.5}
#sg .footer-bottom p{font-size:.8rem;color:var(--muted)}
#sg .footer-bottom-links{display:flex;gap:1.5rem}
#sg .footer-bottom-links a{font-size:.8rem;color:var(--muted);transition:color .2s}
#sg .footer-bottom-links a:hover{color:var(--accent)}

/* ── Toast ───────────────────────────────────────────── */
#sg-toast{position:fixed;top:-100px;left:50%;transform:translateX(-50%);background:#22c55e;color:#fff;padding:1rem 2rem;border-radius:999px;font-family:'Inter',sans-serif;font-size:.95rem;font-weight:500;box-shadow:0 8px 32px rgba(0,0,0,.25);z-index:99999;transition:top .4s cubic-bezier(.4,0,.2,1);white-space:nowrap;pointer-events:none}
#sg-toast.show{top:90px}

/* ── Cookie consent ──────────────────────────────────── */
#sg-cookie{display:flex;position:fixed;bottom:1.5rem;right:1.5rem;z-index:99998;background:var(--bg);border:1px solid var(--border);border-radius:1rem;padding:1.25rem 1.75rem;box-shadow:0 8px 40px rgba(0,0,0,.35);max-width:420px;width:calc(100% - 2rem);align-items:center;gap:1.25rem;flex-wrap:wrap;transform:translateY(140%);transition:transform .45s cubic-bezier(.34,1.56,.64,1)}
#sg-cookie.show{transform:translateY(0)}
#sg-cookie p{flex:1;font-size:.875rem;color:var(--muted);line-height:1.6;min-width:180px;margin:0}
#sg-cookie .cookie-icon{flex-shrink:0;width:22px;height:22px;color:var(--accent)}

/* ── Legal Modal ─────────────────────────────────────── */
#sg-pp-overlay,#sg-tos-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(5px);z-index:10002;align-items:flex-start;justify-content:center;padding:2rem;overflow-y:auto}
#sg-pp-overlay.open,#sg-tos-overlay.open{display:flex}
#sg .legal-modal{background:var(--bg);border:1px solid var(--border);border-radius:1.25rem;padding:2.5rem 2.5rem 2rem;width:100%;max-width:700px;margin:auto;position:relative;animation:sgModalIn .25s ease}
#sg .legal-modal h2{font-size:1.6rem;margin-bottom:.35rem}
#sg .legal-modal .legal-date{font-size:.82rem;color:var(--muted);margin-bottom:2rem}
#sg .legal-modal h3{font-size:.95rem;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.07em;margin:1.5rem 0 .5rem}
#sg .legal-modal p,#sg .legal-modal li{font-size:.875rem;color:var(--muted);line-height:1.75;margin-bottom:.5rem}
#sg .legal-modal ul{list-style:disc;padding-left:1.25rem;margin-bottom:.5rem}
#sg .legal-modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;color:var(--muted);cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:.5rem;transition:all .2s}
#sg .legal-modal-close:hover{background:var(--primary);color:var(--fg)}

/* ── Animations ──────────────────────────────────────── */
@keyframes sgModalIn{from{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:none}}
@keyframes sgFadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
@keyframes sgRevealL{from{opacity:0;transform:translateX(-48px)}to{opacity:1;transform:none}}
@keyframes sgRevealR{from{opacity:0;transform:translateX(48px)}to{opacity:1;transform:none}}

/* ── About page animations ───────────────────────────── */
#sg #sg-about .section-title{animation:sgFadeUp .55s ease .05s both}
#sg #sg-about .about-text{animation:sgRevealL .7s ease .1s both}
#sg #sg-about .mission-card{animation:sgRevealR .7s ease .25s both}

/* ── Responsive ──────────────────────────────────────── */
@media(max-width:1023px){
  #sg .grid-4{grid-template-columns:repeat(2,1fr)}
  #sg .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
  #sg .about-grid{grid-template-columns:1fr;gap:2.5rem}
}
@media(max-width:767px){
  #sg .grid-4,#sg .grid-3{grid-template-columns:1fr}
  #sg .footer-grid{grid-template-columns:1fr}
  #sg .footer-bottom{flex-direction:column;text-align:center}
  #sg .section{padding:4rem 0}
  #sg .testi-slide{flex:0 0 100%}
  #sg .stats-grid{grid-template-columns:repeat(2,1fr)}
  #sg .stat-card:nth-child(2){border-right:none}
  #sg .stat-card:nth-child(1),#sg .stat-card:nth-child(2){border-bottom:1px solid var(--border)}
}
@media(min-width:768px) and (max-width:1023px){
  #sg .testi-slide{flex:0 0 50%}
}
@media(prefers-reduced-motion:reduce){
  #sg #sg-about .about-text,#sg #sg-about .mission-card{animation:none;opacity:1;transform:none}
}
