/* ============================================================
   STORIX ENERGY — Main Stylesheet
   Fonts: Raleway (headings) + Inter (body)
   Colors: Navy #174361 | Gold #FED433 | Green #2BA166
   ============================================================ */

:root {
  --navy:       #174361;
  --navy-dark:  #0f2d45;
  --navy-mid:   #1a5276;
  --gold:       #FED433;
  --gold-dark:  #d4ae2a;
  --green:      #2BA166;
  --green-dark: #228a55;
  --white:      #FFFFFF;
  --off-white:  #F5F7FA;
  --gray-100:   #F0F2F5;
  --gray-200:   #E4E6EA;
  --gray-300:   #D1D5DB;
  --gray-400:   #9CA3AF;
  --gray-500:   #6B7280;
  --gray-600:   #4B5563;
  --gray-700:   #374151;
  --gray-900:   #111827;

  --font-heading: 'Raleway', system-ui, sans-serif;
  --font-body:    'Inter', system-ui, -apple-system, sans-serif;

  --shadow-xs: 0 1px 2px rgba(0,0,0,0.05);
  --shadow-sm: 0 2px 8px rgba(0,0,0,0.07);
  --shadow-md: 0 4px 20px rgba(0,0,0,0.09);
  --shadow-lg: 0 8px 32px rgba(0,0,0,0.11);
  --shadow-xl: 0 16px 48px rgba(0,0,0,0.14);

  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 16px;
  --radius-xl: 24px;

  --transition: 0.25s ease;
  --container-max: 1200px;
  --nav-height: 72px;
}

/* ——— Reset ——— */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body { font-family: var(--font-body); color: var(--gray-900); background: var(--white); line-height: 1.6; -webkit-font-smoothing: antialiased; }
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }
input, textarea, select { font-family: inherit; }

/* ——— Typography ——— */
h1,h2,h3,h4,h5,h6 { font-family: var(--font-heading); line-height: 1.22; color: var(--navy); }
h1 { font-size: clamp(2rem,5vw,3.5rem); }
h2 { font-size: clamp(1.75rem,3.5vw,2.625rem); }
h3 { font-size: clamp(1.25rem,2.5vw,1.75rem); }
h4 { font-size: 1.25rem; }
p  { color: var(--gray-700); line-height: 1.75; }

/* ——— Layout ——— */
.container { max-width: var(--container-max); margin: 0 auto; padding: 0 24px; }
.section    { padding: 96px 0; }
.section-sm { padding: 64px 0; }
.section-alt { background: var(--off-white); }

.grid-2 { display: grid; grid-template-columns: repeat(2,1fr); gap: 32px; }
.grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 32px; }
.grid-4 { display: grid; grid-template-columns: repeat(4,1fr); gap: 24px; }

@media(max-width:1024px){ .grid-4{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:768px){
  .grid-2,.grid-3,.grid-4{ grid-template-columns:1fr; }
  .section{ padding:64px 0; }
}

/* ——— Section Header ——— */
.section-header { margin-bottom: 52px; }
.section-header.center { text-align: center; max-width: 700px; margin-left: auto; margin-right: auto; }
.section-label { display:inline-block; font-size:.75rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--green); margin-bottom:12px; }
.section-title { margin-bottom: 16px; }
.section-subtitle { font-size:1.0625rem; color:var(--gray-500); line-height:1.75; }

/* ——— Buttons ——— */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 14px 28px; border-radius: var(--radius-md);
  font-size: .9375rem; font-weight: 600; font-family: var(--font-body);
  transition: all var(--transition); cursor: pointer;
  white-space: nowrap; border: 2px solid transparent;
}
.btn-primary   { background:var(--navy);  color:var(--white); border-color:var(--navy); }
.btn-primary:hover { background:var(--navy-dark); border-color:var(--navy-dark); transform:translateY(-1px); box-shadow:var(--shadow-md); }
.btn-secondary { background:var(--gold);  color:var(--navy);  border-color:var(--gold); }
.btn-secondary:hover { background:var(--gold-dark); border-color:var(--gold-dark); transform:translateY(-1px); box-shadow:var(--shadow-md); }
.btn-outline   { background:transparent; color:var(--navy);  border-color:var(--navy); }
.btn-outline:hover { background:var(--navy); color:var(--white); transform:translateY(-1px); }
.btn-outline-white { background:transparent; color:var(--white); border-color:rgba(255,255,255,.5); }
.btn-outline-white:hover { background:rgba(255,255,255,.1); border-color:var(--white); }
.btn-green { background:var(--green); color:var(--white); border-color:var(--green); }
.btn-green:hover { background:var(--green-dark); border-color:var(--green-dark); transform:translateY(-1px); }
.btn-sm { padding:10px 20px; font-size:.875rem; }
.btn-lg { padding:18px 36px; font-size:1.0625rem; }

