:root {
  --red: #d6093b;
  --red-dark: #aa062f;
  --ink: #434f4f;
  --ink-2: #263131;
  --muted: #6f7a7a;
  --paper: #f7f6f3;
  --paper-2: #efede8;
  --white: #fff;
  --line: rgba(67, 79, 79, .17);
  --shadow: 0 24px 70px rgba(32, 43, 43, .13);
  --shadow-soft: 0 12px 34px rgba(32, 43, 43, .09);
  --radius: 28px;
  --radius-sm: 16px;
  --container: min(1240px, calc(100vw - 40px));
  --font-sans: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-serif: Georgia, "Times New Roman", serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  background: var(--white);
  font-family: var(--font-sans);
  font-size: 17px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}
body.menu-open { overflow: hidden; }
img { max-width: 100%; display: block; }
a { color: inherit; }
button, input, select, textarea { font: inherit; }
button { cursor: pointer; }
[hidden] { display: none !important; }
.container { width: var(--container); margin-inline: auto; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.skip-link { position: fixed; left: 12px; top: -100px; z-index: 9999; background: var(--ink-2); color: white; padding: .7rem 1rem; border-radius: 8px; }
.skip-link:focus { top: 12px; }

h1, h2, h3 { margin: 0 0 .7em; color: var(--ink-2); line-height: 1.08; letter-spacing: -.035em; }
h1 { font-size: clamp(3rem, 6.4vw, 6.3rem); font-weight: 650; }
h2 { font-size: clamp(2.2rem, 4vw, 4.35rem); font-weight: 620; }
h3 { font-size: clamp(1.25rem, 2vw, 1.6rem); font-weight: 650; }
p { margin: 0 0 1.2rem; }
.lead { font-size: clamp(1.15rem, 2vw, 1.42rem); line-height: 1.55; color: var(--muted); max-width: 740px; }
.eyebrow { display: inline-flex; align-items: center; gap: .7rem; margin-bottom: 1.2rem; color: var(--red); font-size: .78rem; font-weight: 800; letter-spacing: .13em; text-transform: uppercase; }
.eyebrow::before { content: ""; width: 38px; height: 2px; background: currentColor; }
.kicker { font-family: var(--font-serif); font-size: clamp(1.18rem, 2vw, 1.48rem); font-style: italic; color: var(--red); }
.section { padding: clamp(78px, 10vw, 142px) 0; }
.section-compact { padding: clamp(58px, 8vw, 96px) 0; }
.section-paper { background: var(--paper); }
.section-ink { background: var(--ink-2); color: rgba(255,255,255,.78); }
.section-ink h2, .section-ink h3 { color: white; }
.section-red { background: var(--red); color: white; }
.section-red h2, .section-red h3 { color: white; }
.section-head { display: grid; grid-template-columns: minmax(0, .75fr) minmax(280px, .42fr); gap: 4rem; align-items: end; margin-bottom: clamp(42px, 7vw, 84px); }
.section-head p { color: var(--muted); max-width: 530px; }
.section-ink .section-head p { color: rgba(255,255,255,.72); }

.button { display: inline-flex; align-items: center; justify-content: center; gap: .65rem; min-height: 52px; padding: .85rem 1.35rem; border: 1px solid transparent; border-radius: 999px; font-weight: 750; text-decoration: none; transition: transform .2s ease, background .2s ease, color .2s ease, border-color .2s ease; }
.button:hover { transform: translateY(-2px); }
.button-solid { background: var(--red); color: white; box-shadow: 0 12px 26px rgba(214,9,59,.2); }
.button-solid:hover { background: var(--red-dark); }
.button-outline { border-color: var(--line); background: white; color: var(--ink-2); }
.button-outline:hover { border-color: var(--red); color: var(--red); }
.button-light { background: white; color: var(--ink-2); }
.button-small { min-height: 42px; padding: .62rem 1.05rem; font-size: .92rem; }
.button-arrow::after { content: "→"; font-size: 1.1em; }
.actions { display: flex; flex-wrap: wrap; gap: .8rem; align-items: center; }
.text-link { color: var(--red); font-weight: 750; text-decoration-thickness: 1px; text-underline-offset: 4px; }

.utility-bar { background: var(--ink-2); color: rgba(255,255,255,.77); font-size: .78rem; }
.utility-inner { min-height: 34px; display: flex; align-items: center; justify-content: space-between; gap: 2rem; }
.utility-inner p { margin: 0; letter-spacing: .035em; }
.utility-links { display: flex; align-items: center; gap: 1.2rem; }
.utility-links a { text-decoration: none; }
.utility-emergency { color: white; background: var(--red); padding: .2rem .65rem; border-radius: 999px; font-weight: 750; }
.site-header { position: sticky; top: 0; z-index: 1000; background: rgba(255,255,255,.94); backdrop-filter: blur(18px); border-bottom: 1px solid transparent; transition: box-shadow .2s ease, border-color .2s ease; }
.site-header.is-scrolled { border-bottom-color: var(--line); box-shadow: 0 8px 28px rgba(38,49,49,.06); }
.header-inner { min-height: 88px; display: flex; align-items: center; justify-content: space-between; gap: 2rem; }
.brand { display: grid; width: min(310px, 29vw); min-width: 220px; text-decoration: none; }
.brand img { width: 100%; height: auto; }
.brand-descriptor { margin-top: .22rem; color: var(--ink); font-size: .66rem; font-weight: 800; letter-spacing: .13em; text-align: center; text-transform: uppercase; }
.primary-nav { display: flex; align-items: center; gap: clamp(.75rem, 1.6vw, 1.35rem); }
.nav-link { position: relative; padding: 1.9rem 0; text-decoration: none; color: var(--ink-2); font-size: .91rem; font-weight: 670; white-space: nowrap; }
.nav-link::after { content: ""; position: absolute; left: 0; right: 100%; bottom: 20px; height: 2px; background: var(--red); transition: right .2s ease; }
.nav-link:hover::after, .nav-link.is-active::after { right: 0; }
.nav-link.is-active { color: var(--red); }
.menu-toggle { display: none; width: 48px; height: 48px; border: 0; border-radius: 50%; background: var(--paper); padding: 13px; }
.menu-toggle span:not(.sr-only) { display: block; height: 2px; margin: 5px 0; background: var(--ink-2); }

.hero { position: relative; overflow: hidden; padding: clamp(56px, 8vw, 112px) 0 clamp(84px, 11vw, 150px); }
.hero::before { content: ""; position: absolute; width: 560px; height: 560px; right: -260px; top: -220px; border-radius: 50%; border: 100px solid rgba(214,9,59,.055); pointer-events: none; }
.hero-grid { display: grid; grid-template-columns: minmax(0, 1.04fr) minmax(420px, .96fr); gap: clamp(38px, 6vw, 86px); align-items: center; }
.hero-copy { max-width: 720px; }
.hero h1 span { color: var(--red); }
.hero .lead { margin-bottom: 2.1rem; }
.hero-micro { margin-top: 2rem; display: flex; gap: 1rem 2.2rem; flex-wrap: wrap; font-size: .9rem; color: var(--muted); }
.hero-micro strong { color: var(--ink-2); }
.hero-visual { position: relative; padding: 0 0 42px 34px; }
.hero-image-wrap { overflow: hidden; border-radius: 180px 28px 180px 28px; box-shadow: var(--shadow); background: var(--paper); }
.hero-image-wrap img { width: 100%; aspect-ratio: 1.04 / 1; object-fit: cover; object-position: 58% center; }
.hero-card { position: absolute; left: -10px; bottom: 0; max-width: 300px; padding: 1.2rem 1.35rem; border-radius: 18px; background: var(--ink-2); color: white; box-shadow: var(--shadow-soft); }
.hero-card strong { display: block; margin-bottom: .2rem; font-size: 1.05rem; }
.hero-card span { color: rgba(255,255,255,.7); font-size: .9rem; }
.hero-mark { position: absolute; right: -24px; top: 32px; width: 112px; height: 112px; padding: 22px; border-radius: 50%; background: white; box-shadow: var(--shadow-soft); }

.trust-strip { border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.trust-grid { display: grid; grid-template-columns: repeat(4,1fr); }
.trust-item { padding: 2rem clamp(1rem, 3vw, 2.4rem); border-right: 1px solid var(--line); }
.trust-item:first-child { padding-left: 0; }
.trust-item:last-child { border-right: 0; }
.trust-item strong { display: block; color: var(--ink-2); font-size: clamp(1.35rem, 2vw, 1.8rem); }
.trust-item span { color: var(--muted); font-size: .9rem; }

.card-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.card { position: relative; min-height: 330px; padding: clamp(26px, 4vw, 42px); border: 1px solid var(--line); border-radius: var(--radius); background: white; box-shadow: 0 1px 0 rgba(0,0,0,.02); transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.card:hover { transform: translateY(-5px); box-shadow: var(--shadow-soft); border-color: rgba(214,9,59,.28); }
.card-number { display: inline-grid; place-items: center; width: 42px; height: 42px; margin-bottom: 3.2rem; border-radius: 50%; background: var(--paper); color: var(--red); font-weight: 800; }
.card p { color: var(--muted); }
.card-link { position: absolute; left: clamp(26px, 4vw, 42px); right: clamp(26px, 4vw, 42px); bottom: 30px; display: flex; justify-content: space-between; align-items: center; color: var(--red); font-weight: 750; text-decoration: none; }
.card-link::after { content: "↗"; }
.card-dark { background: var(--ink-2); border-color: var(--ink-2); }
.card-dark h3 { color: white; }
.card-dark p { color: rgba(255,255,255,.68); }

.split { display: grid; grid-template-columns: minmax(0, 1fr) minmax(380px, .9fr); gap: clamp(48px, 8vw, 112px); align-items: center; }
.split.reverse { grid-template-columns: minmax(380px, .9fr) minmax(0, 1fr); }
.split-copy { max-width: 630px; }
.split-media { position: relative; }
.split-media img { width: 100%; min-height: 460px; object-fit: cover; border-radius: var(--radius); box-shadow: var(--shadow-soft); }
.image-caption { position: absolute; left: 22px; bottom: 22px; max-width: 310px; padding: .9rem 1.1rem; background: rgba(255,255,255,.92); backdrop-filter: blur(8px); border-radius: 14px; font-size: .85rem; font-weight: 750; color: var(--ink-2); }
.check-list { list-style: none; margin: 1.8rem 0 2rem; padding: 0; display: grid; gap: .72rem; }
.check-list li { position: relative; padding-left: 1.75rem; }
.check-list li::before { content: ""; position: absolute; left: 0; top: .55em; width: 9px; height: 9px; border-radius: 50%; background: var(--red); box-shadow: 0 0 0 5px rgba(214,9,59,.09); }

.quote-panel { position: relative; padding: clamp(38px, 7vw, 84px); overflow: hidden; border-radius: var(--radius); background: var(--ink-2); color: white; }
.quote-panel::after { content: ""; position: absolute; right: -120px; top: -100px; width: 340px; height: 340px; border: 70px solid rgba(214,9,59,.35); border-radius: 50%; }
.quote-panel blockquote { position: relative; z-index: 1; margin: 0; max-width: 920px; font-family: var(--font-serif); font-size: clamp(2rem, 4.2vw, 4.5rem); line-height: 1.12; letter-spacing: -.03em; }
.quote-panel cite { display: block; margin-top: 1.8rem; font: 700 .95rem var(--font-sans); color: rgba(255,255,255,.62); }

.process-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 18px; counter-reset: process; }
.process-step { position: relative; padding: 34px 28px; border-top: 3px solid var(--red); background: white; min-height: 250px; }
.process-step::before { counter-increment: process; content: "0" counter(process); display: block; margin-bottom: 2rem; color: var(--red); font-weight: 800; }
.process-step p { color: var(--muted); font-size: .95rem; }

.service-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; }
.service-tile { min-height: 250px; display: flex; flex-direction: column; justify-content: space-between; padding: 30px; border-radius: 22px; background: white; border: 1px solid var(--line); text-decoration: none; transition: transform .2s ease, border-color .2s ease; }
.service-tile:hover { transform: translateY(-4px); border-color: var(--red); }
.service-icon { width: 48px; height: 48px; display: grid; place-items: center; border-radius: 50%; background: var(--paper); color: var(--red); font-weight: 850; }
.service-tile p { margin: 0; color: var(--muted); }
.service-tile .arrow { margin-top: 1.4rem; color: var(--red); font-weight: 800; }

.cta-band { display: grid; grid-template-columns: 1fr auto; gap: 2rem; align-items: center; padding: clamp(36px, 6vw, 70px); border-radius: var(--radius); background: var(--red); color: white; }
.cta-band h2 { color: white; font-size: clamp(2rem, 4vw, 4rem); margin-bottom: .35rem; }
.cta-band p { max-width: 660px; margin: 0; color: rgba(255,255,255,.8); }

.page-hero { position: relative; overflow: hidden; padding: clamp(62px, 9vw, 120px) 0 clamp(68px, 9vw, 118px); background: var(--paper); }
.page-hero::after { content: ""; position: absolute; right: -180px; bottom: -250px; width: 520px; height: 520px; border: 88px solid rgba(214,9,59,.08); border-radius: 50%; }
.page-hero-grid { position: relative; z-index: 1; display: grid; grid-template-columns: minmax(0, .8fr) minmax(300px, .34fr); gap: 4rem; align-items: end; }
.page-hero h1 { max-width: 900px; font-size: clamp(3rem, 6vw, 6.1rem); }
.page-hero-side { color: var(--muted); }
.breadcrumbs { margin-bottom: 1.4rem; color: var(--muted); font-size: .82rem; }
.breadcrumbs a { text-decoration: none; }

.feature-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 20px; }
.feature { padding: 32px; border: 1px solid var(--line); border-radius: 20px; background: white; }
.feature strong { display: block; margin-bottom: .55rem; color: var(--ink-2); font-size: 1.15rem; }
.feature p { color: var(--muted); margin: 0; }

