/* ========================================
   DESIGN TOKENS
   ======================================== */
:root{
  /* Colors — KVG brand palette */
  --color-white:#fff;
  --color-black:#000;
  --color-primary:#f28f24;          /* carrot-orange — buttons & primary actions */
  --color-primary-dark:#d97a10;
  --color-primary-text:#3b2300;     /* High contrast text for primary buttons */
  --color-link:#009de0;             /* cerulean — text links */
  --color-secondary:#eb0000;        /* persimmon — accents & badges */
  --color-accent:#ebc818;           /* gold-tips */
  --color-background:#f7f8f9;       /* porcelain */
  --color-surface:#fff;             /* milk */
  --color-surface-alt:#e9eaee;      /* athens-gray */
  --color-border:#dbdce1;           /* mischka */
  --color-border-strong:#cdcfd5;    /* ghost */
  --color-text-main:#404452;        /* bright-gray */
  --color-text-muted:#777a83;       /* storm-gray */
  --color-text-light:#a2a6b3;       /* gray-chateau */

  /* Semantic colors */
  --color-success:#16a34a;
  --color-success-dark:#15803d;
  --color-success-light:#22c55e;
  --color-success-bg:#f0fdf4;
  --color-success-border:#bbf7d0;
  --color-warning:#f28f24;
  --color-warning-dark:#a16207;
  --color-warning-bg:#fbecda;
  --color-warning-border:#dbc2a6;
  --color-caution-bg:#fff7ed;
  --color-caution-border:#fed7aa;
  --color-star:#ebc818;
  --color-star-text:#b8960b;
  --color-surface-warm:#fdf8f2;
  --color-surface-overlay-0:rgb(255 255 255 / 0);
  --color-surface-overlay-10:rgb(255 255 255 / 0.1);
  --color-surface-overlay-20:rgb(255 255 255 / 0.2);
  --color-surface-overlay-25:rgb(255 255 255 / 0.25);
  --color-surface-overlay-40:rgb(255 255 255 / 0.4);
  --color-surface-overlay-90:rgb(255 255 255 / 0.9);
  --color-surface-overlay-94:rgb(255 255 255 / 0.94);
  --color-surface-overlay-95:rgb(255 255 255 / 0.95);
  --color-surface-overlay-96:rgb(255 255 255 / 0.96);
  --color-surface-overlay-100:rgb(255 255 255 / 1);
  --color-primary-bg-soft:rgb(242 143 36 / 0.06);
  --color-primary-border-soft:rgb(242 143 36 / 0.15);
  --color-primary-shadow-soft:rgb(242 143 36 / 0.25);
  --color-primary-shadow:rgb(242 143 36 / 0.3);
  --color-primary-border-strong:rgb(242 143 36 / 0.35);
  --color-primary-border-hover:rgb(242 143 36 / 0.4);
  --color-overlay-medium:rgb(0 0 0 / 0.5);
  --color-overlay-strong:rgb(0 0 0 / 0.6);
  --color-text-main-overlay-05:rgb(64 68 82 / 0.05);
  --color-overlay-dark:rgb(0 0 0 / 0.8);
  --color-overlay-darker:rgb(0 0 0 / 0.9);
  --color-lightbox-bg:#1a1d24;
  --color-lightbox-media:#2a2d35;
  --color-provider-tui:#70cbf4;
  --color-provider-sunweb:#e11b22;
  --color-provider-booking:#003580;

  /* Focus */
  --focus-ring:3px solid rgb(0 157 224 / 0.45);

  /* Radii */
  --radius:0.25rem;       /* 4px */
  --radius-lg:0.625rem;   /* 10px */
  --radius-full:9999px;

  /* Fonts — KVG fonts */
  --font-display:"SF Pro Display", system-ui, sans-serif;
  --font-body:"SF Pro Display", system-ui, sans-serif;

  /* Shadows — KVG layered style */
  --shadow-card:0 .4px .8px 0 rgba(0,0,0,.02), 0 1.33px 2.67px 0 rgba(0,0,0,.02), 0 6px 12px 0 rgba(0,0,0,.04);
  --shadow-card-hover:0 1.2px 2.4px 0 rgba(0,0,0,.09), 0 4px 8px 0 rgba(0,0,0,.12), 0 18px 36px 0 rgba(0,0,0,.21);
  --shadow-elevated:0 4px 8px 0 rgba(0,0,0,.12);
  --shadow-sticky:0 -4px 20px rgba(0,0,0,.08);
  --shadow-xs:0 1px 2px 0 rgb(0 0 0 / 0.05);
  --shadow-soft:0 2px 4px rgb(0 0 0 / 0.1);
  --shadow-soft-lg:0 4px 6px rgb(0 0 0 / 0.1);
  --shadow-award:0 2px 8px rgb(0 0 0 / 0.06);
  --shadow-primary-soft:0 10px 15px -3px var(--color-primary-shadow-soft);
  --shadow-primary:0 10px 15px -3px var(--color-primary-shadow);
  --shadow-dialog:0 20px 60px rgb(0 0 0 / 0.25);

  /* Layout dimensions */
  --site-max:1200px;
  --site-gutter:clamp(1rem, 3vw, 2rem);
  --sidebar-w:22rem;

  /* Z-index scale */
  --z-base:1;
  --z-raised:2;
  --z-overlay:10;
  --z-header:40;
  --z-sticky-bar:50;
}

