/* =========================================================================
   SÜDI — Design System
   Brand: Off-White #F7F7F5 · Blau #0A67D9 · vier Welt-Farben
   Fonts: Slofyn (Display/Wortmarke) · Cottorway Pro (UI/Text)
   ========================================================================= */

/* ---------- Fonts (selbst-gehostet, DSGVO-konform) ---------- */
@font-face{font-family:'Slofyn';src:url('../fonts/Slofyn.otf') format('opentype');font-weight:400;font-style:normal;font-display:swap;}
@font-face{font-family:'Cottorway';src:url('../fonts/CottorwayPro-Light.otf') format('opentype');font-weight:300;font-style:normal;font-display:swap;}
@font-face{font-family:'Cottorway';src:url('../fonts/CottorwayPro-Regular.otf') format('opentype');font-weight:400;font-style:normal;font-display:swap;}
@font-face{font-family:'Cottorway';src:url('../fonts/CottorwayPro-Medium.otf') format('opentype');font-weight:500;font-style:normal;font-display:swap;}
@font-face{font-family:'Cottorway';src:url('../fonts/CottorwayPro-SemiBold.otf') format('opentype');font-weight:600;font-style:normal;font-display:swap;}
@font-face{font-family:'Cottorway';src:url('../fonts/CottorwayPro-Bold.otf') format('opentype');font-weight:700;font-style:normal;font-display:swap;}
@font-face{font-family:'Cottorway';src:url('../fonts/CottorwayPro-ExtraBold.otf') format('opentype');font-weight:800;font-style:normal;font-display:swap;}
@font-face{font-family:'Cottorway';src:url('../fonts/CottorwayPro-Black.otf') format('opentype');font-weight:900;font-style:normal;font-display:swap;}
@font-face{font-family:'Cottorway';src:url('../fonts/CottorwayItalics-Medium.otf') format('opentype');font-weight:500;font-style:italic;font-display:swap;}

/* ---------- Tokens ---------- */
:root{
  --bg:#F7F7F5;
  --ink:#161410;
  --ink-soft:#5a564e;
  --line:#e6e5e0;
  --paper:#ffffff;

  --blue:#0A67D9;
  --blue-700:#0852ae;
  --blue-100:#e4eefb;

  /* Welt-Farben */
  --studio:#0A67D9;       --studio-soft:#e4eefb;
  --schmeckt:#630801;     --schmeckt-pop:#FF9BD2;   --schmeckt-soft:#fbe3ef;
  --zeigt:#F14704;        --zeigt-pop:#F14704;       --zeigt-cream:#FDFEB3; --zeigt-soft:#fde7d8;
  --tbd:#115604;          --tbd-pop:#ADFF1D;         --tbd-soft:#eafbc7;

  /* Standard-Akzent (neutral/Hub) = Blau */
  --accent:var(--blue);
  --accent-ink:#ffffff;
  --accent-soft:var(--blue-100);

  --font-display:'Slofyn', system-ui, sans-serif;
  --font:'Cottorway', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;

  --fs-hero:clamp(3.4rem, 11vw, 9rem);
  --fs-900:clamp(2.6rem, 7vw, 5.5rem);
  --fs-800:clamp(2rem, 4.6vw, 3.4rem);
  --fs-700:clamp(1.5rem, 3vw, 2.2rem);
  --fs-600:clamp(1.2rem, 1.8vw, 1.5rem);
  --fs-500:1.125rem;
  --fs-400:1rem;
  --fs-300:.875rem;

  --wrap:1200px;
  --gap:clamp(1rem,2.5vw,2rem);
  --section-y:clamp(3.5rem,8vw,7rem);
  --radius:28px;
  --radius-sm:16px;
  --pill:999px;
  --shadow:0 18px 50px -22px rgba(20,18,12,.35);
  --shadow-sm:0 8px 24px -14px rgba(20,18,12,.3);
  --ease:cubic-bezier(.2,.7,.2,1);
}

