/* ==========================================================================
   standortbestimmung.css — Seitenspezifische Regeln (Leistung 1)
   Nur Regeln, die NICHT identisch in base.css/components.css stehen.
   Enthält außerdem die für diese Seite spezifischen Varianten von Hero,
   Karten-Stack und Dark-CTA (Quelle weicht hier vom geteilten Standard ab).
   ========================================================================== */

/* ---------- HERO (zweispaltig mit Stat-Kacheln) ---------- */
.hero { padding: 100px 0 96px; margin-top: 0; padding-top: 100px; }
.hero-geo .grid-lines { opacity: 0.4; }
.hero-geo .compass-lg { width: 620px; height: 620px; top: -80px; right: -120px; opacity: 0.5; }
.hero-geo .compass-sm { width: 200px; height: 200px; bottom: 40px; left: 4%; opacity: 0.3; }
.hero .hero-grid { display: grid; grid-template-columns: 1.15fr 0.85fr; gap: 72px; align-items: center; }
.hero .text-col .eyebrow { color: var(--color-brass-light); margin-bottom: 22px; }
.hero .text-col h1 {
  font-size: 62px; line-height: 1.04; letter-spacing: -0.03em;
  color: var(--color-paper); margin-bottom: 28px;
}
.hero .text-col h1 .highlight {
  color: var(--color-brass-light); font-style: italic; font-family: "Lora", serif; font-weight: 400;
}
.hero .text-col .lead {
  font-size: 21px; line-height: 1.5; margin-bottom: 38px;
  color: rgba(250, 248, 245, 0.82); max-width: 540px;
}
.hero .text-col .cta-row { display: flex; gap: 12px; flex-wrap: wrap; }

.hero-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.hero-stat {
  background: rgba(250, 248, 245, 0.06);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(250, 248, 245, 0.12);
  border-radius: 10px;
  padding: 26px 22px;
  position: relative;
  overflow: hidden;
  transition: transform 0.35s var(--ease), border-color 0.35s var(--ease), background 0.35s var(--ease);
}
.hero-stat::after {
  content: ""; position: absolute; left: 0; bottom: 0; height: 2px; width: 0;
  background: linear-gradient(90deg, var(--color-brass), var(--color-brass-light));
  transition: width 0.5s var(--ease-out);
}
.hero-stat:hover {
  transform: translateY(-4px);
  border-color: rgba(184, 149, 74, 0.4);
  background: rgba(250, 248, 245, 0.09);
}
.hero-stat:hover::after { width: 100%; }
.hero-stat .value {
  font-family: "Inter", sans-serif; font-size: 34px; font-weight: 600;
  color: var(--color-paper); letter-spacing: -0.03em; margin-bottom: 6px; line-height: 1;
}
.hero-stat .value .unit { font-size: 16px; color: var(--color-brass-light); margin-left: 4px; font-weight: 400; }
.hero-stat .label {
  font-family: "JetBrains Mono", monospace; font-size: 11px; letter-spacing: 0.12em;
  text-transform: uppercase; color: rgba(250, 248, 245, 0.6);
}

/* ---------- STATS STRIP ---------- */
.stats-strip { background: var(--color-paper); padding: 56px 0; border-bottom: 1px solid var(--color-border); }
.stats-strip .grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; }
.stat-cell { position: relative; padding-left: 24px; border-left: 2px solid var(--color-brass); }
.stat-cell .value {
  font-family: "Inter", sans-serif; font-size: 38px; font-weight: 600;
  color: var(--color-marine); letter-spacing: -0.025em; line-height: 1.1; margin-bottom: 6px;
}
.stat-cell .label { font-family: "Inter", sans-serif; font-size: 14px; color: var(--color-stone); }