/* ========================================
   RESET & BASE
   ======================================== */
*, *::before, *::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{display:block;min-height:100vh;background-color:var(--color-surface);font-family:var(--font-body);color:var(--color-text-main);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;background:none;border:none;color:inherit}
ul, ol{list-style:none}

/* ========================================
   UTILITIES
   ======================================== */
/* Material Symbols helper */
.icon-filled{font-variation-settings:"FILL" 1}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0}
.no-scrollbar{-ms-overflow-style:none;scrollbar-width:none}
.no-scrollbar::-webkit-scrollbar{display:none}
.line-clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.line-clamp-4{display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}
.justify-end{justify-content:flex-end}

/* ========================================
   ANIMATIONS
   ======================================== */
@keyframes fadeInUp{
  from {opacity:0;transform:translateY(12px)}
  to {opacity:1;transform:translateY(0)}
}
.animate-fade-in{animation:fadeInUp 0.4s ease-out both}
/* Section-reveal initial state (injected by JS, defined here to avoid CLS). */
.section--reveal-pending{opacity:0;transform:translateY(12px)}

/* ========================================
   LAYOUT
   ======================================== */
#main{width:100%;min-height:calc(100vh - var(--header-h));min-height:calc(100dvh - var(--header-h));overflow:visible;padding-bottom:calc(7rem + env(safe-area-inset-bottom, 0px))}

/* ========================================
   BREADCRUMB
   ======================================== */
#breadcrumb{padding:0.75rem 1rem 0.25rem}
#breadcrumb ol{display:flex;align-items:center;gap:0;overflow-x:auto;font-size:0.75rem;color:var(--color-text-light)}
#breadcrumb li{display:flex;align-items:center;white-space:nowrap}
#breadcrumb li + li::before{content:"chevron_right";display:inline-flex;align-items:center;margin:0 0.25rem;color:var(--color-text-light);font-family:"Material Symbols Outlined";font-size:14px;font-style:normal;font-variation-settings:"FILL" 0;line-height:1}
#breadcrumb a{transition:color 0.15s}
#breadcrumb a:hover{color:var(--color-link)}
#breadcrumb li:not(:has(a)){font-weight:500;color:var(--color-text-muted)}

/* ========================================
   SECTIONS (shared shell)
   ======================================== */
.section{padding:1.5rem 1rem 2rem}
.section--border{border-top:1px solid var(--color-border)}
.section--bg-white{background-color:var(--color-surface)}
.section--bg-alt{background-color:var(--color-background)}
.section--bg-muted{background-color:var(--color-surface-alt)}
.section--bg-warm{background-color:var(--color-surface-warm)}
.section__header{margin-bottom:1.25rem}
.section__title{font-family:var(--font-display);font-size:1.25rem;font-weight:700;color:var(--color-text-main)}

/* ========================================
   LINK ARROW (shared base)
   ======================================== */
.link-arrow{display:flex;align-items:center;gap:0.25rem;font-size:0.875rem;font-weight:700;color:var(--color-link);transition:text-decoration 0.15s}
.link-arrow:hover{text-decoration:underline}
.link-arrow .material-symbols-outlined{font-size:16px}
.link-arrow--muted{font-size:0.8125rem;font-weight:600;color:var(--color-text-muted)}
.link-arrow--muted:hover{color:var(--color-link)}

/* ========================================
   ALT CAROUSEL (shared base)
   ======================================== */
.alt-carousel{display:flex;gap:0.75rem;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:0.5rem}

/* ========================================
   BUTTONS: PRIMARY ACTIONS
   ======================================== */