/* ---------- Reset / Base ---------- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{-webkit-text-size-adjust:100%}
html:focus-within{scroll-behavior:smooth}
body{
  font-family:var(--font);
  font-weight:400;
  color:var(--ink);
  background:var(--bg);
  line-height:1.55;
  font-size:var(--fs-400);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,video{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none;padding:0}
:focus-visible{outline:3px solid var(--blue);outline-offset:3px;border-radius:6px}

/* ---------- Helpers ---------- */
.wrap{width:min(100% - 2.4rem, var(--wrap));margin-inline:auto}
.section{padding-block:var(--section-y)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link{position:fixed;top:-100px;left:1rem;z-index:1000;background:var(--blue);color:#fff;padding:.7rem 1.1rem;border-radius:12px;font-weight:700}
.skip-link:focus{top:1rem}
.eyebrow{font-weight:700;letter-spacing:.14em;text-transform:uppercase;font-size:.78rem;color:var(--accent)}

/* ---------- Typography ---------- */
.display{font-family:var(--font-display);font-weight:400;line-height:.92;letter-spacing:-.01em}
h1,h2,h3,h4{font-weight:800;line-height:1.05;letter-spacing:-.02em}
h2.section-title{font-size:var(--fs-800);max-width:18ch}
p{max-width:64ch}
.lead{font-size:var(--fs-600);color:var(--ink-soft);font-weight:500}

/* ---------- Tags (Marken-Motiv: [wort] [wort]) ---------- */
.tags{display:flex;flex-wrap:wrap;gap:.4rem .9rem;font-style:italic;font-weight:500;color:var(--accent)}
.tags span::before{content:'['} .tags span::after{content:']'}
.tags span{white-space:nowrap}

/* ---------- Sticker / Pills ---------- */
.sticker{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--font-display);
  background:var(--paper);color:var(--accent);
  border:3px solid var(--accent);
  padding:.5rem 1.1rem;border-radius:var(--pill);
  box-shadow:var(--shadow-sm);
  transform:rotate(-2deg);
}
.chip{display:inline-flex;align-items:center;gap:.45rem;background:var(--accent-soft);color:var(--accent);
  font-weight:700;font-size:.8rem;padding:.35rem .8rem;border-radius:var(--pill)}
.dot{width:10px;height:10px;border-radius:50%;background:var(--accent);display:inline-block;flex:0 0 auto}
a.sticker{transition:transform .2s var(--ease)}
a.sticker:hover{transform:rotate(-2deg) scale(1.04)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.55rem;font-weight:700;
  padding:.85rem 1.5rem;border-radius:var(--pill);transition:transform .2s var(--ease),background .2s,box-shadow .2s;
  border:2.5px solid transparent;white-space:nowrap}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn-primary{background:var(--accent);color:var(--accent-ink);box-shadow:var(--shadow-sm)}
.btn-primary:hover{box-shadow:var(--shadow)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--bg)}
.btn-light{background:var(--paper);color:var(--accent);border-color:var(--paper)}
.btn .arrow{transition:transform .2s var(--ease)}
.btn:hover .arrow{transform:translateX(3px)}

/* ---------- Header / Nav ---------- */
.site-header{position:sticky;top:0;z-index:100;background:color-mix(in srgb,var(--bg) 86%,transparent);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.7rem 0;width:min(100% - 2.4rem,var(--wrap));margin-inline:auto}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--font-display);font-size:1.5rem;color:var(--blue)}
.brand img{width:38px;height:38px}
.nav-links{display:flex;align-items:center;gap:.3rem}
.nav-links a{padding:.5rem .8rem;border-radius:var(--pill);font-weight:600;font-size:.95rem;transition:background .15s,color .15s}
.nav-links a:hover,.nav-links a[aria-current="page"]{background:var(--accent-soft);color:var(--accent)}
.nav-cta{margin-left:.4rem}
.nav-toggle{display:none;width:46px;height:46px;border-radius:14px;border:2px solid var(--ink);align-items:center;justify-content:center}
.nav-toggle span{position:relative;width:20px;height:2px;background:var(--ink);transition:.25s}
.nav-toggle span::before,.nav-toggle span::after{content:'';position:absolute;left:0;width:20px;height:2px;background:var(--ink);transition:.25s}
.nav-toggle span::before{top:-6px}.nav-toggle span::after{top:6px}
.nav-toggle[aria-expanded="true"] span{background:transparent}
.nav-toggle[aria-expanded="true"] span::before{top:0;transform:rotate(45deg)}
.nav-toggle[aria-expanded="true"] span::after{top:0;transform:rotate(-45deg)}

