:root {
  --ink: #161817;
  --ink-soft: #2d312e;
  --paper: #f7f4ee;
  --stone: #e5ded2;
  --mist: #eef2ef;
  --olive: #58624a;
  --terracotta: #9c4f34;
  --wine: #5d2830;
  --white: #fffdf8;
  --shadow: 0 24px 70px rgba(14, 16, 15, 0.18);
  --max: 1180px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--paper); font-family: "Segoe UI", Roboto, Arial, sans-serif; line-height: 1.55; }
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

.site-header { position: fixed; z-index: 10; top: 0; left: 0; right: 0; display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 24px; padding: 18px clamp(18px, 4vw, 48px); color: var(--white); background: linear-gradient(180deg, rgba(12, 13, 12, 0.68), rgba(12, 13, 12, 0.22)); backdrop-filter: blur(12px); }
.brand { display: inline-flex; align-items: center; gap: 12px; font-size: 0.9rem; font-weight: 700; letter-spacing: 0.05em; text-transform: uppercase; }
.brand-mark { display: grid; place-items: center; width: 42px; height: 42px; border: 1px solid rgba(255, 253, 248, 0.8); border-radius: 50%; font-family: Georgia, "Times New Roman", serif; font-size: 0.78rem; }
.main-nav { justify-self: center; display: flex; align-items: center; gap: clamp(14px, 3vw, 34px); font-size: 0.92rem; }
.main-nav a { opacity: 0.86; }
.main-nav a:hover, .main-nav a:focus-visible { opacity: 1; }
.language-switch { display: inline-grid; grid-template-columns: repeat(4, 42px); border: 1px solid rgba(255, 253, 248, 0.36); border-radius: 6px; overflow: hidden; }
.language-switch button { min-width: 0; height: 36px; border: 0; color: var(--white); background: rgba(255, 253, 248, 0.08); font: inherit; font-size: 0.78rem; cursor: pointer; }
.language-switch button[aria-pressed="true"] { color: var(--ink); background: var(--white); }

.hero { position: relative; min-height: min(760px, 78svh); display: grid; align-items: center; padding: 120px clamp(22px, 6vw, 80px) 78px; overflow: hidden; color: var(--white); }
.hero-image, .hero-shade { position: absolute; inset: 0; }
.hero-image { width: 100%; height: 100%; object-fit: cover; object-position: center; }
.hero-shade { background: linear-gradient(90deg, rgba(11, 13, 12, 0.82) 0%, rgba(11, 13, 12, 0.58) 42%, rgba(11, 13, 12, 0.13) 100%), linear-gradient(180deg, rgba(11, 13, 12, 0.45), rgba(11, 13, 12, 0.18) 44%, rgba(11, 13, 12, 0.58)); }
.hero-content { position: relative; width: min(650px, 100%); }
.eyebrow { margin: 0 0 14px; color: var(--stone); font-size: 0.78rem; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; }
.eyebrow.dark { color: var(--terracotta); }
.eyebrow.light { color: #f0c9a9; }
h1, h2, h3, p { margin-top: 0; }
h1, h2 { font-family: Georgia, "Times New Roman", serif; font-weight: 500; line-height: 1.02; }
h1 { max-width: 10ch; margin-bottom: 24px; font-size: clamp(4.1rem, 9vw, 8.4rem); }
h2 { margin-bottom: 0; font-size: clamp(2.15rem, 4.8vw, 4.35rem); }
h3 { margin-bottom: 14px; font-size: 1.28rem; line-height: 1.25; }
.hero-copy { max-width: 620px; margin-bottom: 34px; color: rgba(255, 253, 248, 0.88); font-size: clamp(1.08rem, 2vw, 1.35rem); }
.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; }
.button { display: inline-flex; align-items: center; justify-content: center; min-height: 48px; padding: 13px 20px; border: 1px solid transparent; border-radius: 6px; font-weight: 800; cursor: pointer; }
.button-primary { color: var(--white); background: var(--terracotta); box-shadow: 0 18px 42px rgba(83, 36, 24, 0.28); }
.button-primary:hover, .button-primary:focus-visible { background: var(--wine); }
.button-secondary { color: var(--white); border-color: rgba(255, 253, 248, 0.58); background: rgba(255, 253, 248, 0.06); }

