/* ============ BUTTONS ============ */
.btn-primary {
  background: var(--bronze); color: #fff;
  padding: 1.05rem 2.1rem; border-radius: var(--radius-sm);
  font-size: .9rem; letter-spacing: .03em;
  display: inline-flex; align-items: center; gap: .7rem;
  transition: background .3s, transform .3s, box-shadow .3s, color .3s;
  position: relative; overflow: hidden;
}
.btn-primary:hover        { background: #fff; color: var(--forest-deep); transform: translateY(-3px); box-shadow: var(--shadow-deep); }
.btn-primary .ar          { transition: transform .3s; }
.btn-primary:hover .ar    { transform: translateX(5px); }

.btn-ghost {
  font-size: .9rem; letter-spacing: .03em;
  padding: 1.05rem .4rem;
  color: #fff;
  border-bottom: 1.5px solid var(--bronze-soft);
  transition: color .3s, border-color .3s;
}
.btn-ghost:hover { color: var(--bronze-soft); }

.btn-outline-light {
  border: 1.5px solid rgba(196,163,115,.55);
  color: #fff;
  padding: 1.05rem 2.1rem;
  border-radius: var(--radius-sm);
  font-size: .9rem; letter-spacing: .03em;
  display: inline-flex; align-items: center; gap: .7rem;
  transition: background .3s, border-color .3s, color .3s, transform .3s;
}
.btn-outline-light:hover {
  background: rgba(168,128,79,.18);
  border-color: var(--bronze-soft);
  color: var(--bronze-soft);
  transform: translateY(-2px);
}
.btn-outline-light .ar { transition: transform .3s; }
.btn-outline-light:hover .ar { transform: translateX(4px); }

.btn-outline {
  border: 1.5px solid var(--forest-deep);
  color: var(--forest-deep);
  padding: .9rem 1.8rem;
  border-radius: var(--radius-sm);
  font-size: .88rem; letter-spacing: .04em;
  display: inline-flex; align-items: center; gap: .6rem;
  transition: background .3s, color .3s, transform .3s;
  position: relative; overflow: hidden;
}
.btn-outline:hover { background: var(--forest-deep); color: var(--paper); transform: translateY(-2px); }

/* ============ HERO ============ */
.hero {
  position: relative;
  height: calc(100vh - 38px);
  min-height: 620px;
  margin-top: -84px;
  display: flex; align-items: flex-end;
  overflow: hidden;
  background: #2b322c;
}

.hero-media {
  position: absolute; inset: 0; z-index: 0;
  background:
    radial-gradient(150% 140% at 58% 36%, rgba(234,220,196,.68) 0%, rgba(228,215,188,.40) 40%, rgba(190,176,145,.18) 64%, rgba(155,142,112,.06) 80%, transparent 92%),
    linear-gradient(150deg, #555f50 0%, #454e41 38%, #363f32 64%, #212b22 84%, #161c16 100%);
  animation: heroBreath 14s ease-in-out infinite;
}

.hero-media::before {
  content: ""; position: absolute; inset: -25%;
  background:
    radial-gradient(115% 130% at 60% 32%, rgba(244,228,200,.72) 0%, rgba(240,222,192,.46) 38%, rgba(236,218,185,.22) 62%, rgba(232,214,180,.07) 82%, transparent 95%),
    radial-gradient(34% 46% at 24% 78%, rgba(74,93,72,.30), transparent 74%);
  animation: lightWander 19s cubic-bezier(.45,.05,.55,.95) infinite;
  will-change: transform;
}

.hero-media::after {
  content: ""; position: absolute; inset: 0;
  background:
    linear-gradient(to top,  rgba(20,28,22,.88) 0%, rgba(20,28,22,.16) 54%, rgba(20,28,22,.34) 100%),
    linear-gradient(to right, rgba(20,28,22,.60), rgba(20,28,22,.06) 56%, transparent 76%);
}

.hero::before {
  content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background: radial-gradient(40% 55% at 75% 60%, rgba(196,163,115,.22) 0%, rgba(196,163,115,.08) 45%, transparent 75%);
  animation: lightCounter 23s cubic-bezier(.45,.05,.55,.95) infinite;
  will-change: transform, opacity;
}

.hero::after {
  content: ""; position: absolute; top: -30%; left: 0; width: 160%; height: 160%;
  z-index: 0; pointer-events: none;
  background: linear-gradient(115deg,
    transparent 36%,
    rgba(245,240,228,.20) 45%,
    rgba(245,240,228,.38) 50%,
    rgba(245,240,228,.20) 55%,
    transparent 64%);
  mix-blend-mode: screen;
  animation: rayShimmer 16s ease-in-out infinite;
  will-change: transform;
}

.hero-grain {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='100'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.4'/%3E%3C/svg%3E");
  mix-blend-mode: overlay; opacity: .55;
}

.hero-cursor-glow {
  position: absolute; width: 360px; height: 360px; border-radius: 50%;
  background: radial-gradient(circle, rgba(232,228,214,.08), transparent 68%);
  transform: translate(-50%,-50%);
  pointer-events: none; z-index: 1;
  opacity: 0; transition: opacity .6s ease;
  mix-blend-mode: screen;
}
.hero:hover .hero-cursor-glow { opacity: 1; }

.hero-content {
  position: relative; z-index: 2;
  width: 100%; max-width: 1380px;
  margin: 0 auto;
  padding: 0 clamp(1rem,4vw,3.5rem) clamp(3.5rem,8vh,7rem);
}
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: .7rem;
  font-size: .72rem; letter-spacing: .26em; text-transform: uppercase;
  color: rgba(255,255,255,.92); margin-bottom: 1.6rem;
  opacity: 0; animation: rise 1s .2s forwards;
  background: rgba(10,16,10,.38);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  padding: .38rem 1.1rem .38rem .7rem;
  border-radius: 2rem;
  border: 1px solid rgba(255,255,255,.10);
}
.hero-eyebrow::before { content: ""; width: 28px; height: 1px; background: var(--bronze-soft); flex-shrink: 0; }

.hero h1 {
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(2.6rem,6vw,5.4rem);
  line-height: 1.03;
  letter-spacing: -.015em;
  color: #fff;
  max-width: 18ch;
  margin-bottom: 1.6rem;
}

.hero h1 span {
  display: block;
  opacity: 0;
  background: linear-gradient(100deg,
    #ffffff 0%, #ffffff 38%,
    #f6ecd8 45%, #ecd3a6 50%, #f6ecd8 55%,
    #ffffff 62%, #ffffff 100%);
  background-size: 260% 100%;
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}
.hero h1 span:nth-child(1) { animation: rise 1.1s .35s forwards, sheen 8.5s ease-in-out 1.6s infinite; }
.hero h1 span:nth-child(2) { animation: rise 1.1s .50s forwards, sheen 8.5s ease-in-out 1.9s infinite; }
.hero h1 span:nth-child(3) { animation: rise 1.1s .65s forwards, sheen 8.5s ease-in-out 2.2s infinite; }

.hero h1 .em {
  -webkit-text-fill-color: var(--bronze-soft);
  color: var(--bronze-soft);
  background: none;
}

.hero p.lead {
  font-size: 1.1rem;
  max-width: 34rem;
  color: rgba(244,241,234,.82);
  margin-bottom: 2.4rem;
  opacity: 0; animation: rise 1.1s .85s forwards;
}
.hero-actions {
  display: flex; gap: 1.1rem; flex-wrap: wrap; align-items: center;
  opacity: 0; animation: rise 1.1s 1s forwards;
}

.hero-meta {
  position: absolute; right: clamp(1rem,4vw,3.5rem); bottom: clamp(3.5rem,8vh,7rem);
  z-index: 2; text-align: right;
  border-right: 1.5px solid var(--bronze-soft);
  padding-right: 1.3rem;
  opacity: 0; animation: rise 1.1s 1.15s forwards;
}
.hero-meta .big   { font-family: var(--serif); font-size: 3.6rem; color: #fff; line-height: 1; }
.hero-meta .small { font-size: .68rem; letter-spacing: .22em; text-transform: uppercase; color: var(--bronze-soft); margin-top: .5rem; }

.hero-scroll {
  position: absolute; left: 50%; transform: translateX(-50%);
  bottom: 1.4rem; z-index: 2;
  font-size: .62rem; letter-spacing: .3em; text-transform: uppercase;
  color: rgba(244,241,234,.7);
  display: flex; flex-direction: column; align-items: center; gap: .5rem;
  opacity: 0; animation: rise 1s 1.4s forwards;
}
.hero-scroll .bar {
  width: 1px; height: 38px;
  background: rgba(244,241,234,.3);
  position: relative; overflow: hidden;
  box-shadow: 0 0 8px rgba(196,163,115,.4);
}
.hero-scroll .bar::after {
  content: ""; position: absolute; top: -100%; left: 0; width: 100%; height: 100%;
  background: var(--bronze-soft); animation: drop 2s infinite;
}

/* ============ HERO FAQ BADGE ============ */
.hero-faq-badge {
  position: absolute;
  right: clamp(1rem,4vw,3.5rem);
  top: 50%;
  transform: translateY(-50%);
  z-index: 3;
  display: flex; flex-direction: column; align-items: center;
  gap: .9rem;
  padding: 1.6rem 1.1rem;
  border-radius: 100px;
  background: rgba(160,160,155,.13);
  backdrop-filter: blur(22px) saturate(130%);
  -webkit-backdrop-filter: blur(22px) saturate(130%);
  border: 1px solid rgba(255,255,255,.18);
  box-shadow:
    0 0 0 .5px rgba(255,255,255,.08) inset,
    0 8px 32px rgba(0,0,0,.28),
    0 1px 0 rgba(255,255,255,.14) inset;
  text-decoration: none;
  opacity: 0; animation: rise 1.1s 1.3s forwards;
  transition: background .35s, box-shadow .35s, transform .35s;
}
.hero-faq-badge::before {
  content: "";
  position: absolute; inset: 0;
  border-radius: 100px;
  background: linear-gradient(160deg,
    rgba(255,255,255,.12) 0%,
    rgba(255,255,255,.04) 40%,
    transparent 70%);
  pointer-events: none;
}
.hero-faq-badge:hover {
  background: rgba(180,180,175,.22);
  box-shadow:
    0 0 0 .5px rgba(255,255,255,.14) inset,
    0 12px 40px rgba(0,0,0,.34),
    0 1px 0 rgba(255,255,255,.22) inset;
  transform: translateY(calc(-50% - 4px));
}
.hero-faq-icon svg {
  width: 22px; height: 22px;
  color: rgba(255,255,255,.75);
  display: block;
}
.hero-faq-label {
  font-size: .62rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: rgba(255,255,255,.8);
  text-align: center;
  line-height: 1.5;
  writing-mode: vertical-lr;
  transform: rotate(180deg);
}
.hero-faq-arrow svg {
  width: 16px; height: 16px;
  color: rgba(255,255,255,.5);
  display: block;
  animation: drop 2.4s 2s infinite;
}

/* ============ WAY CARDS ============ */
.ways { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; }

.way {
  position: relative; overflow: hidden;
  background: linear-gradient(165deg, rgba(255,255,255,.7) 0%, rgba(244,241,234,.55) 60%, rgba(236,230,218,.5) 100%);
  backdrop-filter: blur(2px);
  border: 1px solid rgba(255,255,255,.6);
  box-shadow: 0 1px 0 rgba(255,255,255,.7) inset, 0 12px 32px -20px rgba(28,38,32,.25);
  border-radius: var(--radius);
  padding: 2.6rem 2.1rem 2.2rem;
  transition: transform .5s cubic-bezier(.2,.7,.2,1), box-shadow .5s, border-color .45s;
  will-change: transform;
}
.way::before {
  content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 3px;
  background: linear-gradient(90deg, var(--bronze), var(--bronze-soft));
  transform: scaleX(0); transform-origin: left;
  transition: transform .5s cubic-bezier(.2,.7,.2,1);
  z-index: 5;
}
.way:hover            { transform: translateY(-10px); box-shadow: var(--shadow); border-color: rgba(255,255,255,.85); }
.way:hover::before    { transform: scaleX(1); }
.way.tilt-on          { transition: transform .12s ease-out, box-shadow .5s; }

.way-num  { font-family: var(--serif); font-size: .85rem; color: var(--bronze); letter-spacing: .2em; margin-bottom: 1.6rem; }
.way-icon {
  width: 54px; height: 54px; margin-bottom: 1.5rem; color: var(--forest);
  transition: transform .6s cubic-bezier(.2,.7,.2,1), color .5s;
}
.way:hover .way-icon  { transform: rotate(-6deg) scale(1.08); color: var(--bronze); }
.way h3   { font-family: var(--serif); font-weight: 400; font-size: 1.5rem; color: var(--forest-deep); margin-bottom: .8rem; }
.way p    { font-size: .94rem; color: var(--moss); margin-bottom: 1.7rem; }
.way-link {
  font-size: .82rem; letter-spacing: .05em; text-transform: uppercase;
  color: var(--forest-deep); display: inline-flex; align-items: center; gap: .5rem;
  border-bottom: 1px solid var(--bronze); padding-bottom: .3rem;
  transition: gap .3s, color .3s;
}
.way:hover .way-link  { gap: .9rem; color: var(--bronze); }

/* ============ LEGACY SECTION ============ */
.legacy {
  background: var(--forest-deep); color: var(--paper);
  border-radius: 10px; overflow: hidden;
  display: grid; grid-template-columns: 1fr 1fr;
  transition: box-shadow .6s ease;
}
.legacy:hover { box-shadow: 0 30px 80px -30px rgba(168,128,79,.35); }

.legacy-text { padding: clamp(2.5rem,5vw,4.5rem); }
.legacy-text .sec-eyebrow         { color: var(--bronze-soft); }
.legacy-text .sec-eyebrow::before { background: var(--bronze-soft); }
.legacy-text h2 {
  font-family: var(--serif); font-weight: 300;
  font-size: clamp(1.9rem,3.2vw,2.9rem); line-height: 1.12; margin-bottom: 1.5rem;
}
.legacy-text h2 .em { font-style: italic; color: var(--bronze-soft); }
.legacy-text p      { color: rgba(244,241,234,.7); font-size: 1rem; margin-bottom: 1.2rem; max-width: 42ch; }
.legacy-quote {
  font-family: var(--serif); font-style: italic; font-size: 1.25rem;
  color: var(--bronze-soft); border-left: 2px solid var(--bronze);
  padding-left: 1.3rem; margin: 2rem 0; line-height: 1.5;
}
.legacy-stats { display: flex; gap: 2.8rem; margin-top: 2.4rem; flex-wrap: wrap; }
.stat .n { font-family: var(--serif); font-size: 2.6rem; color: var(--paper); line-height: 1; }
.stat .l { font-size: .72rem; letter-spacing: .16em; text-transform: uppercase; color: rgba(244,241,234,.55); margin-top: .5rem; }

.legacy-visual {
  position: relative; min-height: 440px;
  background-size: cover; background-position: center;
}
.legacy-visual::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(120deg, rgba(28,38,32,.55), transparent 60%);
}
.legacy-visual .vtag {
  position: absolute; bottom: 1.8rem; left: 1.8rem; right: 1.8rem; z-index: 2;
  font-size: .74rem; letter-spacing: .04em; color: rgba(244,241,234,.9);
  background: rgba(20,28,22,.55); backdrop-filter: blur(6px);
  border: 1px solid var(--line-light); border-radius: var(--radius-sm); padding: .9rem 1.1rem;
}
.legacy-visual .vtag b { font-family: var(--serif); font-weight: 500; color: var(--paper); }

/* ============ ART CARDS ============ */
.arten-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 1.2rem; }

.art-card {
  position: relative; overflow: hidden;
  border-radius: var(--radius-sm);
  aspect-ratio: 3/4; display: flex; align-items: flex-end;
  border: 1px solid var(--line);
  cursor: pointer;
  transition: transform .5s cubic-bezier(.2,.7,.2,1);
  will-change: transform;
}
.art-card .ph {
  position: absolute; inset: 0; z-index: 0;
  background-size: cover; background-position: center;
  transition: transform .8s cubic-bezier(.2,.7,.2,1);
}
.art-card::after {
  content: ""; position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(transparent 30%, rgba(20,28,22,.93));
}
.art-card:hover         { transform: translateY(-8px); }
.art-card:hover .ph     { transform: scale(1.09); }
.art-card.tilt-on       { transition: transform .12s ease-out; }

.art-body       { position: relative; z-index: 2; padding: 1.7rem 1.5rem; color: var(--paper); width: 100%; }
.art-body .k    { font-size: .66rem; letter-spacing: .22em; text-transform: uppercase; color: var(--bronze-soft); margin-bottom: .6rem; }
.art-body h3    { font-family: var(--serif); font-weight: 400; font-size: 1.45rem; margin-bottom: .3rem; }
.art-body p     { font-size: .84rem; color: rgba(244,241,234,.72); max-height: 0; overflow: hidden; opacity: 0; transition: max-height .5s, opacity .4s, margin .4s; }
.art-card:hover .art-body p { max-height: 90px; opacity: 1; margin-top: .4rem; }
.art-body .more { font-size: .74rem; letter-spacing: .08em; text-transform: uppercase; margin-top: .9rem; display: inline-flex; align-items: center; gap: .45rem; color: var(--bronze-soft); }

.arten-foot                   { margin-top: 2.4rem; display: flex; justify-content: center; }
.arten-foot .btn-primary      { background: var(--forest-deep); }
.arten-foot .btn-primary:hover { background: var(--bronze); color: #fff; }

/* ============ PAGE BANNER (Subpages) ============ */
.page-banner {
  background: var(--forest-deep);
  color: var(--paper);
  padding: 7rem clamp(1rem,4vw,3.5rem) 4.5rem;
  position: relative;
  overflow: hidden;
}
.page-banner::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(60% 80% at 30% 0%, rgba(196,163,115,.18), transparent 70%),
    linear-gradient(to right, rgba(20,28,22,.5), transparent 80%);
}
.page-banner::after {
  content: '';
  position: absolute; bottom: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(168,128,79,.4), transparent);
}
.page-banner-inner {
  max-width: 1380px; margin: 0 auto;
  position: relative; z-index: 1;
}
.breadcrumb {
  font-size: .72rem; letter-spacing: .18em; text-transform: uppercase;
  color: var(--bronze-soft); margin-bottom: 1.4rem;
  display: flex; align-items: center; gap: .55rem;
}
.breadcrumb a { color: rgba(244,241,234,.55); transition: color .2s; }
.breadcrumb a:hover { color: var(--bronze-soft); }
.breadcrumb .sep { opacity: .4; font-size: .6rem; }
.page-banner h1 {
  font-family: var(--serif); font-weight: 300;
  font-size: clamp(2rem,4.5vw,4rem);
  line-height: 1.1; max-width: 20ch;
  margin-bottom: 1.1rem;
}
.page-banner h1 .em { font-style: italic; color: var(--bronze-soft); }
.page-banner p.lead {
  font-size: 1.05rem;
  color: rgba(244,241,234,.72);
  max-width: 50ch; line-height: 1.7;
}

