*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:"Source Sans 3","Segoe UI",Tahoma,sans-serif;
  color:var(--color-text);
  min-height:100vh;
  background:radial-gradient(circle at 15% 15%, rgba(0,85,170,.2), transparent 45%), var(--color-bg);
}

main{
  position:relative;
}

main::before{
  content:"";
  position:absolute;
  inset:0;
  opacity:0;
  pointer-events:none;
  z-index:0;
}

main > *{
  position:relative;
  z-index:1;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
[hidden]{display:none !important}

.container{max-width:var(--max-width);padding:0 20px;margin:0 auto}
.container.narrow{max-width:680px}

/* =========================
   HEADER / NAV
========================= */
.site-header{
  position:sticky;top:0;z-index:40;
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(229,231,235,.7);
}
.header-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:4px 0;
  gap:10px;
  flex-wrap:nowrap;
}
.brand{
  display:flex;
  align-items:center;
  flex:0 0 120px;
  padding:2px 0 4px;
}
.brand-logo{
  height:72px;
  width:auto;
  max-width:100%;
}

.nav{
  display:flex;
  gap:12px;
  align-items:center;
  flex:1;
  flex-wrap:nowrap;
  justify-content:flex-end;
  overflow:hidden;
  white-space:nowrap;
}

@media (max-width: 1100px){
  .header-row{
    flex-wrap:wrap;
  }
  .nav{
    flex-wrap:wrap;
    justify-content:flex-start;
    white-space:normal;
    overflow:visible;
  }
}
.nav a{
  padding:6px 10px;
  border-radius:10px;
  font-weight:600;
  color:var(--color-muted);
  font-size:.88rem;
}
.nav a:hover{background:rgba(0,85,170,.08);color:var(--color-primary)}
.nav-link-intranet{
  padding:6px 14px;
  border:1px solid rgba(37,99,235,.3);
  background:rgba(37,99,235,.08);
  color:var(--color-primary);
  font-weight:700;
  border-radius:999px;
}

.header-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}

.header-bottom{
  padding:0 20px 6px;
}
.header-actions--bottom{
  justify-content:flex-end;
  width:100%;
}

/* =========================
   SYSTEM HEADER/FOOTER
========================= */
.header-system{
  background:#f7f8fb;border-bottom:1px solid rgba(15,23,42,.08);
  padding:12px 20px;display:flex;align-items:center;justify-content:space-between;gap:12px;
  position:fixed;top:0;left:0;right:0;z-index:120;max-height:64px;height:64px
}
.header-system__logo{
  height:26px;
  width:auto;
}
.header-system__brand{display:flex;align-items:center;gap:6px;font-weight:600;color:#0f172a}
.header-system__brand small{
  display:block;font-size:.85rem;color:#64748b;letter-spacing:.2em;text-transform:uppercase
}
.header-system__tag{
  font-size:.8rem;letter-spacing:.2em;color:#475569;text-transform:uppercase
}
.header-system__actions{display:flex;align-items:center;gap:10px}
.header-system__label{font-size:.9rem;color:#475569}

.footer-system{
  padding:16px 20px;background:#f9fafb;border-top:1px solid rgba(15,23,42,.08);
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  font-size:.9rem;color:#475569;
  position:fixed;bottom:0;left:0;right:0;z-index:110;height:56px
}
.system-shell main{
  padding-top:80px;padding-bottom:84px;
  position:relative;
}
.system-shell main::before{
  content:"";
  position:absolute;
  inset:32px 10% 32px;
  background:url('../logos/logo.png') center/contain no-repeat;
  opacity:.04;
  pointer-events:none;
  z-index:0;
  filter:grayscale(1);
}
.system-shell main > *{
  position:relative;
  z-index:1;
}
.footer-system__item{font-weight:600}
.footer-system__item a{color:#0f172a;text-decoration:none;font-weight:700}

/* =========================
   BUTTONS (CTA)
========================= */
.btn-intranet{
  border-radius:20px;
  padding:10px 18px;
  border:1px solid rgba(37,99,235,.9);
  background:#fff;
  color:var(--color-primary);
  font-weight:700;
  letter-spacing:.01em;
  text-transform:none;
  font-size:.95rem;
  transition:background .2s ease,color .2s ease,border .2s ease;
}
.btn-intranet:hover{
  background:var(--color-primary);
  border-color:var(--color-primary);
  color:#fff;
}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:10px 18px;border-radius:15px;border:0;cursor:pointer;
  font-weight:700;text-transform:uppercase;letter-spacing:.02em
}
.btn-primary{
  background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));
  color:#fff;
  box-shadow:0 20px 40px rgba(0,85,170,.35)
}
.btn-outline{border:2px solid rgba(0,85,170,.6);color:var(--color-primary);background:transparent}
.btn-sm{padding:6px 14px;font-size:.82rem}
.btn-danger{
  background:#e03;
  color:#fff;
}
.btn-danger:hover{
  background:#c02;
}

