/*
Theme Name: Galeria de Arte
Theme URI: https://example.com
Description: Tema minimalista para galeria de arte contemporanea
Version: 6.0
Author: Lovable
Text Domain: galeria-arte
*/

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&display=swap');

:root {
  --color-bg: #ffffff;
  --color-fg: #111111;
  --color-muted: #5f5f5f;
  --color-border: rgba(17,17,17,.12);
  --color-soft: #f3efe8;
  --font-display: 'Plus Jakarta Sans', sans-serif;
  --font-body: 'Plus Jakarta Sans', sans-serif;
}

* { margin:0; padding:0; box-sizing:border-box; }

html { scroll-behavior:smooth; }

body {
  font-family:var(--font-body);
  color:var(--color-fg);
  background:var(--color-bg);
  -webkit-font-smoothing:antialiased;
  letter-spacing:-.01em;
}

body.menu-open,
body.search-open {
  overflow:hidden;
}

img { max-width:100%; height:auto; display:block; }
a { color:inherit; text-decoration:none; }
button, input, textarea, select { font:inherit; }

.site-header {
  position:fixed;
  inset:0 0 auto;
  z-index:100;
  padding:1rem 1.2rem;
  transition:background .35s ease, box-shadow .35s ease, backdrop-filter .35s ease;
}

.site-header.scrolled {
  background:rgba(255,255,255,.88);
  box-shadow:0 1px 0 var(--color-border);
  backdrop-filter:blur(14px);
}

.site-header__inner,
.site-header__right,
.site-header__left {
  display:flex;
  align-items:center;
}

.site-header__inner {
  justify-content:space-between;
  gap:1rem;
}

.logo span {
  display:inline-block;
  font-family:var(--font-display);
  font-size:.9rem;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
}

.site-header__right {
  gap:.75rem;
}

.header-search,
.menu-toggle {
  min-height:2.8rem;
  border:1px solid rgba(17,17,17,.18);
  border-radius:999px;
  background:rgba(255,255,255,.84);
}

.header-search {
  width:2.8rem;
  display:flex;
  align-items:center;
  overflow:hidden;
  transition:width .35s ease, background .35s ease, border-color .35s ease;
}

.header-search.active,
.header-search:focus-within {
  width:min(22rem, 50vw);
  background:#fff;
  border-color:rgba(17,17,17,.35);
}

.header-search__toggle,
.menu-toggle {
  cursor:pointer;
  background:transparent;
  border:none;
  color:var(--color-fg);
}

.header-search__toggle {
  width:2.8rem;
  min-height:2.8rem;
}

.menu-toggle {
  padding:0 1rem;
  font-size:.72rem;
  font-weight:700;
  letter-spacing:.16em;
  text-transform:uppercase;
}

.search-icon {
  display:block;
  width:.78rem;
  height:.78rem;
  margin:0 auto;
  border:1.5px solid currentColor;
  border-radius:50%;
  position:relative;
}

.search-icon::after {
  content:'';
  position:absolute;
  width:.42rem;
  height:1.5px;
  background:currentColor;
  right:-.25rem;
  bottom:-.08rem;
  transform:rotate(45deg);
}

.header-search__form {
  flex:1;
}

.header-search__form input {
  width:100%;
  border:none;
  background:transparent;
  outline:none;
  padding-right:1rem;
  font-size:.76rem;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.fullscreen-menu {
  position:fixed;
  inset:0;
  z-index:200;
  background:#ffffff;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:opacity .3s ease, visibility .3s ease;
}

.fullscreen-menu.open {
  opacity:1;
  visibility:visible;
  pointer-events:auto;
}

.fullscreen-menu__inner {
  min-height:100%;
  padding:1.2rem;
  display:flex;
  flex-direction:column;
}

.fullscreen-menu__top {
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding-bottom:1rem;
}

.fullscreen-menu__eyebrow,
.fullscreen-menu__preview-label,
.search-overlay__top {
  font-size:.72rem;
  font-weight:700;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--color-muted);
}

.close-btn {
  background:none;
  border:none;
  cursor:pointer;
  font-size:.72rem;
  font-weight:700;
  letter-spacing:.16em;
  text-transform:uppercase;
}

.fullscreen-menu__content {
  flex:1;
  display:grid;
  grid-template-columns:minmax(18rem,1fr) minmax(18rem,42vw);
  gap:2rem;
  align-items:stretch;
}

.fullscreen-menu__list {
  list-style:none;
  display:flex;
  flex-direction:column;
  justify-content:center;
  min-height:100%;
}

