/*
Theme Name: IPTV Alpen
Theme URI: https://iptvalpen.com/
Author: iptv österreich
Author URI: https://iptvalpen.com/
Description: Production-ready custom WordPress theme for iptv österreich (iptvalpen.com). Design family: App / Control Center with alpine accents. Mobile-first, fast, accessible, localized for Austria (de-AT). No jQuery, inline SVG icons only.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: iptv-alpen
*/

/* ============================================================
   DESIGN SYSTEM — "Control Center" (App dashboard, alpine)
   Brand CSS prefix: alpen-
   ============================================================ */
:root {
  /* Color system */
  --alpen-bg: #ffffff;
  --alpen-bg-soft: #f5f7fa;
  --alpen-bg-soft-2: #eef2f7;
  --alpen-cockpit: #0f1722;        /* deep charcoal cockpit */
  --alpen-cockpit-2: #16202e;
  --alpen-heading: #0f1722;
  --alpen-text: #46505e;
  --alpen-text-soft: #6b7686;
  --alpen-on-dark: #e8eef6;
  --alpen-on-dark-soft: #9aa7b8;

  --alpen-primary: #e11d2e;        /* alpine red (CTA) */
  --alpen-primary-600: #c0152a;
  --alpen-primary-700: #a01124;
  --alpen-accent: #14b8c4;         /* glacier teal (tech) */
  --alpen-accent-600: #0e98a3;
  --alpen-success: #18a558;
  --alpen-warning: #f5a623;
  --alpen-whatsapp: #25d366;
  --alpen-whatsapp-600: #1da851;

  --alpen-border: #e2e8f0;
  --alpen-border-dark: rgba(255,255,255,.12);

  /* Shadows */
  --alpen-shadow-sm: 0 1px 2px rgba(15,23,34,.06), 0 1px 3px rgba(15,23,34,.08);
  --alpen-shadow-md: 0 8px 24px rgba(15,23,34,.08);
  --alpen-shadow-lg: 0 24px 60px rgba(15,23,34,.14);
  --alpen-shadow-cockpit: 0 30px 80px rgba(8,15,28,.45);

  /* Radius */
  --alpen-r-sm: 10px;
  --alpen-r: 16px;
  --alpen-r-lg: 22px;
  --alpen-r-pill: 999px;

  /* Layout */
  --alpen-max: 1180px;
  --alpen-gut: clamp(16px, 4vw, 28px);

  /* Type */
  --alpen-font-head: "Space Grotesk", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --alpen-font-body: "DM Sans", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

/* ----------------------------- Reset / base ----------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--alpen-font-body);
  font-size: 17px;
  line-height: 1.65;
  color: var(--alpen-text);
  background: var(--alpen-bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img, svg, video { max-width: 100%; height: auto; display: block; }
a { color: var(--alpen-primary-600); text-decoration: none; }
a:hover { text-decoration: underline; }
h1, h2, h3, h4 { font-family: var(--alpen-font-head); color: var(--alpen-heading); line-height: 1.15; margin: 0 0 .5em; font-weight: 700; }
h1 { font-size: clamp(2rem, 5.2vw, 3.25rem); letter-spacing: -.02em; }
h2 { font-size: clamp(1.6rem, 3.6vw, 2.4rem); letter-spacing: -.015em; }
h3 { font-size: clamp(1.2rem, 2.4vw, 1.5rem); }
p { margin: 0 0 1rem; }
ul, ol { margin: 0 0 1rem; padding-left: 1.25rem; }
:focus-visible { outline: 3px solid var(--alpen-accent); outline-offset: 2px; border-radius: 4px; }

/* ----------------------------- Layout helpers ----------------------------- */
.alpen-container { width: 100%; max-width: var(--alpen-max); margin-inline: auto; padding-inline: var(--alpen-gut); }
.alpen-section { padding-block: clamp(48px, 7vw, 96px); }
.alpen-section--soft { background: var(--alpen-bg-soft); }
.alpen-section--dark { background: var(--alpen-cockpit); color: var(--alpen-on-dark); }
.alpen-section--dark h1, .alpen-section--dark h2, .alpen-section--dark h3 { color: #fff; }
.alpen-eyebrow {
  display: inline-flex; align-items: center; gap: .5rem;
  font-family: var(--alpen-font-head); font-weight: 600; font-size: .8rem;
  text-transform: uppercase; letter-spacing: .12em;
  color: var(--alpen-accent-600);
  background: rgba(20,184,196,.1); padding: .35rem .75rem; border-radius: var(--alpen-r-pill);
}
.alpen-section--dark .alpen-eyebrow { color: #6fe3ec; background: rgba(20,184,196,.16); }
.alpen-section__head { max-width: 660px; margin-bottom: clamp(28px, 4vw, 48px); }
.alpen-section__head--center { margin-inline: auto; text-align: center; }
.alpen-lead { font-size: 1.12rem; color: var(--alpen-text-soft); }
.alpen-section--dark .alpen-lead { color: var(--alpen-on-dark-soft); }
.alpen-grid { display: grid; gap: clamp(16px, 2.4vw, 26px); }
.alpen-grid--2 { grid-template-columns: repeat(2, 1fr); }
.alpen-grid--3 { grid-template-columns: repeat(3, 1fr); }
.alpen-grid--4 { grid-template-columns: repeat(4, 1fr); }
.alpen-visually-hidden { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* ----------------------------- Buttons ----------------------------- */
.alpen-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .55rem;
  font-family: var(--alpen-font-head); font-weight: 600; font-size: 1rem; line-height: 1;
  padding: .95rem 1.5rem; border-radius: var(--alpen-r-pill);
  border: 1.5px solid transparent; cursor: pointer; text-decoration: none;
  transition: transform .15s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
  min-height: 50px;
}
.alpen-btn:hover { text-decoration: none; transform: translateY(-2px); }
.alpen-btn--primary { background: var(--alpen-primary); color: #fff; box-shadow: 0 10px 24px rgba(225,29,46,.32); }
.alpen-btn--primary:hover { background: var(--alpen-primary-600); color: #fff; }
.alpen-btn--ghost { background: transparent; color: var(--alpen-heading); border-color: var(--alpen-border); }
.alpen-btn--ghost:hover { border-color: var(--alpen-heading); color: var(--alpen-heading); }
.alpen-section--dark .alpen-btn--ghost { color: #fff; border-color: var(--alpen-border-dark); }
.alpen-btn--accent { background: var(--alpen-accent); color: #062a2d; }
.alpen-btn--accent:hover { background: var(--alpen-accent-600); color: #fff; }
.alpen-btn--wa { background: var(--alpen-whatsapp); color: #06351b; }
.alpen-btn--wa:hover { background: var(--alpen-whatsapp-600); color: #fff; }
.alpen-btn--lg { padding: 1.1rem 1.9rem; font-size: 1.06rem; min-height: 56px; }
.alpen-btn--block { width: 100%; }

/* ----------------------------- Header ----------------------------- */
.alpen-skip-link { position: absolute; left: -999px; top: 0; z-index: 1000; background: #fff; color: var(--alpen-heading); padding: .75rem 1rem; border-radius: 0 0 var(--alpen-r-sm) 0; font-weight: 600; }
.alpen-skip-link:focus { left: 0; }

.alpen-header { position: sticky; top: 0; z-index: 100; background: rgba(255,255,255,.88); backdrop-filter: saturate(160%) blur(12px); border-bottom: 1px solid var(--alpen-border); }
.alpen-header__bar { display: flex; align-items: center; gap: 1rem; min-height: 68px; }
.alpen-brand { display: inline-flex; align-items: center; gap: .6rem; font-family: var(--alpen-font-head); font-weight: 700; color: var(--alpen-heading); font-size: 1.1rem; }
.alpen-brand:hover { text-decoration: none; }
.alpen-brand img { height: 38px; width: auto; }
.alpen-nav { margin-left: auto; }
.alpen-nav ul { list-style: none; display: flex; gap: .35rem; margin: 0; padding: 0; align-items: center; }
.alpen-nav a { display: inline-block; padding: .55rem .8rem; border-radius: var(--alpen-r-pill); font-weight: 500; font-size: .98rem; color: var(--alpen-heading); }
.alpen-nav a:hover, .alpen-nav .current-menu-item > a { background: var(--alpen-bg-soft-2); text-decoration: none; }
.alpen-header__cta { display: flex; align-items: center; gap: .5rem; }
.alpen-burger { display: none; background: none; border: 1.5px solid var(--alpen-border); border-radius: var(--alpen-r-sm); width: 46px; height: 46px; align-items: center; justify-content: center; cursor: pointer; }
.alpen-burger svg { width: 24px; height: 24px; }

@media (max-width: 960px) {
  .alpen-burger { display: inline-flex; }
  .alpen-nav { position: fixed; inset: 68px 0 auto 0; background: #fff; border-bottom: 1px solid var(--alpen-border); margin: 0; padding: 1rem var(--alpen-gut) 1.4rem; transform: translateY(-120%); transition: transform .28s ease; box-shadow: var(--alpen-shadow-md); max-height: calc(100vh - 68px); overflow-y: auto; }
  .alpen-nav[data-open="true"] { transform: translateY(0); }
  .alpen-nav ul { flex-direction: column; align-items: stretch; gap: .15rem; }
  .alpen-nav a { padding: .85rem 1rem; font-size: 1.05rem; }
  .alpen-header__cta .alpen-btn--ghost { display: none; }
}

/* ----------------------------- Hero (dashboard) ----------------------------- */
.alpen-hero { position: relative; background: radial-gradient(120% 130% at 80% -10%, #1d2c40 0%, var(--alpen-cockpit) 55%, #0a111c 100%); color: var(--alpen-on-dark); overflow: hidden; }
.alpen-hero::before { content: ""; position: absolute; inset: 0; background-image: radial-gradient(rgba(255,255,255,.05) 1px, transparent 1px); background-size: 22px 22px; opacity: .5; pointer-events: none; }
.alpen-hero__inner { display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(24px, 4vw, 56px); align-items: center; padding-block: clamp(48px, 7vw, 90px); position: relative; }
.alpen-hero h1 { color: #fff; }
.alpen-hero h1 .alpen-hl { background: linear-gradient(100deg, #ff5066, #ffb199); -webkit-background-clip: text; background-clip: text; color: transparent; }
.alpen-hero__lead { font-size: 1.15rem; color: var(--alpen-on-dark-soft); max-width: 52ch; }
.alpen-hero__cta { display: flex; flex-wrap: wrap; gap: .75rem; margin-top: 1.6rem; }
.alpen-hero__chips { display: flex; flex-wrap: wrap; gap: .5rem 1.2rem; margin-top: 1.8rem; list-style: none; padding: 0; }
.alpen-hero__chips li { display: flex; align-items: center; gap: .45rem; font-size: .95rem; color: var(--alpen-on-dark); }
.alpen-hero__chips svg { width: 18px; height: 18px; color: var(--alpen-accent); flex: none; }

/* dashboard mockup */
.alpen-dash { background: linear-gradient(180deg, #18222f, #0d1622); border: 1px solid var(--alpen-border-dark); border-radius: var(--alpen-r-lg); box-shadow: var(--alpen-shadow-cockpit); padding: 14px; }
.alpen-dash__bar { display: flex; gap: 6px; padding: 4px 6px 12px; }
.alpen-dash__bar span { width: 11px; height: 11px; border-radius: 50%; background: #344256; }
.alpen-dash__screen { background: #0a121d; border-radius: var(--alpen-r); padding: 14px; display: grid; gap: 12px; }
.alpen-dash__feature { display: flex; align-items: center; gap: 10px; background: rgba(255,255,255,.04); border: 1px solid var(--alpen-border-dark); border-radius: var(--alpen-r-sm); padding: 10px 12px; }
.alpen-dash__feature svg { width: 22px; height: 22px; color: var(--alpen-accent); flex: none; }
.alpen-dash__feature b { color: #fff; font-family: var(--alpen-font-head); font-size: .98rem; }
.alpen-dash__feature small { display: block; color: var(--alpen-on-dark-soft); font-size: .82rem; }
.alpen-dash__tiles { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; }
.alpen-dash__tile { aspect-ratio: 3/4; border-radius: 8px; background: linear-gradient(160deg, #243348, #16202e); border: 1px solid var(--alpen-border-dark); }
.alpen-dash__tile:nth-child(2) { background: linear-gradient(160deg, #3a2230, #241622); }
.alpen-dash__tile:nth-child(3) { background: linear-gradient(160deg, #1d3340, #14242e); }

@media (max-width: 860px) {
  .alpen-hero__inner { grid-template-columns: 1fr; }
  .alpen-dash { max-width: 460px; margin-inline: auto; }
}

/* ----------------------------- Trust bar / stats ----------------------------- */
.alpen-stats { display: grid; grid-template-columns: repeat(4,1fr); gap: clamp(12px,2vw,22px); }
.alpen-stat { text-align: center; padding: 1.2rem 1rem; background: #fff; border: 1px solid var(--alpen-border); border-radius: var(--alpen-r); box-shadow: var(--alpen-shadow-sm); }
.alpen-stat__num { font-family: var(--alpen-font-head); font-weight: 700; font-size: clamp(1.5rem,3vw,2rem); color: var(--alpen-heading); line-height: 1; }
.alpen-stat__label { font-size: .92rem; color: var(--alpen-text-soft); margin-top: .35rem; }

/* ----------------------------- Cards / generic panel ----------------------------- */
.alpen-card { background: #fff; border: 1px solid var(--alpen-border); border-radius: var(--alpen-r); padding: clamp(20px,2.6vw,30px); box-shadow: var(--alpen-shadow-sm); transition: transform .2s ease, box-shadow .2s ease; height: 100%; }
.alpen-card--hover:hover { transform: translateY(-4px); box-shadow: var(--alpen-shadow-md); }
.alpen-card__icon { width: 48px; height: 48px; border-radius: var(--alpen-r-sm); display: inline-flex; align-items: center; justify-content: center; background: rgba(20,184,196,.12); color: var(--alpen-accent-600); margin-bottom: 1rem; }
.alpen-card__icon svg { width: 26px; height: 26px; }
.alpen-card h3 { margin-bottom: .4rem; }
.alpen-card p { margin-bottom: 0; color: var(--alpen-text-soft); }

/* ----------------------------- Feature tabs (control panel) ----------------------------- */
.alpen-tabs__list { display: flex; flex-wrap: wrap; gap: .5rem; margin-bottom: 1.6rem; }
.alpen-tab { font-family: var(--alpen-font-head); font-weight: 600; font-size: .98rem; padding: .7rem 1.1rem; border-radius: var(--alpen-r-pill); border: 1.5px solid var(--alpen-border); background: #fff; color: var(--alpen-heading); cursor: pointer; }
.alpen-tab[aria-selected="true"] { background: var(--alpen-cockpit); color: #fff; border-color: var(--alpen-cockpit); }
.alpen-tabpanel { display: none; }
.alpen-tabpanel[data-active="true"] { display: block; animation: alpen-fade .3s ease; }
.alpen-panelgrid { display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(20px,3vw,40px); align-items: center; }
.alpen-panelgrid ul { list-style: none; padding: 0; }
.alpen-panelgrid li { display: flex; gap: .6rem; padding: .45rem 0; }
.alpen-panelgrid li svg { width: 20px; height: 20px; color: var(--alpen-success); flex: none; margin-top: 3px; }
@keyframes alpen-fade { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }
@media (max-width: 760px) { .alpen-panelgrid { grid-template-columns: 1fr; } }

/* ----------------------------- Pricing (segmented selector) ----------------------------- */
.alpen-seg { display: inline-flex; background: var(--alpen-bg-soft-2); border-radius: var(--alpen-r-pill); padding: 5px; gap: 4px; }
.alpen-seg button { font-family: var(--alpen-font-head); font-weight: 600; border: none; background: transparent; color: var(--alpen-text); padding: .6rem 1.1rem; border-radius: var(--alpen-r-pill); cursor: pointer; font-size: .95rem; }
.alpen-seg button[aria-pressed="true"] { background: #fff; color: var(--alpen-heading); box-shadow: var(--alpen-shadow-sm); }
.alpen-plans { display: grid; grid-template-columns: repeat(4,1fr); gap: clamp(14px,2vw,22px); margin-top: 2rem; }
.alpen-plan { position: relative; background: #fff; border: 1.5px solid var(--alpen-border); border-radius: var(--alpen-r-lg); padding: 1.6rem 1.4rem; display: flex; flex-direction: column; }
.alpen-plan--feature { border-color: var(--alpen-primary); box-shadow: 0 18px 44px rgba(225,29,46,.16); }
.alpen-plan__badge { position: absolute; top: -13px; left: 50%; transform: translateX(-50%); background: var(--alpen-primary); color: #fff; font-family: var(--alpen-font-head); font-weight: 600; font-size: .76rem; letter-spacing: .04em; text-transform: uppercase; padding: .3rem .8rem; border-radius: var(--alpen-r-pill); white-space: nowrap; }
.alpen-plan__name { font-family: var(--alpen-font-head); font-weight: 600; color: var(--alpen-text-soft); }
.alpen-plan__price { font-family: var(--alpen-font-head); font-weight: 700; font-size: 2.4rem; color: var(--alpen-heading); line-height: 1; margin: .4rem 0; }
.alpen-plan__price small { font-size: .95rem; font-weight: 500; color: var(--alpen-text-soft); }
.alpen-plan__per { font-size: .9rem; color: var(--alpen-text-soft); margin-bottom: 1rem; }
.alpen-plan ul { list-style: none; padding: 0; margin: 0 0 1.4rem; }
.alpen-plan li { display: flex; gap: .5rem; font-size: .95rem; padding: .3rem 0; }
.alpen-plan li svg { width: 18px; height: 18px; color: var(--alpen-success); flex: none; margin-top: 3px; }
.alpen-plan .alpen-btn { margin-top: auto; }
@media (max-width: 900px) { .alpen-plans { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 520px) { .alpen-plans { grid-template-columns: 1fr; } }

/* ----------------------------- Steps ----------------------------- */
.alpen-steps { counter-reset: step; display: grid; grid-template-columns: repeat(4,1fr); gap: clamp(16px,2.4vw,26px); }
.alpen-step { position: relative; padding-top: 3.4rem; }
.alpen-step::before { counter-increment: step; content: counter(step); position: absolute; top: 0; left: 0; width: 46px; height: 46px; border-radius: 50%; background: var(--alpen-cockpit); color: #fff; font-family: var(--alpen-font-head); font-weight: 700; display: flex; align-items: center; justify-content: center; font-size: 1.2rem; }
.alpen-step h3 { font-size: 1.15rem; }
.alpen-step p { color: var(--alpen-text-soft); margin: 0; }
@media (max-width: 820px) { .alpen-steps { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 480px) { .alpen-steps { grid-template-columns: 1fr; } }

/* ----------------------------- Device cards ----------------------------- */
.alpen-devices { display: grid; grid-template-columns: repeat(4,1fr); gap: clamp(14px,2vw,20px); }
.alpen-device { text-align: center; background: #fff; border: 1px solid var(--alpen-border); border-radius: var(--alpen-r); padding: 1.5rem 1rem; box-shadow: var(--alpen-shadow-sm); transition: transform .2s ease; }
.alpen-device:hover { transform: translateY(-4px); }
.alpen-device svg { width: 40px; height: 40px; color: var(--alpen-cockpit); margin: 0 auto .7rem; }
.alpen-device b { font-family: var(--alpen-font-head); color: var(--alpen-heading); display: block; }
.alpen-device small { color: var(--alpen-text-soft); }
@media (max-width: 760px) { .alpen-devices { grid-template-columns: repeat(2,1fr); } }

/* ----------------------------- Scenario cards (no fake reviews) ----------------------------- */
.alpen-scenario { background: var(--alpen-bg-soft); border: 1px solid var(--alpen-border); border-left: 4px solid var(--alpen-accent); border-radius: var(--alpen-r); padding: 1.6rem; }
.alpen-scenario__role { font-family: var(--alpen-font-head); font-weight: 600; color: var(--alpen-heading); }
.alpen-scenario__tag { font-size: .8rem; color: var(--alpen-accent-600); font-weight: 600; text-transform: uppercase; letter-spacing: .05em; }
.alpen-scenario p { margin: .6rem 0 0; }

/* ----------------------------- FAQ accordion ----------------------------- */
.alpen-faq { max-width: 820px; margin-inline: auto; display: grid; gap: .7rem; }
.alpen-faq__item { background: #fff; border: 1px solid var(--alpen-border); border-radius: var(--alpen-r); overflow: hidden; }
.alpen-faq__q { width: 100%; display: flex; justify-content: space-between; align-items: center; gap: 1rem; text-align: left; background: none; border: none; cursor: pointer; padding: 1.15rem 1.3rem; font-family: var(--alpen-font-head); font-weight: 600; font-size: 1.05rem; color: var(--alpen-heading); }
.alpen-faq__q svg { width: 22px; height: 22px; flex: none; transition: transform .25s ease; color: var(--alpen-primary); }
.alpen-faq__q[aria-expanded="true"] svg { transform: rotate(45deg); }
.alpen-faq__a { padding: 0 1.3rem; max-height: 0; overflow: hidden; transition: max-height .3s ease, padding .3s ease; }
.alpen-faq__a[data-open="true"] { padding: 0 1.3rem 1.25rem; }
.alpen-faq__a p { margin: 0; color: var(--alpen-text-soft); }

/* ----------------------------- Support / WhatsApp band ----------------------------- */
.alpen-support { display: grid; grid-template-columns: repeat(3,1fr); gap: clamp(14px,2vw,22px); }
.alpen-support__card { background: rgba(255,255,255,.04); border: 1px solid var(--alpen-border-dark); border-radius: var(--alpen-r); padding: 1.5rem; }
.alpen-support__card svg { width: 30px; height: 30px; color: var(--alpen-accent); margin-bottom: .7rem; }
.alpen-support__card b { color: #fff; font-family: var(--alpen-font-head); display: block; font-size: 1.1rem; }
.alpen-support__card p, .alpen-support__card a { color: var(--alpen-on-dark-soft); }
@media (max-width: 760px) { .alpen-support { grid-template-columns: 1fr; } }

/* ----------------------------- Comparison / generic table ----------------------------- */
.alpen-table-wrap { overflow-x: auto; }
table.alpen-table { width: 100%; border-collapse: collapse; background: #fff; border: 1px solid var(--alpen-border); border-radius: var(--alpen-r); overflow: hidden; }
.alpen-table th, .alpen-table td { padding: .9rem 1rem; text-align: left; border-bottom: 1px solid var(--alpen-border); }
.alpen-table thead th { background: var(--alpen-bg-soft-2); font-family: var(--alpen-font-head); }

/* ----------------------------- Final CTA banner ----------------------------- */
.alpen-cta-banner { background: linear-gradient(110deg, var(--alpen-primary), #ff5f54); color: #fff; border-radius: var(--alpen-r-lg); padding: clamp(28px,5vw,56px); text-align: center; box-shadow: var(--alpen-shadow-lg); }
.alpen-cta-banner h2 { color: #fff; }
.alpen-cta-banner p { color: rgba(255,255,255,.92); max-width: 60ch; margin-inline: auto; }
.alpen-cta-banner .alpen-btn--primary { background: #fff; color: var(--alpen-primary-700); box-shadow: none; }
.alpen-cta-banner .alpen-btn--primary:hover { background: #fff7f7; color: var(--alpen-primary-700); }
.alpen-cta-banner .alpen-btn--ghost { color: #fff; border-color: rgba(255,255,255,.6); }

/* ----------------------------- Blog cards ----------------------------- */
.alpen-posts { display: grid; grid-template-columns: repeat(3,1fr); gap: clamp(18px,2.4vw,28px); }
.alpen-post { background: #fff; border: 1px solid var(--alpen-border); border-radius: var(--alpen-r); overflow: hidden; box-shadow: var(--alpen-shadow-sm); display: flex; flex-direction: column; transition: transform .2s ease, box-shadow .2s ease; }
.alpen-post:hover { transform: translateY(-4px); box-shadow: var(--alpen-shadow-md); }
.alpen-post__thumb { aspect-ratio: 16/9; background: var(--alpen-bg-soft-2); object-fit: cover; width: 100%; }
.alpen-post__body { padding: 1.2rem 1.3rem 1.4rem; display: flex; flex-direction: column; flex: 1; }
.alpen-post__meta { font-size: .82rem; color: var(--alpen-text-soft); text-transform: uppercase; letter-spacing: .04em; margin-bottom: .4rem; }
.alpen-post h3 { font-size: 1.18rem; margin-bottom: .5rem; }
.alpen-post h3 a { color: var(--alpen-heading); }
.alpen-post__more { margin-top: auto; font-family: var(--alpen-font-head); font-weight: 600; color: var(--alpen-primary-600); }
@media (max-width: 860px) { .alpen-posts { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 560px) { .alpen-posts { grid-template-columns: 1fr; } }

/* ----------------------------- Article / single ----------------------------- */
.alpen-article { max-width: 760px; margin-inline: auto; }
.alpen-article__meta { color: var(--alpen-text-soft); font-size: .95rem; margin-bottom: 1.2rem; }
.alpen-article :is(h2,h3) { margin-top: 1.8em; }
.alpen-article img { border-radius: var(--alpen-r); margin: 1.5rem 0; }
.alpen-article blockquote { border-left: 4px solid var(--alpen-accent); margin: 1.5rem 0; padding: .4rem 0 .4rem 1.2rem; color: var(--alpen-heading); font-size: 1.1rem; }

/* ----------------------------- Breadcrumbs ----------------------------- */
.alpen-crumbs { font-size: .9rem; color: var(--alpen-text-soft); padding-block: 1rem; }
.alpen-crumbs a { color: var(--alpen-text-soft); }
.alpen-crumbs span[aria-current] { color: var(--alpen-heading); font-weight: 600; }

/* ----------------------------- Page hero (inner pages) ----------------------------- */
.alpen-pagehero { background: var(--alpen-bg-soft); border-bottom: 1px solid var(--alpen-border); padding-block: clamp(36px,5vw,64px); }
.alpen-pagehero h1 { margin-bottom: .5rem; }
.alpen-pagehero p { max-width: 64ch; color: var(--alpen-text-soft); margin: 0; font-size: 1.1rem; }

/* ----------------------------- Forms ----------------------------- */
.alpen-field { margin-bottom: 1.1rem; }
.alpen-field label { display: block; font-family: var(--alpen-font-head); font-weight: 600; margin-bottom: .4rem; color: var(--alpen-heading); }
.alpen-input, .alpen-textarea, .alpen-select { width: 100%; font-family: inherit; font-size: 1rem; padding: .85rem 1rem; border: 1.5px solid var(--alpen-border); border-radius: var(--alpen-r-sm); background: #fff; color: var(--alpen-heading); }
.alpen-input:focus, .alpen-textarea:focus, .alpen-select:focus { border-color: var(--alpen-accent); outline: none; box-shadow: 0 0 0 3px rgba(20,184,196,.18); }
.alpen-textarea { min-height: 140px; resize: vertical; }

/* ----------------------------- Footer ----------------------------- */
.alpen-footer { background: var(--alpen-cockpit); color: var(--alpen-on-dark-soft); padding-block: clamp(40px,6vw,72px) 0; }
.alpen-footer a { color: var(--alpen-on-dark-soft); }
.alpen-footer a:hover { color: #fff; }
.alpen-footer__top { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: clamp(24px,3vw,40px); }
.alpen-footer__brand img { height: 40px; margin-bottom: 1rem; }
.alpen-footer__brand p { max-width: 38ch; }
.alpen-footer h4 { color: #fff; font-size: 1rem; margin-bottom: 1rem; }
.alpen-footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: .55rem; }
.alpen-footer__bottom { margin-top: clamp(28px,4vw,48px); border-top: 1px solid var(--alpen-border-dark); padding-block: 1.4rem; display: flex; flex-wrap: wrap; gap: .6rem 1.4rem; justify-content: space-between; font-size: .88rem; }
.alpen-footer__legal { display: flex; flex-wrap: wrap; gap: .4rem 1.1rem; }
@media (max-width: 820px) { .alpen-footer__top { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .alpen-footer__top { grid-template-columns: 1fr; } }

/* ----------------------------- Sticky mobile CTA ----------------------------- */
.alpen-mobile-cta { position: fixed; left: 0; right: 0; bottom: 0; z-index: 90; display: none; gap: .6rem; padding: .6rem var(--alpen-gut) calc(.6rem + env(safe-area-inset-bottom)); background: rgba(255,255,255,.96); backdrop-filter: blur(10px); border-top: 1px solid var(--alpen-border); }
.alpen-mobile-cta .alpen-btn { flex: 1; min-height: 48px; padding-block: .7rem; }
@media (max-width: 720px) { .alpen-mobile-cta { display: flex; } body { padding-bottom: 76px; } }

/* ----------------------------- Pagination ----------------------------- */
.alpen-pagination { display: flex; flex-wrap: wrap; gap: .4rem; justify-content: center; margin-top: 2.5rem; }
.alpen-pagination .page-numbers { display: inline-flex; min-width: 44px; height: 44px; align-items: center; justify-content: center; padding: 0 .7rem; border: 1px solid var(--alpen-border); border-radius: var(--alpen-r-sm); color: var(--alpen-heading); font-family: var(--alpen-font-head); font-weight: 600; }
.alpen-pagination .page-numbers.current { background: var(--alpen-cockpit); color: #fff; border-color: var(--alpen-cockpit); }
.alpen-pagination a.page-numbers:hover { border-color: var(--alpen-cockpit); text-decoration: none; }

/* ----------------------------- Utilities ----------------------------- */
.alpen-text-center { text-align: center; }
.alpen-mt-2 { margin-top: 2rem; }
.alpen-stack > * + * { margin-top: 1rem; }
.alpen-note { background: var(--alpen-bg-soft); border: 1px solid var(--alpen-border); border-radius: var(--alpen-r-sm); padding: 1rem 1.2rem; font-size: .95rem; }
.alpen-updated { display: inline-block; background: var(--alpen-bg-soft-2); border-radius: var(--alpen-r-pill); padding: .3rem .9rem; font-size: .85rem; color: var(--alpen-text-soft); margin-bottom: 1.5rem; }

/* ----------------------------- Reduced motion ----------------------------- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; scroll-behavior: auto !important; }
}

/* ----------------------------- Reveal-on-scroll ----------------------------- */
.alpen-reveal { opacity: 0; transform: translateY(18px); transition: opacity .5s ease, transform .5s ease; }
.alpen-reveal.is-visible { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .alpen-reveal { opacity: 1; transform: none; } }