/* ——— Navigation ——— */
.nav {
  position: fixed; top: 0; left: 0; right: 0;
  height: var(--nav-height); z-index: 1000;
  background: rgba(255,255,255,.97);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--gray-200);
  transition: box-shadow var(--transition);
}
.nav.scrolled { box-shadow: var(--shadow-md); }
.nav-inner { display:flex; align-items:center; justify-content:space-between; height:100%; }
.nav-logo { display:flex; align-items:center; height:56px; }
.nav-logo img { height:54px; width:auto; }
.nav-links { display:flex; align-items:center; gap:2px; }
.nav-link { padding:8px 14px; font-size:.9rem; font-weight:500; color:var(--gray-700); border-radius:var(--radius-sm); transition:all var(--transition); }
.lang-switcher { display:flex; align-items:center; gap:4px; margin-left:4px; padding:0 4px; }
.lang-btn { font-size:.78rem; font-weight:700; letter-spacing:.06em; padding:5px 9px; border-radius:var(--radius-sm); color:var(--gray-500); background:none; border:1.5px solid transparent; transition:all var(--transition); cursor:pointer; }
.lang-btn:hover { color:var(--navy); border-color:var(--gray-300); }
.lang-btn.active { color:var(--navy); border-color:var(--navy); background:var(--gray-100); }
.nav-link:hover, .nav-link.active { color:var(--navy); background:var(--gray-100); }
.nav-hamburger { display:none; flex-direction:column; gap:5px; padding:8px; }
.nav-hamburger span { width:24px; height:2px; background:var(--navy); border-radius:2px; transition:all var(--transition); display:block; }
.nav-hamburger.open span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.nav-hamburger.open span:nth-child(2) { opacity:0; }
.nav-hamburger.open span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }
.nav-mobile {
  display:none; position:fixed; top:var(--nav-height); left:0; right:0; bottom:0;
  background:white; z-index:999; padding:24px; flex-direction:column; gap:4px; overflow-y:auto;
}
.nav-mobile.open { display:flex; }
.nav-mobile .nav-link { display:block; padding:14px 16px; font-size:1rem; border-radius:var(--radius-md); border-bottom:1px solid var(--gray-100); }
.nav-mobile-cta { margin-top:20px; }
@media(max-width:968px){
  .nav-links { display:none; }
  .nav-cta .btn { display:none; }
  .nav-hamburger { display:flex; }
}

/* ——— Hero ——— */
.hero {
  min-height: 100vh; background: var(--navy);
  display:flex; align-items:center;
  position:relative; overflow:hidden;
  padding-top: var(--nav-height);
}
.hero-img {
  position:absolute; inset:0; z-index:0;
  background-image: url('../assets/images/hero-bg.jpg');
  background-size:cover; background-position:center;
}
.hero-bg {
  position:absolute; inset:0; z-index:1;
  background:
    radial-gradient(ellipse at 15% 60%, rgba(43,161,102,.14) 0%, transparent 55%),
    radial-gradient(ellipse at 85% 20%, rgba(254,212,51,.08) 0%, transparent 50%),
    linear-gradient(135deg,rgba(23,67,97,.72) 0%,rgba(15,45,69,.68) 60%,rgba(8,29,46,.78) 100%);
}
.hero-grid {
  position:absolute; inset:0; z-index:2;
  background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:64px 64px;
}
.hero-content { position:relative; z-index:3; max-width:780px; padding:80px 0 100px; }
.hero-badge {
  display:inline-flex; align-items:center; gap:10px;
  background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.14);
  border-radius:100px; padding:8px 18px; margin-bottom:32px;
  font-size:.8125rem; font-weight:500; color:rgba(255,255,255,.8); letter-spacing:.04em;
}
.hero-badge-dot { width:6px; height:6px; border-radius:50%; background:var(--green); animation:pulse 2.2s infinite; }
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(1.3)} }
.hero-title { font-size:clamp(2.125rem,5vw,3.75rem); color:var(--white); margin-bottom:24px; line-height:1.13; }
.hero-title em { font-style:italic; color:var(--gold); }
.hero-subtitle { font-size:clamp(1rem,2vw,1.25rem); color:rgba(255,255,255,.72); margin-bottom:40px; line-height:1.72; max-width:580px; }
.hero-actions { display:flex; gap:16px; flex-wrap:wrap; margin-bottom:60px; }
.hero-tech-pills { display:flex; flex-wrap:wrap; gap:12px; }
.tech-pill {
  display:flex; align-items:center; gap:8px;
  padding:10px 18px; background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.14); border-radius:100px;
  font-size:.8125rem; font-weight:500; color:rgba(255,255,255,.85); transition:all var(--transition);
}
.tech-pill:hover { background:rgba(255,255,255,.13); border-color:rgba(255,255,255,.28); }
.tech-pill-icon { font-size:1.125rem; }
.hero-scroll {
  position:absolute; bottom:36px; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:8px;
  color:rgba(255,255,255,.35); font-size:.7rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase;
  animation:bounce 2.2s infinite;
}
.hero-scroll svg { opacity:.4; }
@keyframes bounce { 0%,100%{transform:translateX(-50%) translateY(0)} 50%{transform:translateX(-50%) translateY(7px)} }