/* ---------- Hero (Hub) ---------- */
.hero{position:relative;padding-block:clamp(3rem,7vw,6rem) clamp(2rem,5vw,4rem);overflow:hidden}
.hero-inner{display:grid;gap:1.6rem;justify-items:start}
.hero h1{margin:0}
.hero .kicker{display:inline-flex;align-items:center;gap:.5rem}
.hero-word{font-family:var(--font-display);font-size:var(--fs-hero);color:var(--blue);line-height:.86;letter-spacing:-.01em}
.hero-sub{font-size:var(--fs-700);font-weight:800;max-width:20ch}
.hero-sub em{color:var(--blue);font-style:normal}
.hero p.lead{max-width:54ch}
.hero-actions{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:.4rem}
.hero-bubbles{position:absolute;inset:0;z-index:-1;pointer-events:none}
.bubble{position:absolute;border-radius:50%;opacity:.5;filter:blur(2px)}

/* ---------- Worlds (vier Welten) ---------- */
.worlds-head{display:flex;align-items:end;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1.4rem}
.worlds-rail{display:flex;gap:1.2rem;overflow-x:auto;scroll-snap-type:x mandatory;padding:.6rem .2rem 1.6rem;
  scrollbar-width:thin;scroll-padding-left:1.2rem}
.worlds-rail::-webkit-scrollbar{height:8px}
.worlds-rail::-webkit-scrollbar-thumb{background:var(--line);border-radius:99px}
.world{scroll-snap-align:start;flex:0 0 min(86vw,460px);min-height:clamp(420px,60vh,560px);
  border-radius:var(--radius);padding:clamp(1.4rem,2.5vw,2.2rem);color:#fff;position:relative;overflow:hidden;
  display:flex;flex-direction:column;justify-content:flex-start;gap:.5rem;
  background:var(--w);box-shadow:var(--shadow);isolation:isolate}
.world--studio{--w:var(--studio)} .world--schmeckt{--w:var(--schmeckt)}
.world--zeigt{--w:var(--zeigt)} .world--tbd{--w:var(--tbd)}
.world .w-photo{position:absolute;inset:0;z-index:-1;object-fit:cover;width:100%;height:100%;opacity:.32;mix-blend-mode:luminosity}
.world::after{content:'';position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,transparent,var(--w) 78%)}
.world .w-top{display:flex;justify-content:space-between;align-items:start;gap:1rem}
.w-index{font-family:var(--font-display);font-size:1.2rem;opacity:.85}
.w-name{font-family:var(--font-display);font-size:clamp(2.4rem,6vw,3.6rem);line-height:.9;margin-top:.4rem}
.w-name small{display:block;font-size:.42em;opacity:.9}
.world .tags{color:rgba(255,255,255,.92);margin-top:.7rem}
.w-desc{font-weight:500;max-width:34ch;margin-top:.8rem}
.w-link{display:inline-flex;align-items:center;gap:.5rem;font-weight:800;margin-top:auto;
  background:#fff;color:var(--w);padding:.7rem 1.2rem;border-radius:var(--pill);width:fit-content;transition:transform .2s var(--ease)}
.world:hover .w-link{transform:translateX(4px)}
/* zeigt nutzt helle Pop-Farbe für Lesbarkeit */
.world--zeigt .w-name{color:var(--zeigt-cream)}
.world--tbd .w-name{color:var(--tbd-pop)}
.world--schmeckt .w-name{color:var(--schmeckt-pop)}
.rail-controls{display:flex;gap:.5rem}
.rail-btn{width:48px;height:48px;border-radius:50%;border:2px solid var(--ink);display:grid;place-items:center;transition:.2s}
.rail-btn:hover{background:var(--ink);color:var(--bg)}
.rail-btn[disabled]{opacity:.3;cursor:default}

/* ---------- "Was läuft" cards ---------- */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.2rem}
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .2s var(--ease),box-shadow .2s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card .c-media{aspect-ratio:4/3;background:var(--accent-soft);object-fit:cover;width:100%}
.card .c-body{padding:1.2rem;display:flex;flex-direction:column;gap:.5rem;flex:1}
.card .c-date{font-weight:700;color:var(--accent);font-size:.85rem}
.card h3{font-size:var(--fs-600)}
.badge{align-self:flex-start;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;
  padding:.25rem .6rem;border-radius:var(--pill);background:var(--accent);color:var(--accent-ink)}

