/* ========================
       Design-Variablen (Farben/Spacing/Radius)
    =========================*/
    :root {
      --primary:#64C4BC;   /* türkis */
      --brand-primary: #64C4BC;     /* Primär */
      --brand-primary-600: #3FAAA3; /* Hover */
      --brand-secondary: #055555;   /* Headlines/Text */
      --brand-accent: #055555;      /* Akzent dunkel */
      --brand-bg: #EAEEE0;          /* Hintergrund */
      --brand-muted: #53606a;       /* Sekundärtext */
      --brand-card: #ffffff;        /* Karten */
      --c-white: #ffffff;        /* Weiß */
	  --t-black: #2c2c2c;        /* Weiß */
	  --brand-white: #fafffb;
      --radius: 0px;
      --radius-xl: 0px;
      --radius-lg: 0px;
      --radius-md: 0px;
      --radius-sm: 8px;

      --shadow-soft: 0 10px 30px rgba(0,0,0,.08);
      --shadow-lift: 0 6px 16px rgba(0,0,0,.12);
      --shadow: 0 10px 30px rgba(0,0,0,.08);
      --shadow-lg: 0 18px 60px rgba(0,0,0,.12);
      --container: clamp(280px, 92vw, 1200px);
      --nav-h: 70px;
    }

    *, *::before, *::after { box-sizing: border-box; }
    html, body { height: 100%; scroll-behavior: smooth; }
    body {
      margin: 0; color: var(--t-black); background: var(--brand-white);
      /*font-family: "Tinos", "Times New Roman", Times, serif;*/
      line-height: 1.5; text-rendering: optimizeLegibility; -webkit-font-smoothing: antialiased;
    }

    /* ===== Section: USP Cards ===== */
    section{ padding: clamp(3rem, 6vw, 5rem) 0; position:relative; }
    .section__head{ display:flex; align-items:center; justify-content:space-between; gap:1rem; margin-bottom: 1.5rem; }
    .section__title{ font-size: clamp(1.6rem, 3.2vw, 2.4rem); margin:0; }