/* ============ CONTENT AREAS ============ */
.page-section { padding: clamp(3rem,7vw,6rem) clamp(1rem,4vw,3.5rem); }
.page-section.warm { background: var(--paper-warm); }
.page-section.dark { background: var(--forest-deep); color: var(--paper); }

.content-max { max-width: 1380px; margin: 0 auto; }
.content-narrow { max-width: 860px; margin: 0 auto; }

.content-text h2 {
  font-family: var(--serif); font-weight: 300;
  font-size: clamp(1.6rem,2.8vw,2.4rem);
  color: var(--forest-deep); line-height: 1.15; margin-bottom: 1.2rem;
}
.page-section.dark .content-text h2 { color: var(--paper); }
.content-text p {
  font-size: 1.0rem; color: var(--moss); margin-bottom: 1.2rem; line-height: 1.75;
}
.page-section.dark .content-text p { color: rgba(244,241,234,.72); }
.content-text h3 {
  font-family: var(--serif); font-size: 1.3rem;
  color: var(--forest-deep); margin: 1.8rem 0 .7rem;
}

.two-col {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: clamp(2rem,5vw,4rem); align-items: start;
}
.two-col-wide {
  display: grid; grid-template-columns: 1.4fr 1fr;
  gap: clamp(2rem,5vw,4rem); align-items: start;
}