/* =========================
   FLASH
========================= */
main{min-height:70vh}
.flash-wrap{padding-top:14px}
.flash{padding:10px 12px;border-radius:8px;border:1px solid var(--color-line);background:#fff;margin-bottom:8px}
.flash-error{border-color:#f0b8b8;background:#fff1f1}
.flash-warning{border-color:#f3e2a7;background:#fff8df}
.flash-success{border-color:#b6e0c7;background:#effaf3}

/* =========================
   GLOBAL SECTION + TYPO
========================= */
.section{
  padding:var(--section-spacing) 0;
  border-top:1px solid rgba(229,231,235,.6);
  background:rgba(255,255,255,.92);
  box-shadow:0 35px 70px rgba(15,23,42,.03);
  border-radius:32px;
  margin:20px 0
}
.section-header{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}
.section-header .eyebrow{letter-spacing:.25em;text-transform:uppercase;font-size:.8rem;color:var(--color-primary)}

.eyebrow{font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;color:var(--color-secondary);margin:0 0 10px}
.eyebrow--light{color:rgba(255,255,255,.6);letter-spacing:.2em}

h1{
  font-family:"Montserrat","Segoe UI",sans-serif;
  font-size:clamp(2rem,4vw,3.2rem);
  line-height:1.1;
  margin:0 0 14px;
  color:var(--color-primary)
}
h2,h3,h4{
  font-family:"Montserrat","Segoe UI",sans-serif;
  margin:0 0 12px;
  color:var(--color-primary)
}
p{margin:0 0 12px;line-height:1.5}
.muted{color:var(--color-muted)}

/* =========================
   ABOUT / VALUES
========================= */
.about-copy{display:grid;gap:16px;line-height:1.6;margin-bottom:32px}
.about-values{display:flex;flex-direction:column;gap:16px;margin-top:32px}

.about-header{
  display:flex;
  flex-direction:column;
  gap:12px;
  margin-bottom:24px;
}
.about-story{
  max-width:780px;
  margin:0 auto;
  line-height:1.7;
  color:var(--color-muted);
}

.about-mission-line{
  background:rgba(0,85,170,.08);
  border-radius:20px;
  padding:18px 24px;
  border:1px solid rgba(0,0,0,.05);
  font-weight:500;
  display:flex;
  gap:12px;
  align-items:center;
}
.about-mission-line strong{
  letter-spacing:.3em;
  text-transform:uppercase;
  font-size:.78rem;
}
.mission-line{font-size:1.05rem;font-weight:500;color:var(--color-muted)}

.values-label{font-size:.85rem;text-transform:uppercase;letter-spacing:.3em;color:#0f172a;margin-bottom:12px}
.values-grid{margin-top:12px}
.values-grid .card{
  min-height:180px;padding:22px;display:flex;flex-direction:column;gap:10px;
  background:#fff;border-radius:20px;border:1px solid rgba(0,0,0,.08);
  box-shadow:0 15px 30px rgba(15,23,42,.07)
}
.values-grid .card h3{margin:0;font-size:1.2rem;color:#0f172a}
.values-grid .card p{margin:0;color:var(--color-muted);line-height:1.5;font-size:.95rem}

.values-hover-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px}
.value-card{
  background:#f8f9ff;border:1px solid rgba(15,23,42,.08);
  border-radius:14px;padding:18px;transition:transform .2s ease,border .2s ease,box-shadow .2s ease;
  min-height:120px;display:flex;flex-direction:column;gap:6px;justify-content:flex-end
}
.value-card h4{margin:0;font-size:1rem;color:#0f172a}
.value-card p{
  margin:0;color:rgba(15,23,42,.7);font-size:.9rem;
  max-height:0;opacity:0;overflow:hidden;
  transition:opacity .2s ease,margin .2s ease,max-height .2s ease
}
.value-card:hover{transform:translateY(-6px);border-color:var(--color-primary);box-shadow:0 15px 30px rgba(15,23,42,.2)}
.value-card:hover p{opacity:1;margin-top:6px;max-height:200px}

/* =========================
   BLOG DETAIL (cover)
========================= */
.section-blog-detail .blog-detail-cover{
  width:100%;max-width:640px;border-radius:20px;margin:24px 0;
  object-fit:cover;display:block
}
.section-blog-detail h1{
  font-size:clamp(2.2rem,4vw,2.6rem);
  margin-bottom:4px;
}
.section-blog-detail .blog-detail-content{
  max-width:860px;
  font-size:1rem;
  line-height:1.6;
  margin-bottom:0;
}

/* =========================
   DIFFERENTIALS
========================= */
.differentials-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px}
.differentials-grid .card{
  min-height:140px;padding:18px;border-radius:22px;
  box-shadow:0 15px 30px rgba(15,23,42,.08);
  border:1px solid rgba(0,0,0,.06)
}

/* =========================
   HERO
========================= */
.hero{
  padding:95px 0 74px;
  border-top:none;
  background:linear-gradient(135deg, rgba(0,51,102,.2), rgba(0,85,170,.08));
  border-radius:32px;
  margin:20px 0;
  border:1px solid rgba(0,85,170,.25);
  box-shadow:0 40px 80px rgba(4,27,115,.18)
}
.hero-grid{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:48px;
  align-items:stretch;
  position:relative
}
.hero h1{font-size:clamp(2.1rem,3vw,3rem);line-height:1.2;max-width:720px}
.hero .muted{max-width:640px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}

.hero-kpi-shell{
  background:#ffffffa5;border-radius:30px;padding:26px;
  box-shadow:0 20px 50px rgba(15,23,42,.18);
  position:relative;overflow:hidden;min-height:280px;
  border:1px solid rgba(0,0,0,.06);
  display:flex;flex-direction:column;justify-content:space-between
}
.hero-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px}
.hero-kpi-grid .kpi-card.hero{
  background:transparent;border:1px solid rgba(0,0,0,.08);
  box-shadow:none;padding:18px;min-height:120px;
  display:flex;flex-direction:column;justify-content:center;gap:4px
}

/* ✅ label do KPI em negrito (não afeta o valor animado) */
.hero-kpi-grid .kpi-card.hero .muted.small{
  color:var(--color-muted);
  margin-bottom:6px;
  font-size:.9rem;
  font-weight:700;
}

.hero-kpi-grid .kpi-value{font-size:2rem;margin:0;color:var(--color-primary)}
.hero-kpi-header{margin-bottom:14px}

/* =========================
   KPI SECTIONS
========================= */
.section-lead{font-weight:600;margin-bottom:18px}

.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}
.kpi-card{
  background:linear-gradient(145deg,rgba(0,51,102,.15),rgba(90,155,203,.08));
  border-radius:26px;padding:26px;border:1px solid rgba(0,85,170,.2);
  box-shadow:0 35px 60px rgba(0,0,0,.1)
}
.kpi-value{font-size:2.2rem;margin-bottom:8px;font-weight:700}

.section-kpi-dark{background:#0c1221;border-radius:32px;padding:70px 0;margin:40px 0}
.kpi-grid-dark{
  background:rgba(255,255,255,.04);
  border-radius:30px;padding:28px;
  box-shadow:0 25px 60px rgba(15,23,42,.45);
  border:1px solid rgba(255,255,255,.1)
}
.kpi-grid-dark .kpi-card{background:transparent;border:1px solid rgba(255,255,255,.15);box-shadow:none;color:#fff}
.kpi-grid-dark .kpi-value{font-size:2.6rem;color:#fff}
.kpi-grid-dark .muted{color:rgba(255,255,255,.8)}

/* =========================
   LAYOUT UTILS
========================= */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.value-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.value-grid span{display:block;background:#fff;border:1px solid var(--color-line);padding:10px;border-radius:8px}

.card-grid{display:grid;gap:16px}
.card-grid.cols-4{grid-template-columns:repeat(4,1fr)}
.card-grid.cols-3{grid-template-columns:repeat(3,1fr)}
.card-grid.blog-grid{margin-top:30px}

.card{
  background:#fff;border-radius:28px;padding:24px;
  box-shadow:0 30px 60px rgba(15,23,42,.08);
  border:1px solid rgba(0,0,0,.04);
  display:flex;flex-direction:column;gap:12px
}

/* =========================
   BLOG (HOME/INDEX)
========================= */
.blog-grid article.card{display:flex;flex-direction:column;gap:12px;}
.blog-grid .btn-outline{margin-top:auto;align-self:flex-start;padding:8px 14px;font-size:.85rem;border-radius:999px;}

.blog-hero-grid{
  display:grid;
  grid-template-columns:1fr minmax(220px,340px);
  gap:28px;
  align-items:stretch;
  margin-bottom:32px
}
.blog-hero-copy{display:flex;flex-direction:column;gap:16px}
.blog-hero-copy h1{font-size:clamp(2.4rem,3vw,2.9rem);line-height:1.2;margin-bottom:0}
.blog-hero-copy .muted{max-width:520px;font-size:.95rem}
.blog-hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:10px}

.blog-highlight-card{
  margin-top:12px;
  background:rgba(255,255,255,.05);
  border-radius:24px;
  padding:22px;
  display:grid;
  grid-template-columns:3fr 2fr;
  gap:18px;
  border:1px solid rgba(255,255,255,.15);
  box-shadow:0 25px 50px rgba(0,0,0,.25)
}
.blog-highlight-body h2{margin:0;font-size:1.8rem}
.blog-highlight-body p{margin:12px 0}
.blog-highlight-thumb img{
  width:100%;height:100%;object-fit:cover;border-radius:18px;max-width:320px
}
.blog-hero-extra{
  background:#fff;border-radius:26px;padding:28px;border:1px solid var(--color-line);
  box-shadow:0 20px 50px rgba(15,23,42,.08);
  display:flex;flex-direction:column;gap:12px
}
.blog-hero-extra h3{margin:0;color:var(--color-primary)}
.blog-hero-highlights{display:grid;gap:10px;margin-top:10px}
.blog-hero-highlights span{
  display:block;padding:10px 14px;border-radius:12px;border:1px solid rgba(0,85,170,.2);
  background:rgba(0,85,170,.05);font-weight:600
}

.hero-card img{width:100%;border-radius:18px;margin-bottom:16px;max-height:360px;object-fit:cover}

.blog-carousel-section{margin-top:32px}
.blog-carousel-header{align-items:center;margin-bottom:16px}
.blog-carousel-shell{position:relative;display:flex;align-items:center}
.blog-carousel-track{
  flex:1;display:flex;gap:18px;overflow-x:auto;padding-bottom:10px;
  scroll-snap-type:x mandatory;margin:0 20px
}
.blog-carousel-card{
  min-width:220px;max-width:280px;flex:0 0 auto;
  scroll-snap-align:start;display:flex;flex-direction:column;gap:10px;
  border-radius:24px;border:1px solid rgba(0,0,0,.05);
  box-shadow:0 20px 40px rgba(15,23,42,.08);
  text-align:left;padding:16px;background:#fff
}
.blog-carousel-card .btn-outline{padding:8px 16px;margin-top:auto}
.blog-carousel-card:nth-child(even){
  background:linear-gradient(180deg,#f8fbff,#ffffff);
  box-shadow:0 25px 45px rgba(15,23,42,.12)
}
.blog-carousel-card:nth-child(even) .blog-carousel-thumb{margin-top:4px}
.blog-carousel-thumb img{width:100%;height:180px;object-fit:cover;border-radius:16px;margin-bottom:10px}

.blog-carousel-control{
  width:48px;height:48px;border-radius:50%;border:none;
  background:var(--color-primary);color:#fff;font-size:1.8rem;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;box-shadow:0 20px 40px rgba(0,0,0,.3);
  transition:transform .2s ease,opacity .2s ease
}
.blog-carousel-control:hover{transform:translateY(-2px)}
.blog-carousel-control:disabled{opacity:.4;cursor:not-allowed}
.blog-carousel-control--prev{position:absolute;left:-14px;top:50%;transform:translateY(-50%)}
.blog-carousel-control--next{position:absolute;right:-14px;top:50%;transform:translateY(-50%)}

.blog-modal{
  position:fixed;inset:0;background:rgba(0,0,0,.7);
  display:none;align-items:center;justify-content:center;
  padding:20px;z-index:120
}
.blog-modal.open{display:flex}
.blog-modal-content{
  background:#fff;border-radius:20px;padding:28px;max-width:520px;width:100%;
  box-shadow:0 15px 40px rgba(15,23,42,.3);display:grid;gap:16px
}
.blog-modal-close{border:none;background:transparent;font-size:24px;line-height:1;cursor:pointer;justify-self:flex-end}

/* =========================
   TABS / PROJECT FILTERS / IFC
========================= */
.tabs{display:flex;gap:8px;margin-bottom:18px}
.tab-btn{padding:10px 14px;border:1px solid var(--color-line);background:#fff;border-radius:8px;cursor:pointer}
.tab-btn.active{border-color:var(--color-primary);color:var(--color-primary);font-weight:700}
.tab-content{display:none}
.tab-content.active{display:block}

.project-tabs{background:#f5f6fb;padding:12px;border-radius:22px}
.project-tabs .tab-btn{
  border-radius:999px;padding:10px 20px;background:#fff;border-color:var(--color-line);color:#0f172a
}
.project-tabs .tab-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}
.project-tabs .tab-btn:not(.active):hover{background:rgba(37,99,235,.12)}

.ifc-filter{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:20px}
.type-filter-btn{
  border-radius:999px;padding:8px 16px;background:#f3f4f9;border:1px solid rgba(15,23,42,.15);
  color:var(--color-primary);font-weight:600;cursor:pointer
}
.type-filter-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}

.type-pill-stack{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}
.type-pill{
  border-radius:999px;padding:6px 12px;background:rgba(0,85,170,.08);
  border:1px solid rgba(0,85,170,.3);font-size:.85rem;font-weight:600;color:var(--color-primary)
}

.project-filters{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:20px}
.project-filters label{font-size:.85rem;display:flex;flex-direction:column;gap:6px}
.project-filters select{border-radius:6px;border:1px solid var(--color-line);padding:8px;background:#fff;font:inherit}

.project-card{display:flex;flex-direction:column}
.thumb{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:8px;border:1px solid var(--color-line);margin-bottom:10px}
.thumb-empty{display:flex;align-items:center;justify-content:center;background:#f8f9fd;color:var(--color-muted)}

/* =========================
   RENDER GRID
========================= */
.render-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}
.render-item{
  border:0;background:linear-gradient(135deg,rgba(0,51,102,.05),rgba(90,155,203,.05));
  padding:0;border-radius:18px;overflow:hidden;text-align:left;cursor:pointer;
  box-shadow:0 30px 50px rgba(0,0,0,.12)
}
.render-item img{width:100%;aspect-ratio:16/10;object-fit:cover}
.render-item span{display:block;padding:10px 12px;font-weight:600}

.render-item__content{padding:0 12px 10px}
.ifc-model-list{list-style:none;margin:0;padding:0 12px;display:flex;flex-direction:column;gap:.35rem}
.ifc-model-list li{font-size:.9rem;display:flex;justify-content:space-between;gap:.5rem;align-items:flex-end}
.ifc-model-list small{display:block}
.ifc-render-item{
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  gap:10px;
}
.ifc-render-item .render-thumb{
  border-bottom-left-radius:0;
  border-bottom-right-radius:0;
}
.ifc-render-item a{
  margin:0 12px 12px;
  width:calc(100% - 24px);
  align-self:flex-start;
}

.ifc-tag-panel{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  padding:0 12px 4px;
}
.ifc-tag{
  border-radius:999px;
  padding:4px 12px;
  background:rgba(15,23,42,.08);
  border:1px solid rgba(15,23,42,.2);
  font-size:.9rem;
  font-weight:600;
  color:var(--color-primary);
}

.paragraph-note{margin-bottom:12px;font-weight:600;letter-spacing:.02em;color:rgba(0,0,0,.6)}

/* =========================
   CLIENTS / MAP / TEAM / CULTURE / JOBS
========================= */
.client-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
  gap:16px;
  align-items:stretch;
  justify-items:center;
}
.client-card{
  border:1px solid var(--color-line);
  border-radius:8px;
  background:#fff;
  min-height:140px;
  width:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px;
  filter:grayscale(1);
  transition:filter .2s ease;
  overflow:hidden;
}
.client-card:hover{filter:grayscale(0)}
.client-card img{
  width:100%;
  height:100%;
  object-fit:contain;
  display:block;
}
.client-placeholder{
  font-size:.85rem;
  color:var(--color-muted);
  text-align:center;
}

.map-shell{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:24px;padding:32px;border-radius:32px;background:#0f172a;
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 40px 80px rgba(0,0,0,.25);
  color:#fff
}
.map-visual{
  background:linear-gradient(135deg,rgba(255,255,255,.04),rgba(0,0,0,.05));
  border-radius:28px;padding:24px;display:flex;align-items:center;justify-content:center
}
.map-shell svg{width:100%;height:auto;max-height:300px}
.map-pin{fill:#10b981;stroke:#fff;stroke-width:2}
.map-details{display:flex;flex-direction:column;gap:18px}
.state-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}
.state-card{padding:14px 16px;border-radius:18px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1)}
.state-card strong{font-size:1rem}
.state-card p{margin:2px 0}
.state-card small{color:rgba(255,255,255,.6)}
.map-shell .muted{color:rgba(255,255,255,.75)}

.team-grid{display:grid;grid-template-columns:repeat(2,minmax(260px,1fr));gap:16px;margin-top:28px}
.team-card{
  background:#fff;border:1px solid var(--color-line);
  border-radius:var(--radius);padding:18px;
  display:grid;grid-template-columns:90px 1fr;gap:12px;align-items:center;
  box-shadow:var(--shadow);
  transition:transform .2s ease,box-shadow .2s ease;
  cursor:default;
}
.team-card[data-team-card]{cursor:pointer}
.team-card[data-team-card]:hover{transform:translateY(-4px);box-shadow:0 18px 34px rgba(15,23,42,.18)}
.team-card figure{margin:0}
.team-card img{
  border-radius:8px;
  aspect-ratio:1/1;
  object-fit:cover;
  filter:grayscale(1) brightness(0.9);
  transition:filter .25s ease;
}
.team-card:hover img,
.team-card:focus-visible img,
.team-card:focus-within img{
  filter:grayscale(0) brightness(1);
}
.team-card__cta{display:inline-flex;align-items:center;gap:6px;margin-top:8px;font-weight:600;color:var(--color-primary);font-size:.9rem}
.team-card__cta::after{content:"›";font-size:1rem}

.team-modal{
  position:fixed;
  inset:0;
  background:rgba(8,15,32,.8);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
  z-index:140;
}
.team-modal__dialog{
  position:relative;
  background:#fff;
  border-radius:30px;
  box-shadow:0 40px 80px rgba(8,15,32,.35);
  display:grid;
  grid-template-columns:minmax(240px,320px) minmax(0,1fr);
  gap:28px;
  max-width:min(960px,94vw);
  width:100%;
  padding:32px;
}
.team-modal__close{
  position:absolute;
  top:18px;
  right:18px;
  border:none;
  width:42px;
  height:42px;
  border-radius:50%;
  background:rgba(15,23,42,.08);
  color:#0f172a;
  font-size:1.6rem;
  cursor:pointer;
}
.team-modal__media{
  border-radius:22px;
  overflow:hidden;
  background:#f5f5f7;
  min-height:280px;
}
.team-modal__media img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.team-modal__content{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.team-modal__eyebrow{
  margin:0;
  color:var(--color-secondary);
}
.team-modal__bio{
  margin:8px 0 0;
  color:var(--color-muted);
  line-height:1.5;
}
.team-modal__actions{
  margin-top:12px;
}
@media (max-width:860px){
  .team-modal__dialog{
    grid-template-columns:1fr;
    padding:26px 22px 22px;
  }
  .team-modal__media{
    min-height:220px;
  }
  .team-modal__close{
    top:12px;
    right:12px;
  }
}

.culture-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 24px;
  margin-top: 32px;
}
.culture-card {
  background: #fff;
  border: 1px solid var(--color-line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  cursor: pointer;
  transition: transform 0.3s, box-shadow 0.3s;
  min-height: 100%;
}
.culture-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 38px rgba(0, 0, 0, 0.15);
}
.culture-card:focus-visible {
  outline: 2px solid var(--color-secondary);
  outline-offset: 2px;
}
.culture-card img {
  width: 100%;
  height: 260px;
  object-fit: cover;
}
.culture-card__content {
  padding: 1.35rem;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 0.4rem;
}
.culture-card__content h3 {
  margin: 0;
  font-size: 1.2rem;
  line-height: 1.3;
}
.culture-card__cta span {
  color: var(--color-muted);
  font-size: 0.9rem;
}
.gallery-previews{display:flex;flex-wrap:wrap;gap:12px;margin-top:8px}
.gallery-previews figure{margin:0;width:120px;background:#f8fafc;border:1px solid var(--color-line);border-radius:6px;overflow:hidden;display:flex;flex-direction:column}
.gallery-previews img{width:100%;height:80px;object-fit:cover}
.gallery-previews figcaption{padding:6px;text-align:center}
.format-controls{display:flex;gap:8px;margin-bottom:8px}
.format-controls button{border:1px solid var(--color-line);border-radius:4px;background:#fff;padding:4px 10px;font-weight:600;cursor:pointer}
.format-controls button:hover{border-color:var(--color-secondary);color:var(--color-secondary)}

.jobs-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-left:0}
.job-card{
  background:#fff;
  border:1px solid var(--color-line);
  border-radius:var(--radius);
  padding:18px;
  box-shadow:var(--shadow);
  display:flex;
  flex-direction:column;
  gap:12px;
  min-height:320px;
}
.job-card__meta{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:12px;
  font-size:.85rem;
  letter-spacing:.2em;
  text-transform:uppercase;
}
.job-card__type{
  font-weight:700;
  color:var(--color-secondary);
}
.job-card__location{
  color:var(--color-muted);
}
.job-card__actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:auto;
}
.jobs-message{font-size:1.2rem;font-weight:600;margin:12px 0 0;color:var(--color-primary)}
.job-modal{
  position:fixed;
  inset:0;
  background:rgba(5,9,20,.8);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:120;
  padding:24px;
  overflow:auto;
}
.job-modal[hidden]{display:none}
.job-modal__backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.7);
}
.job-modal__dialog{
  position:relative;
  max-width:min(640px,90vw);
  width:100%;
  background:#111424;
  border-radius:20px;
  padding:26px;
  display:flex;
  flex-direction:column;
  gap:18px;
  box-shadow:0 24px 40px rgba(0,0,0,.5);
  color:#fff;
}
.job-modal__close{
  position:absolute;
  top:16px;
  right:16px;
  border:none;
  background:#fff;
  color:#0f1624;
  border-radius:999px;
  width:44px;
  height:44px;
  cursor:pointer;
  font-weight:600;
}
.job-modal__media{
  border-radius:16px;
  overflow:hidden;
  min-height:220px;
  background:#0f1624;
}
.job-modal__media img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.job-modal__body{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.jobs-teaser{font-size:1rem;font-weight:700;text-transform:uppercase;letter-spacing:.2em;color:var(--color-secondary)}
.job-form{margin-top:24px;background:#fff;border:1px solid var(--color-line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px}
.form-grid input,.form-grid select,.form-grid textarea{width:100%;border:1px solid var(--color-line);border-radius:8px;padding:10px;background:#fff;font:inherit}
.job-form label.file-label{display:flex;flex-direction:column;gap:6px}
.job-form input[type=file]{min-height:46px;padding:10px;border-radius:8px;border:1px solid var(--color-line);background:#f6f7fb}

/* =========================
   IFC UPLOAD
========================= */
.ifc-types{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:8px;margin-bottom:14px}
.ifc-type{display:flex;align-items:center;gap:8px;padding:6px 10px;background:#f3f4f6;border-radius:10px;font-weight:600;color:#0f172a}
.ifc-type input{accent-color:var(--color-primary)}
.ifc-upload-section{display:flex;flex-direction:column;gap:12px}
.ifc-upload-list{display:flex;flex-direction:column;gap:12px}
.ifc-upload-row{display:grid;grid-template-columns:1fr 180px auto;gap:10px;align-items:center}
.ifc-upload-row input[type=file]{border:1px solid var(--color-line);border-radius:6px;padding:6px 8px;background:#fff}
.ifc-upload-row select{border-radius:6px;border:1px solid var(--color-line);padding:6px 10px;background:#fff;font:inherit}
.icon-btn{width:36px;height:36px;border-radius:50%;border:1px solid var(--color-line);background:#fff;color:#0f172a;font-weight:700;cursor:pointer}

/* =========================
   FAQ
========================= */
.faq-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;margin-top:20px}
.faq-item{border:1px solid var(--color-line);border-radius:var(--radius);background:#fff;box-shadow:var(--shadow);overflow:hidden}
.faq-question{width:100%;border:none;background:var(--color-bg);padding:16px;text-align:left;font-size:1rem;font-weight:600;cursor:pointer}
.faq-answer{padding:0 16px 16px;margin:0;display:none;font-size:.95rem}
.faq-item.open .faq-answer{display:block}

/* =========================
   SERVICES HIGHLIGHT (YOUR BLOCK)
========================= */
.section-services-highlight{
  background:#272c33;
  padding:52px 0;
  background-image:
    linear-gradient(0deg, rgba(255,255,255,.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.08) 1px, transparent 1px);
  background-size:48px 48px;
  border:1px solid rgba(255,255,255,.05);
}
.services-highlight-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(320px,1fr));
  gap:32px;
  align-items:center;
}
.services-highlight-grid--tight{
  grid-template-columns:minmax(0,2fr) minmax(180px,1fr);
}
.services-highlight-copy{
  padding-right:24px;
  max-width:820px;
}
.services-highlight-copy h2{
  font-size:2.4rem;
  margin-bottom:16px;
  color:#fff;
}
.services-highlight-lead{
  font-size:1.1rem;
  color:rgba(255,255,255,.85);
  max-width:100%;
  margin-bottom:16px;
}
/* sem duplicação e sem travar largura */
.services-highlight-copy p{
  color:rgba(255,255,255,.75);
  margin-bottom:20px;
  max-width:100%;
}

.services-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
}
.services-highlight-copy .btn{border-radius:20px}
.section-services-highlight .btn-outline{border-color:rgba(255,255,255,.4);color:#fff}
.section-services-highlight .btn-outline:hover{border-color:#fff}

.services-actions--three .btn-outline{
  border-color:rgba(255,255,255,.4);
  color:#fff;
  background:transparent;
}
.services-actions--three .btn-primary{
  background:linear-gradient(135deg, #1d4ed8, #2563eb);
  color:#fff;
}

.services-logo-panel{
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
  background:rgba(255,255,255,.08);
  border-radius:24px;
  border:1px solid #f1f0ea;
  box-shadow:0 10px 30px rgba(0,0,0,.25);
}
.services-logo-panel img{
  width:min(640px, 90%);
  height:auto;
}

/* =========================
   SERVICE LIST
========================= */
.section-service-list{
  padding-top:50px;
  padding-bottom:60px;
}
.section-service-list .section-header h2{margin-bottom:12px}
.services-card-grid{
  display:grid;
  gap:20px;
  grid-template-columns:repeat(3,minmax(0,1fr));
  align-items:stretch;
  grid-auto-rows:1fr;
  width:100%;
}
.service-card{
  padding:20px 24px;
  border-radius:18px;
  border:1px solid rgba(15,23,42,.06);
  box-shadow:0 10px 24px rgba(15,23,42,.08);
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap:14px;
  min-height:320px;
  width:100%;
}
.service-card__thumb{
  height:180px;
  border-radius:14px;
  overflow:hidden;
  display:block;
}
.service-card__body{
  display:flex;
  flex-direction:column;
  gap:4px;
  padding-bottom:0;
}
.service-card__thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.service-card__body h3{
  margin:0 0 6px;
  font-size:1.2rem;
  line-height:1.25;
}
.service-card__body p{
  margin:0;
  color:var(--color-muted);
  font-size:.95rem;
  line-height:1.4;
}
@media (max-width:1024px){
  .services-card-grid{
    grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  }
}
@media (max-width:640px){
  .service-card{
    min-height:auto;
    padding:8px;
    border-radius:12px;
  }
  .service-card__thumb{
    height:138px; /* 120px + 15% = 138px */
    border-radius:10px;
  }
}

.services-master{
  display:flex;
  flex-direction:column;
  gap:18px;
}
.services-master-tabs{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.service-tab-btn{
  border:1px solid rgba(37,99,235,.3);
  background:#fff;
  border-radius:999px;
  padding:10px 18px;
  font-weight:700;
  color:var(--color-primary);
  cursor:pointer;
  transition:background .2s ease,border .2s ease;
}
.service-tab-btn.active{
  background:var(--color-primary);
  color:#fff;
  border-color:var(--color-primary);
}
.services-master-panel{
  display:none;
}
.services-master-panel.active{
  display:block;
}
.services-master-panel__header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  border-bottom:1px solid rgba(15,23,42,.08);
  padding-bottom:12px;
  margin-bottom:18px;
  gap:10px;
}
.services-master-panel__actions{white-space:nowrap;}
.service-carousel{
  position:relative;
  display:flex;
  align-items:center;
  gap:12px;
}
.service-carousel-track{
  display:flex;
  gap:16px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  padding-bottom:10px;
}
.service-carousel-card{
  flex:0 0 calc(33.333% - 12px);
  min-width:260px;
  scroll-snap-align:start;
  border-radius:22px;
  border:1px solid rgba(15,23,42,.08);
  box-shadow:0 12px 30px rgba(15,23,42,.08);
  background:#fff;
  display:flex;
  flex-direction:column;
  gap:10px;
  padding:18px;
}
.service-carousel-card h3{margin:0;}
.service-carousel-card p{margin:0;color:var(--color-muted);}
.service-carousel-card .service-carousel-thumb img{border-radius:16px;}
.service-carousel-card .service-carousel-thumb{border-radius:16px;}
@media (max-width:1024px){
  .service-carousel-card{
    flex:0 0 calc(50% - 12px);
  }
}
@media (max-width:640px){
  .service-carousel-card{
    flex:0 0 100%;
  }
}
.service-carousel-thumb img{
  width:100%;
  height:140px;
  object-fit:cover;
  border-radius:16px;
}
.service-carousel-body h3{margin:0;font-size:1.2rem;}
.service-carousel-body p{margin:0;color:var(--color-muted);}
.service-carousel-control{
  border:none;
  background:rgba(37,99,235,.08);
  color:var(--color-primary);
  width:40px;
  height:40px;
  border-radius:50%;
  cursor:pointer;
  font-size:1.4rem;
  display:flex;
  align-items:center;
  justify-content:center;
}
.service-carousel-control:disabled{opacity:.3;cursor:not-allowed;}
.project-section .project-tabs{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.project-tabs .btn{margin-left:auto;}
.render-grid--service{gap:18px;}
.section-downloads{
  background:#f6f8fd;
}
.downloads-master .services-master-panel__header{
  border-bottom:1px solid rgba(15,23,42,.12);
}
.downloads-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:18px;
}
.download-card{
  border-radius:24px;
  border:1px solid rgba(15,23,42,.08);
  background:#fff;
  padding:20px;
  display:flex;
  flex-direction:column;
  gap:14px;
  box-shadow:0 20px 38px rgba(15,23,42,.08);
  min-height:260px;
}
.download-card__thumb img{
  width:100%;
  height:160px;
  object-fit:cover;
  border-radius:18px;
}
.download-card__body h3{margin:0 0 6px;font-size:1.15rem;}
.download-card__body p{margin:0;color:var(--color-muted);line-height:1.5;}
.download-card__meta{
  list-style:none;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:12px 0 0;
  padding:0;
}
.download-card__meta li{
  padding:4px 12px;
  border-radius:999px;
  background:rgba(15,23,42,.08);
  font-size:.85rem;
  font-weight:600;
  color:#0f172a;
}
.download-card__actions{margin-top:auto;}
.download-card__eyebrow{margin-bottom:4px;display:inline-block;color:var(--color-primary);}
@media (max-width:640px){
  .downloads-grid{
    grid-template-columns:1fr;
  }
}
.service-page-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:20px;
  margin-top:24px;
}
.service-page-card{
  border-radius:24px;
  border:1px solid rgba(15,23,42,.08);
  box-shadow:0 20px 40px rgba(15,23,42,.08);
  padding:18px;
  display:flex;
  flex-direction:column;
  gap:12px;
  cursor:pointer;
}
.service-page-card img{
  width:100%;
  height:180px;
  object-fit:cover;
  border-radius:16px;
}
.service-page-card h3{margin:0;}
.service-page-card p{margin:0;color:var(--color-muted);line-height:1.5;}
.light-grid-background{
  background:#f7f8fb;
  background-image:
    linear-gradient(0deg, rgba(15,23,42,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(15,23,42,.05) 1px, transparent 1px);
  background-size:120px 120px;
  padding-top:40px;
}

.section-policies .policy-list{
  margin:0;
  padding:0;
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:16px;
}
.section-policies .policy-list a{
  display:inline-flex;
  padding:14px 18px;
  border-radius:14px;
  border:1px solid rgba(15,23,42,.12);
  background:#eff6ff;
  color:var(--color-primary);
  font-weight:600;
  text-decoration:none;
  transition:transform .2s ease,box-shadow .2s ease;
}
.section-policies .policy-list a:hover{
  transform:translateY(-2px);
  box-shadow:0 15px 30px rgba(15,23,42,.15);
}

.policy-content{
  background:#fff;
  border-radius:24px;
  padding:28px;
  border:1px solid rgba(15,23,42,.1);
  box-shadow:0 20px 40px rgba(15,23,42,.1);
  line-height:1.6;
  white-space:normal;
  font-size:1rem;
}
.policy-content p{
  margin:0 0 14px;
}
.policy-content p.policy-section-title{
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:.95rem;
  margin-bottom:6px;
}
.policy-content ul{
  margin:0 0 12px 1.5rem;
  padding:0;
  list-style:disc;
}
.policy-content ul li{
  margin-bottom:6px;
}
/* =========================
   CONTACT (HOME - COMPACT)
========================= */
.section-contact{
  background:#f7f8fb;
  color:var(--color-text);
  padding:44px 0 42px;
  border-top:none;
}

.contact-header{
  max-width:860px;
  margin:0 auto 22px;
  text-align:center;
}

.contact-brief{
  display:grid;
  grid-template-columns:minmax(260px, 380px) minmax(0, 1fr);
  gap:18px;
  align-items:start;
  max-width:1100px;
  margin:0 auto;
}

.contact-brief__info{
  background:#fff;
  border:1px solid rgba(15,23,42,.08);
  border-radius:22px;
  padding:22px;
  box-shadow:0 18px 40px rgba(15,23,42,.06);
  display:flex;
  flex-direction:column;
  gap:12px;
}

.contact-brief__info h3{
  margin:0;
  font-size:1.35rem;
  color:var(--color-primary);
  text-transform:none;
  line-height:1.4;
}

.contact-brief__info p{
  margin:0;
  font-size:1rem;
  line-height:1.7;
  color:var(--color-muted);
}

.contact-brief__meta{
  display:grid;
  gap:10px;
  margin-top:4px;
  padding-top:14px;
  border-top:1px solid rgba(15,23,42,.08);
}

.contact-meta-item{
  display:flex;
  flex-direction:column;
  gap:4px;
}
.contact-meta-item strong{
  font-size:.78rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--color-muted);
}
.contact-meta-item a,
.contact-meta-item span{
  font-weight:600;
  color:#0f172a;
}

.contact-brief__form{
  background:#fff;
  border:1px solid rgba(15,23,42,.08);
  border-radius:22px;
  padding:22px;
  box-shadow:0 18px 40px rgba(15,23,42,.06);
}

.contact-form-brief{
  display:grid;
  gap:12px;
}

.contact-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:12px;
}

.contact-field{
  display:flex;
  flex-direction:column;
  gap:6px;
  font-weight:600;
  color:#0f172a;
}

.contact-field > span{
  font-size:.72rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(15,23,42,.65);
}

.contact-field input,
.contact-field select,
.contact-field textarea{
  width:100%;
  border:1px solid rgba(15,23,42,.14);
  border-radius:14px;
  padding:12px 14px;
  background:#fff;
  font:inherit;
}

.contact-field textarea{
  min-height:140px;
  resize:vertical;
}

.contact-file input[type=file]{
  border:1px dashed rgba(15,23,42,.22);
  border-radius:14px;
  padding:12px 14px;
  background:#fbfcff;
}

.contact-attachments small{display:block;margin-top:6px}

.contact-consent{
  display:flex;
  gap:10px;
  align-items:flex-start;
  font-weight:600;
  color:rgba(15,23,42,.75);
}
.contact-consent input{margin-top:3px}

.contact-actions-brief{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:4px;
}

.contact-note{margin:0}

@media (max-width:960px){
  .contact-brief{
    grid-template-columns:1fr;
  }
  .contact-grid{
    grid-template-columns:1fr;
  }
}


/* =========================
   ADMIN LOGIN
========================= */
.section.admin-login .stack-form{gap:12px}
.section.admin-login .btn{padding:10px 18px;font-size:1rem;text-transform:none;letter-spacing:0}

.cta-final{background:rgba(90,155,203,.08)}
.center{text-align:center}

/* =========================
   FLOATING BUTTONS
========================= */
.floating-buttons{
  position:fixed;right:24px;bottom:24px;display:flex;
  flex-direction:column;gap:12px;z-index:120
}
.floating-button{
  width:56px;height:56px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:#fff;
  box-shadow:0 20px 40px rgba(0,0,0,.25);
  transition:transform .2s ease
}
.floating-button svg{width:28px;height:28px;fill:#fff}
.floating-button--whatsapp{background:#25d366}
.floating-button--instagram{background:#e1306c}
.floating-button:hover{transform:translateY(-3px)}

/* =========================
   LIGHTBOX
========================= */
.lightbox{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.6);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:100;
  padding:28px;
  overflow-y:auto;
}
.lightbox-overlay{
  position:absolute;
  inset:0;
  background:inherit;
  z-index:-1;
}
.lightbox-inner{
  position:relative;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:26px;
  width:100%;
  max-width:min(1100px,96vw);
  padding:18px;
  text-align:center;
}
.lightbox-content{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:24px;
  width:100%;
}
.lightbox-media{
  width:100%;
  max-width:600px;
  border-radius:18px;
  overflow:hidden;
  background:#04050a;
  min-height:300px;
  box-shadow:0 20px 40px rgba(0,0,0,.4);
  margin:0 auto;
}
.lightbox-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.lightbox-copy{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.lightbox-title{
  margin:0;
  font-size:2rem;
  line-height:1.25;
  font-weight:600;
  text-align:left;
  color:#fff;
}
.lightbox p{
  color:#fff;
  margin:0;
  text-align:left;
}
.lightbox-description{
  margin-top:4px;
  font-size:1rem;
  line-height:1.6;
  width:100%;
}
.lightbox-description[hidden]{display:none}
.lightbox-copy{
  background:transparent;
  padding:0;
  width:100%;
  max-width:none;
  color:#fff;
}
.lightbox-nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:44px;
  height:44px;
  border:0;
  border-radius:999px;
  background:#fff;
  color:#222;
  font-size:28px;
  line-height:1;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:.9;
}
.lightbox-nav:disabled{opacity:.4;cursor:default}
.lightbox-nav.prev{left:-6px}
.lightbox-nav.next{right:-6px}

@media (max-width:900px){
  .lightbox-inner{
    padding:16px;
  }
  .lightbox-media{
    min-height:260px;
  }
  .lightbox-nav.prev{
    left:8px;
  }
  .lightbox-nav.next{
    right:8px;
  }
}
.lightbox-close{position:absolute;top:-6px;right:-6px;padding:10px 14px;border:0;background:#fff;border-radius:6px;cursor:pointer}
.lightbox-nav{
  position:absolute;top:50%;transform:translateY(-50%);
  width:44px;height:44px;border:0;border-radius:999px;
  background:#fff;color:#222;font-size:28px;line-height:1;
  cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:.9
}
.lightbox-nav:disabled{opacity:.4;cursor:default}
.lightbox-nav.prev{left:-6px}
.lightbox-nav.next{right:-6px}

/* =========================
   FORMS
========================= */
.stack-form{display:grid;gap:8px}
input,select,textarea{width:100%;border:1px solid var(--color-line);border-radius:8px;padding:10px;background:#fff;font:inherit}
textarea{min-height:120px;resize:vertical}

/* =========================
   ADMIN / TABLES
========================= */
.dashboard-head{display:flex;justify-content:space-between;align-items:center;gap:10px}
.placeholder-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:22px}

.admin-nav{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.admin-nav a{padding:8px 10px;border:1px solid var(--color-line);border-radius:6px;background:#fff}
.row-between{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px}

.table{
  width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--color-line);
  border-radius:8px;overflow:hidden
}
.table th,.table td{padding:10px;border-bottom:1px solid var(--color-line);text-align:left;vertical-align:top}
.table .actions{display:flex;gap:6px;flex-wrap:wrap}

.inline-list{list-style:none;padding:0;margin:10px 0;display:grid;gap:8px}
.inline-list li{
  display:flex;justify-content:space-between;gap:10px;align-items:center;
  border:1px solid var(--color-line);padding:8px 10px;border-radius:8px;background:#fff
}

/* =========================
   FOOTER
========================= */
.site-footer{padding:60px 0 40px;background:#fff;border-top:1px solid var(--color-line)}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px;align-items:flex-start}
.footer-grid--contact{grid-template-columns:minmax(220px,280px) repeat(2,minmax(220px,1fr));align-items:flex-start}
.footer-contact-grid{display:flex;flex-direction:column;gap:10px}
.footer-contact-row{display:flex;align-items:center;gap:12px}
.footer-contact-row p,.footer-contact-row a{margin:0;color:var(--color-muted)}
.footer-line{height:1px;background:var(--color-line);margin:24px 0}
.footer-brand img{height:64px;margin-bottom:12px}
.footer-brand .muted{max-width:260px}
.footer-brand.footer-brand--logo img{height:min(160px,65vw);width:auto}
.footer-column{display:flex;flex-direction:column;gap:6px}
.footer-column a{color:var(--color-muted);font-weight:600;transition:color .2s ease}
.footer-column a:hover{color:var(--color-primary)}
.footer-title{color:var(--color-primary);font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:6px}
.footer-bottom{display:flex;flex-direction:column;gap:6px;margin-top:12px}
.footer-bottom strong{color:var(--color-primary)}
.footer-bottom a{color:var(--color-primary)}
.footer-bottom--wide{
  display:flex;flex-direction:row;align-items:center;justify-content:space-between;
  gap:12px;flex-wrap:nowrap;margin-top:12px
}
.footer-developed{margin:0;font-weight:600}
.footer-developed a{color:var(--color-primary)}
.footer-contact-column .footer-contact-row{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.footer-contact-row p{margin:0;color:var(--color-muted)}
.footer-icon{font-size:1.2rem;display:inline-flex}
.footer-contact-row a{color:var(--color-primary)}

/* =========================
   IFC VIEWER
========================= */
.viewer-shell{padding:30px 0 80px}
.viewer-topbar{
  display:flex;align-items:center;gap:10px;
  max-width:var(--max-width);margin:0 auto;padding:0 20px
}
.viewer-body{
  display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:12px;
  max-width:var(--max-width);margin:12px auto 0;padding:0 20px
}
.viewer-canvas{height:70vh;background:#fff;border:1px solid var(--color-line);border-radius:10px;overflow:hidden}
.viewer-sidebar{background:#fff;border:1px solid var(--color-line);border-radius:10px;padding:14px}
.viewer-frame{
  position:relative;
  max-width:min(960px,94vw);
  margin:16px auto 0;
  padding-bottom:80px;
  border-radius:18px;
  border:1px solid rgba(15,23,42,.15);
  background:#fff;
  box-shadow:0 20px 40px rgba(5,15,38,.16);
  overflow:hidden;
}
.viewer-frame .viewer-fullscreen-btn{
  position:absolute;
  top:16px;
  right:20px;
  z-index:2;
}
.viewer-frame .viewer-canvas{
  min-height:62vh;
  height:min(70vh,560px);
  border:none;
  border-radius:0;
}
.viewer-loader{font-weight:700;color:var(--color-primary);margin-top:14px}
.viewer-controls{margin-top:12px}
.viewer-filters{margin-top:16px;display:grid;gap:6px}
.viewer-filters h4{margin:0 0 6px 0;font-size:.95rem}
.viewer-filters label{display:flex;gap:8px;align-items:center;font-size:.95rem}
.viewer-filters-panel{
  position:absolute;
  left:50%;
  bottom:18px;
  transform:translateX(-50%);
  width:min(720px,86%);
  background:rgba(255,255,255,.95);
  border-radius:16px;
  border:1px solid rgba(15,23,42,.17);
  padding:10px 16px 14px;
  box-shadow:0 20px 36px rgba(5,15,38,.25);
  z-index:1;
}
.viewer-filters-panel .viewer-filters-heading{
  text-align:center;
  margin-bottom:6px;
}
.viewer-filters-panel .viewer-filters{
  justify-content:center;
}

/* =========================
   RESPONSIVE
========================= */
@media (max-width:1024px){
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .card-grid.cols-4{grid-template-columns:repeat(2,1fr)}
  .card-grid.cols-3,.render-grid{grid-template-columns:repeat(2,1fr)}
  .client-grid{grid-template-columns:repeat(3,1fr)}
  .team-grid{grid-template-columns:1fr}
}

@media (max-width:780px){
  .hero-grid,.two-col,.placeholder-grid,.viewer-body,.footer-grid{grid-template-columns:1fr}
  .section{padding:var(--section-spacing-mobile) 0}
  .hero{padding-top:74px}
  .card-grid.cols-3,.render-grid,.client-grid,.card-grid.cols-4{grid-template-columns:1fr}
  .table{font-size:.9rem}
  .team-grid{grid-template-columns:1fr}
  .blog-carousel-control{display:none}
  .map-shell{grid-template-columns:1fr}
  .contact-grid--split{grid-template-columns:1fr}
}

@media (max-width:900px){
  .header-row{flex-direction:column;align-items:flex-start;gap:10px}
  .nav{width:100%;justify-content:flex-start}
  .header-actions{width:100%;justify-content:flex-start}
}

@media (max-width:768px){
  .footer-bottom--wide{flex-wrap:wrap}
}