/* ——— Stats Bar ——— */
.stats-bar { background:var(--navy-dark); padding:40px 0; border-top:1px solid rgba(255,255,255,.07); }
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:0; }
.stat-item { text-align:center; padding:16px 24px; border-right:1px solid rgba(255,255,255,.08); }
.stat-item:last-child { border-right:none; }
.stat-value { font-family:var(--font-heading); font-size:2.25rem; font-weight:700; color:var(--gold); line-height:1; margin-bottom:8px; }
.stat-label { font-size:.875rem; color:rgba(255,255,255,.55); font-weight:500; }
@media(max-width:768px){
  .stats-grid { grid-template-columns:repeat(2,1fr); }
  .stat-item { border-right:none; border-bottom:1px solid rgba(255,255,255,.08); }
  .stat-item:nth-child(odd) { border-right:1px solid rgba(255,255,255,.08); }
  .stat-item:nth-last-child(-n+2) { border-bottom:none; }
}

/* ——— About ——— */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
.about-img-wrap { border-radius:var(--radius-xl); overflow:hidden; margin-bottom:24px; aspect-ratio:16/9; }
.about-img { width:100%; height:100%; object-fit:cover; display:block; }
.about-card { background:var(--navy); border-radius:var(--radius-xl); padding:48px; color:white; position:relative; overflow:hidden; }
.about-card::before { content:''; position:absolute; top:-50px; right:-50px; width:180px; height:180px; background:var(--gold); opacity:.06; border-radius:50%; }
.about-card::after  { content:''; position:absolute; bottom:-60px; left:-30px;  width:150px; height:150px; background:var(--green); opacity:.07; border-radius:50%; }
.about-card-title { font-size:1.375rem; font-family:var(--font-heading); color:white; margin-bottom:16px; }
.about-card-text  { color:rgba(255,255,255,.72); font-size:.9375rem; line-height:1.75; margin-bottom:24px; }
.about-tech-chips { display:flex; gap:8px; flex-wrap:wrap; margin-top:24px; }
.about-tech-chip  { padding:6px 14px; background:rgba(255,255,255,.1); border-radius:100px; font-size:.8rem; font-weight:500; color:rgba(255,255,255,.82); }
.about-highlights { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-top:32px; }
.about-highlight { background:var(--off-white); border-radius:var(--radius-md); padding:20px; border-left:3px solid var(--navy); }
.about-highlight-value { font-family:var(--font-heading); font-size:1.5rem; font-weight:700; color:var(--navy); }
.about-highlight-label { font-size:.8125rem; color:var(--gray-500); margin-top:4px; }
@media(max-width:768px){ .about-grid{ grid-template-columns:1fr; gap:40px; } .about-highlights{ grid-template-columns:repeat(2,1fr); } }

/* ——— Value Cards ——— */
.value-card {
  background:var(--white); border-radius:var(--radius-lg); padding:32px;
  box-shadow:var(--shadow-sm); border:1px solid var(--gray-200);
  transition:all var(--transition); border-top:3px solid transparent;
}
.value-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-4px); border-top-color:var(--navy); }
.value-icon { width:52px; height:52px; border-radius:var(--radius-md); display:flex; align-items:center; justify-content:center; margin-bottom:20px; font-size:1.375rem; }
.icon-navy  { background:rgba(23,67,97,.08); }
.icon-gold  { background:rgba(254,212,51,.18); }
.icon-green { background:rgba(43,161,102,.1); }
.value-title { font-size:1.0625rem; font-weight:700; color:var(--navy); margin-bottom:10px; font-family:var(--font-body); }
.value-text  { font-size:.9375rem; color:var(--gray-500); line-height:1.65; }

