:root{
  --beige:#bd9e64;
  --black:#1a1a1a;
  --bg:#f6f2ea;
  --card:#ffffff;
  --text:#1a1a1a;
  --muted:rgba(26,26,26,.72);
  --line:rgba(26,26,26,.14);
  --shadow:0 10px 30px rgba(26,26,26,.12);

  --title-font:"Cinzel Decorative", serif;
  --body-font:"Livvic", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;

  --radius:18px;
  --radius2:26px;
}

/* Tema escuro */
[data-theme="dark"]{
  --bg:#0f0f0f;
  --card:#151515;
  --text:#f5f0e6;
  --muted:rgba(245,240,230,.72);
  --line:rgba(245,240,230,.14);
  --shadow:0 12px 34px rgba(0,0,0,.35);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }

body{
  margin:0;
  font-family:var(--body-font);
  color:var(--text);
  background:var(--bg);
}

a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }

.container{
  width:min(1100px, 92%);
  margin-inline:auto;
}

.skip{
  position:absolute;
  left:-999px;
  top:0;
  background:var(--beige);
  color:var(--black);
  padding:10px 12px;
  border-radius:10px;
  z-index:50;
}
.skip:focus{
  left:12px;
  top:12px;
}

/* HEADER */
.topbar{
  position:sticky;
  top:0;
  z-index:40;
  background:color-mix(in srgb, var(--bg) 88%, transparent);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}

.topbar__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 0;
  gap:14px;
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:240px;
}

.brand__logo{
  width:44px;
  height:44px;
  object-fit:contain;
  border-radius:12px;
  background:color-mix(in srgb, var(--card) 85%, transparent);
  border:1px solid var(--line);
  padding:6px;
}

.brand__text{
  display:flex;
  flex-direction:column;
  line-height:1.1;
}

.brand__name{
  font-family:var(--title-font);
  font-weight:700;
  letter-spacing:.3px;
}

.brand__role{
  font-size:12px;
  color:var(--muted);
  margin-top:3px;
}

.nav{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.nav a{
  font-size:13px;
  color:var(--muted);
}

.nav a:hover{
  color:var(--text);
}

.actions{
  display:flex;
  gap:10px;
  align-items:center;
}

/* BOTÕES */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid var(--line);
  background:transparent;
  font-weight:600;
  font-size:14px;
  cursor:pointer;
  transition:transform .18s ease, background .18s ease, border-color .18s ease, color .18s ease, box-shadow .18s ease;
}

.btn:hover{
  transform:translateY(-1px);
}

.btn--primary{
  background:var(--beige);
  border-color:color-mix(in srgb, var(--beige) 60%, var(--line));
  color:var(--black);
}

.btn--outline{
  background:transparent;
  border-color:color-mix(in srgb, var(--beige) 45%, var(--line));
}

.btn--ghost{
  width:42px;
  height:42px;
  padding:0;
  border-radius:999px;
}

.icon{
  font-size:16px;
}

/* HERO */
.hero{
  position:relative;
  padding:64px 0 30px;
  overflow:hidden;
}

.hero__bg{
  position:absolute;
  inset:-200px -200px auto auto;
  width:520px;
  height:520px;
  background:radial-gradient(circle at 30% 30%, color-mix(in srgb, var(--beige) 55%, transparent), transparent 60%);
  pointer-events:none;
}

.hero__grid{
  display:grid;
  gap:22px;
}

.kicker{
  display:inline-block;
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted);
  border-left:3px solid var(--beige);
  padding-left:10px;
  margin-bottom:14px;
}

.title{
  font-family:var(--title-font);
  font-size:38px;
  line-height:1.08;
  margin:0 0 12px;
}

.subtitle{
  margin:0 0 18px;
  color:var(--muted);
  max-width:58ch;
}

.hero__cta{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.hero__badges{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:16px;
}

.badge{
  border:1px solid var(--line);
  background:color-mix(in srgb, var(--card) 70%, transparent);
  padding:8px 10px;
  border-radius:999px;
  font-size:13px;
  color:var(--muted);
}

/* CARDS */
.card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius2);
  box-shadow:var(--shadow);
  padding:18px;
}

.card__title{
  font-family:var(--title-font);
  margin:0 0 10px;
  font-size:18px;
}

.list{
  margin:0;
  padding-left:18px;
  color:var(--muted);
  line-height:1.7;
}

.card__meta{
  margin-top:14px;
  display:grid;
  gap:10px;
}

.meta{
  display:flex;
  flex-direction:column;
}

.meta__label{
  font-size:12px;
  color:var(--muted);
}

.meta__value{
  font-weight:700;
}

/* SECTIONS */
.section{
  padding:56px 0;
}

.section--alt{
  background:color-mix(in srgb, var(--card) 55%, transparent);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}

.section__head{
  margin-bottom:18px;
}

.section__title{
  font-family:var(--title-font);
  font-size:28px;
  margin:0 0 8px;
}

