/* =========================
   Lucas Camargo — Dark + Gold v3
   Tipografia: Inter + Playfair Display
   ========================= */

:root{
  --bg:#0b0e12;          /* fundo carvão */
  --surface:#12151b;     /* cartões/sections */
  --muted:#171b22;       /* superfícies suaves */
  --line:#2a2f3a;        /* linhas/divisórias */
  --text:#f5f2e9;        /* texto principal (off-white quente) */
  --subtle:#c8c3b6;      /* texto secundário */
  --accent:#d4af37;      /* ouro principal */
  --accent-2:#f3d98a;    /* ouro claro (hover/shine) */
  --accent-3:#a37e09;    /* ouro profundo (borda/sombra) */
  --wrap:1160px;
  --radius:16px;
  --shadow:0 16px 40px rgba(0,0,0,.35);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  background:var(--bg);
  color:var(--text);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

h1,h2,h3{margin:0 0 .5rem}
.serif{font-family:"Playfair Display", serif}
.lead{color:var(--subtle);max-width:72ch}
.kicker{letter-spacing:.18em;text-transform:uppercase;color:var(--subtle);font-size:11px}

/* Util */
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 20px}
.section{padding:72px 0}
.fade-up{opacity:0;transform:translateY(12px);transition:opacity .5s ease,transform .5s ease;transition-delay:var(--delay,0ms)}
.fade-up.inview{opacity:1;transform:translateY(0)}

/* Header */
.site-header{position:sticky;top:0;z-index:40;background:rgba(11,14,18,.72);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.site-header .wrap{display:flex;align-items:center;gap:16px;justify-content:space-between;padding:12px 20px}
.brand{display:flex;align-items:center;gap:12px;color:var(--text);text-decoration:none}
.logo{height:80px;width:auto;display:block}
.brand-text{display:flex;flex-direction:column;line-height:1.05}
.brand-text em{font-style:normal;font-size:12px;color:var(--subtle)}
.nav{display:flex;gap:18px}
.nav a{opacity:.95;padding:8px 10px;border-radius:10px;text-decoration:none;color:var(--text);border:1px solid transparent}
.nav a:hover{background:var(--muted);border-color:var(--line)}
.nav-toggle{display:none;background:transparent;border:1px solid var(--line);color:var(--text);padding:8px 10px;border-radius:10px}
.header-cta{margin-left:auto}
@media (max-width:820px){
  .nav{display:none}
  .nav.open{display:flex;position:absolute;right:16px;top:56px;flex-direction:column;gap:8px;padding:10px;background:var(--surface);border:1px solid var(--line);border-radius:12px}
  .nav-toggle{display:inline-block}
  .header-cta{display:none}
}

/* Botões */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 16px;border-radius:999px;border:1px solid var(--line);background:var(--muted);color:var(--text);font-weight:600;text-decoration:none;transition:transform .15s ease, box-shadow .2s ease, background .2s ease}
.btn:hover{transform:translateY(-1px)}
.btn.primary{background:linear-gradient(180deg,var(--accent),var(--accent-3));border-color:transparent;color:#0b0e12;box-shadow:0 6px 16px rgba(212,175,55,.35)}
.btn.primary:hover{background:linear-gradient(180deg,var(--accent-2),var(--accent))}
.btn.ghost{background:transparent;border:1px solid var(--accent);color:var(--accent)}
.btn.ghost:hover{box-shadow:0 4px 12px rgba(212,175,55,.25);background:rgba(212,175,55,.08)}
.btn.sm{padding:8px 12px;font-size:14px}

/* Hero */
.hero{position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;align-items:center;gap:36px}
.hero-title{font-size:clamp(38px,5.2vw,64px);font-weight:600;letter-spacing:-.02em}
.hero .lead{margin-top:12px}
.cta-row{display:flex;gap:10px;margin-top:18px;flex-wrap:wrap}
.chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.chip{padding:8px 12px;border-radius:999px;background:var(--muted);border:1px solid var(--line);font-size:14px;color:var(--subtle)}
.hero-portrait img{width:100%;max-width:520px;aspect-ratio:3/4;object-fit:cover;border-radius:16px;box-shadow:0 20px 60px rgba(212,175,55,.25)}
.hero-bg{position:absolute;inset:-40% -30% auto -30%;height:420px;z-index:-1;background:radial-gradient(600px 220px at 80% 10%, rgba(212,175,55,.08), transparent 60%), radial-gradient(600px 220px at 10% 0%, rgba(255,255,255,.06), transparent 60%)}
@media (max-width:1000px){.hero-grid{grid-template-columns:1fr;gap:28px}.hero-portrait{order:-1;justify-self:start}}

/* Section heads */
.section-hd h2{font-size:clamp(26px,3.2vw,40px);font-weight:600}
.section-hd p{margin:6px 0 0}
.section-head-row{display:flex;align-items:end;justify-content:space-between;gap:16px}

/* Cards info/serviços */
.about-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:14px}
@media (max-width:960px){.about-cards{grid-template-columns:1fr}}
.info-card{display:grid;grid-template-columns:auto 1fr;gap:12px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}
.info-icon{width:22px;height:22px}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:14px}
@media (max-width:960px){.services-grid{grid-template-columns:1fr}}
.service-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.service-card p{color:var(--subtle);margin-top:6px}