.btn-primary,
.btn-provider{display:inline-flex;align-items:center;justify-content:center;background-color:var(--color-primary);box-shadow:var(--shadow-xs);color:var(--color-primary-text);font-weight:700;transition:all 0.2s cubic-bezier(0.4, 0, 0.2, 1)}
.btn-primary{gap:0.25rem;padding:0.625rem 1.25rem;font-size:0.875rem;border-radius:var(--radius-full)}
.btn-primary:hover,
.btn-provider:hover{background-color:var(--color-primary-dark);box-shadow:0 6px 16px var(--color-primary-shadow);transform:translateY(-2px)}
.btn-primary:active,
.btn-provider:active{box-shadow:0 2px 8px var(--color-primary-shadow);transform:translateY(0) scale(0.98)}
.btn-primary .material-symbols-outlined,
.btn-provider .material-symbols-outlined{font-size:16px}

/* ========================================
   DIALOG OVERLAY (shared base for modal dialogs)
   ======================================== */
body:has(dialog[open]){overflow:hidden}
body:has(dialog[open]) #main{overflow:hidden}

.dialog-overlay{margin:0;padding:0;border:none;background:transparent;inset:0;max-width:100%;max-height:100%;width:100%;height:100%;opacity:0;transition:opacity 0.22s ease, display 0.22s allow-discrete, overlay 0.22s allow-discrete}
.dialog-overlay[open]{display:flex;align-items:stretch;justify-content:center;opacity:1}
@starting-style{
.dialog-overlay[open]{opacity:0}
}
.dialog-overlay::backdrop{opacity:0;transition:opacity 0.22s ease, display 0.22s allow-discrete, overlay 0.22s allow-discrete}
.dialog-overlay[open]::backdrop{opacity:1}
@starting-style{
.dialog-overlay[open]::backdrop{opacity:0}
}
.dialog-overlay__panel{display:flex;flex-direction:column;width:100%;max-width:none;height:100vh;height:100dvh;min-height:0;pointer-events:auto}

@media (prefers-reduced-motion: reduce){
.dialog-overlay,
.dialog-overlay[open],
.dialog-overlay::backdrop,
.dialog-overlay[open]::backdrop{transition:none}
}

/* ========================================
   STICKY BOTTOM BAR (shared positioning)
   ======================================== */
#sticky-bar{position:fixed;right:0;bottom:0;left:0;z-index:var(--z-sticky-bar);display:flex;align-items:center;justify-content:space-between;width:100%;padding:0.75rem 1rem calc(0.75rem + env(safe-area-inset-bottom, 0px));background-color:rgba(255, 255, 255, 0.85);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid rgba(219, 220, 225, 0.5);box-shadow:0 -10px 25px -5px rgba(0, 0, 0, 0.05)}

/* ================================================================
   SHARED RESPONSIVE LAYOUT
   ================================================================ */
@media (min-width: 768px){
body{background-color:var(--color-background)}
#main{padding:0 var(--site-gutter) 4rem;max-width:var(--site-max);margin:0 auto;overflow:visible}

#sticky-bar{display:none}

#breadcrumb{padding:1rem 0 0.5rem}
#breadcrumb ol{font-size:0.75rem}

.section{padding:2rem 0;border-radius:var(--radius-lg)}
.section--border{border-top:none}
.section__title{font-size:1.5rem}

.section--bg-white,
.section--bg-alt,
.section--bg-warm{padding:1.75rem;margin-bottom:1.25rem;border:1px solid var(--color-border);background-color:var(--color-surface)}
.section--bg-alt{background-color:var(--color-background)}
.section--bg-warm{background-color:var(--color-surface-warm)}
.section--bg-muted{padding:1.5rem;margin-bottom:1.25rem;border-radius:var(--radius-lg);background-color:var(--color-surface-alt)}

.alt-carousel{display:grid;grid-template-columns:repeat(3, 1fr);overflow-x:visible;scroll-snap-type:none}
.alt-carousel--horizontal{display:flex;overflow-x:auto;scroll-snap-type:x mandatory}

.dialog-overlay{padding:2rem;align-items:center !important;justify-content:center !important}
.dialog-overlay__panel{max-width:min(54rem, 100%);height:auto;max-height:min(100dvh - 4rem, 56rem);border-radius:1rem;box-shadow:var(--shadow-dialog);overflow:hidden}
}

@media (min-width: 1024px){
#main{padding:0 var(--site-gutter) 5rem}

#breadcrumb{padding:1.25rem 0 0.5rem}

.alt-carousel{grid-template-columns:repeat(4, 1fr)}
}

@media (min-width: 1280px){
:root{--sidebar-w:24rem}
}