.section__desc{
  margin:0;
  color:var(--muted);
  max-width:80ch;
}

/* CLIENTES */
.client-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
}

.client-card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius2);
  box-shadow:var(--shadow);
  padding:16px;
  display:flex;
  align-items:center;
  gap:14px;
  transition:transform .18s ease, border-color .18s ease;
}

.client-card:hover{
  transform:translateY(-2px);
  border-color:color-mix(in srgb, var(--beige) 45%, var(--line));
}

.client-card__logo{
  width:70px;
  height:70px;
  border-radius:18px;
  border:1px solid var(--line);
  background:color-mix(in srgb, var(--card) 80%, transparent);
  overflow:hidden;
  flex:0 0 auto;
  display:grid;
  place-items:center;
  position:relative;
}

.client-card__logo img{
  width:100%;
  height:100%;
  object-fit:cover;
  padding:0;
  display:block;
}

.client-card__logo-fallback{
  display:none;
  font-size:12px;
  color:var(--muted);
  font-weight:800;
}

.client-card__logo.no-image .client-card__logo-fallback{
  display:block;
}

.client-card__name{
  font-family:var(--title-font);
  font-weight:700;
  letter-spacing:.2px;
  font-size:18px;
}

/* CONTEÚDO DO CLIENTE */
.grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(260px, 1fr));
  gap:24px;
  align-items:start;
}

.work{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius2);
  overflow:hidden;
  box-shadow:var(--shadow);
}

.work__media{
  background:transparent;
  padding:0;
}

.work__media img{
  width:100%;
  height:auto;
  display:block;
  object-fit:contain;
  border-radius:22px;
}

.work__body{
  padding:16px;
}

.work__title{
  margin:0 0 8px;
  font-size:18px;
  font-family:var(--title-font);
}

.work__text{
  margin:0 0 12px;
  color:var(--muted);
}

.work__tags{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:10px;
}

.pill{
  font-size:12px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--line);
  color:var(--muted);
}

.ratio{
  margin-top:10px;
  position:relative;
  width:100%;
  padding-top:56.25%;
  border-radius:14px;
  overflow:hidden;
  border:1px solid var(--line);
}

.ratio--short{
  padding-top:177.77%;
}

.ratio iframe{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
}

.portfolio-more{
  margin-top:18px;
  display:flex;
  justify-content:center;
}

/* PORTFÓLIO PRIVADO */
.private-portfolio{
  margin-top:18px;
}

.private-portfolio__card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius2);
  box-shadow:var(--shadow);
  padding:18px;
}

.private-portfolio__title{
  margin:0 0 8px;
  font-family:var(--title-font);
}

.private-portfolio__text{
  margin:0 0 14px;
  color:var(--muted);
}

/* HEADER DO CLIENTE */
.client-header{
  display:grid;
  gap:14px;
  align-items:start;
  margin-bottom:14px;
}

.client-header__logo{
  width:72px;
  height:72px;
  border-radius:18px;
  border:1px solid var(--line);
  background:color-mix(in srgb, var(--card) 80%, transparent);
  overflow:hidden;
  display:grid;
  place-items:center;
}

.client-header__logo img{
  width:100%;
  height:100%;
  object-fit:cover;
}

/* ABAS / CATEGORIAS */
.folder-nav{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:10px 0 0;
}

.folder-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid var(--line);
  background:color-mix(in srgb, var(--card) 70%, transparent);
  color:var(--text);
  font-weight:700;
  transition:transform .18s ease, border-color .18s ease, background .18s ease, color .18s ease, box-shadow .18s ease;
}

.folder-btn:hover{
  transform:translateY(-1px);
  border-color:color-mix(in srgb, var(--beige) 45%, var(--line));
}

.folder-btn.is-active{
  background:var(--beige);
  color:var(--black);
  border-color:color-mix(in srgb, var(--beige) 60%, var(--line));
  box-shadow:0 8px 20px rgba(0,0,0,.18);
}

.folder-btn.is-active:hover{
  transform:none;
}

.folder-title{
  font-family:var(--title-font);
  font-size:20px;
  margin:22px 0 12px;
  scroll-margin-top:90px;
}

/* SOBRE */
.about{
  display:grid;
  gap:18px;
}

.about__highlights{
  margin-top:14px;
  display:grid;
  gap:12px;
}

.mini{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:14px;
}

.mini h3{
  margin:0 0 6px;
  font-family:var(--title-font);
  font-size:16px;
}

.mini p{
  margin:0;
  color:var(--muted);
}

.about__photo{
  position:relative;
  border-radius:var(--radius2);
  overflow:hidden;
  border:1px solid var(--line);
  background:var(--card);
  min-height:260px;
}

.about__photo img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.about__placeholder{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--muted);
  font-weight:700;
}

/* CONTATO */
.contact{
  display:grid;
  gap:14px;
}

.contact__card,
.contact__note{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius2);
  box-shadow:var(--shadow);
  padding:16px;
}