/* Portfólio / Projetos */
.filters{display:flex;gap:8px;flex-wrap:wrap}
.pill{border:1px solid var(--line);background:transparent;color:var(--text);padding:8px 12px;border-radius:999px;font-size:14px;cursor:pointer;transition:.2s ease}
.pill:hover{background:rgba(212,175,55,.08);border-color:var(--accent)}
.pill.is-active{background:var(--accent);color:#0b0e12;border-color:var(--accent)}
.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:18px}
@media (max-width:1040px){.projects-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.projects-grid{grid-template-columns:1fr}}
.project-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease}
.project-card:hover{transform:translateY(-2px);border-color:rgba(212,175,55,.35);box-shadow:var(--shadow), 0 0 0 1px rgba(212,175,55,.2) inset}
.project-card img{width:100%;display:block;aspect-ratio:16/10;object-fit:cover;filter:saturate(.95) contrast(1.02)}
.project-info{padding:14px}
.project-info h3{margin:0 0 4px;font-size:18px}
.project-info p{margin:0;color:var(--subtle);font-size:14px}

/* Depoimentos */
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media (max-width:960px){.testimonials-grid{grid-template-columns:1fr}}
.quote{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.quote cite{display:block;color:var(--subtle);font-size:14px;margin-top:10px}

/* FAQ */
.faq{margin-top:18px;display:grid;gap:10px}
.faq details{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:14px 16px}
.faq summary{cursor:pointer;list-style:none;font-weight:600;color:var(--text)}
.faq summary::-webkit-details-marker{display:none}
.faq details[open]{border-color:rgba(212,175,55,.35);box-shadow:0 0 0 1px rgba(212,175,55,.1) inset}
.faq p{margin:10px 0 0;color:var(--subtle)}

/* Contato */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:18px;margin-top:18px}
@media (max-width:960px){.contact-grid{grid-template-columns:1fr}}
.contact-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:18px}
.contact-list{margin:0;padding:0;list-style:none;display:grid;gap:10px}
.contact-form{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:18px;display:grid;gap:12px}
.contact-form label{display:grid;gap:6px;font-size:14px;color:var(--subtle)}
.contact-form input,.contact-form textarea{background:var(--muted);border:1px solid var(--line);color:var(--text);padding:12px;border-radius:12px}
.contact-form input:focus,.contact-form textarea:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:transparent}
/* ===== Form Actions — grid para alinhar consentimentos e botão ===== */
.form-actions{
  display:grid;
  grid-template-columns: 1fr auto; /* consentimentos à esquerda, botão à direita */
  column-gap:16px;
  row-gap:8px;
  align-items:start;
}

/* botões dentro do grupo ficam à direita, alinhados ao topo e ocupam a altura dos dois checks */
.form-actions .btn{
  grid-column:2;
  grid-row:1 / span 2;
  align-self:start;
}

/* status do formulário sempre em uma linha inteira abaixo */
.form-actions .form-status{
  grid-column:1 / -1;
}
/* ===== Checkbox estilizado no tema ===== */
.checkbox{
  grid-column:1;
  display:flex;
  align-items:flex-start;
  gap:10px;
  color:var(--subtle);
  font-size:14px;
  line-height:1.5;
  margin:0; /* garante alinhamento com grid */
}

/* deixa o quadradinho maior, alinhado com o texto e no dourado do tema */
.checkbox input[type="checkbox"]{
  width:18px;
  height:18px;
  margin-top:2px;        /* alinha com a primeira linha do texto */
  accent-color:var(--accent);
  border-radius:4px;
}

/* links dentro do texto do consentimento no padrão do site */
.checkbox a{
  color:var(--accent);
  text-decoration:underline;
}
.checkbox a:hover{
  color:var(--accent-2);
  text-decoration:none;
}
/* ===== Mobile: empilhar tudo e botão abaixo ===== */
@media (max-width:640px){
  .form-actions{
    grid-template-columns:1fr;
  }
  .form-actions .btn{
    grid-column:1;
    grid-row:auto;
    justify-self:start; /* mantém alinhado à esquerda */
  }
}