/* ============ INFO CARDS ============ */
.info-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 1.4rem; margin-top: 2.4rem;
}
.info-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 2rem 1.8rem;
  position: relative; overflow: hidden;
  transition: transform .4s cubic-bezier(.2,.7,.2,1), box-shadow .4s;
}
.info-card:hover { transform: translateY(-6px); box-shadow: var(--shadow); }
.info-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--bronze), var(--bronze-soft));
}
.info-card .card-num {
  font-family: var(--serif); font-size: .8rem;
  color: var(--bronze); letter-spacing: .2em; margin-bottom: 1rem;
}
.info-card .card-icon {
  width: 44px; height: 44px; color: var(--forest);
  margin-bottom: 1.1rem;
  transition: color .3s;
}
.info-card:hover .card-icon { color: var(--bronze); }
.info-card h3 {
  font-family: var(--serif); font-size: 1.15rem;
  color: var(--forest-deep); margin-bottom: .6rem;
}
.info-card p { font-size: .92rem; color: var(--moss); line-height: 1.65; }

/* ============ STEPS ============ */
.steps { display: grid; gap: 1.4rem; margin-top: 2.4rem; }
.step {
  display: flex; gap: 1.5rem; align-items: flex-start;
  padding: 1.8rem 2rem;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  transition: box-shadow .4s, transform .4s;
}
.step:hover { box-shadow: var(--shadow); transform: translateX(6px); }
.step-num {
  width: 44px; height: 44px; min-width: 44px;
  border-radius: 50%;
  background: var(--forest-deep);
  color: var(--paper);
  font-family: var(--serif); font-size: 1rem;
  display: flex; align-items: center; justify-content: center;
}
.step-body h3 {
  font-family: var(--serif); font-size: 1.1rem;
  color: var(--forest-deep); margin-bottom: .45rem;
}
.step-body p { font-size: .92rem; color: var(--moss); line-height: 1.65; }

