 /* ─── DESIGN TOKENS ─────────────────────────────────────── */
 :root {
     --col-graphite: #121315;
     --col-graphite-2: #2e3035;
     --col-meta: #8a8d94;
     --col-fog: #f9f9f9;
     --col-white: #ffffff;
     --col-border: #2e3035;

     --font-sans: 'Space Grotesk', sans-serif;
     --font-mono: 'DM Mono', monospace;

     --fs-h1: clamp(2rem, 6vw, 3.75rem);
     --fs-h2: clamp(1.5rem, 4vw, 2.5rem);
     --fs-h3: clamp(1.125rem, 2.5vw, 1.5rem);
     --fs-body: 1rem;
     --fs-small: 0.875rem;
     --fs-mono: 0.6875rem;

     --space-xs: 0.5rem;
     --space-sm: 1rem;
     --space-md: 2rem;
     --space-lg: 4rem;
     --space-xl: 6rem;

     --max-w: 1400px;
     --pad-inline: clamp(1.25rem, 5vw, 3rem);
     --transition: 0.25s cubic-bezier(0.4, 0, 0.2, 1);
 }

 /* ─── RESET ─────────────────────────────────────────────── */
 *,
 *::before,
 *::after {
     box-sizing: border-box;
     margin: 0;
     padding: 0;
 }

 html {
     scroll-behavior: smooth;
     -webkit-text-size-adjust: 100%;
 }

 body {
     background: var(--col-fog);
     color: var(--col-graphite);
     font-family: var(--font-sans);
     font-size: var(--fs-body);
     line-height: 1.6;
     overflow-x: hidden;
 }

 img {
     display: block;
     max-width: 100%;
 }

 a {
     color: inherit;
     text-decoration: none;
 }

 button {
     font-family: inherit;
     cursor: pointer;
     border: none;
     background: none;
 }

 ul,
 ol {
     list-style: none;
 }

 /* ─── FOCUS VISIBLE ──────────────────────────────────────── */
 :focus-visible {
     outline: 2px solid var(--col-graphite);
     outline-offset: 3px;
 }

 /* ─── UTILITY ────────────────────────────────────────────── */
 .mono {
     font-family: var(--font-mono);
     font-size: var(--fs-mono);
     letter-spacing: 0.12em;
     text-transform: uppercase;
 }

 .tag {
     display: inline-block;
     font-family: var(--font-mono);
     font-size: var(--fs-mono);
     letter-spacing: 0.1em;
     text-transform: uppercase;
     color: var(--col-meta);
     padding: 0.25rem 0;
 }

 .container {
     max-width: var(--max-w);
     margin-inline: auto;
     padding-inline: var(--pad-inline);
 }

 .container-wide {
     max-width: 95svw;
     margin-inline: auto;
     padding-inline: var(--pad-inline);
 }

 .section-label {
     font-family: var(--font-mono);
     font-size: var(--fs-mono);
     letter-spacing: 0.15em;
     text-transform: uppercase;
     color: var(--col-meta);
     margin-bottom: var(--space-md);
     display: flex;
     align-items: center;
     gap: var(--space-sm);
 }

 .section-label::after {
     content: '';
     flex: 1;
     height: 1px;
     background: var(--col-border);
     max-width: 120px;
 }

 /* ─── BUTTONS ─────────────────────────────────────────────── */
 .btn {
     display: inline-flex;
     align-items: center;
     justify-content: center;
     gap: 0.5rem;
     min-height: 44px;
     padding: 0.75rem 1.75rem;
     font-family: var(--font-mono);
     font-size: var(--fs-mono);
     letter-spacing: 0.12em;
     text-transform: uppercase;
     border-radius: 0;
     transition: background var(--transition), color var(--transition), border-color var(--transition);
     position: relative;
     overflow: hidden;
 }

 .btn::after {
     content: '';
     position: absolute;
     inset: 0;
     opacity: 0;
     transition: opacity var(--transition);
 }

 .btn:hover::after {
     opacity: 1;
 }

 .btn-primary {
     background: var(--col-graphite);
     color: var(--col-fog);
     border: 1px solid var(--col-graphite);
 }

 .btn-primary:hover {
     background: var(--col-graphite-2);
     border-color: var(--col-graphite-2);
 }

 .btn-outline {
     background: transparent;
     color: var(--col-graphite);
     border: 1px solid var(--col-graphite);
 }

 .btn-outline:hover {
     background: var(--col-graphite);
     color: var(--col-fog);
 }

 .btn-ghost-white {
     background: transparent;
     color: var(--col-fog);
     border: 1px solid rgba(249, 249, 249, 0.35);
 }

 .btn-ghost-white:hover {
     background: rgba(249, 249, 249, 0.1);
     border-color: var(--col-fog);
 }

 /* ─── DIAGONAL DIVIDER ───────────────────────────────────── */
 .diagonal-divider {
     width: 100%;
     height: 2px;
     background: linear-gradient(90deg, transparent 0%, var(--col-border) 30%, var(--col-border) 70%, transparent 100%);
     transform: skewY(-0.4deg);
     margin: 0;
 }

 .diagonal-divider--light {
     background: linear-gradient(90deg, transparent 0%, rgba(249, 249, 249, 0.15) 30%, rgba(249, 249, 249, 0.15) 70%, transparent 100%);
 }

 /* ─── SCROLL REVEAL ──────────────────────────────────────── */
 .reveal {
     opacity: 0;
     transform: translateY(28px);
     transition: opacity 0.7s cubic-bezier(0.4, 0, 0.2, 1), transform 0.7s cubic-bezier(0.4, 0, 0.2, 1);
 }

 .reveal.visible {
     opacity: 1;
     transform: translateY(0);
 }

 .reveal-delay-1 {
     transition-delay: 0.1s;
 }

 .reveal-delay-2 {
     transition-delay: 0.2s;
 }

 .reveal-delay-3 {
     transition-delay: 0.3s;
 }

 .reveal-delay-4 {
     transition-delay: 0.4s;
 }

 /* ════════════════════════════════════════════════════════════
       HEADER / NAV
    ════════════════════════════════════════════════════════════ */
 .site-header {
     position: fixed;
     top: 0;
     left: 0;
     right: 0;
     z-index: 100;
     background: rgba(18, 19, 21, 0.96);
     backdrop-filter: blur(8px);
     -webkit-backdrop-filter: blur(8px);
     border-bottom: 1px solid var(--col-border);
 }

 .nav-inner {
     display: flex;
     align-items: center;
     justify-content: space-between;
     height: 60px;
 }

 .nav-logo {
     font-family: var(--font-mono);
     font-size: 0.8125rem;
     letter-spacing: 0.18em;
     text-transform: uppercase;
     color: var(--col-fog);
     font-weight: 400;
 }

 .nav-logo span {
     color: var(--col-meta);
 }

 .nav-links {
     display: flex;
     gap: var(--space-md);
     align-items: center;
 }

 .nav-links a {
     font-family: var(--font-mono);
     font-size: var(--fs-mono);
     letter-spacing: 0.12em;
     text-transform: uppercase;
     color: var(--col-meta);
     transition: color var(--transition);
 }

 .nav-links a:hover {
     color: var(--col-fog);
 }

 /* Hamburger */
 .nav-toggle {
     display: none;
     flex-direction: column;
     gap: 5px;
     width: 28px;
     min-height: 44px;
     padding: 10px 0;
     justify-content: center;
 }

 .nav-toggle span {
     display: block;
     height: 1px;
     background: var(--col-fog);
     transition: transform var(--transition), opacity var(--transition);
 }

 .nav-toggle.open span:nth-child(1) {
     transform: translateY(6px) rotate(45deg);
 }

 .nav-toggle.open span:nth-child(2) {
     opacity: 0;
 }

 .nav-toggle.open span:nth-child(3) {
     transform: translateY(-6px) rotate(-45deg);
 }

 .nav-mobile {
     display: none;
     flex-direction: column;
     background: var(--col-graphite);
     padding: var(--space-md) var(--pad-inline);
     gap: var(--space-sm);
     border-top: 1px solid var(--col-border);
 }

 .nav-mobile.open {
     display: flex;
 }

 .nav-mobile a {
     font-family: var(--font-mono);
     font-size: 0.8125rem;
     letter-spacing: 0.14em;
     text-transform: uppercase;
     color: var(--col-meta);
     padding: 0.5rem 0;
     border-bottom: 1px solid var(--col-border);
     transition: color var(--transition);
 }

 .nav-mobile a:hover {
     color: var(--col-fog);
 }

 @media (max-width: 767px) {
     .nav-links {
         display: none;
     }

     .nav-toggle {
         display: flex;
     }
 }

 /* ════════════════════════════════════════════════════════════
       HERO
    ════════════════════════════════════════════════════════════ */
 .hero {
     background: var(--col-graphite);
     color: var(--col-fog);
     min-height: 100svh;
     display: flex;
     flex-direction: column;
     justify-content: flex-end;
     padding-top: 60px;
     position: relative;
     overflow: hidden;
     align-items: center;
     justify-content: center;
 }

 /* geometric grid overlay */
 .hero-grid {
     position: absolute;
     inset: 0;
     background-image:
         linear-gradient(rgba(249, 249, 249, 0.03) 1px, transparent 1px),
         linear-gradient(90deg, rgba(249, 249, 249, 0.03) 1px, transparent 1px);
     background-size: 80px 80px;
     pointer-events: none;
 }

 /* diagonal accent line */
 .hero-diagonal {
     position: absolute;
     top: 0;
     right: -10%;
     width: 55%;
     height: 100%;
     background: linear-gradient(135deg, transparent 40%, rgba(249, 249, 249, 0.025) 40%, rgba(249, 249, 249, 0.025) 60%, transparent 60%);
     transform: skewX(-8deg);
     pointer-events: none;
 }

 .hero-content {
     position: relative;
     z-index: 2;
     transform: translatey(-15%);
 }

 .hero-eyebrow {
     font-family: var(--font-mono);
     font-size: var(--fs-mono);
     letter-spacing: 0.18em;
     text-transform: uppercase;
     color: var(--col-meta);
     margin-bottom: var(--space-md);
 }

 .hero-headline {
     font-size: var(--fs-h1);
     font-weight: 700;
     line-height: 1.05;
     letter-spacing: -0.02em;
     max-width: 18ch;
     margin-bottom: var(--space-md);
 }

 .hero-headline em {
     font-style: normal;
     color: var(--col-meta);
 }

 .hero-sub {
     font-size: clamp(1rem, 1.5vw, 1.25rem);
     font-weight: 300;
     color: rgba(249, 249, 249, 0.65);
     max-width: 55ch;
     margin-bottom: var(--space-lg);
     line-height: 1.7;
 }

 .hero-cta {
     display: flex;
     flex-wrap: wrap;
     gap: var(--space-sm);
     align-items: center;
 }

 .hero-bottom-bar {
     position: absolute;
     bottom: 0;
     z-index: 2;
     border-top: 1px solid var(--col-border);
     padding-block: var(--space-sm);
     display: flex;
     gap: var(--space-xl);
     flex-wrap: wrap;
 }

 .hero-stat {
     display: flex;
     flex-direction: column;
 }

 .hero-stat strong {
     font-size: 1.5rem;
     font-weight: 700;
     line-height: 1;
 }

 .hero-stat span {
     font-family: var(--font-mono);
     font-size: var(--fs-mono);
     letter-spacing: 0.1em;
     text-transform: uppercase;
     color: var(--col-meta);
     margin-top: 0.25rem;
 }

 @media (max-width: 767px) {
     .hero-content {
         display: flex;
         Flex-direction: column;
         padding-block: 05ch;
         align-items: center;
         text-align: center;
         transform: translatey(-25%);
     }


     .hero-bottom-bar {
         display: flex;
         flex-direction: column;
         gap: var(--space-xs);
     }

     .hero-cta {
         justify-content: center;
     }

     .hero-stat {
         z-index: 2;
         padding-block: var(--space-sm);
     }

     .hero-stat strong {
         font-size: 1rem;
     }

     .hero-stat span {
         font-size: 0.6rem;
     }
 }

 /* ════════════════════════════════════════════════════════════
       conceito
    ════════════════════════════════════════════════════════════ */
 .conceito {
     background: var(--col-fog);
     padding-block: var(--space-xl);
     min-height: 100svh;
     display: flex;
     align-items: center;
 }

 .conceito-grid {
     display: grid;
     grid-template-columns: 1fr 1fr;
     padding-top: var(--space-md);
     justify-content: space-around;

 }

 .conceito-headline {
     font-size: var(--fs-h2);
     font-weight: 700;
     line-height: 1.15;
     letter-spacing: -0.02em;
     margin-bottom: var(--space-md);
     text-align: center;
 }

 .conceito-body {
     font-size: 1.0625rem;
     line-height: 1.8;
     color: var(--col-graphite-2);
     font-weight: 300;
     text-align: justify;
 }

 .conceito-body p+p {
     margin-top: 1.25rem;
 }

 .conceito-body strong {
     font-weight: 600;
     color: var(--col-graphite);
 }

 .conceito-grid .conceito-left {
     padding-right: var(--space-lg);
 }

 .conceito-right {
     padding-left: var(--space-lg);
     border-left: 1px solid var(--col-border);
 }

 .conceito-quote {
     font-size: clamp(1.25rem, 2.5vw, 1.75rem);
     font-weight: 500;
     line-height: 1.35;
     letter-spacing: -0.01em;
     margin-bottom: var(--space-md);
 }

 .conceito-quote::before {
     font-family: var(--font-mono);
     font-size: var(--fs-mono);
     letter-spacing: 0.1em;
     color: var(--col-meta);
     display: block;
     margin-bottom: var(--space-sm);
 }

 .conceito-values {
     display: flex;
     flex-direction: column;
     gap: 0;
 }

 .conceito-value {
     padding: var(--space-sm) 0;
     border-bottom: 1px solid var(--col-border);
     display: flex;
     align-items: baseline;
     gap: var(--space-sm);
 }

 .conceito-value:first-child {
     border-top: 1px solid var(--col-border);
 }

 .conceito-value .tag {
     flex-shrink: 0;
 }

 .conceito-value p {
     font-size: var(--fs-small);
     color: var(--col-meta);
     line-height: 1.5;
 }

 @media (max-width: 767px) {
     .conceito {
         padding-block-start: var(--space-xl);
         min-height: 150svh;
     }

     .conceito-grid {
         display: flex;
         flex-direction: column;
     }

     .conceito-grid .conceito-left {
         padding-right: 0;
         border-right: none;
         padding-bottom: var(--space-md);
     }

     .conceito-right {
         padding-left: 0;
         border-left: none;
         border-top: 1px solid var(--col-border);
         padding-top: var(--space-md);
     }
 }

 /* ════════════════════════════════════════════════════════════
       PROJETOS
    ════════════════════════════════════════════════════════════ */
 .projetos {
     background: var(--col-graphite);
     color: var(--col-fog);
     padding-block: var(--space-xl);
     min-height: 100svh;
     align-items: center;
     justify-content: center;

 }

 .projetos .hero-grid {
     opacity: 0.5;
 }

 .projetos-inner {
     position: relative;
     z-index: 2;
 }

 .projetos-header {
     display: flex;
     align-items: flex-end;
     justify-content: space-between;
     flex-wrap: wrap;
     gap: var(--space-md);
     margin-bottom: var(--space-lg);
 }

 .projetos-headline {
     font-size: var(--fs-h2);
     font-weight: 700;
     line-height: 1.1;
     letter-spacing: -0.02em;
 }

 .projetos-sub {
     font-weight: 300;
     color: rgba(249, 249, 249, 0.55);
     max-width: 36ch;
     font-size: var(--fs-small);
     margin-top: 0.5rem;
 }

 /* Placeholder project tiles */
 .projetos-grid {
     display: grid;
     grid-template-columns: repeat(3, 1fr);
     gap: 2px;
     background: var(--col-border);
     margin-bottom: var(--space-lg);
     margin-left: var(--space-md);
     margin-right: var(--space-md);
 }

 .projeto-card {
     background: var(--col-graphite);
     aspect-ratio: 4/3;
     position: relative;
     overflow: hidden;
     transition: transform var(--transition);
 }

 .projeto-card:hover .projeto-overlay {
     opacity: 1;
 }

 .projeto-card:hover img {
     transform: scale(1.04);
 }

 .projeto-card img {
    aspect-ratio: 4/3;
     object-fit: cover;     
     position: absolute;
     inset: 0;
     background: var(--col-graphite-2);
     transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
 }

 /* Textured placeholder using CSS */
 .projeto-card:nth-child(1) .projeto-img-bg {
     background: #1e2025;
 }

 .projeto-card:nth-child(2) .projeto-img-bg {
     background: #252830;
 }

 .projeto-card:nth-child(3) .projeto-img-bg {
     background: #1a1c20;
 }

 .projeto-overlay {
     position: absolute;
     inset: 0;
     background: rgba(18, 19, 21, 0.75);
     display: flex;
     flex-direction: column;
     justify-content: flex-end;
     padding: var(--space-md);
     opacity: 0;
     transition: opacity var(--transition);
 }

 .projeto-type {
     font-family: var(--font-mono);
     font-size: var(--fs-mono);
     letter-spacing: 0.12em;
     text-transform: uppercase;
     color: var(--col-meta);
     margin-bottom: 0.4rem;
 }

 .projeto-name {
     font-size: 1.125rem;
     font-weight: 600;
     color: var(--col-fog);
 }

 .projetos-cta {
     display: flex;
     flex-wrap: wrap;
     gap: var(--space-sm);
     align-items: center;
 }

 .ig-link {
     display: inline-flex;
     align-items: center;
     gap: 0.5rem;
     font-family: var(--font-mono);
     font-size: var(--fs-mono);
     letter-spacing: 0.12em;
     text-transform: uppercase;
     color: var(--col-meta);
     transition: color var(--transition);
     min-height: 44px;
 }

 .ig-link:hover {
     color: var(--col-fog);
 }

 .ig-link svg {
     flex-shrink: 0;
 }

 @media (max-width: 767px) {
     .projetos {
         min-height: 150svh;
     }

     .projetos-grid {
         grid-template-columns: 1fr;
     }

     .projeto-overlay {
         opacity: 1;
     }
 }

 @media (min-width: 768px) and (max-width: 1023px) {
     .projetos-grid {
         grid-template-columns: repeat(2, 1fr);
     }
 }

 /* ════════════════════════════════════════════════════════════
       SERVIÇOS
    ════════════════════════════════════════════════════════════ */
 .servicos {
     background: var(--col-fog);
     padding-block: var(--space-xl);
     min-height: 100svh;
 }

 .servicos-grid {
     display: grid;
     grid-template-columns: repeat(2, 1fr);
     gap: 1px;
     background: var(--col-border);
     margin-top: var(--space-md);
 }

 .servico-card {
     background: var(--col-fog);
     padding: var(--space-md) var(--space-md) var(--space-lg);
     position: relative;
     transition: background var(--transition);
     height: 100%;
 }

 .servico-card:hover {
     background: var(--col-graphite);
     color: var(--col-fog);
 }

 .servico-card:hover .servico-num {
     color: rgba(249, 249, 249, 0.15);
 }

 .servico-card:hover .servico-title {
     color: var(--col-fog);
 }

 .servico-card:hover .servico-desc {
     color: rgba(249, 249, 249, 0.55);
 }

 .servico-card:hover .servico-tag {
     color: rgba(249, 249, 249, 0.3);
 }

 .servico-num {
     font-family: var(--font-mono);
     font-size: 3.5rem;
     font-weight: 300;
     color: rgba(18, 19, 21, 0.08);
     line-height: 1;
     margin-bottom: var(--space-sm);
     transition: color var(--transition);
 }

 .servico-tag {
     font-family: var(--font-mono);
     font-size: var(--fs-mono);
     letter-spacing: 0.12em;
     text-transform: uppercase;
     color: var(--col-meta);
     margin-bottom: var(--space-xs);
     display: block;
     transition: color var(--transition);
 }

 .servico-title {
     font-size: var(--fs-h3);
     font-weight: 700;
     letter-spacing: -0.01em;
     margin-bottom: var(--space-sm);
     transition: color var(--transition);
 }

 .servico-desc {
     font-size: var(--fs-small);
     line-height: 1.7;
     color: var(--col-meta);
     font-weight: 300;
     transition: color var(--transition);
     max-width: 32ch;
 }

 .servico-arrow {
     position: absolute;
     bottom: var(--space-md);
     right: var(--space-md);
     width: 24px;
     height: 24px;
     transition: opacity var(--transition), transform var(--transition);
 }

 .servico-card:hover .servico-arrow {
     opacity: 1;
     transform: translate(2px, -2px);
     transform: rotate(90deg);
 }

 @media (max-width: 575px) {
     .servicos {
         min-height: 180svh;
     }

     .servicos-grid {
         grid-template-columns: 1fr;
     }
 }

 /* ════════════════════════════════════════════════════════════
       SOBRE
    ════════════════════════════════════════════════════════════ */
 .sobre {
     background: var(--col-graphite);
     color: var(--col-fog);
     padding-block: var(--space-xl);
     position: relative;
     min-height: 100svh;
     overflow: hidden;
 }

 .sobre .section-label {
     position: relative;
     z-index: 2;
     display: flex;
 }

 .sobre .hero-grid {
     opacity: 0.4;
 }

 .sobre-inner {
     position: relative;
     z-index: 2;
     display: grid;
     grid-template-columns: 1fr 1fr;
     gap: var(--space-lg);
 }

 .sobre-photo {
     position: relative;
 }

 .sobre-photo-frame {
     aspect-ratio: 3/4;
     background: var(--col-graphite-2);
     position: relative;
     overflow: hidden;
 }

 .sobre-photo-frame::before {
     content: '';
     position: absolute;
     inset: 0;
     background: linear-gradient(135deg, #2e3035 0%, #1a1c20 100%);
 }

 /* Placeholder avatar */
 .sobre-photo-placeholder {
     position: absolute;
     inset: 0;
     display: flex;
     align-items: center;
     justify-content: center;
 }

 .sobre-photo-placeholder svg {
     opacity: 0.15;
 }

 .sobre-photo-accent {
     position: absolute;
     bottom: -1px;
     right: -1px;
     width: 60%;
     height: 4px;
     background: var(--col-fog);
 }

 .sobre-photo-caption {
     margin-top: var(--space-sm);
     font-family: var(--font-mono);
     font-size: var(--fs-mono);
     letter-spacing: 0.1em;
     text-transform: uppercase;
     color: var(--col-meta);
 }

 .sobre-headline {
     font-size: var(--fs-h2);
     font-weight: 700;
     line-height: 1.1;
     letter-spacing: -0.02em;
     padding-bottom: var(--space-md);
     padding-top: 0;
 }

 .sobre-body {
     font-size: 1.0625rem;
     line-height: 1.8;
     color: rgba(249, 249, 249, 0.6);
     font-weight: 300;
 }

 .sobre-body p+p {
     margin-top: 1.25rem;
 }

 .sobre-body strong {
     color: var(--col-fog);
     font-weight: 600;
 }

 .sobre-body em {
     font-style: italic;
     color: var(--col-meta);
     font-family: var(--font-mono);
     font-size: var(--fs-mono);
     letter-spacing: 0.1em;
 }

 .sobre-credentials {
     margin-top: var(--space-md);
     display: flex;
     flex-direction: column;
     gap: 0;
     border-top: 1px solid var(--col-border);
 }

 .credential {
     padding: var(--space-xs) 0;
     border-bottom: 1px solid var(--col-border);
     display: flex;
     align-items: baseline;
     gap: var(--space-sm);
 }

 .credential .tag {
     color: rgba(249, 249, 249, 0.25);
     flex-shrink: 0;
 }

 .credential p {
     font-size: var(--fs-small);
     color: rgba(249, 249, 249, 0.5);
     line-height: 1.5;
 }

 @media (max-width: 767px) {
     .sobre {
         min-height: 155svh;
         flex-direction: column;
     }

     .sobre-inner {
         grid-template-columns: 1fr;
     }

     .sobre-photo {
         order: -1;
     }

     .sobre-photo-frame {
         aspect-ratio: 4/3;
     }
 }

 /* ════════════════════════════════════════════════════════════
       CONTATO / FOOTER
    ════════════════════════════════════════════════════════════ */
 .contato {
     background: var(--col-fog);
     padding-block: var(--space-xl);
 }

 .contato-grid {
     display: grid;
     grid-template-columns: 1fr 1fr;
     gap: var(--space-lg);
     align-items: start;
 }

 .contato-headline {
     font-size: var(--fs-h2);
     font-weight: 700;
     line-height: 1.1;
     letter-spacing: -0.02em;
     margin-bottom: var(--space-md);
 }

 .contato-desc {
     font-size: 1.0625rem;
     line-height: 1.8;
     color: var(--col-meta);
     font-weight: 300;
     margin-bottom: var(--space-md);
     max-width: 40ch;
 }

 .contato-cta {
     display: flex;
     flex-wrap: wrap;
     gap: var(--space-sm);
 }

 .contato-info {
     display: flex;
     flex-direction: column;
     gap: 0;
 }

 .info-item {
     padding: var(--space-sm) 0;
     border-bottom: 1px solid var(--col-border);
     display: flex;
     flex-direction: column;
     gap: 0.25rem;
 }

 .info-item:first-child {
     border-top: 1px solid var(--col-border);
 }

 .info-label {
     font-family: var(--font-mono);
     font-size: var(--fs-mono);
     letter-spacing: 0.12em;
     text-transform: uppercase;
     color: var(--col-meta);
 }

 .info-value {
     font-size: var(--fs-small);
     font-weight: 500;
     transition: color var(--transition);
 }

 .info-value a {
     transition: color var(--transition);
 }

 .info-value a:hover {
     color: var(--col-meta);
 }

 @media (max-width: 767px) {
     .contato-grid {
         text-align: center;
     }

     .contato-cta {
         justify-content: center;
     }

     .contato-grid {
         grid-template-columns: 1fr;
     }
 }



 /* ════════════════════════════════════════════════════════════
       projeto
    ════════════════════════════════════════════════════════════ */
 .projeto {
     background: var(--col-fog);
     color: var(--col-graphite);
     padding-block: var(--space-xl);
     position: relative;
     overflow: hidden;
 }

 .projeto .section-label {
     position: relative;
     z-index: 2;
     display: flex;
 }

 .projeto .hero-grid {
     opacity: 0.4;
 }

 .projeto-inner {
     position: relative;
     z-index: 2;
     display: grid;
     grid-template-columns: minmax(450px, 1fr) minmax(600px, 2fr);
     gap: var(--space-md);
     align-items: center;
 }

 .projeto-photo {
     position: relative;
 }

 .projeto-inner img {
     width: 100%;
     height: auto;
     display: block;
 }

 .projeto-photo-frame::before {
     content: '';
     position: absolute;
     inset: 0;
     background: linear-gradient(135deg, #2e3035 0%, #1a1c20 100%);
 }

 .projeto-photo-accent {
     position: absolute;
     bottom: -1px;
     right: -1px;
     width: 60%;
     height: 4px;
     background: var(--col-fog);
 }

 .projeto-photo-caption {
     margin-top: var(--space-sm);
     font-family: var(--font-mono);
     font-size: var(--fs-mono);
     letter-spacing: 0.1em;
     text-transform: uppercase;
     color: var(--col-meta);
 }

 .projeto-headline {
     font-size: var(--fs-h2);
     font-weight: 700;
     line-height: 1.1;
     letter-spacing: -0.02em;
     padding-bottom: var(--space-md);
     padding-top: 0;
 }

 .projeto-body {
     font-size: 1.0625rem;
     line-height: 1.8;
     color: var(--col-graphite);
     font-weight: 300;
     text-align: justify;
 }

 .projeto-body p+p {
     margin-top: 1.25rem;
 }

 .projeto-body strong {
     color: var(--col-graphite);
     font-weight: 600;
 }

 .projeto-body em {
     font-style: italic;
     color: var(--col-graphite);
     font-family: var(--font-mono);
     font-size: var(--fs-mono);
     letter-spacing: 0.1em;
 }

 .projeto-credentials {
     margin-top: var(--space-md);
     display: flex;
     flex-direction: column;
     gap: 0;
     border-top: 1px solid var(--col-border);
 }

 .dado {
     padding: var(--space-xs) 0;
     border-bottom: 1px solid var(--col-border);
     display: flex;
     align-items: baseline;
     gap: var(--space-sm);
 }

 .dado .tag {
     color: var(--col-graphite-2);
     flex-shrink: 0;
 }

 .dado p {
     font-size: var(--fs-small);
     color: var(--col-graphite);
     line-height: 1.5;
 }

 @media (max-width: 767px) {
     .projeto {
         flex-direction: column;
     }

     .container-wide {
         padding-inline: 2svw;
     }

     .projeto-headline {
         text-align: center;
     }

     .projeto-inner {
         display: flex;
         flex-direction: column-reverse;
     }

     .projeto-photo {
         order: -1;
     }
 }

 /* ════════════════════════════════════════════════════════════
       fotos
    ════════════════════════════════════════════════════════════ */
 .fotos {
     background: var(--col-graphite);
     color: var(--col-fog);
     padding-block: var(--space-xl);
     min-height: 100svh;
     padding-inline: var(--space-lg);
 }

 .galeria {
    display: grid;
    grid-template-columns: 1fr 1fr;
     column-gap: var(--space-sm);
 }

 .fotos-grid {
     display: block;
     overflow: hidden;
     margin-bottom: var(--space-sm);
 }

 .fotos-grid img {
     aspect-ratio: 5/3.5;
     object-fit: cover;
     display: block;
     transition: all 0.5s;
 }

 .fotos-grid img:hover {
     transform: scale(1.05);
     transition: all 1s;
 }

 /* call to action button*/
 .fotos-cta {
     display: flex;
     flex-wrap: wrap;
     gap: var(--space-sm);
     align-items: center;
     justify-content: space-between;
 }

 .ig-link {
     display: inline-flex;
     align-items: center;
     gap: 0.5rem;
     font-family: var(--font-mono);
     font-size: var(--fs-mono);
     letter-spacing: 0.12em;
     text-transform: uppercase;
     color: var(--col-meta);
     transition: color var(--transition);
     min-height: 44px;
 }

 .ig-link:hover {
     color: var(--col-fog);
 }

 .ig-link svg {
     flex-shrink: 0;
 }

 @media (max-width: 767px) {

     .galeria {
         column-count: 1;
     }

     .fotos {
         padding-inline: 3svw;
     }
 }

 /* ─── FOOTER ──────────────────────────────────────────────── */
 .site-footer {
     background: var(--col-graphite);
     color: var(--col-fog);
     padding-block: var(--space-md);
     border-top: 1px solid var(--col-border);
 }

 .footer-inner {
     display: flex;
     align-items: center;
     justify-content: space-between;
     flex-wrap: wrap;
     gap: var(--space-sm);
 }

 .footer-logo {
     font-family: var(--font-mono);
     font-size: var(--fs-mono);
     letter-spacing: 0.18em;
     text-transform: uppercase;
     color: var(--col-fog);
 }

 .footer-meta {
     font-family: var(--font-mono);
     font-size: var(--fs-mono);
     letter-spacing: 0.1em;
     text-transform: uppercase;
     color: var(--col-meta);
     text-align: right;
 }

 .footer-social {
     display: flex;
     gap: var(--space-sm);
     align-items: center;
 }

 .footer-social a {
     color: var(--col-meta);
     transition: color var(--transition);
     display: flex;
     align-items: center;
     min-height: 44px;
     min-width: 44px;
     justify-content: center;
 }

 .footer-social a:hover {
     color: var(--col-fog);
 }

 @media (max-width: 767px) {
     .footer-inner {
         justify-content: center;
         text-align: center;
     }

     .footer-meta {
         text-align: center;
     }
 }