.fullscreen-menu__nav nav,
.fullscreen-menu__nav ul,
.fullscreen-menu__nav li {
  list-style:none;
  margin:0;
  padding:0;
}

.fullscreen-menu__item {
  border-top:1px solid var(--color-border);
}

.fullscreen-menu__item:last-child {
  border-bottom:1px solid var(--color-border);
}

.fullscreen-menu__item a {
  display:flex;
  align-items:center;
  min-height:4.8rem;
  font-family:var(--font-display);
  font-size:clamp(1.6rem, 3.6vw, 3.65rem);
  font-weight:800;
  letter-spacing:-.04em;
  text-transform:uppercase;
  color:#111111 !important;
  opacity:1 !important;
  transition:padding-left .25s ease, opacity .25s ease;
}

.fullscreen-menu__nav,
.fullscreen-menu__item,
.fullscreen-menu__item a {
  position:relative;
  z-index:3;
}

.fullscreen-menu__item.active a,
.fullscreen-menu__item a:hover {
  padding-left:.6rem;
}

.fullscreen-menu__preview {
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  gap:1rem;
}

.fullscreen-menu__preview-frame {
  width:100%;
  height:min(68vh, 44rem);
  overflow:hidden;
  background:var(--color-soft);
}

.fullscreen-menu__preview-frame img {
  width:100%;
  height:100%;
  object-fit:cover;
  opacity:0;
  transform:scale(1.04);
  transition:opacity .35s ease, transform .45s ease;
}

.fullscreen-menu__preview-frame img.is-visible {
  opacity:1;
  transform:scale(1);
}

.search-overlay {
  position:fixed;
  inset:0;
  z-index:250;
  display:none;
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(16px);
  padding:5.5rem 1.2rem 2rem;
}

.search-overlay.open {
  display:flex;
}

.search-overlay__inner {
  width:min(56rem, 100%);
}

.search-overlay__top {
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:.75rem;
}

.close-search {
  background:none;
  border:none;
  font-size:1.7rem;
  cursor:pointer;
}

.search-results {
  margin-top:1.5rem;
}

.search-results a {
  display:block;
  padding:1rem 0;
  border-bottom:1px solid var(--color-border);
  font-family:var(--font-display);
  font-size:1rem;
  font-weight:700;
  text-transform:uppercase;
}

.hero-slider {
  position:relative;
  width:100%;
  height:100svh;
  min-height:42rem;
  overflow:hidden;
  background:#000;
}

.hero-stage {
  position:relative;
  width:100%;
  background:#000;
}

.hero-slide {
  position:absolute;
  inset:0;
  transform:translateX(100%);
  opacity:1;
  transition:transform .8s cubic-bezier(.2,.7,0,1);
  z-index:1;
  will-change:transform;
}

.hero-slide.active {
  transform:translateX(0);
  z-index:3;
}

.hero-slide.prev {
  transform:translateX(-100%);
  z-index:2;
}

.hero-slide.next {
  transform:translateX(100%);
  z-index:1;
}

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

.hero-slide .overlay {
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.08) 0%, rgba(0,0,0,.38) 58%, rgba(0,0,0,.7) 100%);
}

.hero-caption {
  position:absolute;
  left:1.4vw;
  right:1.4vw;
  bottom:2.2vw;
  z-index:10;
  color:#fff;
  max-width:66%;
}

.hero-caption-meta {
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:1rem;
  margin-bottom:1rem;
}

.hero-caption .label,
.hero-caption .date {
  font-size:.72rem;
  letter-spacing:.16em;
  text-transform:uppercase;
}

.hero-caption .label { font-weight:700; opacity:.85; }
.hero-caption .date { opacity:.7; }

.highlights-swiper .info {
  position:absolute;
  left:1.4vw;
  bottom:2.2vw;
  width:auto;
  max-width:66%;
  z-index:1;
  transform:translate3d(0, 2em, 0);
  opacity:0;
}

.highlights-swiper .highlight-item.active + .overlay,
.highlights-swiper .highlight-item.active {
  z-index:3;
}

.highlights-swiper .info.active {
  animation-name:slide_up;
  animation-duration:.4s;
  animation-iteration-count:1;
  animation-fill-mode:forwards;
  animation-timing-function:cubic-bezier(.1,.1,0,1);
  pointer-events:none;
}

.hero-caption h1 {
  font-family:var(--font-display);
  font-size:clamp(2.6rem, 6vw, 5.8rem);
  font-weight:800;
  text-transform:uppercase;
  line-height:.95;
  letter-spacing:-.05em;
}