/* ============ FAQ ACCORDION ============ */
.faq-list { margin-top: 2rem; }
.faq-item { border-bottom: 1px solid var(--line); }
.faq-item summary {
  padding: 1.3rem 0;
  cursor: pointer;
  font-family: var(--serif); font-size: 1.05rem;
  color: var(--forest-deep);
  list-style: none;
  display: flex; justify-content: space-between; align-items: center;
  gap: 1rem;
  transition: color .2s;
}
.faq-item summary:hover { color: var(--bronze); }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
  content: '+'; color: var(--bronze); font-size: 1.4rem; line-height: 1;
  transition: transform .3s; flex-shrink: 0;
}
.faq-item[open] summary::after { transform: rotate(45deg); }
.faq-item[open] summary { color: var(--bronze); }
.faq-answer {
  padding: 0 0 1.4rem;
  font-size: .96rem; color: var(--moss); line-height: 1.75;
}

/* ============ CTA SECTION ============ */
.cta-section {
  background: var(--forest-deep);
  color: var(--paper);
  padding: clamp(3.5rem,8vw,7rem) clamp(1rem,4vw,3.5rem);
  text-align: center;
  position: relative; overflow: hidden;
}
.cta-section::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(50% 70% at 50% 0%, rgba(196,163,115,.18), transparent 70%);
}
.cta-section .content-max { position: relative; }
.cta-section .sec-eyebrow { justify-content: center; }
.cta-section .sec-eyebrow { color: var(--bronze-soft); }
.cta-section .sec-eyebrow::before { background: var(--bronze-soft); }
.cta-section h2 {
  font-family: var(--serif); font-weight: 300;
  font-size: clamp(1.8rem,3.2vw,3rem);
  line-height: 1.12; margin-bottom: 1.2rem;
}
.cta-section p {
  color: rgba(244,241,234,.7);
  max-width: 46ch; margin: 0 auto 2.4rem;
  font-size: 1.05rem;
}
.cta-actions {
  display: flex; gap: 1.1rem;
  justify-content: center; flex-wrap: wrap;
}