/* ——— Approach Diagram ——— */
.approach-wrap { background:var(--navy); border-radius:var(--radius-xl); padding:56px; position:relative; overflow:hidden; }
.approach-wrap::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 50% 110%,rgba(43,161,102,.14),transparent 60%); }
.approach-header { text-align:center; position:relative; z-index:1; margin-bottom:48px; }
.approach-header h3 { color:white; font-size:1.625rem; margin-bottom:10px; }
.approach-header p  { color:rgba(255,255,255,.62); font-size:.9375rem; }
.approach-grid { display:grid; grid-template-columns:1fr 1fr 1fr; gap:20px; position:relative; z-index:1; }
.approach-col { background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); border-radius:var(--radius-lg); padding:28px; }
.approach-col-icon { font-size:1.75rem; margin-bottom:14px; }
.approach-col-label { font-size:.7rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--gold); margin-bottom:10px; }
.approach-col-title { font-size:1.125rem; color:white; font-family:var(--font-heading); margin-bottom:16px; }
.approach-col-items { display:flex; flex-direction:column; gap:8px; }
.approach-col-item { font-size:.8125rem; color:rgba(255,255,255,.68); padding:7px 12px; background:rgba(255,255,255,.05); border-radius:6px; border-left:2px solid rgba(254,212,51,.4); }
.approach-connector { text-align:center; margin-top:32px; position:relative; z-index:1; }
.approach-connector p { color:rgba(255,255,255,.5); font-size:.875rem; font-style:italic; }
@media(max-width:768px){ .approach-wrap{ padding:32px 24px; } .approach-grid{ grid-template-columns:1fr; } }

/* ——— Service Preview Cards ——— */
.service-card {
  background:var(--white); border-radius:var(--radius-lg); padding:40px;
  border:1px solid var(--gray-200); box-shadow:var(--shadow-sm);
  transition:all var(--transition); position:relative; overflow:hidden;
}
.service-card::after { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--navy); transform:scaleX(0); transition:transform var(--transition); }
.service-card:hover { box-shadow:var(--shadow-xl); transform:translateY(-5px); }
.service-card:hover::after { transform:scaleX(1); }
.service-card-icon { width:60px; height:60px; border-radius:var(--radius-md); display:flex; align-items:center; justify-content:center; margin-bottom:24px; font-size:1.625rem; }
.service-card-title { font-size:1.375rem; font-family:var(--font-heading); color:var(--navy); margin-bottom:14px; }
.service-card-text  { font-size:.9375rem; color:var(--gray-500); line-height:1.7; margin-bottom:24px; }
.service-list { display:flex; flex-direction:column; gap:9px; }
.service-list li { display:flex; align-items:flex-start; gap:10px; font-size:.9rem; color:var(--gray-600); line-height:1.5; }
.service-list li::before { content:'→'; color:var(--green); font-weight:700; flex-shrink:0; margin-top:1px; }

/* ——— Tabs (generic) ——— */
.tabs-wrap { background:var(--white); border-radius:var(--radius-xl); box-shadow:var(--shadow-md); overflow:hidden; border:1px solid var(--gray-200); }
.tabs-nav  { display:flex; background:var(--off-white); border-bottom:1px solid var(--gray-200); overflow-x:auto; scrollbar-width:none; }
.tabs-nav::-webkit-scrollbar { display:none; }
.tab-btn { flex:1; min-width:140px; padding:18px 20px; font-size:.9rem; font-weight:600; color:var(--gray-500); text-align:center; border-bottom:3px solid transparent; transition:all var(--transition); white-space:nowrap; }
.tab-btn:hover  { color:var(--navy); background:rgba(23,67,97,.04); }
.tab-btn.active { color:var(--navy); border-bottom-color:var(--navy); background:var(--white); }
.tab-panel { display:none; padding:48px; animation:fadeUp .3s ease; }
.tab-panel.active { display:block; }
@keyframes fadeUp { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }
@media(max-width:768px){ .tab-panel{ padding:28px 20px; } .tab-btn{ min-width:120px; padding:14px 16px; } }

/* ——— Tech Tabs ——— */
.tech-tabs-nav { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:36px; }
.tech-tab-btn { padding:12px 24px; border-radius:100px; font-size:.9rem; font-weight:600; color:var(--gray-500); background:var(--gray-100); border:2px solid transparent; transition:all var(--transition); }
.tech-tab-btn:hover { color:var(--navy); background:var(--gray-200); }
.tech-tab-btn.active { background:var(--navy); color:var(--white); border-color:var(--navy); }
.tech-panel { display:none; animation:fadeUp .3s ease; }
.tech-panel.active { display:block; }
.tech-panel-img-wrap { position:relative; border-radius:var(--radius-xl); overflow:hidden; margin-bottom:28px; aspect-ratio:21/7; }
.tech-panel-img { width:100%; height:100%; object-fit:cover; display:block; }
.tech-panel-img-caption { position:absolute; bottom:0; left:0; right:0; padding:12px 20px; background:linear-gradient(transparent,rgba(15,45,69,.82)); color:rgba(255,255,255,.9); font-size:.8125rem; font-weight:600; letter-spacing:.03em; }
.tech-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.tech-feat-card { background:var(--white); border-radius:var(--radius-lg); padding:28px; border:1px solid var(--gray-200); transition:all var(--transition); }
.tech-feat-card:hover { box-shadow:var(--shadow-md); border-color:var(--navy); }
.tech-feat-title { font-size:1rem; font-weight:700; color:var(--navy); margin-bottom:14px; display:flex; align-items:center; gap:10px; }
.tech-feat-list { display:flex; flex-direction:column; gap:7px; }
.tech-feat-list li { font-size:.875rem; color:var(--gray-600); padding-left:14px; position:relative; line-height:1.55; }
.tech-feat-list li::before { content:'•'; position:absolute; left:0; color:var(--green); font-weight:700; }
@media(max-width:768px){ .tech-grid{ grid-template-columns:1fr; } }