.hero-caption .cta,
.article-button {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:2.9rem;
  margin-top:1.35rem;
  padding:0 1.15rem;
  border:1px solid currentColor;
  border-radius:999px;
  font-size:.72rem;
  font-weight:700;
  letter-spacing:.16em;
  text-transform:uppercase;
  transition:background .25s ease, color .25s ease, border-color .25s ease;
}

.hero-caption .cta:hover,
.article-button:hover {
  background:var(--color-fg);
  color:#fff;
}

.hero-indicators {
  position:absolute;
  right:1.2rem;
  bottom:1.4rem;
  z-index:10;
  display:flex;
  gap:.4rem;
}

.hero-indicators button {
  width:2rem;
  height:2px;
  border:none;
  background:rgba(255,255,255,.28);
  cursor:pointer;
}

.hero-indicators button.active {
  background:#fff;
}

@keyframes slide_up {
  0% {
    transform:translate3d(0, 2em, 0);
    opacity:0;
  }
  100% {
    transform:translate3d(0, 0, 0);
    opacity:1;
  }
}


.home-intro-strip {
  display:grid;
  grid-template-columns:minmax(0, 1fr);
  gap:1.5rem;
  align-items:start;
  padding:2.75rem 1.2rem 3.5rem;
  border-bottom:1px solid var(--color-border);
  background:#fff;
}

.home-intro-strip__eyebrow {
  margin-bottom:1rem;
  font-size:.76rem;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
}

.home-intro-strip h2 {
  width:100%;
  max-width:none;
  font-family:var(--font-display);
  font-size:clamp(3.6rem, 10vw, 10rem);
  font-weight:800;
  line-height:.88;
  letter-spacing:-.08em;
  text-transform:uppercase;
  color:#111;
  text-wrap:balance;
  word-break:normal;
}

.home-intro-strip p {
  margin-top:.5rem;
  max-width:68rem;
  font-size:clamp(1rem, 2vw, 1.4rem);
  line-height:1.6;
  color:var(--color-muted);
}

.news-section,
.home-works-section,
.artist-grid,
.expo-grid,
.feira-grid,
.vr-grid,
.editorial-grid,
.publication-grid,
.sobre-content,
.article-shell,
.archive-intro,
.publication-single,
.filter-bar {
  padding-left:1.2rem;
  padding-right:1.2rem;
}

.news-section,
.home-works-section { padding-top:4rem; padding-bottom:4rem; }

.news-section .section-header {
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:2rem;
}

.section-title {
  font-family:var(--font-display);
  font-size:1.4rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.06em;
}

.header-link {
  background:none;
  border:none;
  cursor:pointer;
  font-size:.76rem;
  letter-spacing:.16em;
  text-transform:uppercase;
}

.home-news-grid,
.home-works-grid {
  display:grid !important;
  grid-template-columns:repeat(3, minmax(0, 1fr)) !important;
  gap:2rem;
  align-items:start;
}

.news-card {
  border-bottom:1px solid var(--color-border);
  padding-bottom:.5rem;
}

.news-card img {
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  margin-bottom:1rem;
}

.news-card__image {
  display:block;
}

.news-card h3 a {
  color:inherit;
}

.news-card .date,
.card-item .meta,
.editorial-card .meta,
.publication-card .meta,
.publication-copy .meta {
  font-size:.72rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--color-muted);
}

.news-card h3,
.card-item h3,
.editorial-card h2,
.publication-card h2,
.publication-copy h2 {
  font-family:var(--font-display);
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:-.03em;
}

.news-card h3,
.editorial-card h2,
.publication-card h2 {
  margin-top:.65rem;
  font-size:1.05rem;
  line-height:1.3;
}

.home-work-card img {
  width:100%;
  aspect-ratio:4/5;
  object-fit:cover;
  background:var(--color-soft);
}

.home-work-card,
.news-card {
  min-width:0;
}

.home-work-card {
  min-width:0;
}

.home-work-card h3 {
  margin-top:.65rem;
  font-family:var(--font-display);
  font-size:1.05rem;
  font-weight:800;
  letter-spacing:-.03em;
  text-transform:uppercase;
}

.home-work-card .meta {
  margin-top:.85rem;
  font-size:.72rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--color-muted);
}

.home-work-card .summary {
  margin-top:.45rem;
  color:var(--color-muted);
  line-height:1.65;
}

.page-hero {
  position:relative;
  min-height:22rem;
  height:50vh;
  display:flex;
  align-items:flex-end;
  padding:3rem 1.2rem;
  background-size:cover;
  background-position:center;
}