/* ============ EMERGENCY BOX ============ */
.emergency-box {
  background: var(--forest-deep);
  border-radius: var(--radius);
  padding: 2.4rem 2rem;
  text-align: center;
  color: var(--paper);
}
.emergency-box .pulse-ring {
  width: 56px; height: 56px; border-radius: 50%;
  background: var(--bronze); margin: 0 auto 1.2rem;
  display: flex; align-items: center; justify-content: center;
  animation: pulse 2.5s infinite;
}
.emergency-box .big-tel {
  display: block; font-family: var(--serif); font-size: 2.2rem;
  letter-spacing: .04em; color: var(--paper); margin-bottom: .5rem;
  transition: color .3s;
}
.emergency-box .big-tel:hover { color: var(--bronze-soft); }
.emergency-box p { font-size: .88rem; color: rgba(244,241,234,.65); line-height: 1.6; }

/* ============ CONTACT FORM ============ */
.contact-form { display: grid; gap: 1.3rem; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.3rem; }
.form-group label {
  display: block; font-size: .78rem; letter-spacing: .12em;
  text-transform: uppercase; color: var(--bronze);
  margin-bottom: .5rem;
}
.form-group input,
.form-group select,
.form-group textarea {
  width: 100%; padding: .9rem 1.1rem;
  background: #fff; border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  font-family: var(--sans); font-size: .95rem; color: var(--ink);
  transition: border-color .3s, box-shadow .3s;
  outline: none;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: var(--bronze);
  box-shadow: 0 0 0 3px rgba(168,128,79,.12);
}
.form-group textarea { resize: vertical; min-height: 130px; }
.form-submit { margin-top: .4rem; }

