/* ============================================================
   Milbanhos – Cerâmicas · Contemporâneo Ousado (preto + branco + vermelho)
   Paleta da marca (logótipo Milbanhos)
   ============================================================ */

:root {
  --green:   #1c1c1e;   /* preto/carvão (fundo/base da marca) */
  --green-2: #2b2b30;   /* painel / borda escura */
  --green-d: #101012;   /* preto profundo (rodapé / marquee) */
  --ink:     #1a1a1a;   /* texto em fundo claro */
  --soft:    #6c6c70;   /* texto suave em claro */
  --mint:    #a6a6ab;   /* etiquetas / muted em escuro (cinza) */
  --mint-2:  #d1d1d4;   /* corpo em escuro */
  --cream:   #d81f26;   /* VERMELHO — acento da marca */
  --red-d:   #b3161c;   /* vermelho escuro (hover) */
  --cream-2: #f5f4f2;   /* fundo claro das secções */
  --white:   #ffffff;
  --line-l:  #e6e4e0;   /* linha em claro */
  --line-d:  rgba(255,255,255,.14);
  --maxw: 1220px;
  --r: 4px;
  --font: "Space Grotesk", system-ui, sans-serif;
  --body: "Inter", system-ui, sans-serif;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 84px; }
body { font-family: var(--body); color: var(--ink); background: var(--cream-2); line-height: 1.6; -webkit-font-smoothing: antialiased; overflow-x: hidden; }

.wrap { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 34px; }
a { color: inherit; text-decoration: none; }

h1, h2, h3, h4 { font-family: var(--font); font-weight: 700; line-height: .98; letter-spacing: -.02em; text-transform: uppercase; }

.tag { font-family: var(--font); font-size: 12px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--cream); display: inline-block; }
.tag.dark { color: var(--cream); }
.hl { color: var(--cream); }
.hl-d { color: var(--cream); position: relative; }

[data-img] {
  background-color: var(--green-2);
  background-image:
    linear-gradient(150deg, rgba(0,0,0,.30), rgba(216,31,38,.12)),
    radial-gradient(circle at 32% 22%, rgba(255,255,255,.35), transparent 62%);
  background-size: cover; background-position: center;
}