/* ---------- PROBLEM ---------- */
.problem { padding: 130px 0; position: relative; }
.problem .grid { display: grid; grid-template-columns: 1fr 1.5fr; gap: 64px; align-items: start; }
.problem .head .eyebrow { margin-bottom: 16px; }
.problem .head h2 { font-size: 46px; line-height: 1.08; }
.problem .body p { font-size: 19px; line-height: 1.65; margin-bottom: 28px; }
.problem .body .punch {
  font-family: "Inter", sans-serif; font-size: 34px; font-weight: 500; color: var(--color-marine);
  line-height: 1.22; letter-spacing: -0.02em; margin-top: 44px; padding-top: 36px;
  border-top: 1px solid var(--color-border-brass); position: relative;
}
.problem .body .punch::before {
  content: ""; position: absolute; left: 0; top: -1px; width: 80px; height: 1px; background: var(--color-brass);
}
.problem .body .punch .answer { color: var(--color-brass); font-style: italic; font-family: "Lora", serif; font-weight: 400; }

/* ---------- PROCESS: KARTEN-STACK (seitenspezifisch) ---------- */
.process {
  background: var(--color-marine-deep);
  color: var(--color-paper);
  padding: 120px 0 0;
  position: relative;
  overflow: hidden;
}
.process-geo {
  position: absolute; top: 0; right: -150px; width: 600px; height: 600px;
  opacity: 0.18; z-index: 0; pointer-events: none;
}
.process .container { position: relative; z-index: 1; }
.process .head { margin-bottom: 64px; max-width: 720px; }
.process .head .eyebrow { color: var(--color-brass-light); margin-bottom: 16px; }
.process .head h2 { font-size: 46px; line-height: 1.08; color: var(--color-paper); margin-bottom: 20px; }
.process .head p { font-size: 18px; color: rgba(250, 248, 245, 0.75); line-height: 1.6; }