/* ============ SITE FOOTER ============ */
.site-footer { background: var(--forest-deep); color: var(--paper); }
.footer-inner {
  max-width: 1380px; margin: 0 auto;
  padding: 4rem clamp(1rem,4vw,3.5rem) 3.5rem;
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1.2fr;
  gap: 3rem;
}
.footer-logo-wrap .footer-logo {
  font-family: var(--serif); font-size: 1.85rem;
  letter-spacing: .2em; margin-bottom: .3rem;
}
.footer-logo-wrap .footer-tag {
  font-size: .6rem; letter-spacing: .4em; text-transform: uppercase;
  color: var(--bronze); margin-bottom: 1.8rem;
}
.footer-logo-wrap address {
  font-style: normal; font-size: .9rem;
  color: rgba(244,241,234,.6); line-height: 1.85;
}
.footer-logo-wrap address a { transition: color .2s; }
.footer-logo-wrap address a:hover { color: var(--bronze-soft); }
.footer-hours {
  margin-top: 1.2rem; font-size: .78rem;
  color: rgba(244,241,234,.45); line-height: 1.7;
}
.footer-col h4 {
  font-family: var(--serif); font-size: .72rem;
  letter-spacing: .2em; text-transform: uppercase;
  color: var(--bronze); margin-bottom: 1.3rem;
  padding-bottom: .7rem; border-bottom: 1px solid var(--line-light);
}
.footer-col a {
  display: block; font-size: .88rem;
  color: rgba(244,241,234,.6); padding: .35rem 0;
  transition: color .2s, padding-left .2s;
}
.footer-col a:hover { color: var(--paper); padding-left: .6rem; }
.footer-emergency h4 {
  font-family: var(--serif); font-size: .72rem;
  letter-spacing: .2em; text-transform: uppercase;
  color: var(--bronze); margin-bottom: 1.3rem;
  padding-bottom: .7rem; border-bottom: 1px solid var(--line-light);
}
.emergency-tel {
  display: block; font-family: var(--serif); font-size: 2.1rem;
  color: var(--paper); letter-spacing: .04em; margin-bottom: .8rem;
  transition: color .3s;
}
.emergency-tel:hover { color: var(--bronze-soft); }
.emergency-badge {
  display: inline-flex; align-items: center; gap: .5rem;
  font-size: .7rem; letter-spacing: .1em; text-transform: uppercase;
  color: var(--bronze-soft); margin-bottom: 1.1rem;
}
.emergency-badge .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--bronze-soft); animation: pulse 2s infinite; }
.footer-socials { display: flex; gap: .8rem; margin-top: 1.4rem; }
.footer-social {
  width: 36px; height: 36px; border-radius: 50%;
  border: 1px solid var(--line-light);
  display: flex; align-items: center; justify-content: center;
  font-size: .72rem; color: rgba(244,241,234,.55);
  transition: border-color .3s, color .3s, background .3s;
}
.footer-social:hover { border-color: var(--bronze); color: var(--bronze); background: rgba(168,128,79,.1); }