/* ===== Buttons ===== */
.btn { display: inline-flex; align-items: center; justify-content: center; font-family: var(--font); font-size: 14px; font-weight: 600; letter-spacing: .01em; padding: 15px 30px; border-radius: var(--r); cursor: pointer; border: 2px solid transparent; transition: transform .16s, background .2s, color .2s, border-color .2s; }
.btn:hover { transform: translateY(-2px); }
.btn-cream { background: var(--cream); color: #fff; }
.btn-cream:hover { background: var(--red-d); }
.btn-outline { border-color: var(--mint); color: var(--white); }
.btn-outline:hover { background: var(--white); color: var(--green-d); border-color: var(--white); }
.btn-green { background: var(--cream); color: #fff; }
.btn-green:hover { background: var(--red-d); }
.btn-green:hover { background: var(--green-d); }
.btn-block { width: 100%; }

/* ===== Nav ===== */
.nav { position: sticky; top: 0; z-index: 100; background: var(--green); }
.nav-inner { display: flex; align-items: center; justify-content: space-between; height: 74px; gap: 20px; }
.brand { font-family: var(--font); font-size: 23px; font-weight: 700; letter-spacing: -.01em; color: var(--white); }
.brand span { color: var(--cream); font-size: 12px; vertical-align: super; }
.nav-links { display: flex; gap: 30px; margin-left: auto; }
.nav-links a { font-family: var(--font); font-size: 14px; font-weight: 500; color: var(--mint); transition: color .2s; }
.nav-links a:hover { color: var(--white); }
.nav-phone { font-family: var(--font); font-size: 14px; font-weight: 600; padding: 10px 18px; border: 2px solid var(--mint); border-radius: var(--r); color: var(--white); transition: .2s; }
.nav-phone:hover { background: var(--cream); color: #fff; border-color: var(--cream); }
.nav-toggle { display: none; flex-direction: column; gap: 6px; background: none; border: none; cursor: pointer; padding: 6px; }
.nav-toggle span { width: 26px; height: 2px; background: var(--white); }

/* ===== Hero ===== */
.hero { background: var(--green); color: var(--white); padding: 70px 0 90px; }
.hero-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 56px; align-items: center; }
.hero-left .tag { margin-bottom: 24px; }
.hero h1 { font-size: clamp(3.2rem, 8vw, 6.6rem); color: var(--white); margin-bottom: 26px; }
.hero-sub { font-size: 1.12rem; color: var(--mint-2); max-width: 440px; margin-bottom: 34px; }
.hero-actions { display: flex; gap: 14px; flex-wrap: wrap; }
.hero-right { position: relative; }
.hero-img { width: 100%; aspect-ratio: 4/5; border-radius: var(--r); }
.hero-badge { position: absolute; left: -26px; bottom: 30px; background: var(--white); color: var(--ink); border-radius: var(--r); padding: 16px 20px; display: flex; align-items: center; gap: 12px; box-shadow: 0 16px 36px -16px rgba(0,0,0,.5); }
.hero-badge b { color: var(--cream); }
.hero-badge b { font-family: var(--font); font-size: 30px; font-weight: 700; }
.hero-badge span { font-family: var(--font); font-size: 11px; font-weight: 500; letter-spacing: .04em; text-transform: uppercase; line-height: 1.3; }

/* ===== Marquee ===== */
.marquee { background: var(--green-d); color: var(--cream); overflow: hidden; white-space: nowrap; padding: 16px 0; }
.marquee-track { display: inline-flex; animation: slide 32s linear infinite; }
.marquee-track span { font-family: var(--font); font-size: 20px; font-weight: 600; letter-spacing: .02em; text-transform: uppercase; }
@keyframes slide { to { transform: translateX(-50%); } }

/* ===== Sections ===== */
.section { padding: 96px 0; }
.sec-head { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: end; margin-bottom: 56px; }
.sec-head .tag { margin-bottom: 16px; }
.sec-head h2 { font-size: clamp(2.2rem, 5vw, 3.8rem); color: var(--green); }
.sec-lead { font-size: 1.05rem; color: var(--soft); max-width: 400px; justify-self: end; }

/* ===== Cards ===== */
.cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.card { background: var(--white); border: 1px solid var(--line-l); border-radius: var(--r); overflow: hidden; transition: transform .22s, box-shadow .22s; }
.card:hover { transform: translateY(-6px); box-shadow: 0 20px 44px -24px rgba(0,0,0,.4); }
.card-img { width: 100%; aspect-ratio: 16/12; }
.card-body { padding: 24px 24px 28px; }
.card-num { font-family: var(--font); font-size: 13px; font-weight: 700; color: var(--mint); }
.card-body h3 { font-size: 1.4rem; color: var(--green); margin: 6px 0 10px; }
.card-body p { font-size: 14.5px; color: var(--soft); }
.card-cta { background: var(--green); border-color: var(--green); display: flex; align-items: center; }
.card-cta h3 { color: var(--white); font-size: 1.6rem; }
.card-cta p { color: var(--mint-2); margin-bottom: 22px; }

/* ===== Casa de Banho ===== */
.banho { background: var(--green); color: var(--white); padding: 104px 0; }
.banho-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
.banho-body .tag { margin-bottom: 18px; }
.banho-body h2 { font-size: clamp(2.2rem, 5vw, 3.6rem); color: var(--white); margin-bottom: 22px; }
.banho-body > p { color: var(--mint-2); font-size: 1.06rem; max-width: 440px; margin-bottom: 30px; }
.spec { list-style: none; margin-bottom: 34px; }
.spec li { display: flex; justify-content: space-between; align-items: baseline; gap: 20px; padding: 15px 0; border-top: 1px solid var(--line-d); }
.spec li b { font-family: var(--font); font-weight: 600; font-size: 15.5px; color: var(--white); text-transform: uppercase; letter-spacing: .01em; }
.spec li span { font-size: 13.5px; color: var(--mint); }
.banho-img { width: 100%; aspect-ratio: 5/6; border-radius: var(--r); }

/* ===== Trabalhos ===== */
.gallery { display: grid; grid-template-columns: repeat(3, 1fr); grid-auto-rows: 240px; gap: 18px; }
.g-item { border-radius: var(--r); transition: transform .3s; }
.g-item:hover { transform: scale(1.015); }
.g-a { grid-row: span 2; }
.g-d { grid-column: span 2; }
.g-e { grid-row: span 2; }

/* ===== Empresa ===== */
.empresa { background: var(--cream-2); padding: 96px 0; }
.empresa-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: 64px; align-items: start; margin-bottom: 64px; }
.empresa-text .tag { color: var(--green); margin-bottom: 18px; }
.empresa-text h2 { font-size: clamp(2.2rem, 5vw, 3.6rem); color: var(--green); margin-bottom: 22px; }
.empresa-text h2 .hl { color: var(--soft); }
.empresa-text p { color: var(--soft); font-size: 1.06rem; max-width: 470px; }
.empresa-text strong { color: var(--ink); }
.stats { display: flex; flex-direction: column; gap: 0; }
.stat { display: flex; align-items: baseline; gap: 22px; padding: 22px 0; border-top: 2px solid var(--green); }
.stat-n { font-family: var(--font); font-size: 2.8rem; font-weight: 700; color: var(--green); line-height: 1; min-width: 150px; }
.stat-l { font-size: 14px; color: var(--soft); }

.reviews { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.rev { background: var(--white); border: 1px solid var(--line-l); border-radius: var(--r); padding: 28px 26px; }
.rev p { font-family: var(--font); font-size: 1.16rem; font-weight: 500; line-height: 1.4; color: var(--green); margin-bottom: 16px; }
.rev cite { font-size: 12px; font-style: normal; letter-spacing: .04em; text-transform: uppercase; color: var(--soft); }

/* ===== Contactos ===== */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: start; }
.contact-info .tag { color: var(--green); margin-bottom: 18px; }
.contact-info h2 { font-size: clamp(2.2rem, 5vw, 3.4rem); color: var(--green); margin-bottom: 18px; }
.contact-lead { color: var(--soft); margin-bottom: 34px; }
.contact-list { list-style: none; margin-bottom: 30px; }
.contact-list li { padding: 18px 0; border-top: 1px solid var(--line-l); font-size: 15px; }
.contact-list li span { display: block; font-family: var(--font); font-size: 11px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--green); margin-bottom: 7px; }
.contact-list a { border-bottom: 1px solid var(--line-l); }
.contact-list a:hover { border-color: var(--green); color: var(--green); }
.map { border-radius: var(--r); overflow: hidden; border: 1px solid var(--line-l); }
.map iframe { width: 100%; height: 250px; border: 0; display: block; }