.process .stack { position: relative; padding-bottom: 120px; }
.process .stack-card { padding: 56px; }
.process .stack-card[data-index="0"] { top: 100px; background: linear-gradient(135deg, #2A5275 0%, #1B3A52 100%); }
.process .stack-card[data-index="1"] { top: 130px; background: linear-gradient(135deg, #1B3A52 0%, #14304a 100%); }
.process .stack-card[data-index="2"] { top: 160px; background: linear-gradient(135deg, #14304a 0%, #0F2A40 100%); }
.process .stack-card + .stack-card { margin-top: 40px; }
.process .stack-card .card-geo { width: 280px; height: 280px; opacity: 0.12; }
.process .stack-card .card-inner { grid-template-columns: auto 1fr; gap: 56px; align-items: start; }
.process .stack-card .phase-num {
  font-family: "Inter", sans-serif; font-size: 88px; font-weight: 600;
  color: rgba(184, 149, 74, 0.9); letter-spacing: -0.04em; line-height: 0.8;
}
.process .stack-card .phase-content { max-width: 620px; }
.process .stack-card .phase-tag {
  font-family: "JetBrains Mono", monospace; font-size: 12px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--color-brass-light); margin-bottom: 16px; display: block;
}
.process .stack-card h3 { font-family: "Inter", sans-serif; font-size: 32px; color: var(--color-paper); line-height: 1.2; margin-bottom: 18px; }
.process .stack-card p { font-size: 18px; line-height: 1.65; color: rgba(250, 248, 245, 0.85); margin-bottom: 14px; }
.process .stack-card .meta {
  display: inline-flex; align-items: center; gap: 10px; padding: 8px 14px;
  background: rgba(184, 149, 74, 0.14); border: 1px solid rgba(184, 149, 74, 0.3); border-radius: 4px;
  font-family: "JetBrains Mono", monospace; font-size: 12px; color: var(--color-brass-light);
  letter-spacing: 0.1em; text-transform: uppercase; margin-top: 18px;
}

/* geschwungener Übergang process -> deliverables */
.section-curve-top { position: relative; margin-top: -1px; }
.section-curve-top::before {
  content: "";
  display: block;
  height: 80px;
  background: var(--color-paper);
  border-radius: 50% 50% 0 0 / 100% 100% 0 0;
  margin-top: -80px;
  position: relative;
  z-index: 2;
}

/* ---------- DELIVERABLES ---------- */
.deliverables { padding: 40px 0 130px; background: var(--color-paper); }
.deliverables .head { display: grid; grid-template-columns: 1fr 1.5fr; gap: 64px; margin-bottom: 56px; align-items: start; }
.deliverables .head .eyebrow { margin-bottom: 16px; }
.deliverables .head h2 { font-size: 46px; line-height: 1.08; }
.deliverables .head p { font-size: 18px; line-height: 1.65; padding-top: 12px; }
.deliverables-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.deliverable-card {
  background: var(--color-paper); border: 1px solid var(--color-border); border-radius: 12px;
  padding: 38px 34px; position: relative; overflow: hidden;
  transition: transform 0.35s var(--ease), border-color 0.35s var(--ease), box-shadow 0.35s var(--ease);
}
.deliverable-card::after {
  content: ""; position: absolute; left: 0; bottom: 0; height: 3px; width: 0;
  background: linear-gradient(90deg, var(--color-brass), var(--color-brass-light));
  transition: width 0.5s var(--ease-out);
}
.deliverable-card:hover {
  transform: translateY(-4px); border-color: var(--color-border-strong);
  box-shadow: 0 12px 32px rgba(27, 58, 82, 0.08);
}
.deliverable-card:hover::after { width: 100%; }
.deliverable-card .icon {
  width: 40px; height: 40px; margin-bottom: 24px; display: flex; align-items: center; justify-content: center;
  background: rgba(184, 149, 74, 0.1); border-radius: 8px; color: var(--color-brass);
  transition: background 0.3s var(--ease), transform 0.3s var(--ease);
}
.deliverable-card .icon svg { width: 22px; height: 22px; }
.deliverable-card:hover .icon { background: rgba(184, 149, 74, 0.2); transform: scale(1.08) rotate(-3deg); }
.deliverable-card h3 { font-family: "Inter", sans-serif; font-size: 20px; color: var(--color-marine); margin-bottom: 10px; line-height: 1.3; }
.deliverable-card p { font-size: 16px; line-height: 1.6; }
.deliverable-card .bg-accent { position: absolute; right: -30px; bottom: -30px; width: 130px; height: 130px; opacity: 0.05; transition: opacity 0.4s var(--ease); pointer-events: none; }
.deliverable-card:hover .bg-accent { opacity: 0.12; }

/* ---------- PRICE ---------- */
.price { background: var(--color-sand); padding: 130px 0; position: relative; overflow: hidden; }
.price-geo { position: absolute; left: -100px; top: 50%; transform: translateY(-50%); width: 500px; height: 500px; opacity: 0.06; pointer-events: none; }
.price::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(circle at 80% 50%, rgba(184, 149, 74, 0.1) 0%, transparent 50%);
  pointer-events: none;
}
.price .container { position: relative; z-index: 1; }
.price .head .eyebrow { margin-bottom: 16px; }
.price .head h2 { font-size: 46px; line-height: 1.08; margin-bottom: 48px; max-width: 720px; }
.price-display { display: grid; grid-template-columns: 1fr 1.2fr; gap: 80px; align-items: start; }
.price-display .amount .label {
  font-family: "JetBrains Mono", monospace; font-size: 12px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--color-brass); margin-bottom: 16px;
}
.price-display .amount .number {
  font-family: "Inter", sans-serif; font-size: 150px; font-weight: 600; color: var(--color-marine);
  letter-spacing: -0.045em; line-height: 0.88; margin-bottom: 12px; display: inline-block;
  animation: priceBreathe 6s ease-in-out infinite; animation-delay: 0.8s;
}
.price-display .amount .currency { font-size: 58px; color: var(--color-brass); vertical-align: top; margin-left: 4px; }
.price-display .amount .vat { font-family: "Inter", sans-serif; font-size: 16px; color: var(--color-stone); }
@keyframes priceBreathe { 0%, 100% { transform: scale(1); } 50% { transform: scale(1.012); } }
.price-display .details { padding-top: 24px; }
.price-display .details .section-title {
  font-family: "JetBrains Mono", monospace; font-size: 11px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--color-marine); margin-bottom: 16px;
}
.price-display .details ul { list-style: none; margin-bottom: 32px; }
.price-display .details ul li {
  font-family: "Lora", serif; font-size: 17px; line-height: 1.5; padding: 11px 0 11px 24px;
  position: relative; border-bottom: 1px solid rgba(27, 58, 82, 0.08);
}
.price-display .details ul li:last-child { border-bottom: none; }
.price-display .details ul li::before { content: "→"; position: absolute; left: 0; color: var(--color-brass); font-family: "Inter", sans-serif; }
.price-display .details .note {
  font-family: "Lora", serif; font-style: italic; font-size: 15px; color: var(--color-stone);
  line-height: 1.6; padding: 16px 20px; background: rgba(250, 248, 245, 0.7);
  border-left: 2px solid var(--color-brass); border-radius: 0 4px 4px 0;
}

/* ---------- FAQ (Layout: zweispaltig) ---------- */
.faq { padding: 130px 0; }
.faq .head { margin-bottom: 56px; max-width: 720px; }
.faq .head .eyebrow { margin-bottom: 16px; }
.faq .head h2 { font-size: 46px; line-height: 1.08; }
.faq-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0 48px; }

/* ---------- DARK CTA (seitenspezifische Maße) ---------- */
.dark-cta { padding: 130px 0; }
.dark-cta-geo { width: 700px; height: 700px; }
.dark-cta::before { width: 800px; height: 800px; }
.dark-cta h2 { font-size: 50px; line-height: 1.08; }
.dark-cta p { max-width: 620px; }

/* ---------- RESPONSIVE ---------- */
@media (max-width: 1024px) {
  .hero .hero-grid { grid-template-columns: 1fr; gap: 56px; }
  .hero .text-col h1 { font-size: 48px; }
  .hero-geo .compass-lg { width: 420px; height: 420px; opacity: 0.3; }
  .problem .grid { grid-template-columns: 1fr; gap: 32px; }
  .process .stack-card { padding: 40px; }
  .process .stack-card .card-inner { grid-template-columns: 1fr; gap: 24px; }
  .process .stack-card .phase-num { font-size: 64px; }
  .deliverables .head { grid-template-columns: 1fr; gap: 32px; }
  .price-display { grid-template-columns: 1fr; gap: 48px; }
  .price-display .amount .number { font-size: 112px; }
  .faq-grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  .hero { padding: 72px 0 80px; padding-top: 72px; }
  .hero .text-col h1 { font-size: 38px; }
  .hero .text-col .lead { font-size: 18px; }
  .hero-stats { grid-template-columns: 1fr 1fr; gap: 12px; }
  .stats-strip { padding: 40px 0; }
  .stats-strip .grid { grid-template-columns: 1fr 1fr; gap: 24px; }
  .stat-cell .value { font-size: 30px; }
  .problem, .price, .faq, .dark-cta { padding: 80px 0; }
  .process { padding: 80px 0 0; }
  .deliverables { padding: 40px 0 80px; }
  .problem .head h2, .deliverables .head h2, .price .head h2, .faq .head h2, .process .head h2 { font-size: 32px; }
  .problem .body p { font-size: 17px; }
  .problem .body .punch { font-size: 24px; }
  .process .stack-card { padding: 32px 24px; }
  .process .stack-card h3 { font-size: 24px; }
  .process .stack-card[data-index="0"], .process .stack-card[data-index="1"], .process .stack-card[data-index="2"] { top: 80px; }
  .deliverables-grid { grid-template-columns: 1fr; }
  .price-display .amount .number { font-size: 84px; }
  .price-display .amount .currency { font-size: 38px; }
  .dark-cta h2 { font-size: 32px; }
}
