/* ============================================================
   STRANG — MANDATORY SITE-LEVEL COMPONENTS
   ------------------------------------------------------------
   These styles cover the four non-negotiable site components:
     1.  Utility bar (.strang-utility)
     2.  Site header (.strang-header) with dropdown menus
     3.  Site footer (.strang-footer)
     4.  Notdienst ribbon (.strang-ribbon)
     5.  Logo lockup (.strang-logo)

   Every Strang prototype MUST load `colors_and_type.css` and this
   file, drop in the snippets from `site/*.html`, and NOT override
   layout, colors, or behavior.

   Local overrides are explicitly forbidden by the brand guide.
   ============================================================ */

/* ---- Utility bar (top, navy-deep) ---------------------------- */
.strang-utility { background: var(--navy-900); color: var(--cream); font-size: 13px; line-height: 1.4; }
.strang-utility .inner { max-width: 1280px; margin: 0 auto; padding: 9px 32px; display: flex; align-items: center; gap: 20px; flex-wrap: wrap; }
.strang-utility .live { display: inline-flex; align-items: center; gap: 8px; }
.strang-utility .live .dot { width: 8px; height: 8px; border-radius: 9999px; background: var(--strang-orange); flex: none; box-shadow: 0 0 0 0 rgba(251,103,11,.55); animation: strang-pulse 1.8s infinite; }
@keyframes strang-pulse { 0% { box-shadow: 0 0 0 0 rgba(251,103,11,.55); } 70% { box-shadow: 0 0 0 9px rgba(251,103,11,0); } 100% { box-shadow: 0 0 0 0 rgba(251,103,11,0); } }
.strang-utility .hours { color: rgba(250,247,242,.85); }
.strang-utility .right { margin-left: auto; display: inline-flex; align-items: center; gap: 18px; }
.strang-utility a { color: var(--cream); text-decoration: none; display: inline-flex; align-items: center; gap: 8px; }
.strang-utility a:hover { color: var(--strang-orange); }
.strang-utility a.tel { font-family: var(--font-headline); font-weight: 800; font-size: 14px; letter-spacing: -0.015em; }
.strang-utility .sep { color: rgba(250,247,242,.3); }

/* ---- Site header (white, sticky) ----------------------------
   Tightened spec — dichter, 72 px Gesamthöhe, kein globaler
   Header-Underline, Active-Underline NUR unter dem aktiven Item.
   ------------------------------------------------------------ */
.strang-header { position: sticky; top: 0; z-index: 40; background: var(--paper); }
.strang-header .inner { max-width: 1280px; margin: 0 auto; padding: 0 32px; display: flex; align-items: center; height: 72px; }
.strang-header .brand { display: inline-flex; align-items: center; text-decoration: none; }
.strang-header .brand img { height: 44px; width: auto; display: block; }
.strang-header .nav { list-style: none; margin: 0 0 0 40px; padding: 0; display: flex; align-items: center; gap: 22px; font-size: 14px; font-weight: 700; letter-spacing: 0.005em; height: 100%; }
.strang-header .nav > li { position: relative; height: 100%; display: inline-flex; align-items: center; }
.strang-header .nav > li > a { color: var(--ink); text-decoration: none; display: inline-flex; align-items: center; gap: 4px; height: 100%; padding: 0; }
.strang-header .nav > li > a:hover { color: var(--strang-orange); }
.strang-header .nav > li.active > a { color: var(--strang-orange); position: relative; }
.strang-header .nav > li.active > a::after { content: ""; position: absolute; left: 0; right: 0; bottom: 18px; height: 2px; background: var(--strang-orange); }

/* Chevron — thin 1.25 px Lucide-style SVG, scoped via .caret */
.strang-header .nav .caret { display: inline-block; width: 10px; height: 6px; margin-left: 2px; opacity: 0.7; transition: transform 160ms ease; }
.strang-header .nav .caret path { stroke: currentColor; stroke-width: 1.25; fill: none; stroke-linecap: round; stroke-linejoin: round; }
.strang-header .nav > li:hover .caret, .strang-header .nav > li.open .caret, .strang-header .nav > li:focus-within .caret { transform: rotate(180deg); }

/* dropdown */
.strang-header .nav .dropdown { position: absolute; top: 100%; left: 50%; transform: translateX(-50%) translateY(4px); min-width: 320px; background: var(--paper); border: 1px solid var(--line); box-shadow: 0 18px 40px rgba(14,27,61,.14), 0 6px 12px rgba(14,27,61,.06); padding: 8px 0; opacity: 0; pointer-events: none; transition: opacity 140ms ease, transform 140ms ease; border-radius: 0; }
.strang-header .nav > li:hover .dropdown, .strang-header .nav > li.open .dropdown, .strang-header .nav > li:focus-within .dropdown { opacity: 1; pointer-events: auto; transform: translateX(-50%) translateY(0); }
.strang-header .nav .dropdown a { display: grid; grid-template-columns: auto 1fr; gap: 14px; align-items: baseline; padding: 12px 22px; color: var(--ink); text-decoration: none; font-weight: 600; font-size: 14px; }
.strang-header .nav .dropdown a:hover { background: var(--cream); color: var(--strang-orange); }
.strang-header .nav .dropdown a .num { font-family: var(--font-editorial); font-style: italic; font-weight: 300; color: var(--strang-orange); font-size: 14px; font-variation-settings: "opsz" 144, "SOFT" 100; min-width: 24px; }
.strang-header .nav .dropdown a .desc { color: var(--muted); font-size: 12px; font-weight: 500; display: block; margin-top: 2px; }