.trust-bar { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--ink); color: var(--white); }
.trust-bar div { min-height: 108px; padding: 28px clamp(20px, 4vw, 46px); background: var(--ink-soft); }
.trust-bar span { display: block; margin-bottom: 8px; color: #d4b99f; font-size: 0.74rem; font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase; }
.trust-bar strong { font-size: clamp(1rem, 1.7vw, 1.28rem); }

.section { padding: clamp(72px, 10vw, 124px) clamp(20px, 5vw, 68px); }
.intro-section, .about-section { width: min(var(--max), calc(100% - 40px)); margin: 0 auto; display: grid; grid-template-columns: minmax(260px, 0.8fr) minmax(300px, 1fr); gap: clamp(34px, 7vw, 86px); }
.section-body { color: #3f453f; font-size: 1.08rem; }
.feature-list { display: grid; gap: 12px; margin: 28px 0 0; padding: 0; list-style: none; }
.feature-list li { position: relative; padding-left: 30px; }
.feature-list li::before { content: ""; position: absolute; left: 0; top: 0.7em; width: 14px; height: 2px; background: var(--terracotta); }

.service-section { background: var(--mist); }
.section-heading { width: min(var(--max), 100%); margin: 0 auto 44px; }
.service-grid { width: min(var(--max), 100%); margin: 0 auto; display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.service-card { min-height: 380px; display: flex; flex-direction: column; padding: clamp(24px, 3vw, 34px); border: 1px solid rgba(22, 24, 23, 0.1); border-radius: 8px; background: var(--white); box-shadow: var(--shadow); }
.service-number { margin-bottom: 42px; color: var(--terracotta); font-size: 0.78rem; font-weight: 900; letter-spacing: 0.2em; }
.service-card p:not(.service-number) { color: #4a514b; }
.service-card span { margin-top: auto; color: var(--olive); font-weight: 900; }
.service-deposit { width: 100%; margin-top: 18px; text-align: center; }

.quiet-rome { display: grid; grid-template-columns: minmax(260px, 0.75fr) minmax(320px, 1fr); align-items: end; gap: clamp(32px, 7vw, 86px); color: var(--white); background: linear-gradient(135deg, rgba(21, 26, 24, 0.96), rgba(54, 64, 48, 0.94)), var(--olive); }
.quiet-rome h2 { max-width: 680px; }
.rome-list { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: 10px; }
.rome-list span { padding: 10px 14px; border: 1px solid rgba(255, 253, 248, 0.22); border-radius: 999px; color: #f6ecdc; background: rgba(255, 253, 248, 0.07); font-size: 0.92rem; }



.hidden-rome-section { background: var(--white); }
.hidden-heading { display: grid; grid-template-columns: minmax(280px, 0.9fr) minmax(280px, 0.62fr); align-items: end; gap: clamp(24px, 5vw, 60px); }
.hidden-intro { margin: 0; color: #454c46; font-size: 1.06rem; }
.hidden-grid { width: min(var(--max), 100%); margin: 0 auto; display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 18px; }
.hidden-card { min-height: 100%; display: flex; flex-direction: column; overflow: hidden; border: 1px solid rgba(22, 24, 23, 0.1); border-radius: 8px; background: var(--paper); box-shadow: 0 18px 46px rgba(14, 16, 15, 0.12); }
.hidden-card img { width: 100%; aspect-ratio: 4 / 5; object-fit: cover; object-position: center; background: var(--mist); }
.hidden-card-body { display: flex; flex: 1; flex-direction: column; padding: 20px; }
.hidden-card-body h3 { margin-bottom: 10px; }
.hidden-card-body p { color: #4a514b; font-size: 0.96rem; }
.photo-credit { margin-top: auto; padding-top: 14px; color: #697067; font-size: 0.72rem; line-height: 1.35; text-decoration: underline; text-underline-offset: 3px; }
.photo-credit:hover, .photo-credit:focus-visible { color: var(--terracotta); }



.classic-rome-section { display: grid; grid-template-columns: minmax(300px, 0.82fr) minmax(320px, 1fr); align-items: center; gap: clamp(34px, 7vw, 86px); background: var(--mist); }
.classic-rome-media { margin: 0; }
.classic-rome-media img { width: 100%; aspect-ratio: 4 / 3; border: 1px solid rgba(22, 24, 23, 0.1); border-radius: 8px; background: var(--stone); box-shadow: var(--shadow); object-fit: cover; object-position: center; }
.classic-rome-media figcaption { margin-top: 10px; }
.classic-rome-copy { max-width: 720px; }
.classic-rome-copy p:not(.eyebrow) { margin-bottom: 24px; color: #454c46; font-size: 1.08rem; }
.classic-list { display: flex; flex-wrap: wrap; gap: 10px; }
.classic-list span { padding: 10px 14px; border: 1px solid rgba(88, 98, 74, 0.22); border-radius: 999px; color: var(--olive); background: rgba(255, 253, 248, 0.72); font-size: 0.92rem; font-weight: 800; }

.method-section { background: var(--paper); }
.steps { width: min(var(--max), 100%); margin: 0 auto; display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.step { padding: 30px 28px; border-top: 2px solid var(--olive); background: rgba(255, 253, 248, 0.58); }
.step span { display: inline-grid; place-items: center; width: 38px; height: 38px; margin-bottom: 22px; border-radius: 50%; color: var(--white); background: var(--olive); font-weight: 800; }
.step p, .about-copy p { color: #454c46; }
.about-section { align-items: center; }
.about-portrait { width: min(100%, 380px); margin: 0; justify-self: center; }
.about-portrait img { width: 100%; aspect-ratio: 943 / 1536; height: auto; border: 1px solid rgba(88, 98, 74, 0.22); border-radius: 8px; background: var(--mist); box-shadow: var(--shadow); object-fit: cover; object-position: center; }

.contact-section { display: grid; grid-template-columns: minmax(260px, 0.82fr) minmax(320px, 1fr); gap: clamp(34px, 7vw, 92px); color: var(--white); background: var(--ink); }
.contact-copy { align-self: center; }
.contact-copy p { color: rgba(255, 253, 248, 0.76); }
.contact-form { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; padding: clamp(24px, 4vw, 38px); border: 1px solid rgba(255, 253, 248, 0.16); border-radius: 8px; background: rgba(255, 253, 248, 0.06); }
.contact-form label, .contact-form .full { display: grid; gap: 8px; }
.contact-form .full, .contact-form button, .form-status { grid-column: 1 / -1; }
.contact-form span { color: #f3d3b7; font-size: 0.84rem; font-weight: 800; }
input, select, textarea { width: 100%; border: 1px solid rgba(255, 253, 248, 0.18); border-radius: 6px; color: var(--white); background: rgba(255, 253, 248, 0.1); font: inherit; }
input, select { min-height: 46px; padding: 0 12px; }
textarea { resize: vertical; min-height: 130px; padding: 12px; }
select option { color: var(--ink); }
input::placeholder, textarea::placeholder { color: rgba(255, 253, 248, 0.48); }
.form-status { min-height: 24px; margin: 0; color: #f3d3b7; }
.site-footer { display: flex; justify-content: space-between; gap: 18px; padding: 30px clamp(20px, 5vw, 68px); color: #58605a; background: var(--paper); }
.site-footer span:first-child { color: var(--ink); font-weight: 900; }

@media (max-width: 920px) {
  .site-header { grid-template-columns: 1fr auto; }
  .main-nav { display: none; }
  .trust-bar, .service-grid, .steps, .intro-section, .about-section, .quiet-rome, .classic-rome-section, .contact-section { grid-template-columns: 1fr; }
  .hidden-heading, .hidden-grid { grid-template-columns: 1fr 1fr; }
  .rome-list { justify-content: flex-start; }
  .about-portrait { width: min(76vw, 330px); justify-self: start; }
}

@media (max-width: 620px) {
  .site-header { padding: 12px 14px; gap: 12px; }
  .brand span:last-child { display: none; }
  .brand-mark { width: 38px; height: 38px; }
  .language-switch { grid-template-columns: repeat(4, 38px); }
  .language-switch button { height: 34px; }
  .hero { min-height: 76svh; padding: 106px 18px 52px; }
  .hero-shade { background: linear-gradient(90deg, rgba(11, 13, 12, 0.86), rgba(11, 13, 12, 0.5)), linear-gradient(180deg, rgba(11, 13, 12, 0.2), rgba(11, 13, 12, 0.62)); }
  h1 { font-size: clamp(3.6rem, 18vw, 5rem); }
  h2 { font-size: clamp(2rem, 12vw, 3.1rem); }
  .trust-bar div { min-height: 92px; }
  .service-card { min-height: 330px; }
  .hidden-heading, .hidden-grid { grid-template-columns: 1fr; }
  .hidden-card img { aspect-ratio: 16 / 11; }
  .contact-form { grid-template-columns: 1fr; }
  .site-footer { flex-direction: column; }
}