.footer-bottom { border-top: 1px solid var(--line-light); }
.footer-bottom-inner {
  max-width: 1380px; margin: 0 auto;
  padding: 1.4rem clamp(1rem,4vw,3.5rem);
  display: flex; align-items: center; justify-content: space-between;
  gap: 1.5rem; flex-wrap: wrap;
}
.footer-bottom span { font-size: .78rem; color: rgba(244,241,234,.4); }
.footer-bottom nav { display: flex; gap: 1.8rem; flex-wrap: wrap; }
.footer-bottom nav a {
  font-size: .78rem; color: rgba(244,241,234,.4);
  transition: color .2s;
}
.footer-bottom nav a:hover { color: var(--bronze-soft); }

/* ============ QUICK ACCESS STRIP ============ */
.quick-access {
  background: var(--forest-deep);
  border-top: 1px solid var(--line-light);
  position: relative; z-index: 10;
}
.qa-inner {
  max-width: 1380px; margin: 0 auto;
  padding: 0 clamp(1rem,4vw,3.5rem);
  display: flex; align-items: stretch;
  min-height: 86px;
}
.qa-item {
  flex: 1; display: flex; flex-direction: column; justify-content: center;
  padding: 1.2rem 1.8rem;
  color: var(--paper);
  transition: background .3s;
  position: relative; overflow: hidden;
  gap: .2rem;
}
.qa-item::after {
  content: ""; position: absolute; bottom: 0; left: 1.8rem; right: 1.8rem; height: 2px;
  background: var(--bronze);
  transform: scaleX(0); transform-origin: left;
  transition: transform .4s cubic-bezier(.2,.7,.2,1);
}
.qa-item:hover { background: rgba(255,255,255,.06); }
.qa-item:hover::after { transform: scaleX(1); }
.qa-item svg { width: 18px; height: 18px; color: var(--bronze-soft); margin-bottom: .3rem; flex-shrink: 0; }
.qa-label { font-family: var(--serif); font-size: .98rem; font-weight: 400; line-height: 1.2; }
.qa-sub { font-size: .7rem; letter-spacing: .04em; color: rgba(244,241,234,.45); }
.qa-sep {
  width: 1px; background: var(--line-light);
  align-self: stretch; margin: 1.2rem 0; flex-shrink: 0;
}