.notice { padding: 1.2rem 1.4rem; border-left: 4px solid var(--red); border-radius: 0 14px 14px 0; background: rgba(214,9,59,.065); }
.notice strong { color: var(--ink-2); }
.notice-warning { border-left-color: #d27a00; background: #fff7e8; }
.notice-emergency { border-left-color: var(--red); background: #fff0f3; }

.form-layout { display: grid; grid-template-columns: minmax(0, 1fr) 340px; gap: clamp(38px, 7vw, 88px); align-items: start; }
.form-card { padding: clamp(26px, 5vw, 54px); border: 1px solid var(--line); border-radius: var(--radius); background: white; box-shadow: var(--shadow-soft); }
.form-section { padding: 0 0 2rem; margin-bottom: 2rem; border-bottom: 1px solid var(--line); }
.form-section:last-of-type { border-bottom: 0; }
.form-section h2 { font-size: 1.45rem; letter-spacing: -.02em; margin-bottom: 1.2rem; }
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 18px; }
.form-field { display: grid; gap: .45rem; }
.form-field.full { grid-column: 1 / -1; }
.form-field label, .field-label { color: var(--ink-2); font-weight: 700; font-size: .92rem; }
.required { color: var(--red); }
input, select, textarea { width: 100%; min-height: 52px; padding: .8rem .95rem; border: 1px solid #cbd0d0; border-radius: 12px; background: white; color: var(--ink-2); outline: none; transition: border-color .2s ease, box-shadow .2s ease; }
textarea { min-height: 145px; resize: vertical; }
input:focus, select:focus, textarea:focus { border-color: var(--red); box-shadow: 0 0 0 4px rgba(214,9,59,.09); }
input[type="checkbox"], input[type="radio"] { width: 19px; min-height: 19px; accent-color: var(--red); }
.choice-list { display: grid; gap: .75rem; }
.choice { display: flex; align-items: flex-start; gap: .7rem; font-size: .94rem; }
.choice input { margin-top: .18rem; flex: 0 0 auto; }
.field-help { color: var(--muted); font-size: .82rem; }
.tenant-number-card { padding: 1.1rem 1.2rem; border: 1px solid rgba(214,9,59,.22); border-radius: 16px; background: rgba(214,9,59,.045); }
.tenant-number-card input { background: white; font-weight: 750; letter-spacing: .035em; }
.tenant-number-missing { margin-top: .25rem; color: var(--muted); font-weight: 500; }
.tenant-number-card.is-missing { border-color: var(--line); background: var(--paper); }
.tenant-number-card.is-missing input { opacity: .55; }
.file-field { padding: 1rem; border: 1px dashed #bbc2c2; border-radius: 14px; background: var(--paper); }
.file-output { display: block; margin-top: .45rem; color: var(--muted); font-size: .82rem; }
.form-sidebar { position: sticky; top: 145px; display: grid; gap: 18px; }
.sidebar-card { padding: 28px; border-radius: 20px; background: var(--paper); }
.sidebar-card h2 { font-size: 1.25rem; }
.sidebar-card p, .sidebar-card li { color: var(--muted); font-size: .92rem; }
.sidebar-card ul { margin: 0; padding-left: 1.1rem; }
.honeypot { position: absolute !important; left: -9999px !important; width: 1px !important; height: 1px !important; opacity: 0 !important; }

.emergency-hero { background: var(--ink-2); color: white; }
.emergency-hero h1 { color: white; }
.emergency-number { display: inline-flex; margin-top: 1rem; font-size: clamp(2rem, 5vw, 5rem); font-weight: 800; color: white; text-decoration: none; letter-spacing: -.04em; }
.emergency-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; }
.emergency-card { padding: 30px; border-radius: 22px; border: 1px solid var(--line); }
.emergency-card strong { display: block; margin-bottom: .6rem; color: var(--ink-2); font-size: 1.2rem; }

.contact-grid { display: grid; grid-template-columns: minmax(0, .8fr) minmax(0, 1.2fr); gap: clamp(48px, 8vw, 110px); }
.contact-facts { display: grid; gap: 1.4rem; }
.contact-fact { padding-bottom: 1.4rem; border-bottom: 1px solid var(--line); }
.contact-fact span { display: block; color: var(--muted); font-size: .84rem; }
.contact-fact strong, .contact-fact a { color: var(--ink-2); font-size: 1.15rem; text-decoration: none; }

.legal { max-width: 900px; }
.legal h2 { margin-top: 2.4rem; font-size: 1.75rem; }
.legal h3 { margin-top: 1.7rem; font-size: 1.2rem; }
.legal p, .legal li { color: #536060; }
.legal a { color: var(--red); }

.reveal { opacity: 1; transform: none; }
.reveal.is-observed { opacity: 0; transform: translateY(18px); transition: opacity .65s ease, transform .65s ease; }
.reveal.is-observed.is-visible { opacity: 1; transform: none; }

.site-footer { padding: 76px 0 28px; background: var(--ink-2); color: rgba(255,255,255,.68); }
.footer-grid { display: grid; grid-template-columns: 1.5fr repeat(3,1fr); gap: clamp(36px, 6vw, 76px); }
.footer-grid h2 { color: white; font-size: .9rem; letter-spacing: .08em; text-transform: uppercase; }
.footer-grid a { display: block; width: fit-content; margin: .45rem 0; color: rgba(255,255,255,.76); text-decoration: none; }
.footer-grid a:hover { color: white; }
.footer-brand img { width: min(330px, 100%); margin-bottom: 1.5rem; }
.footer-company { display: block; margin: -.45rem 0 1rem; color: rgba(255,255,255,.62); font-size: .78rem; font-weight: 750; letter-spacing: .08em; text-transform: uppercase; }
.footer-brand .footer-claim { max-width: 360px; font-family: var(--font-serif); font-style: italic; font-size: 1.2rem; color: white; }
.footer-bottom { display: flex; justify-content: space-between; gap: 2rem; margin-top: 60px; padding-top: 24px; border-top: 1px solid rgba(255,255,255,.12); font-size: .82rem; }
.footer-bottom p { margin: 0; }
.footer-bottom div { display: flex; gap: 1.2rem; }
.footer-bottom a { text-decoration: none; }

@media (max-width: 1120px) {
  .utility-inner p { display: none; }
  .utility-inner { justify-content: flex-end; }
  .menu-toggle { display: block; z-index: 1002; }
  .brand { width: 280px; }
  .primary-nav { position: fixed; inset: 0 0 0 auto; width: min(430px, 92vw); height: 100dvh; padding: 120px 32px 40px; background: white; box-shadow: -20px 0 50px rgba(0,0,0,.13); display: flex; flex-direction: column; align-items: stretch; gap: 0; transform: translateX(105%); transition: transform .28s ease; overflow-y: auto; }
  .primary-nav.is-open { transform: none; }
  .nav-link { padding: 1rem 0; font-size: 1.12rem; border-bottom: 1px solid var(--line); }
  .nav-link::after { display: none; }
  .nav-cta { margin-top: 1.5rem; }
  .hero-grid { grid-template-columns: 1fr 420px; }
  .process-grid { grid-template-columns: repeat(2,1fr); }
}

@media (max-width: 900px) {
  :root { --container: min(100% - 30px, 720px); }
  .hero-grid, .split, .split.reverse, .page-hero-grid, .section-head, .form-layout, .contact-grid { grid-template-columns: 1fr; }
  .hero-visual { max-width: 650px; margin-top: 15px; }
  .hero h1 { font-size: clamp(3rem, 12vw, 5.4rem); }
  .section-head { gap: 1.4rem; }
  .card-grid, .service-grid { grid-template-columns: repeat(2,1fr); }
  .trust-grid { grid-template-columns: repeat(2,1fr); }
  .trust-item:nth-child(2) { border-right: 0; }
  .trust-item:nth-child(-n+2) { border-bottom: 1px solid var(--line); }
  .split-media { order: -1; }
  .split.reverse .split-media { order: 0; }
  .form-sidebar { position: static; }
  .footer-grid { grid-template-columns: repeat(2,1fr); }
}

@media (max-width: 620px) {
  body { font-size: 16px; }
  .utility-links { width: 100%; justify-content: space-between; gap: .6rem; }
  .utility-links a:nth-child(2) { display: none; }
  .header-inner { min-height: 74px; }
  .brand { min-width: 0; width: 232px; }
  .hero { padding-top: 44px; }
  .hero-grid { display: block; }
  .hero-visual { padding-left: 0; padding-bottom: 56px; }
  .hero-image-wrap { border-radius: 110px 20px 110px 20px; }
  .hero-mark { width: 76px; height: 76px; padding: 15px; right: -6px; top: 18px; }
  .hero-card { left: 12px; right: 12px; max-width: none; }
  .actions { align-items: stretch; }
  .actions .button { width: 100%; }
  .trust-grid, .card-grid, .service-grid, .feature-grid, .process-grid, .emergency-grid, .footer-grid { grid-template-columns: 1fr; }
  .trust-item { border-right: 0; border-bottom: 1px solid var(--line); padding-inline: 0; }
  .trust-item:last-child { border-bottom: 0; }
  .card { min-height: 290px; }
  .split-media img { min-height: 340px; }
  .cta-band { grid-template-columns: 1fr; }
  .form-grid { grid-template-columns: 1fr; }
  .footer-bottom { flex-direction: column; }
  .footer-bottom div { flex-wrap: wrap; }
  .page-hero h1 { font-size: clamp(2.7rem, 14vw, 4.4rem); }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { scroll-behavior: auto !important; animation-duration: .01ms !important; transition-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; }
}

@media (max-width: 520px) { .brand-descriptor { font-size: .55rem; letter-spacing: .09em; } }
.tenant-number-status { display: block; min-height: 1.2em; color: var(--ink-2); font-size: .82rem; font-weight: 700; }
.tenant-number-card input:valid:not(:placeholder-shown) { border-color: #4d7f65; box-shadow: 0 0 0 4px rgba(77,127,101,.08); }
.tenant-number-card input:invalid:not(:placeholder-shown) { border-color: var(--red); }

/* Version 1.6: kuratierter Münchner Verwaltungsbestand */
.hero-image-wrap picture,
.split-media picture,
.portfolio-item picture { display: block; width: 100%; height: 100%; }

.section-portfolio { background: #fff; }
.portfolio-grid {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  grid-auto-flow: dense;
  grid-auto-rows: 210px;
  gap: 18px;
}
.portfolio-item {
  position: relative;
  grid-column: span 4;
  grid-row: span 2;
  min-height: 420px;
  margin: 0;
  overflow: hidden;
  border-radius: 24px;
  background: var(--paper);
  box-shadow: 0 14px 38px rgba(38,49,49,.08);
  isolation: isolate;
}
.portfolio-item--large { grid-column: span 6; }
.portfolio-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .7s cubic-bezier(.2,.65,.25,1), filter .3s ease;
}
.portfolio-item::after {
  content: "";
  position: absolute;
  inset: 42% 0 0;
  z-index: 1;
  background: linear-gradient(to bottom, transparent, rgba(20,29,29,.72));
  pointer-events: none;
}
.portfolio-item:hover img { transform: scale(1.025); }
.portfolio-item figcaption {
  position: absolute;
  z-index: 2;
  left: 24px;
  right: 24px;
  bottom: 22px;
  color: white;
}
.portfolio-item figcaption strong {
  display: block;
  margin-bottom: .12rem;
  font-size: 1.08rem;
  letter-spacing: -.015em;
}
.portfolio-item figcaption span {
  color: rgba(255,255,255,.76);
  font-size: .82rem;
}
.portfolio-note {
  margin: 1.25rem 0 0;
  color: var(--muted);
  font-size: .82rem;
}

@media (max-width: 900px) {
  .portfolio-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); grid-auto-rows: 230px; }
  .portfolio-item,
  .portfolio-item--large { grid-column: span 1; grid-row: span 2; min-height: 460px; }
  .portfolio-item:first-child { grid-column: 1 / -1; min-height: 500px; }
}

@media (max-width: 620px) {
  .portfolio-grid { grid-template-columns: 1fr; grid-auto-rows: auto; gap: 14px; }
  .portfolio-item,
  .portfolio-item--large,
  .portfolio-item:first-child { grid-column: 1; grid-row: auto; min-height: 0; aspect-ratio: 4 / 3; border-radius: 18px; }
  .portfolio-item figcaption { left: 18px; right: 18px; bottom: 16px; }
  .portfolio-item:hover img { transform: none; }
}


/* Version 1.7: responsive Feinschliff, Inhaltsmodule und Barrierearmut */
:focus-visible {
  outline: 3px solid rgba(214, 9, 59, .55);
  outline-offset: 4px;
}
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 0;
  border-color: var(--red);
  box-shadow: 0 0 0 4px rgba(214, 9, 59, .1);
}
.hero-office-image {
  aspect-ratio: 726 / 480 !important;
  object-position: center !important;
}
.section-notice { padding: 1.1rem 0 0; }
.public-notice {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  padding: 1.2rem 1.35rem;
  border: 1px solid rgba(214,9,59,.18);
  border-radius: 18px;
  background: #fff7f9;
}
.public-notice p { margin: .2rem 0 0; color: var(--muted); }
.public-notice strong { color: var(--ink-2); }

.faq-list { display: grid; gap: 12px; max-width: 950px; }
.faq-item {
  border: 1px solid var(--line);
  border-radius: 18px;
  background: white;
  overflow: clip;
}
.faq-item summary {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  min-height: 66px;
  padding: 1rem 1.25rem;
  color: var(--ink-2);
  font-weight: 750;
  cursor: pointer;
  list-style: none;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary span { color: var(--red); font-size: 1.45rem; transition: transform .2s ease; }
.faq-item[open] summary span { transform: rotate(45deg); }
.faq-answer { padding: 0 1.25rem 1.15rem; color: var(--muted); }
.faq-answer p { margin: 0; }

.download-grid,
.job-list { display: grid; gap: 18px; }
.download-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.download-card,
.job-card {
  border: 1px solid var(--line);
  border-radius: 24px;
  background: white;
  padding: clamp(24px, 4vw, 38px);
  box-shadow: 0 10px 30px rgba(38,49,49,.06);
}
.download-card { display: flex; flex-direction: column; justify-content: space-between; gap: 1.4rem; min-height: 290px; }
.download-card h2,
.job-card h2 { font-size: clamp(1.55rem, 2.5vw, 2.25rem); }
.download-card p,
.job-details { color: var(--muted); }
.download-type {
  display: inline-flex;
  margin-bottom: 1rem;
  padding: .25rem .65rem;
  border-radius: 999px;
  background: var(--paper);
  color: var(--red);
  font-size: .72rem;
  font-weight: 850;
  letter-spacing: .1em;
}
.job-list { max-width: 980px; }
.job-details { white-space: pre-line; margin: 1.3rem 0 1.8rem; }

.legal { overflow-wrap: anywhere; }
.legal code { background: var(--paper); border-radius: 6px; padding: .1rem .35rem; }
.legal h2:first-child { margin-top: 0; }

.form-card input,
.form-card select,
.form-card textarea { max-width: 100%; }
.form-card textarea { min-height: 150px; resize: vertical; }
.file-output { overflow-wrap: anywhere; }

@media (max-width: 1120px) {
  body.menu-open::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 1000;
    background: rgba(24, 33, 33, .38);
    backdrop-filter: blur(2px);
  }
  .menu-toggle { position: relative; z-index: 1003; }
  .primary-nav { z-index: 1002; }
  .menu-toggle span:not(.sr-only) { transition: transform .2s ease, opacity .2s ease; }
  .menu-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .menu-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
  .menu-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
}

@media (max-width: 900px) {
  .hero-visual { max-width: 720px; }
  .hero-office-image { min-height: 0; }
  .download-grid { grid-template-columns: 1fr; }
  .public-notice { align-items: flex-start; flex-direction: column; }
}

@media (max-width: 620px) {
  .hero-image-wrap { border-radius: 74px 18px 74px 18px; }
  .hero-office-image { aspect-ratio: 3 / 2 !important; }
  .hero-card { position: relative; left: auto; right: auto; bottom: auto; margin: -18px 12px 0; max-width: none; }
  .hero-mark { top: 12px; right: 6px; }
  .hero-visual { padding-bottom: 0; }
  .page-hero { padding-top: 42px; }
  .public-notice { padding: 1rem; }
  .faq-item summary { align-items: flex-start; }
  .download-card, .job-card { border-radius: 18px; }
  .legal h2 { font-size: 1.5rem; }
}

/* Formularversand: sichtbare Rückmeldung während SMTP, PDF- und Bildverarbeitung */
.form-card.is-submitting {
  position: relative;
}
.form-card.is-submitting button[type="submit"] {
  cursor: wait;
  opacity: .86;
}
.form-card.is-submitting input:not([type="hidden"]),
.form-card.is-submitting select,
.form-card.is-submitting textarea {
  pointer-events: none;
}
.form-card button[type="submit"] .submit-spinner {
  margin-right: .15rem;
}
.submit-spinner {
  display: inline-block;
  width: 1.05rem;
  height: 1.05rem;
  flex: 0 0 auto;
  border: 2px solid currentColor;
  border-right-color: transparent;
  border-radius: 50%;
  animation: submit-spin .75s linear infinite;
}
.submit-spinner-large {
  width: 1.55rem;
  height: 1.55rem;
  border-width: 3px;
  color: var(--red);
}
.form-submit-status {
  display: flex;
  align-items: flex-start;
  gap: .85rem;
  margin-top: 1rem;
  padding: 1rem 1.1rem;
  border: 1px solid rgba(214, 9, 59, .22);
  border-radius: 16px;
  background: #fff7f9;
  color: var(--ink-2);
  box-shadow: 0 8px 24px rgba(38, 49, 49, .06);
}
.form-submit-status strong,
.form-submit-status span {
  display: block;
}
.form-submit-status span {
  margin-top: .2rem;
  color: var(--muted);
  line-height: 1.45;
}
@keyframes submit-spin {
  to { transform: rotate(360deg); }
}
@media (prefers-reduced-motion: reduce) {
  .submit-spinner { animation-duration: 1.5s; }
}

@media print {
  .utility-bar, .site-header, .site-footer, .button, .actions, .menu-toggle { display: none !important; }
  body { color: #000; background: #fff; font-size: 11pt; }
  .section, .section-compact, .page-hero { padding: 1rem 0; }
  a { text-decoration: none; }
  .container { width: 100%; }
}


/* Version 2.1: Datenschutzfreundliche Immobilie1-Objektliste */
.external-listing-consent {
  min-height: 260px;
  padding: clamp(26px, 5vw, 54px);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: white;
  box-shadow: var(--shadow-soft);
}
.external-listing-consent-copy { max-width: 850px; }
.external-listing-consent-copy h3 { margin-top: .8rem; font-size: clamp(1.6rem, 3vw, 2.5rem); }
.external-listing-consent-copy > p { color: var(--muted); max-width: 760px; }
.external-badge {
  display: inline-flex;
  padding: .35rem .7rem;
  border-radius: 999px;
  background: var(--paper);
  color: var(--red);
  font-size: .75rem;
  font-weight: 850;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.external-privacy-note { margin-top: 1.2rem; font-size: .9rem; }
.external-listing-output { min-height: 180px; }
.external-listing-loading,
.external-listing-error {
  display: flex;
  align-items: center;
  gap: .9rem;
  min-height: 150px;
  padding: 1.2rem;
  border-radius: 16px;
  background: var(--paper);
  color: var(--ink-2);
}
.external-listing-error { align-items: flex-start; border: 1px solid rgba(214, 9, 59, .22); background: #fff7f9; }
.external-listing-error strong,
.external-listing-error span { display: block; }
.external-listing-error span { margin-top: .25rem; color: var(--muted); }
.external-listing-output livewire { display: block; width: 100%; }
@media (max-width: 620px) {
  .external-listing-consent .actions { align-items: stretch; flex-direction: column; }
  .external-listing-consent .button { width: 100%; justify-content: center; }
}