/* ——— Pricing Tabs ——— */
.pricing-switcher { display:flex; gap:0; background:var(--gray-100); border-radius:var(--radius-md); padding:4px; width:fit-content; margin-bottom:36px; }
.price-tab-btn { padding:11px 26px; border-radius:calc(var(--radius-md) - 2px); font-size:.9rem; font-weight:600; color:var(--gray-500); transition:all var(--transition); }
.price-tab-btn.active { background:var(--white); color:var(--navy); box-shadow:var(--shadow-sm); }
.price-panel { display:none; animation:fadeUp .3s ease; }
.price-panel.active { display:block; }
.pricing-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }
.pricing-card {
  background:var(--white); border-radius:var(--radius-lg); padding:36px;
  border:1px solid var(--gray-200); transition:all var(--transition); position:relative;
}
.pricing-card:hover { box-shadow:var(--shadow-lg); border-color:var(--navy); }
.pricing-card.featured { background:var(--navy); border-color:var(--navy); }
.pricing-card-badge { position:absolute; top:20px; right:20px; background:var(--gold); color:var(--navy); padding:4px 12px; border-radius:100px; font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.06em; }
.pricing-card-title    { font-size:1.125rem; font-weight:700; color:var(--navy); margin-bottom:6px; }
.pricing-card.featured .pricing-card-title { color:var(--white); }
.pricing-card-subtitle { font-size:.8125rem; font-weight:600; color:var(--green); text-transform:uppercase; letter-spacing:.06em; margin-bottom:16px; }
.pricing-card.featured .pricing-card-subtitle { color:var(--gold); }
.pricing-card-desc     { font-size:.9375rem; color:var(--gray-600); line-height:1.68; }
.pricing-card.featured .pricing-card-desc { color:rgba(255,255,255,.72); }
.pricing-cta-section   { text-align:center; margin-top:48px; padding:48px; background:var(--off-white); border-radius:var(--radius-xl); }
.pricing-cta-section h3 { margin-bottom:12px; }
.pricing-cta-section p  { color:var(--gray-500); margin-bottom:28px; max-width:500px; margin-left:auto; margin-right:auto; }
@media(max-width:768px){ .pricing-grid{ grid-template-columns:1fr; } .pricing-switcher{ flex-direction:column; width:100%; } .price-tab-btn{ text-align:center; } }

/* ——— Team Cards ——— */
.team-card { background:var(--white); border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow-md); transition:all var(--transition); text-align:center; }
.team-card:hover { box-shadow:var(--shadow-xl); transform:translateY(-6px); }
.team-avatar-wrap { background:var(--navy); padding:40px 40px 0; display:flex; justify-content:center; position:relative; }
.team-avatar-wrap::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 50% 100%,rgba(43,161,102,.15),transparent 60%); }
.team-avatar { width:136px; height:136px; border-radius:50%; object-fit:cover; border:4px solid var(--white); box-shadow:var(--shadow-lg); position:relative; z-index:1; background:var(--navy-mid); overflow:hidden; }
.team-info { padding:28px 28px 36px; }
.team-name  { font-size:1.25rem; font-family:var(--font-heading); color:var(--navy); margin-bottom:6px; }
.team-role  { font-size:.8rem; font-weight:700; color:var(--green); text-transform:uppercase; letter-spacing:.07em; margin-bottom:4px; }
.team-credentials { font-size:.875rem; color:var(--gold-dark); font-weight:600; margin-bottom:14px; }
.team-bio   { font-size:.9rem; color:var(--gray-500); line-height:1.65; }
.team-photo-placeholder { width:100%; height:100%; background:var(--navy-mid); display:flex; align-items:center; justify-content:center; }