.strang-header .end { margin-left: auto; display: inline-flex; align-items: center; gap: 12px; }
.strang-header .end .cta { appearance: none; border: 0; background: var(--strang-orange); color: #fff; font-family: var(--font-body); font-weight: 700; font-size: 13px; letter-spacing: 0.04em; padding: 12px 20px; height: 40px; box-sizing: border-box; display: inline-flex; align-items: center; gap: 10px; text-decoration: none; border-radius: 0; cursor: pointer; transition: background 120ms ease, transform 80ms ease; }
.strang-header .end .cta:hover { background: var(--strang-orange-deep); }
.strang-header .end .cta:hover .arrow { transform: translateX(3px); }
.strang-header .end .cta .arrow { transition: transform 160ms ease; }
.strang-header .end .cta:active { transform: translateY(1px); }
.strang-header .end .cta:focus-visible { outline: 0; box-shadow: 0 0 0 3px rgba(251,103,11,.32); }

/* mobile header */
.strang-header .burger { display: none; appearance: none; border: 0; background: transparent; padding: 8px; cursor: pointer; }
.strang-header .burger span { display: block; width: 22px; height: 2px; background: var(--ink); margin: 4px 0; }
@media (max-width: 900px) {
  .strang-header .inner { padding: 0 24px; }
  .strang-header .nav { display: none; }
  .strang-header .end .cta { display: none; }
  .strang-header .burger { display: inline-flex; flex-direction: column; }
}

/* ---- Notdienst ribbon -------------------------------------- */
.strang-ribbon { background: var(--strang-orange); color: #fff; }
.strang-ribbon .inner { max-width: 1280px; margin: 0 auto; padding: 12px 32px; display: flex; align-items: center; gap: 16px; flex-wrap: wrap; font-size: 14px; }
.strang-ribbon .dot { width: 10px; height: 10px; border-radius: 9999px; background: #fff; flex: none; box-shadow: 0 0 0 0 rgba(255,255,255,.7); animation: strang-pulse-w 1.6s infinite; }
@keyframes strang-pulse-w { 0% { box-shadow: 0 0 0 0 rgba(255,255,255,.7); } 70% { box-shadow: 0 0 0 12px rgba(255,255,255,0); } 100% { box-shadow: 0 0 0 0 rgba(255,255,255,0); } }
.strang-ribbon b { font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; font-size: 12px; }
.strang-ribbon a.tel { margin-left: auto; color: #fff; text-decoration: none; font-family: var(--font-headline); font-weight: 800; font-size: 18px; letter-spacing: -0.02em; }
.strang-ribbon a.tel:hover { text-decoration: underline; text-underline-offset: 4px; }

/* ---- Site footer (navy-deep) ------------------------------- */
.strang-footer { background: var(--navy-900); color: var(--cream); padding: 72px 0 28px; }
.strang-footer .inner { max-width: 1280px; margin: 0 auto; padding: 0 32px; }
.strang-footer .cols { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr; gap: 48px; }
.strang-footer .brand-col img { height: 80px; width: auto; display: block; background: var(--cream); padding: 14px 18px; }
.strang-footer .brand-col p { color: rgba(250,247,242,.65); font-size: 14px; max-width: 32ch; margin: 20px 0 18px; line-height: 1.55; }
.strang-footer .brand-col .contact { display: grid; gap: 6px; font-size: 14px; }
.strang-footer .brand-col .contact .tel { font-family: var(--font-headline); font-weight: 800; font-size: 20px; color: var(--cream); text-decoration: none; letter-spacing: -0.022em; }
.strang-footer .brand-col .contact .tel:hover, .strang-footer a:hover { color: var(--strang-orange); }
.strang-footer .brand-col .contact a { color: var(--cream); text-decoration: none; opacity: 0.85; }
.strang-footer h4 { font-family: var(--font-body); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--strang-orange); font-weight: 800; margin: 0 0 16px; }
.strang-footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 9px; }
.strang-footer ul a { color: var(--cream); text-decoration: none; font-size: 14px; opacity: 0.85; }
.strang-footer .meta { display: flex; justify-content: space-between; align-items: center; margin-top: 56px; padding-top: 22px; border-top: 1px solid rgba(250,247,242,.15); font-size: 12px; color: rgba(250,247,242,.6); gap: 16px; flex-wrap: wrap; }
.strang-footer .meta .legal { display: flex; gap: 18px; }
.strang-footer .meta a { color: rgba(250,247,242,.6); text-decoration: none; }
@media (max-width: 900px) {
  .strang-footer .cols { grid-template-columns: 1fr 1fr; }
  .strang-footer .brand-col { grid-column: 1 / -1; }
}

/* ---- Logo lockup ------------------------------------------ */
.strang-logo { display: inline-block; line-height: 0; }
.strang-logo img { display: block; height: 56px; width: auto; }
.strang-logo--on-dark { background: var(--cream); padding: 10px 14px; }
.strang-logo--xs img { height: 32px; }
.strang-logo--sm img { height: 40px; }
.strang-logo--md img { height: 44px; }   /* DEFAULT navbar size (72px header) */
.strang-logo--lg img { height: 72px; }
.strang-logo--xl img { height: 96px; }

/* ============================================================
   PATCH 16.05.2026 — Fehlende .container-Klasse ergänzt
   Wird in CO²-Seite und potenziell anderen Layouts genutzt.
   Definition leitet sich aus DS-Tokens --container-max/--container-pad ab.
   ============================================================ */
.container {
  width: 100%;
  max-width: var(--container-max, 1280px);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--container-pad, 24px);
  padding-right: var(--container-pad, 24px);
  box-sizing: border-box;
}
@media (max-width: 720px) {
  .container {
    padding-left: 20px;
    padding-right: 20px;
  }
}