.page-hero::after {
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(transparent 32%, rgba(0,0,0,.55));
}

.page-hero h1 {
  position:relative;
  z-index:2;
  font-family:var(--font-display);
  font-size:clamp(2.4rem, 5.4vw, 5.2rem);
  font-weight:800;
  line-height:.95;
  letter-spacing:-.05em;
  text-transform:uppercase;
  color:#fff;
}

.artist-grid,
.expo-grid,
.feira-grid,
.vr-grid,
.editorial-grid,
.publication-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(18rem,1fr));
  gap:2rem;
  padding-top:4rem;
  padding-bottom:4rem;
}

.card-item img,
.editorial-card img,
.publication-card img,
.publication-cover img {
  width:100%;
  object-fit:cover;
  background:var(--color-soft);
}

.card-item img { aspect-ratio:3/4; }
.editorial-card img,
.publication-card img,
.publication-cover img { aspect-ratio:4/5; }

.card-item h3 {
  margin-top:.8rem;
  font-size:1rem;
}

.card-item .meta {
  margin-top:.35rem;
}

.expo-single-hero {
  position:relative;
  height:70vh;
  min-height:28rem;
}

.expo-single-hero img {
  width:100%;
  height:100%;
  object-fit:cover;
}

.expo-single-hero .overlay {
  position:absolute;
  inset:0;
  background:linear-gradient(transparent 30%, rgba(0,0,0,.68));
}

.expo-single-hero .caption {
  position:absolute;
  left:1.2rem;
  right:1.2rem;
  bottom:2.5rem;
  z-index:2;
  color:#fff;
}

.expo-single-hero .caption h1 {
  font-family:var(--font-display);
  font-size:clamp(2.3rem, 5vw, 4.8rem);
  font-weight:800;
  line-height:.95;
  letter-spacing:-.05em;
  text-transform:uppercase;
}

.expo-single-hero .caption p,
.expo-single-hero .caption .label {
  margin-top:.5rem;
  font-size:.8rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  opacity:.9;
}

.expo-gallery {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(20rem,1fr));
  gap:1rem;
  padding:3rem 1.2rem;
}

.expo-gallery img {
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  cursor:pointer;
}

.lightbox {
  position:fixed;
  inset:0;
  z-index:300;
  background:rgba(0,0,0,.9);
  display:none;
  align-items:center;
  justify-content:center;
}

.lightbox.open { display:flex; }
.lightbox img { max-height:85vh; max-width:90vw; object-fit:contain; }

.lightbox button {
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  background:none;
  border:none;
  color:#fff;
  font-size:2rem;
  cursor:pointer;
  padding:1rem;
}

.lightbox .lb-prev { left:1rem; }
.lightbox .lb-next { right:1rem; }
.lightbox .lb-close {
  top:1rem;
  right:1.25rem;
  transform:none;
  font-size:1.5rem;
}

.sobre-content {
  max-width:none;
  padding-top:4rem;
  padding-bottom:4rem;
}

.sobre-section {
  padding:0 1.2rem 4rem;
}

.sobre-block {
  display:grid;
  grid-template-columns:minmax(9rem, 14rem) minmax(0, 1fr);
  gap:2rem;
  align-items:start;
  border-top:1px solid var(--color-border);
  padding-top:1.5rem;
}

.sobre-label {
  font-size:.78rem;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:none;
}

.sobre-copy {
  max-width:62rem;
}

.sobre-content h2 {
  font-family:var(--font-display);
  font-size:1.95rem;
  font-weight:800;
  text-transform:uppercase;
  margin-bottom:1.5rem;
}

.sobre-content p,
.article-body p,
.article-body li,
.archive-intro p,
.editorial-card p,
.publication-card p,
.publication-meta p,
.footer-grid p,
.footer-grid a {
  color:var(--color-muted);
  line-height:1.85;
}

.sobre-partners {
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(12rem, 1fr));
  gap:1.25rem;
}

.sobre-partner {
  padding:1rem 0;
  border-bottom:1px solid var(--color-border);
}

.sobre-partner img {
  max-height:3rem;
  width:auto;
}

.sobre-partner p {
  margin-top:.65rem;
  font-size:.92rem;
  color:var(--color-muted);
}

.equipe-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(14rem,1fr));
  gap:2rem;
  padding:0 0 1rem;
}

.equipe-grid .member h4 {
  font-family:var(--font-display);
  font-size:.92rem;
  font-weight:800;
  text-transform:uppercase;
}