/* ——— Case Studies ——— */
.cs-filters { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:36px; }
.cs-filter-btn { padding:9px 20px; border-radius:100px; font-size:.875rem; font-weight:600; color:var(--gray-500); background:var(--gray-100); border:2px solid transparent; transition:all var(--transition); }
.cs-filter-btn:hover { color:var(--navy); background:var(--gray-200); }
.cs-filter-btn.active { background:var(--navy); color:var(--white); }
.cs-card { background:var(--white); border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-sm); border:1px solid var(--gray-200); transition:all var(--transition); }
.cs-card:hover { box-shadow:var(--shadow-xl); transform:translateY(-4px); }
.cs-card-img { aspect-ratio:16/9; background:var(--navy); position:relative; overflow:hidden; display:flex; align-items:center; justify-content:center; }
.cs-card-img img { width:100%; height:100%; object-fit:cover; }
.cs-category-badge { position:absolute; top:14px; left:14px; padding:4px 12px; border-radius:100px; font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.06em; }
.badge-solar { background:var(--gold); color:var(--navy); }
.badge-bess  { background:var(--green); color:var(--white); }
.badge-wind  { background:var(--navy-mid); color:var(--white); }
.badge-hybrid     { background:var(--gray-700); color:var(--white); }
.badge-market     { background:#5b21b6; color:var(--white); }
.badge-regulation { background:#9a3412; color:var(--white); }
.badge-technology { background:#065f46; color:var(--white); }
.badge-general    { background:var(--gray-500); color:var(--white); }

/* ——— Blog Cards ——— */
.blog-card { background:var(--white); border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-sm); border:1px solid var(--gray-200); transition:all var(--transition); display:flex; flex-direction:column; }
.blog-card:hover { box-shadow:var(--shadow-xl); transform:translateY(-4px); }
.blog-card-cover { aspect-ratio:16/9; overflow:hidden; background:var(--off-white); }
.blog-card-cover img { width:100%; height:100%; object-fit:cover; display:block; }
.blog-card-cover-placeholder { display:flex; align-items:center; justify-content:center; font-size:2.5rem; }
.blog-card-body { padding:28px; flex:1; display:flex; flex-direction:column; }
.blog-card-meta { display:flex; align-items:center; gap:8px; flex-wrap:wrap; margin-bottom:12px; }
.blog-card-date  { font-size:.8rem; color:var(--gray-400); }
.blog-card-readtime { font-size:.8rem; color:var(--gray-400); }
.blog-card-title { font-size:1.125rem; font-family:var(--font-heading); color:var(--navy); margin-bottom:10px; line-height:1.35; }
.blog-card-excerpt { font-size:.9375rem; color:var(--gray-500); line-height:1.65; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; flex:1; }
.blog-card-read { margin-top:20px; background:none; border:none; color:var(--navy); font-weight:700; font-size:.875rem; cursor:pointer; padding:0; text-align:left; transition:color var(--transition); }
.blog-card-read:hover { color:var(--green); }
.cs-filter-bar { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:36px; }
.cs-card-body { padding:28px; }
.cs-card-date  { font-size:.8rem; color:var(--gray-400); margin-bottom:10px; }
.cs-card-title { font-size:1.125rem; font-family:var(--font-heading); color:var(--navy); margin-bottom:12px; line-height:1.35; }
.cs-card-excerpt { font-size:.9375rem; color:var(--gray-500); line-height:1.65; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }
.cs-coming-soon { text-align:center; padding:96px 24px; }
.cs-coming-soon-icon { font-size:4rem; margin-bottom:24px; opacity:.3; }

/* ——— Contact ——— */
.contact-grid { display:grid; grid-template-columns:1fr 2fr; gap:56px; align-items:start; }
.contact-sidebar { background:var(--navy); border-radius:var(--radius-xl); padding:48px; color:white; position:sticky; top:calc(var(--nav-height) + 24px); }
.contact-info-label { font-size:.72rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--gold); margin-bottom:6px; }
.contact-info-value { color:rgba(255,255,255,.8); margin-bottom:28px; font-size:.9375rem; line-height:1.6; }
.contact-divider { height:1px; background:rgba(255,255,255,.1); margin:24px 0; }
.form-card { background:var(--white); border-radius:var(--radius-xl); padding:48px; box-shadow:var(--shadow-md); border:1px solid var(--gray-200); }
.form-row  { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-bottom:20px; }
.form-group { display:flex; flex-direction:column; gap:7px; margin-bottom:20px; }
.form-label { font-size:.875rem; font-weight:600; color:var(--gray-700); }
.form-req   { color:var(--green); margin-left:3px; }
.form-input,.form-select,.form-textarea {
  padding:13px 16px; border:1.5px solid var(--gray-200); border-radius:var(--radius-md);
  font-size:.9375rem; color:var(--gray-900); background:var(--white); transition:all var(--transition); width:100%;
}
.form-input:focus,.form-select:focus,.form-textarea:focus { outline:none; border-color:var(--navy); box-shadow:0 0 0 3px rgba(23,67,97,.08); }
.form-textarea { resize:vertical; min-height:130px; }
.form-select { appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 14px center; padding-right:44px; }
/* Honeypot — off-screen, not display:none (bots skip those) */
.form-honeypot { position:absolute; left:-9999px; top:-9999px; width:1px; height:1px; overflow:hidden; opacity:0; pointer-events:none; }
/* Field validation */
.field-error { display:none; color:#b91c1c; font-size:.8rem; margin-top:5px; }
.input-invalid { border-color:#b91c1c !important; background:#fff8f8; }
.input-invalid:focus { outline-color:#b91c1c; box-shadow:0 0 0 3px rgba(185,28,28,.12); }
.form-consent { display:flex; align-items:flex-start; gap:12px; margin-bottom:28px; }
.form-checkbox { width:18px; height:18px; cursor:pointer; flex-shrink:0; margin-top:2px; accent-color:var(--navy); }
.form-consent-text { font-size:.875rem; color:var(--gray-500); line-height:1.6; }
.form-consent-text a { color:var(--navy); text-decoration:underline; }
.form-success { display:none; text-align:center; padding:48px 0; }
.form-success.show { display:block; }
.form-success-icon { font-size:3.5rem; margin-bottom:20px; }
@media(max-width:768px){ .contact-grid{ grid-template-columns:1fr; } .contact-sidebar{ position:static; } .form-row{ grid-template-columns:1fr; } .form-card{ padding:28px 20px; } }

/* ——— Footer ——— */
.footer { background:var(--navy-dark); color:white; padding:80px 0 0; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; margin-bottom:60px; }
.footer-logo { height:48px; width:auto; margin-bottom:20px; background:white; border-radius:8px; padding:5px 10px; }
.footer-desc { font-size:.9375rem; color:rgba(255,255,255,.5); line-height:1.72; margin-bottom:20px; max-width:280px; }
.footer-tagline { font-style:italic; color:var(--gold); font-family:var(--font-heading); font-size:1rem; }
.footer-heading { font-size:.72rem; font-weight:700; letter-spacing:.13em; text-transform:uppercase; color:rgba(255,255,255,.35); margin-bottom:20px; }
.footer-links { display:flex; flex-direction:column; gap:12px; }
.footer-link { font-size:.9375rem; color:rgba(255,255,255,.6); transition:color var(--transition); }
.footer-link:hover { color:var(--gold); }
.footer-contact-item { display:flex; gap:10px; font-size:.9375rem; color:rgba(255,255,255,.6); margin-bottom:12px; align-items:flex-start; }
.footer-contact-icon { color:var(--gold); flex-shrink:0; margin-top:2px; font-size:1rem; }
.footer-bottom { border-top:1px solid rgba(255,255,255,.07); padding:28px 0; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:16px; }
.footer-copy { font-size:.875rem; color:rgba(255,255,255,.3); }
.footer-legal { display:flex; gap:24px; }
.footer-legal a { font-size:.875rem; color:rgba(255,255,255,.4); transition:color var(--transition); }
.footer-legal a:hover { color:rgba(255,255,255,.75); }
@media(max-width:968px){ .footer-grid{ grid-template-columns:1fr 1fr; } }
@media(max-width:600px){ .footer-grid{ grid-template-columns:1fr; } .footer-bottom{ flex-direction:column; text-align:center; } }

/* ——— Cookie Banner ——— */
.cookie-banner {
  position:fixed; bottom:24px; left:24px; right:24px; max-width:620px;
  background:var(--navy); color:white; border-radius:var(--radius-lg);
  padding:24px 28px; box-shadow:var(--shadow-xl); z-index:9999;
  display:flex; align-items:flex-start; gap:18px;
  transform:translateY(140px); opacity:0; transition:all .5s cubic-bezier(.22,1,.36,1);
  pointer-events:none;
}
.cookie-banner.show { transform:translateY(0); opacity:1; pointer-events:all; }
.cookie-icon { font-size:1.75rem; flex-shrink:0; }
.cookie-text { flex:1; }
.cookie-title { font-weight:700; font-size:.9375rem; color:white; margin-bottom:6px; }
.cookie-desc  { font-size:.8125rem; color:rgba(255,255,255,.6); line-height:1.6; }
.cookie-desc a { color:var(--gold); text-decoration:underline; }
.cookie-actions { display:flex; flex-direction:column; gap:8px; flex-shrink:0; }
.cookie-accept { background:var(--gold); color:var(--navy); padding:10px 20px; border-radius:var(--radius-md); font-size:.875rem; font-weight:700; cursor:pointer; border:none; white-space:nowrap; }
.cookie-accept:hover { background:var(--gold-dark); }
.cookie-decline { background:transparent; color:rgba(255,255,255,.5); padding:10px 20px; border-radius:var(--radius-md); font-size:.875rem; font-weight:600; cursor:pointer; border:1px solid rgba(255,255,255,.15); text-align:center; }
.cookie-decline:hover { color:rgba(255,255,255,.8); border-color:rgba(255,255,255,.3); }
@media(max-width:600px){ .cookie-banner{ flex-direction:column; left:16px; right:16px; bottom:16px; } .cookie-actions{ flex-direction:row; width:100%; } .cookie-accept,.cookie-decline{ flex:1; } }

/* ——— Page Hero ——— */
.page-hero { background:var(--navy); padding:140px 0 80px; position:relative; overflow:hidden; }
.page-hero::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 80% 50%,rgba(43,161,102,.1),transparent 60%),linear-gradient(135deg,#174361 0%,#0f2d45 100%); }
.page-hero-inner { position:relative; z-index:1; }
.page-hero-label { display:inline-block; font-size:.72rem; font-weight:700; letter-spacing:.13em; text-transform:uppercase; color:var(--gold); margin-bottom:16px; }
.page-hero-title { font-size:clamp(1.875rem,4vw,3rem); color:var(--white); margin-bottom:18px; }
.page-hero-sub   { font-size:1.0625rem; color:rgba(255,255,255,.68); max-width:640px; line-height:1.72; }
.breadcrumb { display:flex; align-items:center; gap:8px; margin-bottom:24px; }
.breadcrumb span { font-size:.875rem; color:rgba(255,255,255,.4); }
.breadcrumb a    { color:rgba(255,255,255,.55); font-size:.875rem; transition:color var(--transition); }
.breadcrumb a:hover { color:rgba(255,255,255,.85); }
.breadcrumb-sep { color:rgba(255,255,255,.25); }

/* ——— Highlight Block ——— */
.highlight-block { background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 100%); border-radius:var(--radius-xl); padding:56px; text-align:center; color:white; position:relative; overflow:hidden; }
.highlight-block::before { content:''; position:absolute; top:-60px; right:-60px; width:240px; height:240px; background:var(--gold); opacity:.05; border-radius:50%; }
.highlight-block::after  { content:''; position:absolute; bottom:-80px; left:-40px;  width:200px; height:200px; background:var(--green); opacity:.05; border-radius:50%; }
.highlight-block h2 { color:white; margin-bottom:16px; }
.highlight-block p  { color:rgba(255,255,255,.7); margin-bottom:32px; font-size:1.0625rem; line-height:1.72; max-width:540px; margin-left:auto; margin-right:auto; }

/* ——— Policy Pages ——— */
.policy-content { max-width:800px; margin:0 auto; }
.policy-content h2 { font-size:1.5rem; margin-top:48px; margin-bottom:16px; }
.policy-content h3 { font-size:1.125rem; margin-top:32px; margin-bottom:12px; }
.policy-content p  { margin-bottom:16px; }
.policy-content ul { margin-bottom:16px; padding-left:20px; }
.policy-content ul li { margin-bottom:8px; color:var(--gray-700); list-style:disc; }

/* ——— Modal ——— */
.modal-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.65); z-index:9000; align-items:center; justify-content:center; padding:24px; }
.modal-overlay.open { display:flex; }
.modal { background:var(--white); border-radius:var(--radius-xl); max-width:840px; width:100%; max-height:90vh; overflow-y:auto; position:relative; }
.modal-header { background:var(--navy); padding:32px 40px; border-radius:var(--radius-xl) var(--radius-xl) 0 0; }
.modal-close { position:absolute; top:16px; right:16px; width:36px; height:36px; border-radius:50%; background:rgba(255,255,255,.1); display:flex; align-items:center; justify-content:center; cursor:pointer; color:white; font-size:1.375rem; transition:background var(--transition); }
.modal-close:hover { background:rgba(255,255,255,.2); }
.modal-body { padding:40px; }
.modal-gallery { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-bottom:28px; }
.modal-gallery img { border-radius:var(--radius-md); aspect-ratio:4/3; object-fit:cover; width:100%; }

/* ——— Blog placeholder ——— */
.blog-teaser { text-align:center; padding:80px 24px; background:var(--off-white); border-radius:var(--radius-xl); }
.blog-teaser-icon { font-size:3.5rem; margin-bottom:20px; opacity:.35; }

/* ——— Utilities ——— */
.mt-4{margin-top:16px} .mt-6{margin-top:24px} .mt-8{margin-top:32px} .mt-12{margin-top:48px} .mt-16{margin-top:64px}
.mb-4{margin-bottom:16px} .mb-6{margin-bottom:24px} .mb-8{margin-bottom:32px}
.flex{display:flex} .flex-wrap{flex-wrap:wrap} .items-center{align-items:center} .justify-center{justify-content:center} .justify-between{justify-content:space-between} .gap-4{gap:16px} .gap-6{gap:24px}
.text-center{text-align:center} .text-white{color:white} .text-gold{color:var(--gold)} .text-green{color:var(--green)} .text-navy{color:var(--navy)} .text-muted{color:var(--gray-500)}
.divider{height:1px;background:var(--gray-200);margin:48px 0}

/* ——— Fade-in animation ——— */
.fade-in { opacity:0; transform:translateY(20px); transition:opacity .6s ease,transform .6s ease; }
.fade-in.visible { opacity:1; transform:translateY(0); }