/*    .grid{ display:grid; gap:1rem; grid-template-columns: repeat(12, 1fr); }
    .card{ grid-column: span 4; background: var(--c-white); border-radius: var(--radius); box-shadow: var(--shadow); padding:1.2rem; transition: transform .25s ease, box-shadow .25s ease; }
    .card:hover{ transform: translateY(-4px); box-shadow: var(--shadow-lg); }
    .card h3{ margin:.2rem 0 .45rem; font-size:1.15rem; }
    .card p{ margin:0; color: var(--c-ink-2); } */

    /* ========================
       Navigation (Floating Glass)
    =========================*/
    .nav { position: fixed; inset: 12px 0 auto 0; height: var(--nav-h); z-index: 1000; display:flex; justify-content:center; pointer-events:none; }
    .nav-inner { width: var(--container); display:flex; align-items:center; gap:20px; pointer-events:auto; padding:8px 12px; border-radius:0px; background: rgba(255,255,255,.92); backdrop-filter: saturate(1.2) blur(14px); box-shadow: 0 20px 40px rgba(0,0,0,.18); border: 1px solid rgba(100,196,188,.35); transition: box-shadow .25s ease, background .25s ease; }
    .nav.stuck .nav-inner { background: rgba(255,255,255,.98); border-color: rgba(100,196,188,.45); box-shadow: 0 12px 35px rgba(0,0,0,.14); }
    .brand { display:flex; align-items:center; gap:12px; font-weight:800; letter-spacing:.2px; }
    .brand .you { color: var(--brand-primary); }
    .brand img { /*width:36px; height:36px; border-radius: 50%;*/ box-shadow: var(--shadow-soft); }
    .menu { margin-left:auto; display:flex; gap:14px; align-items:center; }
    .menu a { text-decoration:none; color: var(--brand-secondary); padding: 8px 12px; border-radius: 0px; font-weight: 600; transition: transform .2s ease, background .2s ease; }
    .menu a:hover { transform: translateY(-1px); background: rgba(0,0,0,.06); }
    .cta { background: var(--brand-primary); color:#fff !important; box-shadow: var(--shadow-lift); }
    .cta:hover { background: var(--brand-primary-600); transform: translateY(-1px); }
    .hamburger { display:none; margin-left:auto; background:transparent; border:0; width:42px; height:42px; border-radius: 10px; }
    .hamburger:focus-visible { outline: 3px solid var(--brand-primary); }
    @media (max-width: 900px){ .menu { display:none; } .hamburger { display:block; } .menu.open { position:absolute; top: calc(var(--nav-h) + 18px); right: 16px; background:#fff; border-radius: 16px; padding:10px; box-shadow: var(--shadow-lift); display:flex; flex-direction:column; } .menu.open a { padding:10px 14px; } }

    /* ========================
       Fullscreen Slider (100% Breite/Höhe)
    =========================*/
    .slider { position: relative; width:100vw; height:100vh; overflow:hidden; }
    .slides { position:absolute; inset:0; display:flex; transition: transform .8s cubic-bezier(.22,1,.36,1); }
    .slide { position: relative; min-width:100%; height:100%; display:grid; place-items:center; }
    .slide::before { content:""; position:absolute; inset:0; background-size: cover; background-position:center; filter: saturate(1.05) contrast(1.02); transform: scale(1.03); transition: transform 1.8s ease; will-change: transform; background-image: var(--bg); }
    .slide .overlay { position:absolute; inset:0; background: linear-gradient(180deg, rgba(0,0,0,.35) 0%, rgba(0,0,0,.15) 45%, rgba(0,0,0,.35) 100%); }
    .hero { position: relative; z-index: 2; width: var(--container); padding: 0 16px; text-align: left; color: #fff; }
    .eyebrow { display:inline-flex; align-items:center; gap:8px; padding:8px 12px; border-radius:0px; background: rgba(255,255,255,.16); backdrop-filter: blur(4px); font-weight:700; letter-spacing:.3px; }
    .hero h1 { font-family: "Playfair Display", Georgia, serif; font-size: clamp(36px, 6.4vw, 68px); line-height: 1.03; margin: 14px 0 12px; }
    .hero p { max-width: 720px; font-size: clamp(16px, 2.3vw, 20px); opacity: .95; }
    .hero .actions { display:flex; gap:12px; margin-top: 22px; flex-wrap: wrap; }
    .btn { appearance:none; border:0; padding:14px 18px; border-radius: 0px; font-weight: 700; cursor:pointer; text-decoration:none; display:inline-flex; align-items:center; gap:10px; box-shadow: var(--shadow-lift); }
    .btn.primary { background: var(--brand-primary); color:#fff; }
    .btn.primary:hover { background: var(--brand-primary-600); transform: translateY(-1px); }
    .btn.ghost { background: rgba(255,255,255,.14); color:#fff; }
    .btn.ghost:hover { background: rgba(255,255,255,.22); }
    .dots { position:absolute; left:50%; bottom: 22px; transform: translateX(-50%); display:flex; gap:10px; z-index: 3; }
    .dots button { width:9px; height:9px; border-radius:50%; border:0; background: rgba(255,255,255,.6); cursor:pointer; }
    .dots button.active { background:#fff; transform: scale(1.22); }
    .arrow { position:absolute; top:50%; transform:translateY(-50%); z-index:3; width:46px; height:46px; display:grid; place-items:center; border-radius:999px; border:0; background: rgba(255,255,255,.2); backdrop-filter: blur(4px); cursor:pointer; }
    .arrow:hover { background: rgba(255,255,255,.3); }
    .arrow.left { left: 14px; } .arrow.right { right: 14px; }

/* ========================
       Video-Slide (HTML5 Video im Hero)
    =========================*/
    .slide.video::before { display: none; }
    .slide.video video { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }

    /* ========================
       Sections / Cards
    =========================*/
    section { padding: clamp(56px, 9vw, 55px) 16px; position: relative; overflow: clip; }
    .container { width: var(--container); margin: 0 auto; }
    .kicker { font-size:13px; font-weight:800; letter-spacing:.2em; text-transform:uppercase; color: var(--brand-muted); }
    h2 { font-family: "Playfair Display", Georgia, serif; font-size: clamp(28px, 4.2vw, 44px); line-height:1.06; margin: 10px 0 16px; }
    p.lead { font-size: clamp(17px, 2.4vw, 20px); color: #273238; max-width: 900px; }
    .grid { display:grid; gap: 18px; }
    .grid.cols-3 { grid-template-columns: repeat(3, 1fr); }
    .grid.cols-2 { grid-template-columns: repeat(2, 1fr); }
    @media (max-width: 960px){ .grid.cols-3 { grid-template-columns: 1fr 1fr; } }
    @media (max-width: 680px){ .grid.cols-3, .grid.cols-2 { grid-template-columns: 1fr; } }
    .card { background: var(--brand-card); border-radius: var(--radius-lg); box-shadow: var(--shadow-soft); overflow:hidden; transform: translateZ(0); }
    .card .media { position:relative; aspect-ratio: 16/9; background: #eee; overflow:hidden; }
    .card .media img { width:100%; height:100%; object-fit: cover; transform: scale(1.02); transition: transform .7s ease; }
    .card:hover .media img { transform: scale(1.06); }
    .card .body { padding: 18px 18px 20px; }
    .pill { display:inline-flex; align-items:center; padding:6px 10px; border-radius: 999px; background: rgba(100,196,188,.15); color: #055555; font-weight:700; font-size:12px; letter-spacing:.02em; }

    /* ========================
       Parallax & Scroll‑Reveal
    =========================*/
    .parallax { position: absolute; inset: auto auto -40px -40px; width: 240px; height: 240px; filter: blur(0px); opacity:.25; pointer-events:none; transform: translateZ(0); }
    .shape { position:absolute; border-radius: 50%; background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.6), rgba(255,255,255,.1)); box-shadow: 0 10px 30px rgba(0,0,0,.08) inset; }
    .shape.s1 { width: 180px; height: 180px; background: radial-gradient(circle at 30% 30%, #fff, rgba(255,255,255,.2)), linear-gradient(130deg, var(--brand-primary), #b7ece8); mix-blend-mode: multiply; }
    .shape.s2 { width: 140px; height: 140px; right:-30px; top: -30px; background: linear-gradient(130deg, #6fe3ce, #fff); mix-blend-mode: multiply; border-radius: 40% 60% 50% 50%/60% 40% 60% 40%; }
    .reveal { opacity: 1; transform: none; filter: none; transition: opacity .6s ease, transform .7s ease, filter .7s ease; }
    .js-ready .reveal { opacity: 0; transform: translateY(16px) scale(.98); filter: blur(6px); }
    .js-ready .reveal.in { opacity: 1; transform: translateY(0) scale(1); filter: blur(0); }
    @media (prefers-reduced-motion: reduce){ .slides, .slide::before, .shape, .reveal { transition: none !important; animation: none !important; } }

    /* ========================
       Interaktive Weltkarte (ruhige Pins)
    =========================*/
    #map .worldmap { position: relative; height: clamp(320px, 50vw, 580px); border-radius: var(--radius-xl); overflow: hidden; background: radial-gradient(1200px 800px at 20% 20%, #fff, #f3fbf9); box-shadow: var(--shadow-soft); }
    #map svg { width: 100%; height: 100%; display:block; }
    .pin { cursor: pointer; }
    .pin .dot { fill: var(--brand-primary); filter: drop-shadow(0 0 10px rgba(100,196,188,.75)); transform-box: fill-box; transform-origin: center; animation: dotPulse 1.9s ease-in-out infinite; }
    .pin .ring { fill: none; stroke: var(--brand-primary); stroke-width: 2.5; opacity: .85; pointer-events: none; animation: pulse 2.8s ease-out infinite; transform-origin: center; }
    .route { stroke: var(--brand-primary); stroke-width: 2.5; stroke-dasharray: 8 6; stroke-linecap: round; opacity: .9; fill: none; pointer-events: none; }
    @keyframes pulse { 0% { r: 0; opacity: .9; } 60% { r: 22; opacity: 0; } 100% { r: 22; opacity: 0; } }
    @keyframes dotPulse { 0%,100% { transform: scale(1); } 50% { transform: scale(1.35); } } 60% { r: 16; opacity: 0; } 100% { r: 16; opacity: 0; } }
    .map-legend { position: absolute; left: 12px; bottom: 12px; display:flex; gap: 8px; flex-wrap:wrap; z-index: 2; }
    .legend-chip { padding: 6px 10px; border-radius: 999px; background: rgba(5,85,85,.9); color:#fff; font-weight:700; font-size:12px; letter-spacing:.02em; cursor: pointer; user-select:none; border: 1px solid rgba(255,255,255,.5); }
    .legend-chip.active { background: var(--brand-primary); color:#013; }

    /* ========================
       Modal (Map Project)
    =========================*/
    .modal { position: fixed; inset: 0; display: none; align-items: center; justify-content: center; z-index: 2000; }
    .modal.open { display: flex; }
    .modal-backdrop { position:absolute; inset:0; background: rgba(0,0,0,.38); backdrop-filter: blur(2px); }
    .modal-card { position: relative; width: min(860px, 94vw); background: #fff; border-radius: var(--radius-xl); box-shadow: 0 30px 60px rgba(0,0,0,.25); padding: 16px; border: 1px solid rgba(100,196,188,.25); }
    .modal-grid { display:grid; grid-template-columns: 1fr 1.2fr; gap: 14px; }
    .modal-media { aspect-ratio: 4/3; border-radius: var(--radius-lg); overflow:hidden; background:#eee; }
    .modal-media img { width:100%; height:100%; object-fit: cover; display:block; }
    .modal-title { margin: 0 0 6px; font-size: 22px; color: var(--brand-secondary); }
    .modal-meta { margin: 0 0 12px; color: var(--brand-muted); font-size: 14px; }
    .modal-close { position:absolute; top:10px; right:10px; border:0; background: var(--brand-primary); color:#fff; width:36px; height:36px; border-radius: 10px; font-size: 18px; cursor:pointer; box-shadow: var(--shadow-lift); }
    .modal-actions { display:flex; gap: 10px; margin-top: 10px; }
    @media (max-width: 760px){ .modal-grid { grid-template-columns: 1fr; } }

    /* ========================
       Footer
    =========================*/
    footer { background: #0f1320; color:#cbd3e1; padding: 48px 16px 28px; position: relative; }
    footer .container { width: var(--container); }
    footer h4 { margin: 0 0 8px; color:#fff; }
    footer a { color:#e9edf7; text-decoration: none; }
    .foot-grid { display:grid; gap: 18px; grid-template-columns: 1.6fr 1fr .9fr; }
    @media (max-width: 880px){ .foot-grid { grid-template-columns: 1fr; } }
    .legal { opacity:.75; font-size: 13px; margin-top: 20px; }


    /* ======= Newsletter ======= */
    .newsletter { background: linear-gradient(135deg, color-mix(in srgb, var(--brand-secondary) 88%, #000), #0f1a13 60%); color: #fff; border-radius: var(--radius); padding: 28px; display:grid; grid-template-columns: 1.2fr .8fr; gap: 16px; align-items: center; }
    .newsletter input[type="email"] { width: 100%; padding: 12px 14px; border-radius: 10px; border: none; outline: none; }

    @media (max-width: 860px){ .newsletter { grid-template-columns: 1fr; } }

    /* ===== Metrics ===== */
    .metrics{ display:grid; grid-template-columns: repeat(4,1fr); gap:1rem; }
    .kpi{ background: var(--c-white); border-radius: var(--radius); padding:1rem; text-align:center; box-shadow: var(--shadow); }
    .kpi strong{ display:block; font-size: clamp(1.6rem, 4vw, 2.6rem); color: var(--c-primary); }

/* Accessibility: reduce motion */
    @media (prefers-reduced-motion: reduce){
      .slides{ transition: none; }
      .floaty{ animation: none; }
      .marquee__track{ animation: none; }
    }

/* Tiny floating playful shapes */
    .floaty{ position:absolute; border-radius: 50%; opacity:.7; filter: blur(1px); animation: bob 6s ease-in-out infinite; }
    .floaty--1{ width:32px; height:32px; background: var(--c-accent); top:15%; left:8%; animation-delay: .2s; }
    .floaty--2{ width:18px; height:18px; background: #7dd3c7; top:65%; left:12%; animation-delay: .8s; }
    .floaty--3{ width:26px; height:26px; background: #ffd166; top:28%; right:10%; animation-delay: 1.4s; }
    @keyframes bob{ 0%,100%{ transform: translateY(0) } 50%{ transform: translateY(-10px) } }

/* Projects */
    #projects .grid{display:grid; grid-template-columns:repeat(12, 1fr); gap:1rem; margin-top:1.2rem}
    .project{
      grid-column: span 12;
      display:grid; grid-template-columns: 1.2fr 1fr; gap:1rem; align-items:stretch;
      background:white; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow);
      border:1px solid color-mix(in oklab, var(--secondary) 60%, #000 8%);
    }
    .project:nth-child(odd){grid-template-columns:1fr 1.2fr}
    .project__img{min-height:320px; background-size:cover; background-position:center}
    .project__body{padding:1.2rem 1.2rem 1.4rem}
    .project__meta{color:var(--muted); font-weight:600; letter-spacing:.3px}
    .project__title{margin:.2rem 0 .5rem; font-size:clamp(1.3rem, 2.4vw, 1.8rem)}
    .project a.btn{margin-top:.6rem}

 /* Country chip */
    .country{display:inline-flex; align-items:center; gap:.45rem; padding:.35rem .6rem; border-radius:0px; background: color-mix(in oklab, var(--primary) 12%, white); border:1px solid color-mix(in oklab, var(--primary) 35%, #000 0%); box-shadow: inset 0 -1px 0 rgba(0,0,0,.03); font-weight:600; transition: transform .2s ease, box-shadow .2s ease}
    .country .flag{font-size:1.05rem; line-height:1; filter:saturate(110%)}
    .country .name{color: var(--accent); letter-spacing:.2px}
    .country:hover{transform: translateY(-1px); box-shadow: 0 6px 16px rgba(0,0,0,.08)}