.contact-form-wrap { background: var(--green); border-radius: var(--r); padding: 40px 38px; position: sticky; top: 90px; }
.contact-form h3 { font-size: 1.7rem; color: var(--white); margin-bottom: 6px; }
.form-lead { color: var(--mint-2); font-size: 14px; margin-bottom: 24px; }
.field { margin-bottom: 18px; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.field label { display: block; font-family: var(--font); font-size: 11px; font-weight: 600; letter-spacing: .06em; text-transform: uppercase; color: var(--mint); margin-bottom: 8px; }
.field input, .field select, .field textarea { width: 100%; padding: 13px 15px; font-family: var(--body); font-size: 15px; border: 1px solid var(--green-2); border-radius: var(--r); background: #fff; color: var(--ink); }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--cream); box-shadow: 0 0 0 3px rgba(216,31,38,.22); }
.field textarea { resize: vertical; }
.form-feedback { margin-top: 16px; padding: 13px 16px; background: #fff; border-left: 3px solid var(--cream); color: #1a1a1a; border-radius: var(--r); font-size: 14px; }

/* ===== Footer ===== */
.footer { background: var(--green-d); color: var(--mint); padding: 74px 0 32px; }
.foot-word { font-family: var(--font); font-size: clamp(3rem, 15vw, 11rem); font-weight: 700; color: var(--white); line-height: .85; letter-spacing: -.03em; margin-bottom: 44px; }
.foot-base { display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; padding-top: 26px; border-top: 1px solid var(--line-d); font-size: 12.5px; letter-spacing: .02em; }

/* ===== Responsive ===== */
@media (max-width: 940px) {
  .nav-links { position: fixed; top: 74px; right: 0; width: min(80%, 320px); height: calc(100vh - 74px); background: var(--green-d); flex-direction: column; gap: 0; padding: 26px 32px; transform: translateX(100%); transition: transform .3s; }
  .nav-links.open { transform: translateX(0); }
  .nav-links a { padding: 15px 0; font-size: 18px; border-bottom: 1px solid var(--line-d); }
  .nav-phone { display: none; }
  .nav-toggle { display: flex; }
  .hero-grid, .banho-grid, .empresa-grid, .contact-grid, .sec-head { grid-template-columns: 1fr; gap: 44px; }
  .hero-right { order: -1; max-width: 440px; }
  .banho-media { order: -1; }
  .sec-lead { justify-self: start; }
  .cards, .reviews { grid-template-columns: repeat(2, 1fr); }
  .contact-form-wrap { position: static; }
}
@media (max-width: 560px) {
  .wrap { padding: 0 22px; }
  .section, .banho, .empresa { padding: 62px 0; }
  .cards, .reviews { grid-template-columns: 1fr; }
  .gallery { grid-template-columns: 1fr; grid-auto-rows: 260px; }
  .g-a, .g-d, .g-e { grid-row: auto; grid-column: auto; }
  .field-row { grid-template-columns: 1fr; }
  .stat-n { font-size: 2.2rem; min-width: 110px; }
  .marquee-track span { font-size: 16px; }
  .hero-badge { left: auto; right: 14px; }
}

/* ============================================================
   COMPONENTES MULTI-PÁGINA (Portefólio, Especificações, História)
   ============================================================ */

/* Hero de subpágina */
.phero { background: var(--green); color: var(--white); padding: 66px 0 74px; }
.phero .tag { margin-bottom: 18px; }
.phero h1 { font-size: clamp(2.6rem, 7vw, 5.4rem); color: var(--white); }
.phero p { color: var(--mint-2); font-size: 1.12rem; max-width: 560px; margin-top: 22px; }
.crumb { font-family: var(--font); font-size: 12px; font-weight: 500; letter-spacing: .06em; text-transform: uppercase; color: var(--mint); margin-bottom: 24px; }
.crumb a:hover { color: var(--white); }

/* Carrossel */
.carousel { position: relative; overflow: hidden; border-radius: var(--r); background: var(--green-2); }
.carousel-track { display: flex; transition: transform .7s cubic-bezier(.6,.05,.2,1); height: 100%; }
.slide { min-width: 100%; height: 100%; }
.carousel-dots { position: absolute; left: 0; right: 0; bottom: 16px; display: flex; justify-content: center; gap: 8px; z-index: 3; }
.carousel-dots button { width: 9px; height: 9px; border-radius: 50%; border: none; background: rgba(255,255,255,.45); cursor: pointer; padding: 0; transition: .2s; }
.carousel-dots button.active { background: var(--cream); transform: scale(1.25); }

/* Filtros portefólio */
.pfilter { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 40px; }
.pfilter button { font-family: var(--font); font-size: 13px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; padding: 11px 22px; border: 2px solid var(--line-l); background: transparent; color: var(--soft); border-radius: 999px; cursor: pointer; transition: .2s; }
.pfilter button:hover { border-color: var(--green); color: var(--green); }
.pfilter button.active { background: var(--cream); border-color: var(--cream); color: #fff; }

/* Grelha portefólio (masonry-like) */
.pgrid { display: grid; grid-template-columns: repeat(3, 1fr); grid-auto-rows: 260px; gap: 18px; }
.pcard { position: relative; border-radius: var(--r); overflow: hidden; cursor: pointer; }
.pcard .pimg { width: 100%; height: 100%; transition: transform .5s; }
.pcard:hover .pimg { transform: scale(1.06); }
.pcard::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,.74), transparent 55%); opacity: .85; transition: opacity .3s; }
.pcard-cap { position: absolute; left: 20px; bottom: 18px; z-index: 2; color: #fff; }
.pcard-cap b { font-family: var(--font); font-size: 1.1rem; font-weight: 600; text-transform: uppercase; letter-spacing: .01em; display: block; }
.pcard-cap span { font-size: 12.5px; color: var(--mint-2); }
.pcard.tall { grid-row: span 2; }
.pcard.wide { grid-column: span 2; }

/* Projeto em destaque (com lista de produtos) */
.project { background: var(--green); color: var(--white); padding: 100px 0; }
.project-grid { display: grid; grid-template-columns: 1.15fr .85fr; gap: 56px; align-items: center; }
.project-carousel { aspect-ratio: 4/3; }
.project-info .tag { margin-bottom: 16px; }
.project-info h2 { font-size: clamp(2rem, 4.4vw, 3.2rem); color: var(--white); margin-bottom: 16px; }
.project-info > p { color: var(--mint-2); margin-bottom: 26px; max-width: 420px; }
.plist { list-style: none; columns: 1; }
.plist li { padding: 11px 0 11px 26px; border-top: 1px solid var(--line-d); font-size: 14.5px; color: var(--mint-2); position: relative; }
.plist li::before { content: "→"; position: absolute; left: 0; color: var(--cream); font-family: var(--font); }
.plist li b { color: #fff; font-weight: 500; }

/* Projeto em variante clara (alternância) */
.project-light { background: var(--cream-2); color: var(--ink); }
.project-light .tag { color: var(--green); }
.project-light .project-info h2 { color: var(--green); }
.project-light .project-info > p { color: var(--soft); }
.project-light .plist li { border-top-color: var(--line-l); color: var(--soft); }
.project-light .plist li b { color: var(--ink); }
.project-light .plist li::before { color: var(--green); }
.project-light .project-carousel { order: 2; }

/* Tabela de cores (Silmat) */
.cores { margin-top: 26px; }
.cores-img { width: 100%; aspect-ratio: 16/9; border-radius: var(--r); background-color: #fff; background-size: contain; background-repeat: no-repeat; background-position: center; border: 1px solid var(--line-l); }

/* Especificações */
.spec-block { padding: 92px 0; border-bottom: 1px solid var(--line-l); }
.spec-block:nth-child(even) { background: var(--white); }
.spec-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.spec-block:nth-child(even) .spec-media { order: 2; }
.spec-img { width: 100%; aspect-ratio: 4/3; border-radius: var(--r); }
.spec-info .stag { font-family: var(--font); font-size: 12px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: #fff; background: var(--cream); display: inline-block; padding: 6px 14px; border-radius: 999px; margin-bottom: 18px; }
.spec-info h2 { font-size: clamp(1.9rem, 4vw, 3rem); color: var(--green); margin-bottom: 18px; }
.spec-info > p { color: var(--soft); font-size: 1.04rem; margin-bottom: 26px; line-height: 1.7; }
.spec-list { list-style: none; display: grid; grid-template-columns: 1fr 1fr; gap: 10px 22px; margin-bottom: 26px; }
.spec-list li { padding-left: 26px; position: relative; font-size: 14.5px; color: var(--ink); }
.spec-list li::before { content: "✓"; position: absolute; left: 0; top: 0; width: 18px; height: 18px; background: var(--green); color: var(--cream); border-radius: 50%; font-size: 11px; display: grid; place-items: center; }
.spec-pack { display: inline-flex; align-items: center; gap: 12px; font-family: var(--font); font-size: 13px; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; color: var(--green); border: 2px solid var(--green); padding: 10px 18px; border-radius: var(--r); }
.spec-meta { display: flex; flex-wrap: wrap; gap: 10px; }

/* Acabamentos (galeria de texturas) */
.finishes { margin-top: 22px; }
.finishes-title { font-family: var(--font); font-size: 12px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--green); display: block; margin-bottom: 16px; }
.finishes-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px; }
.finish { text-align: center; }
.finish-img { width: 100%; aspect-ratio: 3/4; border-radius: var(--r); margin-bottom: 10px; transition: transform .25s; }
.finish:hover .finish-img { transform: translateY(-4px); }
.finish span { font-size: 12.5px; font-weight: 500; color: var(--soft); }

/* História (index) */
.historia { padding: 100px 0; }
.historia-grid { display: grid; grid-template-columns: .95fr 1.05fr; gap: 60px; align-items: center; }
.historia-img { width: 100%; aspect-ratio: 4/5; border-radius: var(--r); }
.historia-body .tag { color: var(--green); margin-bottom: 18px; }
.historia-body h2 { font-size: clamp(2rem, 4.6vw, 3.4rem); color: var(--green); margin-bottom: 22px; }
.historia-body p { color: var(--soft); font-size: 1.06rem; margin-bottom: 16px; max-width: 520px; }
.hstats { display: flex; flex-wrap: wrap; gap: 14px 36px; margin-top: 30px; padding-top: 26px; border-top: 2px solid var(--green); }
.hstats div { display: flex; flex-direction: column; }
.hstats b { font-family: var(--font); font-size: 2rem; font-weight: 700; color: var(--green); line-height: 1; }
.hstats span { font-size: 12.5px; color: var(--soft); margin-top: 6px; text-transform: uppercase; letter-spacing: .04em; }

/* Teasers (index -> páginas) */
.teasers { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.teaser { position: relative; border-radius: var(--r); overflow: hidden; min-height: 340px; display: flex; align-items: flex-end; padding: 34px; color: #fff; }
.teaser .timg { position: absolute; inset: 0; z-index: 0; transition: transform .5s; }
.teaser:hover .timg { transform: scale(1.05); }
.teaser::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,.85), rgba(0,0,0,.18)); z-index: 1; }
.teaser-in { position: relative; z-index: 2; }
.teaser-in .tag { margin-bottom: 10px; }
.teaser-in h3 { font-size: 1.9rem; color: #fff; margin-bottom: 8px; }
.teaser-in p { color: var(--mint-2); font-size: 14.5px; margin-bottom: 16px; max-width: 320px; }
.teaser-in .arrow { font-family: var(--font); font-weight: 600; text-transform: uppercase; font-size: 13px; letter-spacing: .04em; color: var(--cream); }

/* Lema da marca */
.motto { font-family: var(--font); font-weight: 500; font-size: 1.18rem; line-height: 1.4; color: var(--ink); border-left: 3px solid var(--cream); padding-left: 18px; margin-top: 28px; }
.motto span { color: var(--cream); }

/* Nota de celebração do cliente (portefólio) */
.project-note { margin-top: 22px; padding-top: 16px; border-top: 1px solid var(--line-d); font-size: 14px; color: var(--mint); }
.project-light .project-note { border-top-color: var(--line-l); color: var(--soft); }

/* Lema no rodapé */
.foot-motto { font-family: var(--font); font-weight: 500; font-size: 1.05rem; color: var(--cream); margin: 4px 0 34px; }

@media (max-width: 940px) {
  .pgrid { grid-template-columns: repeat(2, 1fr); }
  .project-grid, .spec-grid, .historia-grid, .teasers { grid-template-columns: 1fr; gap: 40px; }
  .spec-block:nth-child(even) .spec-media { order: 0; }
  .project-carousel { aspect-ratio: 16/10; }
}
@media (max-width: 560px) {
  .pgrid { grid-template-columns: 1fr; grid-auto-rows: 240px; }
  .pcard.tall, .pcard.wide { grid-row: auto; grid-column: auto; }
  .spec-list { grid-template-columns: 1fr; }
  .spec-block, .project, .historia { padding: 60px 0; }
  .finishes-grid { grid-template-columns: repeat(3, 1fr); }
}