/* ---------- Feature band / CTA ---------- */
.band{background:var(--accent);color:var(--accent-ink);border-radius:var(--radius);padding:clamp(1.8rem,4vw,3.2rem);
  display:grid;gap:1.2rem}
.band h2{font-size:var(--fs-800)}
.band .btn-light{align-self:start}

/* ---------- Page hero (Unterseiten) ---------- */
.page-hero{padding-block:clamp(2.4rem,6vw,4.5rem) clamp(1.4rem,3vw,2.4rem)}
.page-hero .sticker{margin-bottom:1.1rem}
.page-hero h1{font-family:var(--font-display);font-weight:400;font-size:var(--fs-900);color:var(--accent);line-height:.9}
.page-hero .lead{margin-top:1rem}
.theme-studio{--accent:var(--studio);--accent-ink:#fff;--accent-soft:var(--studio-soft)}
.theme-schmeckt{--accent:var(--schmeckt);--accent-ink:#fff;--accent-soft:var(--schmeckt-soft)}
.theme-zeigt{--accent:var(--zeigt);--accent-ink:#fff;--accent-soft:var(--zeigt-soft)}
.theme-tbd{--accent:var(--tbd);--accent-ink:#fff;--accent-soft:var(--tbd-soft)}

/* ---------- Generic content grid ---------- */
.grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:clamp(1.2rem,3vw,2.4rem);align-items:start}
.media-frame{border-radius:var(--radius);overflow:hidden;background:var(--accent-soft);aspect-ratio:4/3}
.media-frame img{width:100%;height:100%;object-fit:cover}

/* price / equipment / list cards */
.tile{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem;height:100%}
.tile h3{font-size:var(--fs-600);margin-bottom:.4rem}
.price{font-family:var(--font-display);font-size:2rem;color:var(--accent);line-height:1}
.price small{font-size:.5em;color:var(--ink-soft)}
.feature-list li{display:flex;gap:.6rem;padding:.35rem 0;border-bottom:1px dashed var(--line)}
.feature-list li::before{content:'✦';color:var(--accent)}
.feature-list li:last-child{border-bottom:0}

/* ---------- Forms ---------- */
.form{display:grid;gap:1rem;max-width:560px}
.field{display:grid;gap:.4rem}
.field label{font-weight:700;font-size:.9rem}
.field input,.field textarea,.field select{font:inherit;padding:.8rem 1rem;border:2px solid var(--line);
  border-radius:14px;background:var(--paper);transition:border-color .15s}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--accent)}
.form .hint{font-size:.8rem;color:var(--ink-soft)}

/* ---------- Map ---------- */
.map-embed{border:0;width:100%;height:380px;border-radius:var(--radius)}

/* ---------- Booking embed placeholder ---------- */
.embed-slot{border:2px dashed var(--accent);border-radius:var(--radius);background:var(--accent-soft);
  padding:clamp(1.6rem,4vw,3rem);text-align:center;display:grid;gap:1rem;place-items:center}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:#cfccc4;margin-top:var(--section-y);padding-block:clamp(2.6rem,5vw,4rem)}
.footer-grid{display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:2rem}
.site-footer h4{color:#fff;font-size:.85rem;text-transform:uppercase;letter-spacing:.12em;margin-bottom:.9rem}
.site-footer a{display:block;padding:.25rem 0;transition:color .15s}
.site-footer a:hover{color:#fff}
.footer-brand{font-family:var(--font-display);font-size:2rem;color:#fff;display:flex;align-items:center;gap:.5rem}
.footer-brand img{width:40px}
.footer-bottom{display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;
  margin-top:2.4rem;padding-top:1.4rem;border-top:1px solid rgba(255,255,255,.12);font-size:.85rem}

/* ---------- Consent banner ---------- */
.consent{position:fixed;inset:auto 1rem 1rem;z-index:300;max-width:520px;margin-inline:auto;left:1rem;right:1rem;
  background:var(--paper);border:2px solid var(--ink);border-radius:var(--radius);padding:1.2rem 1.3rem;box-shadow:var(--shadow)}
.consent p{font-size:.9rem}
.consent .row{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:.9rem}
.consent[hidden]{display:none}

/* ---------- Prose (Rechtstexte) ---------- */
.prose{max-width:72ch}
.prose h2{font-size:var(--fs-700);margin:2rem 0 .6rem}
.prose h3{font-size:var(--fs-600);margin:1.3rem 0 .4rem}
.prose p,.prose li{margin-bottom:.6rem;color:var(--ink)}
.prose ul{padding-left:1.2rem;list-style:disc;margin-bottom:.8rem}
.prose a{color:var(--accent);text-decoration:underline}
.note{background:var(--accent-soft);color:var(--ink);border-radius:var(--radius-sm);padding:1rem 1.2rem;margin:1.4rem 0;font-size:.92rem}

/* ---------- Details / FAQ ---------- */
details summary{cursor:pointer;list-style:none}
details summary::-webkit-details-marker{display:none}
details summary::after{content:'+';float:right;color:var(--accent);font-weight:800;font-size:1.2rem;line-height:1}
details[open] summary::after{content:'–'}
details+details{margin-top:.8rem}

/* ---------- 404 ---------- */
.notfound{min-height:60vh;display:grid;place-items:center;text-align:center}
.notfound .display{font-size:clamp(5rem,20vw,12rem);color:var(--blue)}

/* ---------- Responsive ---------- */
@media (max-width:860px){
  .nav-links{position:fixed;inset:64px 0 auto 0;background:var(--bg);flex-direction:column;align-items:stretch;
    gap:.2rem;padding:1rem 1.2rem 1.6rem;border-bottom:1px solid var(--line);transform:translateY(-120%);
    transition:transform .3s var(--ease);box-shadow:var(--shadow)}
  .nav-links[data-open="true"]{transform:translateY(0)}
  .nav-links a{padding:.8rem 1rem;font-size:1.05rem}
  .nav-cta{margin:.4rem 0 0}
  .nav-toggle{display:inline-flex}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:560px){
  .worlds-rail{scroll-snap-type:none;overflow:visible;flex-direction:column}
  .world{flex-basis:auto;min-height:clamp(360px,70vh,460px)}
  .rail-controls{display:none}
  .footer-grid{grid-template-columns:1fr}
  .hero-bubbles{display:none}
}

/* ---------- Motion ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none !important;transition:none !important;scroll-behavior:auto !important}
  .sticker{transform:none}
}
@media (prefers-reduced-motion:no-preference){
  .float{animation:floaty 7s var(--ease) infinite}
  @keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
  .js .reveal{opacity:0;transform:translateY(18px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
  .js .reveal.in{opacity:1;transform:none}
}
