/* =========================================================
   GEROMEL — shared design system
   Used by index.html, about.html, team.html, services.html,
   projects.html, subcontractors.html, contact.html,
   careers.html, testimonials.html, faq.html
   ========================================================= */
:root{
  --bg:        #08090B;
  --bg-2:      #0F1115;
  --bg-3:      #14171C;
  --bg-card:   #15181E;
  --line:      rgba(255,255,255,.08);
  --line-2:    rgba(255,255,255,.14);
  --text:      #F4F4F5;
  --muted:     #9AA0A8;
  --muted-2:   #6E737C;
  --red:       #C41E28;
  --red-2:     #E63946;
  --red-deep:  #8E1219;
  --blue:      #1A3A78;

  --display: "Sora", "Inter", system-ui, sans-serif;
  --sans:    "Inter", system-ui, sans-serif;

  --max:   1340px;
  --pad:   clamp(20px, 4vw, 56px);
  --ease:  cubic-bezier(.22,1,.36,1);
}
*,*::before,*::after{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  line-height:1.55;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; background:none; border:0; cursor:pointer; }
::selection{ background:var(--red); color:#fff; }

/* subtle texture — kept light so it does not look like a template overlay */
body::before{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:1;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 .02 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  opacity:.35;
}
.container{ max-width:var(--max); margin:0 auto; padding:0 var(--pad); position:relative; z-index:2; }
section{ position:relative; z-index:2; }

/* eyebrow */
.kicker{
  font-family:var(--display); font-size:11px; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--red-2);
  display:inline-flex; align-items:center; gap:12px;
  margin:0 0 24px;
}
.kicker::before{ content:""; width:32px; height:1px; background:var(--red); }

.section-title{
  font-family:var(--display); font-weight:600;
  font-size:clamp(36px, 5vw, 64px);
  letter-spacing:-.025em;
  line-height:1.02;
  margin:0 0 14px;
  color:#fff;
}
.section-title.center{ text-align:center; }
.section-eyebrow-wrap{ text-align:center; margin-bottom:64px; }
.section-eyebrow-wrap p{ color:var(--muted); max-width:58ch; margin:14px auto 0; font-size:16px; }

/* =========================================================
   HEADER + FLAG STRIPE
   ========================================================= */
.header{
  position:sticky; top:0; z-index:50;
  background:#000;
  border-bottom:1px solid var(--line);
}
.header.is-scrolled{ border-bottom-color:var(--line-2); }
.flag-stripe{
  height:3px; width:100%;
  background:linear-gradient(90deg,
    var(--red) 0%, var(--red) 33%,
    #fff 33%, #fff 66%,
    var(--blue) 66%, var(--blue) 100%);
  opacity:.85;
}
.topbar{
  display:grid; grid-template-columns:auto 1fr auto;
  align-items:center; gap:clamp(16px, 3vw, 36px);
  padding:14px var(--pad);
  max-width:var(--max); margin:0 auto;
}
.brand{ display:inline-flex; align-items:center; }
.brand img{ height:36px; width:auto; max-width:200px; display:block; }