.form-status{font-size:14px;color:var(--subtle)}
.form-status.ok{color:#10b981}

/* Footer */
.site-footer{border-top:1px solid var(--line);padding:22px 20px;background:linear-gradient(180deg,rgba(212,175,55,.06),rgba(0,0,0,.25))}
.site-footer a{color:var(--accent);text-decoration:none}
.site-footer a:hover{color:var(--accent-2)}

/* WhatsApp flutuante */
.whatsapp-float{position:fixed;right:20px;bottom:20px;width:56px;height:56px;border-radius:50%;background:linear-gradient(180deg,var(--accent-2),var(--accent));display:grid;place-items:center;box-shadow:0 12px 28px rgba(212,175,55,.45);border:1px solid rgba(212,175,55,.55);z-index:30}
.whatsapp-float svg{width:28px;height:28px;fill:#0b0e12}
.whatsapp-float:hover{transform:translateY(-1px);box-shadow:0 14px 32px rgba(212,175,55,.55)}

/* Modal */
.modal{position:fixed;inset:0;display:grid;place-items:end;z-index:60;transition:.2s ease;pointer-events:none;opacity:0}
.modal[aria-hidden="false"]{opacity:1;pointer-events:auto}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.45);backdrop-filter:blur(3px)}
.modal-dialog{position:relative;width:min(1100px,92vw);background:var(--surface);color:var(--text);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:22px 22px 0 0;padding:16px;max-height:88vh;overflow:auto}
@media (min-width:760px){.modal{place-items:center}.modal-dialog{border-radius:22px}}
.modal-head{display:grid;grid-template-columns:1fr auto;align-items:start;gap:10px}
.modal-title{font-size:clamp(22px,3vw,32px);font-weight:600}
.modal-kicker{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--subtle)}
.modal-blurb{color:var(--subtle);margin:10px 0 6px}
modal-gallery {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 14px;
}
.modal-gallery img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 14px;
  object-fit: cover;
}
@media (min-width:760px){.modal-gallery{grid-template-columns:repeat(2,1fr)}}
.gallery-ph {
  background: linear-gradient(135deg, #12161c, #0b0e12);
  border: 1px solid #232a33;
  border-radius: 14px;
  min-height: 180px;
}
@media (max-width: 720px) {
  .modal-gallery { grid-template-columns: 1fr; }
}
.modal-specs{display:grid;grid-template-columns:1fr;gap:12px;margin-top:10px}
@media (min-width:760px){.modal-specs{grid-template-columns:repeat(3,1fr)}}
.spec{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:14px}
.spec-label{display:block;font-size:12px;color:var(--subtle);margin-bottom:4px}
/* ===== Cabeçalho — polimento mobile ===== */
@media (max-width: 820px){
  .site-header{
    background: rgba(11,14,18,.9);
    border-bottom-color: #1a1f28;
  }
  .site-header .wrap{
    padding: 10px 14px;
    gap: 10px;
  }
  .logo{ height: 44px }                 /* era 80px */
  .brand-text{ line-height: 1 }
  .brand-text em{ display: none }       /* remove “Arquitetura & Interiores” no mobile */
  .nav-toggle{
    width: 40px; height: 40px; padding: 0;
    border-radius: 12px;
    border-color: rgba(212,175,55,.35);
    background: rgba(212,175,55,.06);
    box-shadow: 0 4px 14px rgba(212,175,55,.15);
  }
  .nav.open{
    right: 14px; top: 60px;
    border-radius: 14px;
    box-shadow: 0 16px 40px rgba(0,0,0,.45);
  }
  .header-cta{ display: none }          /* some o “Vamos conversar” no topo do mobile */
}

/* (Opcional) Em telas intermediárias, mostrar uma versão compacta do CTA no topo */
@media (min-width: 560px) and (max-width: 820px){
  .header-cta{ display: inline-flex; }
  .header-cta.btn.primary{
    padding: 8px 12px; font-size: 14px; border-radius: 12px;
    box-shadow: 0 6px 16px rgba(212,175,55,.25);
  }
}
/* === HERO: encurtar a seção e cropar o retrato === */
.hero { padding-block: clamp(32px, 6vh, 72px); }

.hero .wrap { max-width: 1120px; }

/* grade centrada e compacta */
.hero-grid {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  align-items: center;
  gap: clamp(24px, 4vw, 40px);
}

/* “moldura” que define a altura e corta o excesso da foto */
.hero-portrait{
  block-size: clamp(380px, 62vh, 620px); /* << controla a altura do retrato */
  aspect-ratio: 3 / 4;
  overflow: hidden;
  border-radius: 16px;
  box-shadow: 0 10px 40px #00000033;
}

/* a imagem ocupa toda a moldura, sem distorção */
.hero-portrait img{
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
  object-position: 50% 35%; /* ajuste fino do enquadramento aqui */
}

/* Mobile: ainda mais curto e com pilha vertical */
@media (max-width: 900px){
  .hero-grid{ grid-template-columns: 1fr; }
  .hero-portrait{
    order: -1; /* foto acima do texto; remova se preferir abaixo */
    block-size: clamp(260px, 46vh, 420px);
    aspect-ratio: 4 / 5;
  }
}