.contact__card h3,
.contact__note h3{
  margin:0 0 6px;
  font-family:var(--title-font);
}

.muted{
  margin:0 0 12px;
  color:var(--muted);
}

.contact__buttons{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

/* FOOTER */
.footer{
  border-top:1px solid var(--line);
  padding:22px 0;
}

.footer__inner{
  display:flex;
  flex-direction:column;
  gap:10px;
  color:var(--muted);
  font-size:14px;
}

.footer__links{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
}

.footer__links a:hover{
  color:var(--text);
}

/* FAB */
.fab{
  position:fixed;
  right:16px;
  bottom:16px;
  z-index:60;
  background:var(--beige);
  color:var(--black);
  padding:12px 14px;
  border-radius:999px;
  border:1px solid color-mix(in srgb, var(--beige) 60%, var(--line));
  box-shadow:var(--shadow);
  font-weight:800;
}

/* ANIMAÇÕES */
.reveal{
  opacity:0;
  transform:translateY(14px);
  transition:opacity .55s ease, transform .55s ease;
}

.reveal.is-visible{
  opacity:1;
  transform:none;
}

/* MASONRY (somente quando a classe é adicionada pelo JS) */
.grid.masonry{
  display:block;
  columns:3 260px;
  column-gap:16px;
}

.grid.masonry .work{
  break-inside:avoid;
  -webkit-column-break-inside:avoid;
  page-break-inside:avoid;
  display:block;
  width:100%;
  margin:0 0 16px;
}

.grid.masonry .work__media{
  padding:0;
  background:transparent;
}

.grid.masonry .work__media img{
  width:100%;
  height:auto;
  display:block;
  object-fit:contain;
  border-radius:22px;
}

/* PAGER */
.section-pager .btn{
  background:color-mix(in srgb, var(--card) 85%, transparent);
  color:var(--text);
  border-color:color-mix(in srgb, var(--beige) 45%, var(--line));
}

.section-pager .btn:hover{
  background:color-mix(in srgb, var(--beige) 18%, var(--card));
}

/* VÍDEO LOCAL */
.work--video .work__media{
  padding:0;
  background:transparent;
}

.work--video video{
  width:100%;
  height:auto;
  display:block;
  border-radius:22px;
  background:#000;
}

/* EMBEDS LIMPOS */
.work--embed{
  background:transparent;
  border:none;
  box-shadow:none;
}

.work--embed .work__media{
  padding:0;
  background:transparent;
}

.work--embed .instagram-media{
  min-width:100% !important;
  max-width:100% !important;
  margin:0 !important;
  border-radius:22px !important;
  overflow:hidden !important;
}

.work--embed .ratio{
  margin-top:0;
  border:none;
  border-radius:22px;
  overflow:hidden;
}

/* MOBILE */
@media (max-width: 859px){
  .topbar__inner{
    flex-wrap:wrap;
    align-items:flex-start;
  }

  .brand{
    min-width:auto;
    flex:1 1 auto;
  }

  .actions{
    margin-left:auto;
    flex:0 0 auto;
  }

  .nav{
    width:100%;
    order:3;
    justify-content:flex-start;
    margin-top:8px;
    gap:8px;
  }

  .nav a{
    font-size:13px;
  }
}

/* DESKTOP */
@media (min-width: 860px){
  .nav{
    gap:18px;
  }

  .hero__grid{
    grid-template-columns:1.2fr .8fr;
    align-items:start;
  }

  .client-grid{
    grid-template-columns:repeat(3, 1fr);
  }

  .client-card{
    flex-direction:column;
    align-items:flex-start;
    padding:18px;
    min-height:160px;
  }

  .client-card__logo{
    width:80px;
    height:80px;
  }

  .grid{
    grid-template-columns:repeat(3, 1fr);
  }

  .grid.masonry{
    display:block;
    columns:3 260px;
  }

  .about{
    grid-template-columns:1.15fr .85fr;
    align-items:start;
  }

  .contact{
    grid-template-columns:1.2fr .8fr;
  }

  .footer__inner{
    flex-direction:row;
    justify-content:space-between;
    align-items:center;
  }

  .client-header{
    grid-template-columns:90px 1fr;
    align-items:center;
  }
}
/* HEADER MAIS COMPACTO NO MOBILE */
@media (max-width: 600px){

  .topbar__inner{
    padding:10px 0; /* antes ~14px */
    gap:8px;
  }

  .brand{
    gap:8px;
  }

  .brand__logo{
    width:36px;
    height:36px;
  }

  .brand__name{
    font-size:14px;
  }

  .brand__role{
    font-size:10px;
  }

  .actions{
    gap:6px;
  }

  .btn--primary{
    padding:8px 12px;
    font-size:13px;
  }

  .btn--ghost{
    width:36px;
    height:36px;
  }

  .nav{
    margin-top:4px;
    gap:6px;
  }

  .nav a{
    font-size:12px;
  }
}