.equipe-grid .member span {
  font-size:.75rem;
  color:var(--color-muted);
}

.archive-intro {
  max-width:58rem;
  padding-top:2rem;
}

.article-shell {
  max-width:72rem;
  padding-top:4rem;
  padding-bottom:4rem;
}

.article-body {
  max-width:54rem;
}

.article-body h2,
.article-body h3 {
  font-family:var(--font-display);
  font-weight:800;
  text-transform:uppercase;
  margin:2rem 0 1rem;
}

.publication-single {
  display:grid;
  grid-template-columns:minmax(15rem,24rem) minmax(0,1fr);
  gap:3rem;
  padding-top:4rem;
  padding-bottom:4rem;
  align-items:start;
}

.publication-copy h2 {
  margin:.5rem 0 1rem;
  font-size:2rem;
}

.publication-meta {
  display:grid;
  gap:.45rem;
  margin-bottom:1.4rem;
}

.details-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(12rem,1fr));
  gap:1rem;
  margin:2rem 0;
}

.details-grid div {
  border-top:1px solid var(--color-border);
  padding-top:1rem;
}

.details-grid strong {
  display:block;
  margin-bottom:.35rem;
  font-family:var(--font-display);
  font-size:.78rem;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.details-grid span {
  color:var(--color-muted);
  line-height:1.6;
}

.empty-state {
  padding:2rem 1.2rem;
  color:var(--color-muted);
}

.filter-bar {
  display:flex;
  gap:1rem;
  flex-wrap:wrap;
  align-items:center;
  padding-top:1.8rem;
  padding-bottom:0;
}

.filter-bar input,
.filter-bar select {
  min-height:2.7rem;
  padding:0 .95rem;
  border:1px solid var(--color-border);
  background:#fff;
}

.tab-bar {
  display:flex;
  gap:1.4rem;
  padding:0 1.2rem;
  border-bottom:1px solid var(--color-border);
  overflow:auto;
}

.tab-bar::-webkit-scrollbar { display:none; }

.tab-bar button {
  background:none;
  border:none;
  cursor:pointer;
  padding:1rem 0;
  color:var(--color-muted);
  border-bottom:2px solid transparent;
  font-size:.76rem;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
}

.tab-bar button.active {
  color:var(--color-fg);
  border-bottom-color:var(--color-fg);
}

.site-footer {
  border-top:1px solid var(--color-border);
  padding:3rem 1.2rem 2rem;
}

.footer-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(16rem,1fr));
  gap:2rem;
  margin-bottom:2rem;
}

.footer-grid h4 {
  font-family:var(--font-display);
  font-size:.8rem;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
  margin-bottom:.9rem;
}

.footer-bottom {
  display:flex;
  justify-content:space-between;
  gap:1rem;
  padding-top:1.4rem;
  border-top:1px solid var(--color-border);
  font-size:.72rem;
  color:var(--color-muted);
}

.page-404 {
  min-height:80vh;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
}

.page-404 h1 {
  font-family:var(--font-display);
  font-size:8rem;
  font-weight:800;
}

.page-404 p { color:var(--color-muted); margin:1rem 0 2rem; }

@media (max-width: 900px) {
  .fullscreen-menu__content {
    grid-template-columns:1fr;
  }

  .fullscreen-menu__preview {
    display:none;
  }
}

@media (max-width: 768px) {
  .site-header {
    padding:.9rem 1rem;
  }

  .logo span {
    font-size:.76rem;
  }

  .header-search.active,
  .header-search:focus-within {
    width:min(13rem, 55vw);
  }

  .fullscreen-menu__item a {
    min-height:4rem;
    font-size:2rem;
  }

  .hero-slider {
    min-height:36rem;
  }

  .hero-caption {
    bottom:3rem;
    left:1rem;
    right:1rem;
  }

  .hero-indicators {
    right:1rem;
    bottom:1.15rem;
  }

  .hero-scroll-note {
    left:1rem;
    bottom:1.15rem;
    right:5rem;
  }

  .publication-single {
    grid-template-columns:1fr;
  }

  .home-intro-strip {
    grid-template-columns:1fr;
  }

  .sobre-block {
    grid-template-columns:1fr;
    gap:1rem;
  }

  .home-news-grid,
  .home-works-grid {
    grid-template-columns:1fr;
  }

  .footer-bottom {
    flex-direction:column;
  }

  .home-intro-strip h2 {
    max-width:none;
    font-size:clamp(2.8rem, 13vw, 4.8rem);
    line-height:.9;
  }
}