.header-nav{ display:flex; justify-content:center; gap:2px; position:relative; }
.header-nav-link{
  position:relative;
  padding:8px 12px;
  font-family:var(--display);
  font-size:11px; font-weight:600; color:rgba(255,255,255,.78);
  letter-spacing:.12em; text-transform:uppercase;
  border-radius:999px;
  transition:color .25s var(--ease), background .25s var(--ease);
  display:inline-flex; align-items:center; gap:6px;
  white-space:nowrap;
}
.header-nav-link i{ font-size:8px; opacity:.6; }
.header-nav-link::before{
  content:""; position:absolute; left:12px; right:12px; bottom:4px;
  height:2px; background:var(--red);
  transform:scaleX(0); transform-origin:left;
  transition:transform .4s var(--ease);
}
.header-nav-link:hover{ color:#fff; background:rgba(255,255,255,.04); }
.header-nav-link:hover::before{ transform:scaleX(1); }
.header-nav-link.active{ color:#fff; }
.header-nav-link.active::before{ transform:scaleX(1); }

.header-nav-group{ position:relative; }
.header-submenu{
  position:absolute; top:calc(100% + 14px); right:0;
  background:rgba(15,17,21,.96); backdrop-filter:blur(20px);
  border:1px solid var(--line); padding:10px; min-width:200px;
  opacity:0; visibility:hidden; transform:translateY(-6px);
  transition:.3s var(--ease); border-radius:10px;
}
.header-nav-group:hover .header-submenu, .header-submenu:hover{
  opacity:1; visibility:visible; transform:translateY(0);
}
.header-submenu a{
  display:block; padding:10px 14px; font-size:12px; font-weight:600;
  color:rgba(255,255,255,.8); border-radius:6px;
  letter-spacing:.12em; text-transform:uppercase;
  transition:background .2s, color .2s;
}
.header-submenu a:hover{ background:rgba(255,255,255,.06); color:#fff; }

.header-cta{
  display:flex; align-items:center; gap:10px;
  flex-shrink:0;
}
.header-phone{
  font-family:var(--sans);
  font-size:14px; font-weight:500;
  letter-spacing:.01em;
  font-variant-numeric:tabular-nums;
  color:rgba(255,255,255,.92);
  padding:0 2px;
  line-height:1;
  white-space:nowrap;
  transition:color .2s;
}
.header-phone:hover{ color:var(--red-2); }
.header-cta .btn{
  padding:10px 18px;
  font-size:11px;
  letter-spacing:.06em;
}

/* hamburger button */
.menu-toggle{
  display:none;
  width:42px; height:42px; border-radius:50%;
  border:1px solid var(--line-2);
  align-items:center; justify-content:center;
  position:relative;
  transition:background .25s;
}
.menu-toggle:hover{ background:rgba(255,255,255,.05); }
.menu-toggle span, .menu-toggle span::before, .menu-toggle span::after{
  display:block; width:18px; height:2px; background:#fff;
  transition:transform .35s var(--ease), top .25s, opacity .25s;
  position:relative;
}
.menu-toggle span::before, .menu-toggle span::after{
  content:""; position:absolute; left:0;
}
.menu-toggle span::before{ top:-6px; }
.menu-toggle span::after{ top:6px; }
body.menu-open .menu-toggle span{ background:transparent; }
body.menu-open .menu-toggle span::before{ top:0; transform:rotate(45deg); }
body.menu-open .menu-toggle span::after{ top:0; transform:rotate(-45deg); }

/* mobile drawer */
body.menu-open{ overflow:hidden; }
.mobile-menu{
  position:fixed; inset:0; z-index:60;
  background:rgba(8,9,11,.98);
  backdrop-filter:blur(24px);
  -webkit-backdrop-filter:blur(24px);
  display:flex; flex-direction:column;
  padding:72px var(--pad) 24px;
  overflow-y:auto;
  opacity:0; visibility:hidden; pointer-events:none;
  transform:translateY(-2%);
  transition:opacity .35s var(--ease), transform .4s var(--ease), visibility .35s;
}
body.menu-open .mobile-menu{
  opacity:1; visibility:visible; pointer-events:auto; transform:translateY(0);
}
.mobile-menu-inner{
  max-width:var(--max); margin:0 auto; width:100%;
  display:flex; flex-direction:column; min-height:min(100%, calc(100vh - 96px));
}
.mobile-menu-eyebrow{ display:none; }
.mobile-menu-list{
  display:flex; flex-direction:column;
  border-top:1px solid var(--line);
}
.mobile-menu-list a{
  display:block;
  padding:12px 0;
  font-family:var(--display); font-weight:500;
  font-size:17px; letter-spacing:-.01em;
  color:#fff;
  border-bottom:1px solid var(--line);
  transition:color .2s;
}
.mobile-menu-list a:hover{ color:var(--red-2); }
.mobile-menu-list .num{ display:none; }
.mobile-menu-foot{
  margin-top:auto; padding-top:20px;
  display:flex; flex-direction:column; gap:10px;
  font-family:var(--display); font-size:12px;
  color:var(--muted); letter-spacing:.06em;
}
.mobile-menu-foot strong{ color:#fff; font-weight:600; font-size:15px; letter-spacing:.1em; }
.mobile-menu-foot .row{ display:flex; gap:14px; flex-wrap:wrap; }
.mobile-menu-foot .row a{
  font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--muted); transition:color .2s;
}
.mobile-menu-foot .row a:hover{ color:#fff; }
.mobile-menu-foot .social{ display:flex; gap:10px; }
.mobile-menu-foot .social a{
  width:42px; height:42px; border-radius:50%; border:1px solid var(--line-2);
  display:inline-flex; align-items:center; justify-content:center;
  color:#fff; font-size:16px;
  transition:background .25s, border-color .25s;
}
.mobile-menu-foot .social a:hover{ background:var(--red); border-color:var(--red); }

/* =========================================================
   BUTTONS
   ========================================================= */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--display); font-weight:600; font-size:12.5px;
  letter-spacing:.08em; text-transform:uppercase;
  padding:13px 22px; border-radius:999px;
  border:1px solid transparent;
  transition:transform .25s var(--ease), background .25s, color .25s, border-color .25s, box-shadow .3s;
  cursor:pointer; white-space:nowrap;
}
.btn .arrow{ transition:transform .25s var(--ease); }
.btn:hover .arrow{ transform:translateX(4px); }
.btn-red{
  background:var(--red); color:#fff;
  box-shadow:0 8px 30px -8px rgba(196,30,40,.5), inset 0 0 0 1px rgba(255,255,255,.05);
}
.btn-red:hover{ background:var(--red-2); box-shadow:0 10px 28px -10px rgba(196,30,40,.55); }
.btn-dark{ background:transparent; border-color:var(--line-2); color:#fff; }
.btn-dark:hover{ background:rgba(255,255,255,.06); border-color:rgba(255,255,255,.3); }
.btn-light{ background:#fff; color:#000; }
.btn-light:hover{ background:#e5e5e5; }

/* =========================================================
   INNER HERO (for subpages)
   ========================================================= */
.inner-hero{
  position:relative;
  padding:130px var(--pad) 90px;
  overflow:hidden;
  text-align:center;
}
.inner-hero::before{
  content:""; position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(196,30,40,.18), transparent 60%),
    linear-gradient(180deg, var(--bg-2), var(--bg));
}
.inner-hero::after{ display:none; }
.inner-hero .container{ position:relative; z-index:1; }
.inner-hero .kicker{ justify-content:center; }
.inner-hero h1{
  font-family:var(--display); font-weight:700;
  font-size:clamp(40px, 7vw, 96px); line-height:.98; letter-spacing:-.035em;
  margin:0 auto 18px; color:#fff;
  max-width:18ch;
}
.inner-hero h1 em{ font-style:normal; color:var(--red-2); }
.inner-hero p{
  color:var(--muted); font-size:clamp(15px, 1.4vw, 18px);
  max-width:54ch; margin:0 auto;
}
.inner-hero-meta{
  display:inline-flex; align-items:center; gap:16px; margin-top:28px;
  font-family:var(--display); font-size:11px; letter-spacing:.2em; text-transform:uppercase;
  color:rgba(255,255,255,.7);
}
.inner-hero-meta .dot{ width:5px; height:5px; border-radius:50%; background:var(--red); }

.breadcrumb{
  display:inline-flex; align-items:center; gap:10px;
  margin-bottom:24px;
  font-family:var(--display); font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--muted);
}
.breadcrumb a{ color:var(--muted); transition:color .2s; }
.breadcrumb a:hover{ color:#fff; }
.breadcrumb .sep{ color:var(--red); }

/* =========================================================
   GENERIC SECTION
   ========================================================= */
.section{ padding:120px 0; position:relative; }
.section-light{ background:var(--bg-2); }
.section.dark{ background:#000; }
.split{ display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }

/* =========================================================
   CARDS / GRID
   ========================================================= */
.cards{ display:grid; gap:24px; }
.cards.two{ grid-template-columns:repeat(2,1fr); }
.cards.three{ grid-template-columns:repeat(3,1fr); }
.cards.four{ grid-template-columns:repeat(4,1fr); }

.card{
  position:relative;
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:16px;
  padding:36px 32px 32px;
  overflow:hidden;
  transition:transform .5s var(--ease), border-color .35s, background .35s;
}
.card::before{
  content:""; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg, transparent, var(--red), transparent);
  transform:scaleX(0); transform-origin:left; transition:transform .6s var(--ease);
}
.card:hover{ transform:translateY(-3px); border-color:var(--line-2); background:#191D25; }
.card:hover::before{ transform:scaleX(1); }
.card-num{ display:none; }
.card-icon{
  display:inline-flex; align-items:center; justify-content:center;
  width:48px; height:48px;
  border:1px solid var(--line-2); border-radius:12px;
  color:var(--red-2); margin-bottom:28px; font-size:20px;
  transition:background .3s, border-color .3s, color .3s;
}
.card:hover .card-icon{ background:var(--red); color:#fff; border-color:var(--red); }
.card h3{
  font-family:var(--display); font-weight:600; font-size:22px;
  margin:0 0 14px; color:#fff; letter-spacing:-.01em;
}
.card p{ color:var(--muted); font-size:14.5px; line-height:1.7; margin:0; }
.card-link{
  display:inline-flex; align-items:center; gap:8px;
  margin-top:24px; padding-top:20px; border-top:1px solid var(--line);
  font-family:var(--display); font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--red-2);
  transition:gap .25s;
}
.card-link:hover{ gap:14px; }

/* =========================================================
   VALUES
   ========================================================= */
.value-grid{
  display:grid; grid-template-columns:repeat(5,1fr); gap:0;
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
}
.value-card{
  padding:40px 28px 36px;
  border-right:1px solid var(--line);
  position:relative; overflow:hidden;
  transition:background .4s var(--ease);
}
.value-card:last-child{ border-right:0; }
.value-card::after{
  content:""; position:absolute; left:0; top:0; height:2px; width:100%;
  background:var(--red); transform:scaleX(0); transform-origin:left;
  transition:transform .55s var(--ease);
}
.value-card:hover{ background:rgba(255,255,255,.03); }
.value-card:hover::after{ transform:scaleX(1); }
.value-card .vnum{ display:none; }
.value-icon{
  font-size:22px; color:var(--red-2); margin-bottom:18px;
  display:inline-flex; transition:transform .4s var(--ease);
}
.value-card:hover .value-icon{ transform:translateY(-4px) scale(1.1); }
.value-card h3{
  font-family:var(--display); font-weight:600; font-size:20px;
  margin:0 0 12px; letter-spacing:-.01em; color:#fff;
}
.value-card p{ margin:0; font-size:13.5px; line-height:1.65; color:var(--muted); }

/* =========================================================
   FOOTER
   ========================================================= */
.footer{
  background:#000;
  border-top:1px solid var(--line);
  padding:80px var(--pad) 40px;
  position:relative; overflow:hidden;
}
.footer .container{ padding:0; }
.footer-grid{
  display:grid; grid-template-columns: 1.6fr 1fr 1fr; gap:60px;
  padding-bottom:48px; border-bottom:1px solid var(--line);
}
.footer-logo{ height:42px; width:auto; margin-bottom:22px; display:block; }
.footer p{ color:var(--muted); font-size:14.5px; line-height:1.7; margin:0 0 14px; max-width:38ch; }
.footer h4{
  font-family:var(--display); font-weight:600; font-size:13px;
  letter-spacing:.18em; text-transform:uppercase;
  color:#fff; margin:0 0 18px;
}
.footer a{
  display:block; color:var(--muted); font-size:14.5px; line-height:2;
  transition:color .2s, transform .2s;
}
.footer a:hover{ color:#fff; transform:translateX(3px); }
.footer-license{
  margin-top:24px; padding:14px 18px; border-radius:10px;
  background:rgba(255,255,255,.03); border:1px solid var(--line);
  display:inline-flex; align-items:center; gap:14px;
}
.footer-license-icon{
  width:38px; height:38px; border-radius:50%;
  background:rgba(196,30,40,.12); color:var(--red-2);
  display:inline-flex; align-items:center; justify-content:center;
  border:1px solid rgba(196,30,40,.3); flex-shrink:0; font-size:16px;
}
.footer-license strong{
  display:block; font-family:var(--display); font-size:12px; letter-spacing:.12em;
  text-transform:uppercase; color:#fff;
}
.footer-license small{
  font-family:var(--display); font-size:11px; letter-spacing:.16em; color:var(--muted);
}
.footer-social{ display:flex; gap:10px; margin-top:18px; }
.footer-social a{
  width:38px; height:38px; border-radius:50%;
  border:1px solid var(--line);
  display:inline-flex; align-items:center; justify-content:center;
  color:#fff; font-size:14px;
  transition:background .25s, border-color .25s;
}
.footer-social a:hover{ background:var(--red); border-color:var(--red); transform:none; }
.footer p.footer-tagline{
  text-align:center;
  margin:40px auto 0;
  max-width:none;
  width:100%;
  font-family:var(--display);
  font-weight:500;
  font-size:13.5px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--muted);
}
.footer-mega{ display:none; }

/* =========================================================
   PROJECT MODAL
   ========================================================= */
.pmodal-backdrop{
  position:fixed; inset:0; z-index:100;
  background:rgba(0,0,0,.82);
  backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
  display:flex; align-items:center; justify-content:center;
  padding:32px var(--pad);
  opacity:0; visibility:hidden; pointer-events:none;
  transition:opacity .35s var(--ease), visibility .35s;
}
.pmodal-backdrop.open{ opacity:1; visibility:visible; pointer-events:auto; }
.pmodal{
  max-width:1100px; width:100%; max-height:88vh; overflow:auto;
  background:var(--bg-card); border:1px solid var(--line-2);
  border-radius:16px; position:relative;
  transform:scale(.96); transition:transform .45s var(--ease);
  display:grid; grid-template-columns:1.2fr 1fr;
}
.pmodal-backdrop.open .pmodal{ transform:scale(1); }
.pmodal-img{ background:#000; min-height:320px; overflow:hidden; position:relative; }
.pmodal-img img{ width:100%; height:100%; object-fit:cover; }
.pmodal-tag{
  position:absolute; top:20px; left:20px;
  font-family:var(--display); font-size:10px; letter-spacing:.18em; text-transform:uppercase;
  padding:6px 12px; border-radius:999px;
  background:rgba(196,30,40,.85); color:#fff;
  border:1px solid rgba(255,255,255,.15);
}
.pmodal-tag.done{ background:rgba(255,255,255,.15); }
.pmodal-body{ padding:44px 44px 40px; display:flex; flex-direction:column; }
.pmodal-num{
  font-family:var(--display); font-size:11px; letter-spacing:.2em;
  color:var(--muted-2); margin-bottom:18px;
}
.pmodal-body h3{
  font-family:var(--display); font-weight:600; font-size:30px;
  color:#fff; letter-spacing:-.015em; margin:0 0 22px; line-height:1.05;
}
.pmodal-meta{ display:flex; flex-direction:column; gap:10px; margin-bottom:24px; padding-bottom:24px; border-bottom:1px solid var(--line); }
.pmodal-meta-row{ display:flex; gap:12px; font-size:13.5px; }
.pmodal-meta-row strong{
  font-family:var(--display); font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--muted); width:90px; flex-shrink:0; padding-top:2px;
}
.pmodal-meta-row span{ color:#fff; }
.pmodal-desc{ color:var(--muted); font-size:14.5px; line-height:1.65; margin:0 0 28px; }
.pmodal-actions{ display:flex; gap:10px; flex-wrap:wrap; margin-top:auto; }
.pmodal-close{
  position:absolute; top:18px; right:18px;
  width:42px; height:42px; border-radius:50%;
  background:rgba(0,0,0,.5); border:1px solid var(--line-2);
  color:#fff; font-size:16px; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:background .2s, border-color .2s;
  z-index:3;
}
.pmodal-close:hover{ background:var(--red); border-color:var(--red); }
body.pmodal-open{ overflow:hidden; }
@media (max-width:800px){
  .pmodal{ grid-template-columns:1fr; max-height:92vh; }
  .pmodal-body{ padding:28px 24px 32px; }
  .pmodal-img{ min-height:240px; aspect-ratio:16/10; }
}

/* =========================================================
   REVEAL
   ========================================================= */
.reveal{ opacity:0; transform:translateY(12px); transition:opacity .5s ease, transform .5s ease; }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:900px){
  .header-nav{ display:none; }
  .menu-toggle{ display:inline-flex; }
  .header-phone{ display:none; }
  .header-cta .btn{ display:none; }
}
@media (max-width:1200px){
  .header-nav-link{ padding:8px 9px; font-size:10px; letter-spacing:.08em; }
  .header-phone{ font-size:13px; }
  .header-cta .btn{ padding:9px 14px; font-size:10px; }
}
@media (max-width:1100px){
  .split{ grid-template-columns:1fr; gap:40px; }
  .cards.three{ grid-template-columns:1fr; }
  .cards.four{ grid-template-columns:repeat(2,1fr); }
  .value-grid{ grid-template-columns:repeat(2,1fr); }
  .value-card{ border-right:1px solid var(--line); border-bottom:1px solid var(--line); }
  .value-card:nth-child(2n){ border-right:0; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
  .header-nav{ gap:0; }
}
@media (max-width:640px){
  .section{ padding:80px 0; }
  .footer-grid{ grid-template-columns:1fr; gap:40px; }
  .value-grid{ grid-template-columns:1fr; }
  .value-card{ border-right:0; }
  .inner-hero{ padding:100px var(--pad) 60px; }
}