/* ============ DIFFERENTIATOR PILLARS ============ */
.pillars { display: grid; grid-template-columns: repeat(4,1fr); gap: 1.5rem; }

.pillar {
  padding: 2.4rem 2rem 2.2rem;
  background: linear-gradient(165deg, rgba(255,255,255,.7) 0%, rgba(244,241,234,.55) 60%, rgba(236,230,218,.5) 100%);
  border: 1px solid rgba(255,255,255,.6);
  box-shadow: 0 1px 0 rgba(255,255,255,.7) inset, 0 8px 28px -18px rgba(28,38,32,.2);
  border-radius: var(--radius);
  position: relative; overflow: hidden;
  transition: transform .5s cubic-bezier(.2,.7,.2,1), box-shadow .5s, border-color .4s;
}
.pillar::before {
  content: ""; position: absolute; bottom: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--bronze), var(--bronze-soft));
  transform: scaleX(0); transform-origin: left;
  transition: transform .5s cubic-bezier(.2,.7,.2,1);
}
.pillar:hover { transform: translateY(-8px); box-shadow: var(--shadow); border-color: rgba(255,255,255,.85); }
.pillar:hover::before { transform: scaleX(1); }

.pillar-icon {
  width: 52px; height: 52px; border-radius: 50%;
  background: var(--forest-deep);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 1.6rem;
  transition: background .4s, transform .5s cubic-bezier(.2,.7,.2,1);
}
.pillar-icon svg { width: 26px; height: 26px; color: var(--bronze-soft); transition: color .4s; }
.pillar:hover .pillar-icon { background: var(--bronze); transform: rotate(-6deg) scale(1.08); }
.pillar:hover .pillar-icon svg { color: #fff; }

.pillar h3 {
  font-family: var(--serif); font-weight: 400; font-size: 1.3rem;
  color: var(--forest-deep); margin-bottom: .75rem;
}
.pillar p { font-size: .9rem; color: var(--moss); line-height: 1.72; }

/* ============ BLOG / AKTUELLES ============ */
.blog-grid {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 1.6rem;
  margin-top: 2.4rem;
}
.blog-card {
  border: 1px solid var(--line); border-radius: var(--radius);
  overflow: hidden; background: #fff;
  transition: transform .4s cubic-bezier(.2,.7,.2,1), box-shadow .4s;
}
.blog-card:hover { transform: translateY(-8px); box-shadow: var(--shadow); }
.blog-thumb {
  height: 220px; background-size: cover; background-position: center;
  transition: transform .8s cubic-bezier(.2,.7,.2,1);
  overflow: hidden;
}
.blog-card:hover .blog-thumb { transform: scale(1.04); }
.blog-body { padding: 1.8rem 1.6rem; }
.blog-tag {
  font-size: .64rem; letter-spacing: .22em; text-transform: uppercase;
  color: var(--bronze); margin-bottom: .7rem;
}
.blog-card h3 {
  font-family: var(--serif); font-size: 1.2rem; color: var(--forest-deep);
  margin-bottom: .65rem; line-height: 1.3;
}
.blog-card p { font-size: .88rem; color: var(--moss); line-height: 1.65; margin-bottom: 1.1rem; }
.blog-meta { font-size: .76rem; color: var(--sand); }
.blog-read { font-size: .78rem; letter-spacing: .06em; text-transform: uppercase; color: var(--bronze); display: inline-flex; align-items: center; gap: .4rem; margin-top: .9rem; }
