/* STRYVA merged CSS (holding + build) */
:root{
  --max: 1120px;
  --ink: #111;
  --muted: #6f6f6f;
  --line: #e9e9e9;
  --bg: #fff;
  --text: #111;
  --hair: #e9e9e9;
}

/* STRYVA Build — isolated CSS (matches Holding DNA) */
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color:var(--ink);
  background:#fff;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

a{color:inherit}
.container{max-width:var(--max);margin:0 auto;padding:0 26px}

/* Header / Nav */
header{background:#fff}
.nav{
  max-width:var(--max);
  margin:0 auto;
  padding:18px 26px;
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.brand {
    display: flex;
    align-items: center;
    text-decoration: none;
    flex-shrink: 0;
}
.brand__logo {
    height: 36px;
    width: auto;
    display: block;
    object-fit: contain;
}

@media (max-width: 640px) {
    .brand__logo {
        height: 28px;
    }
}
nav{display:flex;align-items:center;gap:18px}
nav a{
  text-decoration:none;
  color:var(--muted);
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  padding:10px 0;
}
nav a:hover{color:var(--ink)}

/* Pills (LOGIN / PLATFORM) */
nav a[href*="/login" i],
nav a[href*="/platform" i]{
  padding:10px 18px;
  border-radius:999px;
  letter-spacing:.14em;
  font-weight:500;
  border:1px solid #e6e6e6;
  color:var(--ink);
  background:#fff;
}
/* push actions to far right */
nav a[href*="/login" i]{margin-left:auto; order:98}
nav a[href*="/platform" i]{order:99; background:#111; border-color:#111; color:#fff}
nav a[href*="/login" i]:hover{border-color:#cfcfcf}
nav a[href*="/platform" i]:hover{background:#000;border-color:#000}

/* Hero */
.hero{position:relative;height:420px;overflow:hidden}
.page-contact-build .hero__media {
    background-image: url("../assets/contato-build.png");
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    filter: grayscale(1) contrast(1.06);
    transform: scale(1.01);
    }

.page-build .hero__media {
    background-image: url("../assets/hero.png");
    inset: 0;
    background-size: cover;
    background-position: center;
    filter: grayscale(1) contrast(1.06);
    transform: scale(1.01);
}
.page-build .hero__media_build {
    background-image: url("../assets/hero_build.png");
    inset: 0;
    background-size: cover;
    background-position: center;
    filter: grayscale(1) contrast(1.06);
    transform: scale(1.01);
}
position: absolute;
.page-build .hero__media__contact {
    background-image: url("assets/contato-build.png");
    inset: 0;
    background-size: cover;
    background-position: center;
    filter: grayscale(1) contrast(1.06);
    transform: scale(1.01);
}

position: absolute;

.hero__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient( 180deg, rgba(0,0,0,0.50) 0%, rgba(0,0,0,0.38) 35%, rgba(255,255,255,0.85) 100% );
}
.hero__inner{max-width:var(--max);margin:0 auto;padding:64px 26px 0;position:relative}
.eyebrow{
  letter-spacing:.32em;
  text-transform:uppercase;
  color:#7a7a7a;
  font-size:11px;
  margin-bottom:14px;
}
.hero__title{
  font-size:56px;
  letter-spacing:.30em;
  text-transform:uppercase;
  margin:0 0 14px;
  color: #ffffff;
}
.hero__sub{
  max-width:720px;
  color: rgba(255,255,255,0.85);
  line-height:1.5;
  margin:0 0 22px;
}
.hero__cta{display:flex;gap:12px;flex-wrap:wrap}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:42px;
  padding:0 18px;
  border-radius:999px;
  text-decoration:none;
  font-size:12px;
  letter-spacing:.14em;
  text-transform:uppercase;
  border:1px solid #e6e6e6;
}
.btn--dark{background:#111;border-color:#111;color:#fff}
.btn--dark:hover{background:#000;border-color:#000}
.btn--ghost{background:#fff;color:#111}
.btn--ghost:hover{border-color:#cfcfcf}

/* Sections */
.section{padding:68px 0}
.section--center{text-align:center}
.section__label{
  letter-spacing:.32em;
  text-transform:uppercase;
  color:#9a9a9a;
  font-size:11px;
}
.section__title{
  font-size:44px;
  line-height:1.1;
  margin:18px 0 14px;
}
.section__lead{
  max-width:840px;
  margin:0 auto;
  color:#5a5a5a;
  line-height:1.6;
}
.section__lead--small{max-width:760px}

.divider{height:1px;background:var(--line);margin:54px 0 0}

/* Cards */
.grid{
  margin-top:34px;
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:18px;
}
.card{
  border-top:1px solid var(--line);
  padding-top:18px;
}
.card h3{margin:0 0 10px;font-size:18px;letter-spacing:.06em;text-transform:uppercase}
.card p{margin:0 0 12px;color:#5a5a5a;line-height:1.55}
.card ul{margin:0;padding-left:18px;color:#5a5a5a;line-height:1.65}

/* Projects */
.projects{
  margin-top:34px;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:18px;
}
.project{
  text-decoration:none;
  border-top:1px solid var(--line);
  padding-top:18px;
  display:block;
}
.project__img{
  height:170px;
  background-size:cover;
  background-position:center;
  filter:grayscale(1) contrast(1.06);
}
.project__img--a{background-image:url("../assets/project-a.png")}
.project__img--b{background-image:url("../assets/project-b.png")}
.project__img--c{background-image:url("../assets/project-c.png")}
.project__meta{padding-top:12px}
.project__kicker{letter-spacing:.32em;text-transform:uppercase;color:#9a9a9a;font-size:10px;margin-bottom:6px}
.project__name{font-size:16px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:6px}
.project__desc{color:#5a5a5a;line-height:1.55}

/* Steps */
.steps{margin-top:34px;border-top:1px solid var(--line)}
.step{display:flex;gap:18px;padding:18px 0;border-bottom:1px solid var(--line)}
.step__n{width:64px;letter-spacing:.32em;color:#9a9a9a;font-size:12px}
.step__b h3{margin:0 0 6px;font-size:18px;letter-spacing:.06em;text-transform:uppercase}
.step__b p{margin:0;color:#5a5a5a;line-height:1.6}

/* CTA */
.cta{padding:64px 0;background:#fafafa;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.cta__inner{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.cta__label{letter-spacing:.32em;text-transform:uppercase;color:#9a9a9a;font-size:11px}
.cta__title{margin:10px 0 8px;font-size:34px;line-height:1.15}
.cta__text{margin:0;color:#5a5a5a;line-height:1.6;max-width:560px}
.cta__actions{display:flex;gap:12px;flex-wrap:wrap}

/* Footer */
.footer{padding:48px 0 0}
.footer__inner{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:24px;
  padding-bottom:36px;
  justify-items:center;
  text-align:center;
}
.footer__label{letter-spacing:.32em;text-transform:uppercase;color:#9a9a9a;font-size:11px;margin-bottom:12px}
.footer__line{color:#5a5a5a;line-height:1.9}
.footer__link{display:block;text-decoration:none;color:#5a5a5a;line-height:1.9}
.footer__link:hover{color:#111}
.footer__bottom{border-top:1px solid var(--line);padding:14px 0}
.footer__bottomInner{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;color:#6b6b6b;font-size:12px}
.footer__small{letter-spacing:.02em}

/* Responsive */
@media (max-width: 900px){
  .hero{height:420px}
  .hero__title{font-size:42px}
  .section__title{font-size:36px}
  .projects{grid-template-columns:1fr}
  .grid{grid-template-columns:1fr}
  .footer__inner{grid-template-columns:1fr}
  nav{gap:12px}
  nav a{letter-spacing:.14em}
}
/* --- Hamburger menu (mobile) --- */
.nav__hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 36px;
  height: 36px;
  padding: 4px;
  background: none;
  border: none;
  cursor: pointer;
  z-index: 200;
}
.nav__hamburger span {
  display: block;
  height: 2px;
  width: 100%;
  background: var(--ink);
  border-radius: 2px;
  transition: transform .25s ease, opacity .2s ease;
  transform-origin: center;
}
/* Animação X ao abrir */
.nav__hamburger--open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav__hamburger--open span:nth-child(2) { opacity: 0; }
.nav__hamburger--open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

@media (max-width: 640px) {
  .nav { padding: 14px 18px; position: relative; flex-wrap: wrap; }
  .container { padding: 0 18px; }
  .hero__inner { padding: 56px 18px 0; }
  .hero__title { letter-spacing: .22em; }

  /* Esconde o nav horizontal e mostra o botão */
  nav {
    display: none;
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
    width: 100%;
    background: #fff;
    border-top: 1px solid var(--line);
    padding: 12px 0 16px;
    order: 10;
  }
  nav.nav--open { display: flex; }
  .nav__hamburger { display: flex; }

  nav a {
    width: 100%;
    padding: 11px 4px;
    font-size: 13px;
    letter-spacing: .14em;
    border-bottom: 1px solid var(--line);
  }
  nav a:last-child { border-bottom: none; }

  /* Reset TOTAL de order no mobile — força sequência do HTML */
  nav a                          { order: 0 !important; margin-left: 0 !important; }
  nav a[href*="#holdings" i]     { order: 1 !important; }
  nav a[href*="build" i]         { order: 2 !important; }
  nav a[href*="#development" i]  { order: 3 !important; }
  nav a[href*="contact" i]       { order: 4 !important; }
  nav a[href*="/login" i]        { order: 5 !important; }
  nav a[href*="/platform" i]     { order: 6 !important; }

  /* Remove estilo pill de LOGIN / PLATFORM no mobile */
  nav a[href*="/login" i],
  nav a[href*="/platform" i] {
    padding: 11px 4px;
    border-radius: 0;
    border: none;
    border-bottom: 1px solid var(--line);
    background: none;
    color: var(--muted);
  }
}

/* --- Additions from style.css (deduped) --- */
@media (max-width: 860px){
  .contact-form__grid{grid-template-columns:1fr}
}

/* STRVIA final CSS */ *{box-sizing:border-box}

header{position:sticky;top:0;background:#fff;z-index:100;}

.brand{font-weight:600;letter-spacing:.28em;font-size:14px}

nav a:hover{color:#111}

/* Right-side action buttons */ nav a[href*="/login" i], nav a[href*="/platform" i]{
  padding:10px 18px;
  border-radius:999px;
  letter-spacing:.14em;
  font-weight:500;
  border:1px solid #e6e6e6;
  color:#111;
  background:#fff;
}

/* Push the actions to the far right and order them like the mock: ... CONTACT | (spacer) | LOGIN | PLATFORM */ nav a[href*="/login" i]{margin-left:auto; order:98;}

/* Keep CONTACT with the left links even though it's placed after in the HTML */ nav a[href*="#contact" i]{order:10;}

nav a[href*="#holdings" i]{order:1;}

nav a[href*="#build" i]{order:2;}

nav a[href*="#development" i]{order:3;}

/* Button hovers */ nav a[href*="/login" i]:hover{border-color:#cfcfcf;}

.hero img{width:100%;height:100%;object-fit:cover;filter:grayscale(100%)}

.hero-title{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:56px;letter-spacing:.22em;font-weight:600}

.wrap{max-width:var(--max);margin:0 auto;padding:0 26px}

.section{padding:64px 0}

.kicker{text-align:center;color:#8a8a8a;font-size:12px;letter-spacing:.28em}

h1{text-align:center;font-weight:400;font-size:44px}

.lead{text-align:center;color:#7a7a7a;max-width:820px;margin:0 auto}

.rule{margin:64px auto;border:0;border-top:1px solid var(--hair)}

.two-col{display:grid;grid-template-columns:1fr 1fr;gap:54px}

.card-title{font-size:22px;letter-spacing:.20em;font-weight:600}

.thumb{height:170px;overflow:hidden}

.thumb img{width:100%;height:100%;object-fit:cover;filter:grayscale(100%)}

.subhead{margin:22px 0 6px;font-size:13px;letter-spacing:.16em;font-weight:600}

.desc{color:#7a7a7a}

.learn{text-decoration:none;font-size:12px;letter-spacing:.22em;color:#7a7a7a}

.contact{text-align:center;padding:54px 0;border-top:1px solid var(--hair)}

footer{text-align:center;font-size:11px;color:#aaa;padding:20px}

/* --- Contact form (Get in Touch) --- */ .contact-form{
  background:#fff;
  border:1px solid var(--hair);
  border-radius:14px;
  padding:22px;
  box-shadow:0 12px 30px rgba(0,0,0,.06);
}

.contact-form__head{margin-bottom:16px}

.contact-form__title{
  font-size:28px;
  font-weight:600;
  letter-spacing:.02em;
  margin:0 0 6px;
}

.contact-form__sub{
  color:var(--muted);
  font-size:13px;
  line-height:1.5;
}

.contact-form__grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}

.field{display:flex;flex-direction:column;gap:8px}

.field--full{grid-column:1 / -1}

.field label{
  font-size:12px;
  letter-spacing:.10em;
  text-transform:uppercase;
  color:#8a8a8a;
}

.field input, .field select, .field textarea{
  width:100%;
  padding:14px 14px;
  border:1px solid #ededed;
  border-radius:12px;
  background:#fff;
  color:var(--text);
  font-size:14px;
  outline:none;
}

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

.field input::placeholder, .field textarea::placeholder{color:#b3b3b3}

.field input:focus, .field select:focus, .field textarea:focus{
  border-color:#d3d3d3;
  box-shadow:0 0 0 4px rgba(17,17,17,.06);
}

.contact-form__btn{
  width:100%;
  height:52px;
  border-radius:12px;
  border:1px solid #111;
  background:#111;
  color:#fff;
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  cursor:pointer;
}

.contact-form__btn:hover{background:#000;border-color:#000}



/* --- Footer copyright bar (layout only, STRYVA DNA) --- */
.site-footer{margin-top:0}
.footer-bar{
  background:#0f141a;
  border-top:1px solid rgba(255,255,255,.06);
}
.footer-bar__inner{
  max-width:var(--max);
  margin:0 auto;
  padding:18px 26px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
}
.footer-bar__left{
  color:rgba(255,255,255,.68);
  font-size:13px;
  letter-spacing:.02em;
}
.footer-bar__right{
  display:flex;
  align-items:center;
  gap:12px;
}
.social{
  width:38px;
  height:38px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.28);
  color:rgba(255,255,255,.9);
  text-decoration:none;
}
.social svg{
  width:18px;
  height:18px;
  fill:currentColor;
}
.social:hover{
  border-color:rgba(255,255,255,.45);
  color:#fff;
}

@media (max-width: 640px){
  .footer-bar__inner{flex-direction:column;align-items:flex-start}
}

/* --- Certifications strip --- */
.certifications {
  border-top: 1px solid var(--line);
  padding: 28px 0 32px;
  background: #fff;
}
.certifications__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
}
.certifications__label {
  letter-spacing: .32em;
  text-transform: uppercase;
  color: #9a9a9a;
  font-size: 11px;
  text-align: center;
}
.certifications__logos {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 32px;
}
.cert-logo {
  object-fit: contain;
  opacity: 0.85;
  transition: opacity .2s;
}
.cert-logo:hover {
  opacity: 1;
}
/* LBP roundel — circular badge */
.cert-logo--lbp {
  height: 80px;
  width: auto;
  filter: grayscale(100%);
}
/* SiteWise — banner format */
.cert-logo--sitewise {
  height: 60px;
  width: auto;
}
@media (max-width: 640px) {
  .certifications__logos {
    gap: 20px;
  }
  .cert-logo--lbp  { height: 100px; }
  .cert-logo--sitewise { height: 100px; }
}
