:root {
  --cv-ink: #18201f;
  --cv-muted: #68736f;
  --cv-green: #1f5752;
  --cv-green-soft: #e9f1ed;
  --cv-gold: #b9894a;
  --cv-paper: #f7f6f1;
  --cv-cream: #fffdf7;
}

body {
  min-width: 320px;
  color: var(--cv-ink);
  background: var(--cv-paper);
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

a {
  text-decoration: none;
}

.site-header {
  background: rgba(247, 246, 241, 0.95);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(24, 32, 31, 0.1);
}

.logo-placeholder {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 0.45rem;
  color: var(--cv-ink);
}

.site-logo {
  display: block;
  width: min(150px, 42vw);
  height: auto;
  border-radius: 0.5rem;
}

.nav-link {
  color: #4b5653;
  font-weight: 700;
}

.nav-link:hover,
.nav-link.active {
  color: var(--cv-green);
}

.hero {
  min-height: 72vh;
  display: grid;
  align-items: center;
  color: #fffdf7;
  background:
    linear-gradient(90deg, rgba(13, 24, 24, 0.82), rgba(13, 24, 24, 0.34)),
    url("/images/hero-landscape.svg") center / cover;
}

.about-hero {
  color: #fffdf7;
  background:
    linear-gradient(90deg, rgba(13, 24, 24, 0.78), rgba(13, 24, 24, 0.22)),
    url("/images/about-studio.svg") center / cover;
}

.page-intro {
  background: #ece9df;
}

.eyebrow {
  color: var(--cv-gold);
  font-size: 0.78rem;
  font-weight: 800;
  text-transform: uppercase;
}

.display-title {
  font-size: clamp(2.8rem, 7vw, 5.5rem);
  line-height: 0.98;
}

.section-padding {
  padding: clamp(3.5rem, 8vw, 6rem) 0;
}

.btn-clearview {
  color: #fff;
  background: var(--cv-green);
  border-color: var(--cv-green);
  font-weight: 800;
}

.btn-clearview:hover {
  color: #fff;
  background: #17433f;
  border-color: #17433f;
}

.product-card {
  overflow: hidden;
  height: 100%;
  background: var(--cv-cream);
  border: 1px solid rgba(24, 32, 31, 0.1);
  border-radius: 0.5rem;
  box-shadow: 0 16px 36px rgba(24, 32, 31, 0.08);
}

.product-card img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  background: #dfe9e5;
}

.product-price {
  color: #9d6d34;
  font-weight: 900;
}

.package-card {
  position: relative;
  height: 100%;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(255, 253, 247, 0.96), rgba(255, 253, 247, 1)),
    radial-gradient(circle at top right, rgba(185, 137, 74, 0.22), transparent 38%);
  border: 1px solid rgba(24, 32, 31, 0.1);
  border-radius: 0.5rem;
  box-shadow: 0 16px 36px rgba(24, 32, 31, 0.08);
  transition: transform 180ms ease, box-shadow 180ms ease;
}

.package-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 24px 52px rgba(24, 32, 31, 0.13);
}

.package-card-price {
  color: var(--cv-green);
  font-size: 2rem;
  line-height: 1;
}

.package-specs {
  display: grid;
  gap: 0.75rem;
  padding: 0;
  margin: 1rem 0 0;
  list-style: none;
}

.package-specs li {
  display: flex;
  gap: 0.65rem;
  color: #43504d;
  font-weight: 700;
}

.package-specs i {
  color: var(--cv-gold);
  margin-top: 0.2rem;
}

.form-panel,
.contact-panel {
  background: var(--cv-cream);
  border: 1px solid rgba(24, 32, 31, 0.1);
  border-radius: 0.5rem;
}

.contact-panel {
  color: #fffdf7;
  background: var(--cv-green);
}

.site-footer {
  color: #f7f6f1;
  background: var(--cv-ink);
}

.site-footer p,
.site-footer a {
  color: #cfd5d1;
}

.print-option-card {
  height: 100%;
  background: var(--cv-cream);
  border: 1px solid rgba(24, 32, 31, 0.1);
  border-radius: 0.5rem;
}

.price-preview {
  background: var(--cv-green);
  color: #fffdf7;
  border-radius: 0.5rem;
}

.upload-panel {
  border: 2px dashed rgba(31, 87, 82, 0.28);
  background: var(--cv-green-soft);
  border-radius: 0.5rem;
}

.process-section {
  background: #ece9df;
}

.detail-card {
  height: 100%;
  padding: 1.5rem;
  background: #fffdf7;
  border: 1px solid rgba(24, 32, 31, 0.1);
  border-radius: 0.5rem;
}

.detail-card span {
  color: var(--cv-gold);
  font-weight: 900;
}

.detail-card h3 {
  margin: 0.5rem 0;
  font-size: 1.2rem;
  font-weight: 800;
}

.detail-card p {
  margin: 0;
  color: var(--cv-muted);
}

.featured-package {
  background:
    linear-gradient(135deg, rgba(31, 87, 82, 0.96), rgba(24, 32, 31, 0.96)),
    url("/images/lake-reflection.svg") center / cover;
  color: #fffdf7;
}

.featured-package .lead {
  color: #e8f0ec;
}

.package-inclusion {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  height: 100%;
  padding: 1rem;
  background: rgba(255, 253, 247, 0.1);
  border: 1px solid rgba(255, 253, 247, 0.18);
  border-radius: 0.5rem;
  font-weight: 700;
}

.package-inclusion i {
  color: #f2c16d;
}

.package-price-panel {
  padding: clamp(1.5rem, 4vw, 2.25rem);
  color: var(--cv-ink);
  background: #fffdf7;
  border-radius: 0.5rem;
  box-shadow: 0 22px 48px rgba(0, 0, 0, 0.22);
}

.package-label {
  display: inline-flex;
  padding: 0.35rem 0.75rem;
  color: #fff;
  background: var(--cv-gold);
  border-radius: 999px;
  font-weight: 900;
  text-transform: uppercase;
  font-size: 0.8rem;
}

.package-big-price {
  margin: 0.65rem 0;
  color: var(--cv-green);
  font-size: clamp(4rem, 10vw, 6.5rem);
  line-height: 0.9;
  font-weight: 900;
}

@media (max-width: 575.98px) {
  .site-logo {
    width: min(118px, 38vw);
  }
}
