/*
Theme Name: conntxt
Theme URI: https://conntxt.de
Author: Cornelia Schade
Author URI: https://conntxt.de
Description: Portfolio-Theme für Creative Specialists. Eigenständig, kein Parent-Theme nötig.
Version: 3.0
License: Private
Text Domain: conntxt
Tags: portfolio, dark, minimal
*/

@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Roboto:wght@400;500&family=Open+Sans:ital,wght@1,800&family=Orbitron:wght@700&family=Pacifico&display=swap');

/* ── VARIABLEN ── */
:root {
  --bg:       #1c0000;
  --bg2:      #160000;
  --bg3:      #0e0000;
  --surf:     #2a0000;
  --surf2:    #4a0000;
  --yellow:   #C9A84C;
  --gold:     #C9A84C;
  --gold:     #C9A84C;
  --orange:   #f86613;
  --orange-d: rgba(248,102,19,0.15);
  --green:    #C9A84C;
  --green-d:  rgba(248,195,19,0.12);
  --amber:    #C9A84C;
  --red:      #f86613;
  --purple:   #C9A84C;
  --text:     #ffffff;
  --text2:    rgba(255,255,255,0.65);
  --text3:    rgba(255,255,255,0.35);
  --bd:       rgba(255,255,255,0.12);
  --bd2:      rgba(201,168,76,0.35);
  --r:        12px 0 12px 0;
  --r-btn:    20px 0 20px 0;
  --r-round:  20px;
  --font-head:'Bebas Neue',sans-serif;
  --font-body:'Roboto',sans-serif;
}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--bg);color:var(--text);line-height:1.6;overflow-x:hidden;font-weight:500}
img{max-width:100%;height:auto;display:block}
a{color:var(--yellow);text-decoration:none;transition:color .2s}
a:hover{color:var(--text)}
ul,ol{padding-left:0;list-style:none}
button{cursor:pointer}

/* ── LAYOUT ── */
.wrap{max-width:1210px;margin:0 auto;padding:0 5vw}
.wrap--narrow{max-width:800px;margin:0 auto;padding:0 5vw}
.rule{height:1px;background:var(--bd)}
.site-section{padding:88px 0}
.section-label{font-size:0;color:transparent;margin-bottom:12px;display:flex;align-items:center;gap:0;height:2px}
.section-label::before{content:'';display:inline-block;width:32px;height:1px;background:var(--yellow)}
.section-title{font-family:var(--font-head);font-size:clamp(28px,4vw,52px);font-weight:400;line-height:1.05;letter-spacing:.02em;text-transform:uppercase;margin-bottom:16px}
.section-title em{font-style:normal;color:var(--yellow)}
.lead{font-size:15px;color:var(--text2);max-width:560px;line-height:1.75;font-weight:400;margin-bottom:36px}

/* ── ANIMATIONS ── */
.fade-up{opacity:0;transform:translateY(18px);transition:opacity .55s ease,transform .55s ease}
.fade-up.visible{opacity:1;transform:none}

/* ── BUTTONS ── */
.btn{display:inline-block;padding:10px 24px;font-size:14px;font-weight:400;font-family:var(--font-head);letter-spacing:.08em;text-transform:uppercase;transition:all .2s;border:none;cursor:pointer;text-decoration:none}
.btn--primary{background:var(--gold);color:#fff;border-radius:var(--r-btn)}
.btn--primary:hover{background:#a8893d;transform:translateY(-1px);color:#fff}
.btn--ghost{background:transparent;color:var(--text2);border:1px solid var(--bd);border-radius:var(--r-btn)}
.btn--ghost:hover{border-color:var(--yellow);color:var(--yellow)}
.btn--small{padding:5px 16px;font-size:12px}
.btn--yellow{background:var(--yellow);color:#1c0000;border-radius:var(--r-btn)}
.btn--yellow:hover{background:#e0af10;color:#1c0000}

/* ── CHIPS & BADGES ── */
.chip{font-size:9px;font-weight:500;text-transform:uppercase;letter-spacing:.07em;padding:3px 10px;color:var(--yellow);display:inline-block;border:1px solid rgba(248,195,19,0.3);background:rgba(248,195,19,0.08)}
.chip--yellow{background:rgba(248,195,19,0.12);color:var(--yellow);border-color:rgba(248,195,19,0.3)}
.chip--orange{background:var(--orange-d);color:var(--orange);border-color:rgba(248,102,19,0.3)}
.chip--green{background:var(--green-d);color:var(--green);border-color:rgba(76,175,125,0.25)}
.chip--white{background:rgba(255,255,255,0.08);color:var(--text);border-color:var(--bd)}
.chips{display:flex;flex-wrap:wrap;gap:6px}

/* ── CARDS ── */
.card{background:var(--surf);border:1px solid var(--bd);transition:border-color .2s}
.card:hover{border-color:rgba(248,195,19,0.25)}
.card--padded{padding:22px}
.card--yellow{border-color:var(--bd2);background:rgba(248,195,19,0.05)}

/* ── NAV ── */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 5vw;height:58px;background:rgba(28,0,0,0.93);backdrop-filter:blur(14px);border-bottom:1px solid var(--bd)}
.site-logo{font-family:var(--font-head);font-weight:400;font-size:20px;letter-spacing:.05em;text-transform:uppercase;text-decoration:none;color:var(--text)}
.site-logo span{color:var(--yellow)}
.nav-menu{display:flex;gap:28px;margin:0;padding:0;list-style:none}
.nav-menu a{font-family:var(--font-head);font-size:14px;letter-spacing:.06em;text-transform:uppercase;color:var(--text2);text-decoration:none;transition:color .2s}
.nav-menu a:hover,.nav-menu .current-menu-item a{color:var(--yellow)}
.nav-cta{font-family:var(--font-head);font-size:13px;letter-spacing:.08em;text-transform:uppercase;font-weight:400;color:#1c0000;text-decoration:none;background:var(--yellow);padding:6px 18px;transition:all .2s;border-radius:var(--r-btn)}
.nav-cta:hover{background:#a8893d;color:#fff}
.nav-toggle{display:none;background:none;border:none;color:var(--text2);font-size:18px;padding:4px}

/* ── HERO ── */
.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding-top:100px;padding-bottom:80px;position:relative;overflow:hidden}
.hero__bg{position:absolute;inset:0;background:radial-gradient(ellipse 60% 50% at 65% 40%,rgba(248,195,19,0.06) 0%,transparent 70%),radial-gradient(ellipse 40% 35% at 20% 75%,rgba(248,102,19,0.04) 0%,transparent 60%);pointer-events:none}
.hero__grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.hero__eyebrow{display:inline-flex;align-items:center;gap:7px;background:transparent;border:1px solid var(--yellow);padding:4px 14px;font-family:var(--font-head);font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--yellow);margin-bottom:22px;border-radius:var(--r-btn)}
.hero__title{font-family:var(--font-head);font-size:clamp(42px,6vw,78px);font-weight:400;line-height:0.95;letter-spacing:.02em;text-transform:uppercase;margin-bottom:20px}
.hero__title em{font-style:normal;color:var(--yellow);display:block}
.hero__desc{font-size:14px;color:var(--text2);max-width:440px;line-height:1.75;font-weight:400;margin-bottom:32px}
.hero__actions{display:flex;gap:11px;flex-wrap:wrap}

/* ── PROFILE CARD ── */
.profile-card{background:var(--surf);border:1px solid var(--bd);border-radius:var(--r)}
.profile-card__top{background:var(--bg3);border-bottom:1px solid var(--bd);padding:16px 20px;display:flex;align-items:center;gap:12px}
.profile-card__avatar{width:48px;height:48px;background:var(--surf2);display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-size:20px;font-weight:400;color:var(--yellow);flex-shrink:0;overflow:hidden;letter-spacing:.05em}
.profile-card__avatar img{width:100%;height:100%;object-fit:cover}
.profile-card__name{font-family:var(--font-head);font-size:16px;font-weight:400;letter-spacing:.05em;text-transform:uppercase}
.profile-card__sub{font-size:11px;color:var(--text2);margin-top:1px}
.profile-card__body{padding:18px 20px}
.profile-card__meta{font-size:11px;color:var(--text3);margin-bottom:14px}

/* ── CONTACT FORM ── */
.contact-form{display:flex;flex-direction:column;gap:8px}
.contact-form__row{display:flex;gap:8px}
.contact-form__input{background:#1c0000;border:1px solid var(--bd);padding:8px 12px;font-size:12px;color:var(--text);font-family:var(--font-body);width:100%;outline:none;transition:border-color .2s;font-weight:400}
.contact-form__input:focus{border-color:var(--yellow)}
.contact-form__input::placeholder{color:var(--text3)}
textarea.contact-form__input{resize:vertical;min-height:72px}
.contact-form__btn{background:var(--gold);color:#fff;border:none;padding:9px 20px;font-size:13px;font-weight:400;cursor:pointer;font-family:var(--font-head);letter-spacing:.08em;text-transform:uppercase;transition:background .2s;align-self:flex-end;border-radius:var(--r-btn)}
.contact-form__btn:hover{background:#a8893d}
.contact-form__success{font-size:11px;color:var(--green);display:none;padding:8px 0}

/* ── INFO LIST ── */
.info-list{display:flex;flex-direction:column;gap:4px}
.info-row{display:flex;align-items:flex-start;gap:14px;padding:11px 14px;background:var(--surf);border:1px solid var(--bd);font-size:12px;line-height:1.55;transition:border-color .2s;border-radius:var(--r)}
.info-row:hover{border-color:rgba(248,195,19,0.25)}
.info-key{font-size:9px;font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:var(--text3);flex-shrink:0;width:80px;padding-top:1px}
.info-val{color:var(--text2)}
.info-val strong{color:var(--text);font-weight:500}

/* ── CV TIMELINE ── */
.cv-timeline{display:flex;flex-direction:column;position:relative}
.cv-timeline::before{content:'';position:absolute;left:17px;top:22px;bottom:22px;width:1px;background:linear-gradient(to bottom,var(--yellow),var(--bd))}
.cv-row{display:grid;grid-template-columns:36px 1fr;gap:16px;position:relative}
.cv-dot{width:34px;height:34px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:500;flex-shrink:0;z-index:1;margin-top:4px;font-family:var(--font-head);letter-spacing:.05em}
.cv-card{background:var(--surf);border:1px solid var(--bd);padding:14px 18px;margin-bottom:4px;border-radius:var(--r)}
.cv-year{font-size:9px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;margin-bottom:3px}
.cv-title{font-family:var(--font-head);font-size:14px;font-weight:400;letter-spacing:.04em;text-transform:uppercase;margin-bottom:4px}
.cv-body{font-size:11px;color:var(--text2);line-height:1.6}

/* ── SKILLS GRID ── */
.skills-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.skill-card{background:var(--surf);border:1px solid var(--bd);padding:20px;transition:border-color .2s;border-radius:var(--r)}
.skill-card:hover{border-color:rgba(248,195,19,0.25)}
.skill-card__head{display:flex;align-items:center;gap:0;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--bd)}
.skill-card__icon{display:none}
.skill-card__title{font-family:var(--font-head);font-size:20px;font-weight:400;letter-spacing:.06em;text-transform:uppercase;color:var(--yellow)}
.skill-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px}
.skill-list li{font-size:11px;color:var(--text2);padding-left:12px;position:relative;line-height:1.5}
.skill-list li::before{content:'–';position:absolute;left:0;color:var(--text3)}

/* ── PROJECT CARDS ── */
.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:40px}
.project-card{background:var(--surf);border:1px solid var(--bd);overflow:hidden;transition:all .25s;text-decoration:none;color:inherit;display:block;border-radius:var(--r)}
.project-card:hover{border-color:rgba(248,195,19,0.3);transform:translateY(-2px);color:inherit}
.project-card__thumb{height:180px;background:var(--bg2);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.project-card__thumb img{width:100%;height:100%;object-fit:cover}
.project-card__thumb-placeholder{font-family:var(--font-head);font-size:40px;font-weight:400;color:var(--yellow);opacity:.25;letter-spacing:.05em;text-transform:uppercase}
.project-card__body{padding:22px}
.project-card__title{font-family:var(--font-head);font-size:20px;font-weight:400;letter-spacing:.04em;text-transform:uppercase;margin-bottom:8px}
.project-card__excerpt{font-size:12px;color:var(--text2);line-height:1.65}

/* ── SINGLE PROJECT HERO ── */
.project-hero{background:var(--surf2);border:1px solid var(--bd2);padding:40px 44px;margin-bottom:40px;position:relative;overflow:hidden;border-radius:var(--r)}
.project-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 60% at 80% 50%,rgba(248,195,19,0.05),transparent);pointer-events:none}
.project-hero__eyebrow{font-family:var(--font-head);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--yellow);margin-bottom:10px;position:relative;z-index:1}
.project-hero__title{font-family:var(--font-head);font-size:clamp(28px,4vw,52px);font-weight:400;line-height:1.05;letter-spacing:.03em;text-transform:uppercase;margin-bottom:14px;position:relative;z-index:1}
.project-hero__title span{color:var(--yellow)}
.project-hero__desc{font-size:13px;color:var(--text2);font-weight:400;line-height:1.75;max-width:640px;position:relative;z-index:1}
.project-hero__tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:16px;position:relative;z-index:1}

/* ── PROJECT TABS ── */
.project-nav{display:flex;gap:0;border-bottom:1px solid var(--bd);margin-bottom:0;overflow-x:auto}
.project-tab{flex-shrink:0;background:none;border:none;border-bottom:2px solid transparent;padding:10px 16px;font-family:var(--font-head);font-size:13px;font-weight:400;letter-spacing:.06em;text-transform:uppercase;color:var(--text2);cursor:pointer;transition:color .15s,border-color .15s;white-space:nowrap}
.project-tab.active{color:var(--yellow);border-bottom-color:var(--yellow)}
.project-tab:hover{color:var(--text)}
.ov-tab{flex-shrink:0;background:none;border:none;border-bottom:2px solid transparent;padding:10px 16px;font-family:var(--font-head);font-size:13px;font-weight:400;letter-spacing:.06em;text-transform:uppercase;color:var(--text2);cursor:pointer;transition:color .15s,border-color .15s;white-space:nowrap}
.ov-tab.active{color:var(--yellow);border-bottom-color:var(--yellow)}
.ov-tab:hover{color:var(--text)}
.ov-panel{display:none;padding-top:32px}
.ov-panel.active{display:block}

/* ── PAGE CONTENT ── */
.page-content{padding-top:120px;padding-bottom:80px}
.page-content h1{font-family:var(--font-head);font-size:clamp(32px,4vw,52px);font-weight:400;letter-spacing:.04em;text-transform:uppercase;margin-bottom:24px}
.page-content h2{font-family:var(--font-head);font-size:26px;font-weight:400;letter-spacing:.04em;text-transform:uppercase;margin:32px 0 14px;color:var(--yellow)}
.page-content h3{font-family:var(--font-head);font-size:18px;font-weight:400;letter-spacing:.04em;text-transform:uppercase;margin:24px 0 10px}
.page-content p{font-size:14px;color:var(--text2);line-height:1.8;margin-bottom:16px}
.page-content p strong{color:var(--text);font-weight:500}
.page-content a{color:var(--yellow)}
.page-content ul li{font-size:14px;color:var(--text2);padding-left:16px;position:relative;margin-bottom:4px;line-height:1.75}
.page-content ul li::before{content:'–';position:absolute;left:0;color:var(--text3)}

/* ── SOLUTION BOX ── */
.solution-box{background:var(--surf2);border:1px solid var(--bd2);padding:36px;margin-bottom:32px;position:relative;overflow:hidden;border-radius:var(--r)}
.solution-box::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 60% at 80% 50%,rgba(248,195,19,0.05),transparent);pointer-events:none}
.solution-quote{font-family:var(--font-head);font-size:clamp(16px,2.2vw,26px);font-weight:400;letter-spacing:.03em;text-transform:uppercase;line-height:1.2;margin-bottom:16px;position:relative;z-index:1}
.solution-quote em{font-style:normal;color:var(--yellow)}
.solution-sub{font-size:13px;color:var(--text2);font-weight:400;line-height:1.75;max-width:620px;position:relative;z-index:1}

/* ── FEATURES ── */
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.feature-card{background:var(--surf);border:1px solid var(--bd);padding:22px;transition:all .25s;border-radius:var(--r)}
.feature-card:hover{border-color:rgba(248,195,19,0.25);transform:translateY(-2px)}
.feature-chip{display:inline-flex;font-family:var(--font-head);font-size:10px;font-weight:400;letter-spacing:.1em;text-transform:uppercase;padding:2px 10px;margin-bottom:12px;background:rgba(248,195,19,0.1);color:var(--yellow);border:1px solid rgba(248,195,19,0.25)}
.feature-title{font-family:var(--font-head);font-size:18px;font-weight:400;letter-spacing:.04em;text-transform:uppercase;margin-bottom:6px}
.feature-body{font-size:11px;color:var(--text2);line-height:1.65}

/* ── SOURCES ── */
.sources-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.source-card{background:var(--surf);border:1px solid var(--bd);padding:16px;border-radius:var(--r)}
.source-card--highlight{border-color:var(--bd2);background:rgba(248,195,19,0.05)}
.source-cat{font-family:var(--font-head);font-size:10px;font-weight:400;text-transform:uppercase;letter-spacing:.1em;color:var(--text3);margin-bottom:7px}
.source-card--highlight .source-cat{color:var(--yellow)}
.source-items{font-size:11px;color:var(--text2);line-height:1.8}
.source-note{margin-top:16px;background:var(--surf);border:1px solid var(--bd);border-left:3px solid var(--yellow);padding:16px 20px;font-size:12px;color:var(--text2);line-height:1.7}

/* ── SETUP BOX ── */
.setup-box{background:var(--bg2);border:1px solid var(--bd2);padding:30px;margin-top:32px;display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:center;border-radius:var(--r)}
.setup-steps{display:flex;flex-direction:column;gap:12px}
.setup-step{display:flex;align-items:flex-start;gap:12px}
.step-num{width:26px;height:26px;background:var(--orange);color:#fff;font-family:var(--font-head);font-size:13px;font-weight:400;display:flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:var(--r-btn)}
.step-text strong{font-size:12px;font-weight:500;display:block;margin-bottom:2px}
.step-text span{font-size:11px;color:var(--text2)}
.setup-icons{display:flex;flex-wrap:wrap;gap:6px}
.setup-icon{background:var(--surf);border:1px solid var(--bd);padding:5px 10px;font-size:10px;color:var(--text2);display:flex;align-items:center;gap:5px}
.setup-icon__dot{width:5px;height:5px;background:var(--yellow)}

/* ── PHASES ── */
.phases-timeline{display:flex;flex-direction:column;position:relative}
.phases-timeline::before{content:'';position:absolute;left:19px;top:26px;bottom:26px;width:1px;background:linear-gradient(to bottom,var(--yellow),var(--bd))}
.phase-row{display:grid;grid-template-columns:40px 1fr;gap:18px;position:relative}
.phase-dot{width:38px;height:38px;display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-size:14px;font-weight:400;flex-shrink:0;z-index:1;margin-top:4px}
.phase-card{background:var(--surf);border:1px solid var(--bd);padding:20px 24px;margin-bottom:6px;border-radius:var(--r)}
.phase-label{font-family:var(--font-head);font-size:10px;font-weight:400;text-transform:uppercase;letter-spacing:.1em;margin-bottom:4px}
.phase-title{font-family:var(--font-head);font-size:18px;font-weight:400;letter-spacing:.03em;text-transform:uppercase;margin-bottom:6px}
.phase-body{font-size:12px;color:var(--text2);line-height:1.65;margin-bottom:10px}
.phase-tags{display:flex;gap:5px;flex-wrap:wrap}
.ptag{font-family:var(--font-head);font-size:9px;font-weight:400;letter-spacing:.06em;text-transform:uppercase;padding:2px 9px;border:1px solid var(--bd);color:var(--text3)}

/* ── REVENUE ── */
.revenue-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.rev-card{background:var(--surf);border:1px solid var(--bd);padding:20px;position:relative;overflow:hidden;border-radius:var(--r)}
.rev-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px}
.rev-card--1::after{background:var(--green)} .rev-card--2::after{background:var(--yellow)} .rev-card--3::after{background:var(--orange)} .rev-card--4::after{background:var(--yellow)}
.rev-stream{font-family:var(--font-head);font-size:9px;font-weight:400;text-transform:uppercase;letter-spacing:.1em;color:var(--text3);margin-bottom:7px}
.rev-name{font-family:var(--font-head);font-size:14px;font-weight:400;letter-spacing:.04em;text-transform:uppercase;margin-bottom:4px}
.rev-price{font-family:var(--font-head);font-size:20px;font-weight:400;color:var(--yellow);margin-bottom:4px;letter-spacing:.03em}
.rev-detail{font-size:11px;color:var(--text2);line-height:1.5}

/* ── STATS ── */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.stat-card{background:var(--bg2);border:1px solid var(--bd);padding:20px;text-align:center;border-radius:var(--r)}
.stat-num{font-family:var(--font-head);font-size:28px;font-weight:400;color:var(--yellow);margin-bottom:4px;letter-spacing:.03em}
.stat-label{font-size:10px;color:var(--text2);text-transform:uppercase;letter-spacing:.05em;line-height:1.5}

/* ── EU BOX ── */
.eu-box{background:rgba(76,175,125,0.05);border:1px solid rgba(76,175,125,0.2);padding:32px;margin-bottom:24px;border-radius:var(--r)}
.eu-box p{font-size:13px;color:var(--text2);line-height:1.8;max-width:680px}
.eu-box strong{color:var(--text);font-weight:500}
.eu-checks{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.eu-check{display:flex;align-items:flex-start;gap:9px;font-size:11px;color:var(--text2);background:var(--surf);border:1px solid var(--bd);padding:11px 13px;border-radius:var(--r)}
.eu-check__icon{width:15px;height:15px;flex-shrink:0;background:rgba(248,195,19,.12);color:var(--yellow);font-size:8px;font-weight:700;display:flex;align-items:center;justify-content:center;margin-top:1px}

/* ── FOERDER CARDS ── */
.foerder-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:24px}
.foerder-card{background:var(--surf);border:1px solid var(--bd);padding:24px;transition:border-color .2s;border-radius:var(--r)}
.foerder-card:hover{border-color:var(--bd2)}
.foerder-card--primary{border-color:var(--bd2);background:rgba(248,195,19,0.04)}
.fc-badge{font-family:var(--font-head);display:inline-block;font-size:9px;font-weight:400;text-transform:uppercase;letter-spacing:.1em;padding:2px 10px;margin-bottom:10px;background:rgba(248,195,19,0.1);color:var(--yellow);border:1px solid rgba(248,195,19,0.25)}
.fc-badge--green{background:var(--green-d);color:var(--green);border-color:rgba(76,175,125,.25)} .fc-badge--amber,.fc-badge--blue,.fc-badge--purple{background:rgba(248,195,19,0.1);color:var(--yellow);border-color:rgba(248,195,19,0.25)}
.fc-title{font-family:var(--font-head);font-size:16px;font-weight:400;letter-spacing:.04em;text-transform:uppercase;margin-bottom:5px}
.fc-body{font-size:11px;color:var(--text2);line-height:1.65;margin-bottom:8px}
.fc-detail{font-size:10px;color:var(--text3)}
.foerder-note{background:var(--bg2);border:1px solid var(--bd);border-left:3px solid var(--green);padding:16px 20px;font-size:11px;color:var(--text2);line-height:1.7}

/* ── BOARDS ── */
.boards-layout{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:start}
.vis-step{display:flex;gap:12px;align-items:flex-start;padding:12px;background:var(--surf);border:1px solid var(--bd);margin-bottom:6px;border-radius:var(--r)}
.vis-icon{width:30px;height:30px;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;background:rgba(248,195,19,0.1)}
.vis-step__title{font-family:var(--font-head);font-size:13px;font-weight:400;letter-spacing:.04em;text-transform:uppercase;margin-bottom:2px}
.vis-step__body{font-size:11px;color:var(--text2);line-height:1.55}
.masterboard-visual{background:var(--surf);border:1px solid var(--bd2);border-radius:var(--r);overflow:hidden}
.mb-header{background:var(--bg3);border-bottom:1px solid var(--bd);padding:13px 16px;display:flex;align-items:center;gap:10px}
.mb-avatar{width:30px;height:30px;background:var(--yellow);display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-size:13px;font-weight:400;color:#1c0000;flex-shrink:0;letter-spacing:.05em}
.mb-name{font-family:var(--font-head);font-size:13px;font-weight:400;letter-spacing:.04em;text-transform:uppercase}
.mb-sub{font-size:9px;color:var(--text2)}
.mb-follow{margin-left:auto;background:var(--orange);color:#fff;border:none;padding:4px 12px;font-family:var(--font-head);font-size:10px;font-weight:400;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;border-radius:var(--r-btn)}
.mb-boards-list{padding:10px;display:flex;flex-direction:column;gap:4px}
.mb-board-item{background:var(--bg2);border:1px solid var(--bd);padding:9px 11px;display:flex;align-items:center;justify-content:space-between;border-radius:var(--r)}
.mb-board-name{font-size:11px;font-weight:500}
.mb-board-vis{font-family:var(--font-head);font-size:8px;padding:2px 6px;font-weight:400;letter-spacing:.06em;text-transform:uppercase}
.vis-public{background:rgba(248,195,19,.12);color:var(--yellow)} .vis-follower{background:rgba(248,195,19,0.12);color:var(--yellow)} .vis-collab{background:var(--orange-d);color:var(--orange)} .vis-private{background:rgba(255,255,255,.06);color:var(--text3)}

/* ── BADGES ── */
.badges-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:16px}
.badge-card{background:var(--surf);border:1px solid var(--bd);padding:18px;border-radius:var(--r)}
.badge-pill{font-family:var(--font-head);display:inline-flex;align-items:center;gap:5px;font-size:10px;font-weight:400;letter-spacing:.08em;text-transform:uppercase;padding:3px 10px;margin-bottom:10px;background:rgba(248,195,19,0.1);color:var(--yellow);border:1px solid rgba(248,195,19,0.25)}
.badge-title{font-family:var(--font-head);font-size:14px;font-weight:400;letter-spacing:.04em;text-transform:uppercase;margin-bottom:4px}
.badge-body{font-size:11px;color:var(--text2);line-height:1.6}
.badge-source{margin-top:6px;font-size:9px;color:var(--text3);font-style:italic}

/* ── TOOLBOX ── */
.toolbox-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.tool-card{background:var(--surf);border:1px solid var(--bd);padding:20px;border-radius:var(--r)}
.tool-phase{font-family:var(--font-head);font-size:10px;font-weight:400;text-transform:uppercase;letter-spacing:.1em;margin-bottom:9px}
.tool-title{font-family:var(--font-head);font-size:16px;font-weight:400;letter-spacing:.04em;text-transform:uppercase;margin-bottom:5px}
.tool-body{font-size:11px;color:var(--text2);line-height:1.6}

/* ── PERSONAS ── */
.personas-nav{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:24px}
.persona-tab{font-family:var(--font-head);padding:6px 16px;font-size:12px;font-weight:400;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;border:1px solid var(--bd);background:transparent;color:var(--text2);transition:all .15s;border-radius:var(--r-btn)}
.persona-tab.active,.persona-tab:hover{background:var(--yellow);border-color:var(--yellow);color:#1c0000}
.persona-panel{display:none}
.persona-panel.active{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start}
.p-avatar{width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-size:16px;font-weight:400;margin-bottom:14px;background:var(--surf2)}
.persona-name{font-family:var(--font-head);font-size:20px;font-weight:400;letter-spacing:.04em;text-transform:uppercase;margin-bottom:3px}
.persona-role{font-size:11px;color:var(--text2);margin-bottom:14px}
.persona-story{font-size:12px;color:var(--text2);line-height:1.8}
.persona-board{background:var(--surf);border:1px solid var(--bd);border-radius:var(--r);overflow:hidden}
.pb-bar{background:var(--bg3);border-bottom:1px solid var(--bd);padding:8px 11px;display:flex;align-items:center;gap:6px;font-size:10px}
.pb-bar__title{font-family:var(--font-head);font-weight:400;letter-spacing:.04em;text-transform:uppercase;font-size:11px}
.pb-bar__status{margin-left:auto;font-size:8px;color:var(--orange);font-weight:500;font-family:var(--font-head);letter-spacing:.06em;text-transform:uppercase}
.pb-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;padding:6px}
.pb-tile{height:62px;position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;padding:5px}
.pb-tile__label{font-size:7px;color:rgba(255,255,255,.7);background:rgba(0,0,0,.5);padding:2px 4px;width:fit-content}
.pb-tile__badge{position:absolute;top:4px;right:4px;font-size:6px;font-weight:500;padding:1px 3px;font-family:var(--font-head);letter-spacing:.04em;text-transform:uppercase}
.t1{background:linear-gradient(135deg,#2a0000,#4a0010)} .t2{background:linear-gradient(135deg,#1a0a00,#3a1500)} .t3{background:linear-gradient(135deg,#001a00,#003010)} .t4{background:linear-gradient(135deg,#1a0000,#350000)} .t5{background:linear-gradient(135deg,#0a0010,#200030)} .t6{background:linear-gradient(135deg,#000a1a,#001a35)}
.badge-g{background:rgba(248,195,19,.2);color:var(--yellow)} .badge-b{background:rgba(248,195,19,.2);color:var(--yellow)} .badge-a{background:rgba(248,102,19,.2);color:var(--orange)}

/* ── COMPETITION TABLE ── */
.competition-table{width:100%;border-collapse:separate;border-spacing:0;margin-top:24px;border:1px solid var(--bd)}
.competition-table th{background:var(--surf2);padding:11px 14px;text-align:left;font-family:var(--font-head);font-size:10px;font-weight:400;text-transform:uppercase;letter-spacing:.1em;color:var(--text2);border-bottom:1px solid var(--bd)}
.competition-table td{padding:11px 14px;font-size:11px;border-bottom:1px solid var(--bd);vertical-align:middle}
.competition-table tr:last-child td{border-bottom:none}
.competition-table tr.ov-row td{background:rgba(248,195,19,0.05)}
.competition-table tr.ov-row td:first-child{border-left:3px solid var(--yellow)}
.check-y{color:var(--yellow);font-weight:500} .check-n{color:var(--text3)} .ov-name{font-family:var(--font-head);font-weight:400;letter-spacing:.04em;text-transform:uppercase;font-size:13px}

/* ── PROBLEM CARDS ── */
.problem-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.problem-card{background:var(--surf);border:1px solid var(--bd);padding:24px;position:relative;overflow:hidden;transition:border-color .2s;border-radius:var(--r)}
.problem-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px}
.pc-red::before{background:var(--orange)} .pc-amber::before{background:var(--yellow)} .pc-blue::before{background:var(--yellow)}
.problem-icon{font-size:18px;margin-bottom:10px}
.problem-title{font-family:var(--font-head);font-size:15px;font-weight:400;letter-spacing:.04em;text-transform:uppercase;margin-bottom:8px}
.problem-list{list-style:none;padding:0;margin:0}
.problem-list li{font-size:11px;color:var(--text2);padding:2px 0 2px 11px;position:relative}
.problem-list li::before{content:'–';position:absolute;left:0;color:var(--text3)}

/* ── FOOTER ── */
.site-footer{border-top:1px solid var(--bd);padding:28px 5vw}
.site-footer__inner{max-width:1060px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.footer-logo{font-family:var(--font-head);font-weight:400;font-size:16px;letter-spacing:.06em;text-transform:uppercase;color:var(--text2);text-decoration:none}
.footer-logo span{color:var(--yellow)}
.footer-nav{display:flex;gap:20px;list-style:none;padding:0;margin:0}
.footer-nav a{font-family:var(--font-head);font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--text3);text-decoration:none;transition:color .2s}
.footer-nav a:hover{color:var(--yellow)}
.footer-copy{font-size:11px;color:var(--text3)}

/* ── MISC ── */
.back-link{font-family:var(--font-head);display:inline-flex;align-items:center;gap:7px;font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--text2);text-decoration:none;margin-bottom:32px;transition:color .2s}
.back-link:hover{color:var(--yellow)}
.back-link::before{content:'←'}

/* ── ABOUT GRID ── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .hero__grid,.about-grid,.boards-layout,.features-grid{grid-template-columns:1fr}
  .skills-grid,.sources-grid,.stats-grid,.eu-checks,.foerder-grid,.toolbox-grid{grid-template-columns:1fr 1fr}
  .persona-panel.active{grid-template-columns:1fr}
  .projects-grid{grid-template-columns:1fr}
  .nav-menu{display:none}
  .nav-toggle{display:block}
  .site-section{padding:60px 0}
  .setup-box{grid-template-columns:1fr;padding:22px}
  .project-hero{padding:24px 26px}
}
@media(max-width:600px){
  .skills-grid,.sources-grid,.stats-grid,.eu-checks,.foerder-grid,.toolbox-grid,.badges-grid{grid-template-columns:1fr}
  .site-footer__inner{flex-direction:column;align-items:flex-start}
}

/* ── PROFILE CARD UPDATES ── */
.profile-card__contact{font-size:10px;color:var(--text3);margin-top:3px;letter-spacing:.02em}
.profile-card__top{background:var(--bg3);border-bottom:1px solid var(--bd);padding:16px 20px;display:flex;align-items:center;gap:12px}

/* ── SKILL CARDS: kein Icon mehr ── */
.skill-card__head .skill-card__icon{display:none}

/* ── BACKGROUND auf Sections ── */
.site-section{position:relative}
#skills{background:url(images/hintergrund.png) repeat;background-blend-mode:multiply;background-color:var(--surf)}

/* ── FOERDER + EU checks: grün → gold ── */
.foerder-note{border-left-color:var(--yellow)}

/* ── SKILL HEADLINES – unterschiedliche Schriften ── */
.skill-card__title{font-size:20px;font-weight:400;letter-spacing:.04em;text-transform:uppercase;color:var(--gold)}
.skill-title--konzeption{font-family:'Open Sans',sans-serif;font-weight:800;font-style:italic;text-transform:none;font-size:18px;letter-spacing:0}
.skill-title--digital{font-family:'Orbitron',sans-serif;font-weight:700;font-size:16px;letter-spacing:.06em;text-transform:uppercase}
.skill-title--ausbildung{font-family:Impact,Haettenschweiler,'Arial Narrow Bold',sans-serif;font-weight:400;font-size:20px;letter-spacing:.04em;text-transform:uppercase}
.skill-title--gestaltung{font-family:'Pacifico',cursive;font-weight:400;font-size:18px;letter-spacing:0;text-transform:none}
.skill-title--fuehrung{font-family:'Pacifico',cursive;font-weight:400;font-size:18px;letter-spacing:0;text-transform:none}
.skill-title--print{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:20px;letter-spacing:.06em;text-transform:uppercase}

/* ── HINTERGRUND – überall ── */
.site-section,
.hero,
#ueber,
#skills,
#projekte,
#kontakt {
  background-image: url('hintergrund.png');
  background-size: 400px auto;
  background-repeat: repeat;
  background-blend-mode: overlay;
}

/* Sections haben eigene Hintergrundfarbe + Tapete */
#ueber  { background-color: var(--bg); }
#skills { background-color: var(--bg2); }
#projekte { background-color: var(--bg); }
#kontakt { background-color: var(--bg2); }
.hero { background-color: var(--bg); }

/* Karten leicht transparent damit Tapete durchscheint */
.skill-card,
.cv-card,
.info-row,
.project-card,
.phase-card,
.feature-card,
.rev-card,
.stat-card,
.tool-card,
.source-card,
.foerder-card,
.badge-card,
.eu-check,
.vis-step,
.mb-board-item,
.problem-card {
  background: rgba(42,0,0,0.85);
  backdrop-filter: blur(2px);
}

.solution-box,
.project-hero,
.setup-box {
  background: rgba(74,0,0,0.88);
}

/* ── RITTER-ICONS – Positionierung ── */
.ritter {
  position: absolute;
  pointer-events: none;
  z-index: 2;
}

/* Section-Wrapper braucht position:relative */
.section-has-ritter {
  position: relative;
  overflow: visible;
}

.ritter--hero {
  right: -20px;
  top: -60px;
  width: 140px;
  opacity: 0.9;
}

.ritter--skills {
  right: 0;
  top: -20px;
  width: 130px;
  opacity: 0.85;
}

.ritter--projekte {
  right: 0;
  top: -10px;
  width: 120px;
  opacity: 0.85;
}

.ritter--profil {
  left: 50%;
  transform: translateX(-50%);
  bottom: -60px;
  width: 110px;
  opacity: 0.8;
}

.ritter--kontakt {
  right: 40px;
  bottom: -10px;
  width: 130px;
  opacity: 0.9;
}

/* ── PROJEKT-KARTEN transparent ── */
.project-card {
  background: transparent;
  border: 1px solid var(--gold);
}
.project-card__thumb {
  background: transparent;
}
.project-card__thumb-placeholder {
  font-size: 80px;
  opacity: 0.15;
  color: var(--gold);
}

/* ── PROFILE CARD – KONTAKT gross ── */
.profile-card__kontakt-heading {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 32px;
  letter-spacing: .06em;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.profile-card__kontakt-heading img {
  width: 60px;
  height: auto;
  object-fit: contain;
}


/* ── GHOST BUTTON – nur goldene Outline ── */
.btn--ghost {
  background: transparent !important;
  color: var(--gold);
  border: 1px solid var(--gold);
  border-radius: var(--r-btn);
}
.btn--ghost:hover {
  background: rgba(201,168,76,0.1) !important;
  color: var(--gold);
  border-color: var(--gold);
}

/* Projekt-Card: nur erster Buchstabe groß */
.project-card__thumb-placeholder {
  font-size: 100px !important;
  opacity: 0.12 !important;
  line-height: 1;
}

/* Alle Sections: background auch für overlayer panels */
.ov-panel {
  background-image: url('hintergrund.png');
  background-size: 400px auto;
  background-repeat: repeat;
  background-blend-mode: overlay;
  background-color: transparent;
}

/* ══════════════════════════════════════════════════════
   ALLE FIXES – v7
══════════════════════════════════════════════════════ */

/* Hintergrund: dezenter Verlauf statt Tapete */
body {
  background: linear-gradient(160deg, #1c0000 0%, #0e0000 40%, #000000 100%) !important;
  background-attachment: fixed !important;
}
.site-section, .hero, #hero, #ueber, #skills, #projekte, #kontakt, .site-footer,
.ov-panel, .site-section, section {
  background-image: none !important;
}
#ueber  { background: rgba(28,0,0,0.6); }
#skills { background: rgba(20,0,0,0.5); }
#projekte { background: rgba(28,0,0,0.6); }
#kontakt  { background: rgba(20,0,0,0.5); }

/* Footer schwarz */
.site-footer {
  background: #000000 !important;
  background-image: none !important;
}

/* Ritter komplett entfernen */
.ritter { display: none !important; }

/* profile-card__top komplett weg */
.profile-card__top { display: none !important; }

/* Kontakt-Section verstecken (Formular ist oben in der Card) */
#kontakt-section { display: none; }

/* CV-Titel: letter-spacing */
.cv-title {
  letter-spacing: .1em;
  font-size: 14px !important;
}
.cv-body { font-size: 12px !important; }
.info-row { font-size: 12px !important; }
.info-val { font-size: 12px !important; }

/* Mobile: CV-Timeline unter Info-List */
@media(max-width:900px) {
  .about-grid {
    grid-template-columns: 1fr !important;
    display: flex !important;
    flex-direction: column !important;
  }
  .about-grid .cv-timeline {
    order: 2;
  }
  .about-grid .info-list {
    order: 1;
  }
}

/* Project hero transparent */
.project-hero.fade-up,
.project-hero.fade-up.visible,
.project-hero {
  background: transparent !important;
  border-color: var(--gold) !important;
}

/* Project card thumb – nur 1. Buchstabe, maximal groß */
.project-card__thumb {
  background: transparent !important;
  border: 1px solid var(--gold);
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 180px;
}
.project-card__thumb-placeholder {
  font-size: clamp(60px, 15vw, 140px) !important;
  opacity: 0.15 !important;
  color: var(--gold) !important;
  line-height: 1;
  font-weight: 400;
}

/* Abwechselnde Schriften für Projekt-Thumbnails */
.project-card:nth-child(1) .project-card__thumb-placeholder { font-family: 'Bebas Neue', sans-serif; }
.project-card:nth-child(2) .project-card__thumb-placeholder { font-family: 'Orbitron', sans-serif; font-size: clamp(40px, 10vw, 100px) !important; }
.project-card:nth-child(3) .project-card__thumb-placeholder { font-family: 'Pacifico', cursive; font-size: clamp(50px, 12vw, 110px) !important; }
.project-card:nth-child(4) .project-card__thumb-placeholder { font-family: Impact, sans-serif; }
.project-card:nth-child(5) .project-card__thumb-placeholder { font-family: 'Open Sans', sans-serif; font-weight: 800; font-style: italic; }
.project-card:nth-child(6) .project-card__thumb-placeholder { font-family: 'Bebas Neue', sans-serif; }

/* project-content Überschriften gold + Bebas */
.project-content h1,
.project-content h2,
.project-content h3,
.project-content h4 {
  font-family: 'Bebas Neue', sans-serif !important;
  color: var(--gold) !important;
  text-transform: uppercase;
  letter-spacing: .06em;
}

/* rgba(255,255,255,x) nur bei Borders/Dekorativem durch gold */
.bd-white { border-color: rgba(201,168,76,0.25) !important; }

/* Problem Grid responsive + keine Icons */
@media(max-width:900px) {
  .problem-grid {
    grid-template-columns: 1fr !important;
  }
}
.problem-icon { display: none !important; }

/* Overlayer: blau raus, gold rein */
.ov-tab.active { color: var(--gold) !important; border-bottom-color: var(--gold) !important; }
.ov-tab:hover { color: var(--text) !important; }
.feature-chip { background: rgba(201,168,76,0.1) !important; color: var(--gold) !important; border-color: rgba(201,168,76,0.25) !important; }
.solution-quote em { color: var(--gold) !important; }
.solution-box { border-color: rgba(201,168,76,0.35) !important; }
.source-card--highlight { border-color: rgba(201,168,76,0.35) !important; background: rgba(201,168,76,0.04) !important; }
.source-card--highlight .source-cat { color: var(--gold) !important; }
.foerder-card--primary { border-color: rgba(201,168,76,0.35) !important; background: rgba(201,168,76,0.04) !important; }
.mb-avatar { background: var(--gold) !important; color: #1c0000 !important; }
.mb-follow { background: var(--orange) !important; }
.vis-follower { background: rgba(201,168,76,0.15) !important; color: var(--gold) !important; }
.setup-icon__dot { background: var(--gold) !important; }
.step-num { background: var(--orange) !important; }
.competition-table tr.ov-row td:first-child { border-left-color: var(--gold) !important; }
.competition-table tr.ov-row td { background: rgba(201,168,76,0.05) !important; }
.persona-tab.active,.persona-tab:hover { background: var(--gold) !important; border-color: var(--gold) !important; color: #1c0000 !important; }
.badge-pill { background: rgba(201,168,76,0.1) !important; color: var(--gold) !important; border-color: rgba(201,168,76,0.25) !important; }
.project-nav .project-tab.active { color: var(--gold) !important; border-bottom-color: var(--gold) !important; }
.project-hero__title span { color: var(--gold) !important; }
.project-hero__eyebrow { color: var(--gold) !important; }

/* Mobile First – Global */
@media(max-width:600px) {
  .hero__grid { grid-template-columns: 1fr !important; gap: 32px !important; }
  .hero__title { font-size: clamp(38px, 12vw, 60px) !important; }
  .skills-grid { grid-template-columns: 1fr !important; }
  .projects-grid { grid-template-columns: 1fr !important; }

  .stats-grid { grid-template-columns: 1fr 1fr !important; }
  .features-grid { grid-template-columns: 1fr !important; }
  .toolbox-grid { grid-template-columns: 1fr !important; }
  .sources-grid { grid-template-columns: 1fr 1fr !important; }
  .foerder-grid { grid-template-columns: 1fr !important; }
  .badges-grid { grid-template-columns: 1fr !important; }
  .eu-checks { grid-template-columns: 1fr !important; }
  .boards-layout { grid-template-columns: 1fr !important; }
  .persona-panel.active { grid-template-columns: 1fr !important; }
  .setup-box { grid-template-columns: 1fr !important; }
  .phase-title { font-size: 15px !important; }
  .site-section { padding: 48px 0 !important; }
  .wrap { padding: 0 4vw !important; }
  .project-hero { padding: 20px !important; }
  .ov-nav { -webkit-overflow-scrolling: touch; }
}

/* ══════════════════════════════════════════════════════
   KARUSSELL
══════════════════════════════════════════════════════ */
.cn-carousel {
  position: relative;
  width: 100%;
  margin: 24px 0;
}
.cn-carousel__track-wrap {
  position: relative;
  display: flex;
  align-items: center;
  gap: 0;
}
.cn-carousel__track {
  display: flex;
  gap: 16px;
  overflow: hidden;
  scroll-behavior: smooth;
  flex: 1;
  /* Snap */
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
}
.cn-carousel__item {
  flex: 0 0 auto;
  width: 260px;
  cursor: pointer;
  scroll-snap-align: start;
  border: 1px solid var(--gold);
  border-radius: 12px 0 12px 0;
  overflow: hidden;
  background: var(--surf);
  transition: border-color .2s, transform .2s;
}
.cn-carousel__item:hover {
  border-color: var(--orange);
  transform: translateY(-2px);
}
.cn-carousel__img-wrap {
  height: 180px;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg2);
}
.cn-carousel__img-wrap img {
  width: auto;
  height: 100%;
  object-fit: cover;
  display: block;
}
.cn-carousel__tags {
  padding: 10px 12px;
  gap: 5px;
  flex-wrap: wrap;
  display: flex;
}
/* Pfeil-Buttons */
.cn-carousel__btn {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  background: rgba(201,168,76,0.15);
  border: 1px solid var(--gold);
  color: var(--gold);
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .2s;
  z-index: 2;
}
.cn-carousel__btn:hover { background: rgba(201,168,76,0.3); }
.cn-carousel__btn--prev { margin-right: 8px; }
.cn-carousel__btn--next { margin-left: 8px; }
/* Dots */
.cn-carousel__dots {
  display: flex;
  justify-content: center;
  gap: 6px;
  margin-top: 14px;
}
.cn-carousel__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--bd);
  border: 1px solid var(--gold);
  cursor: pointer;
  transition: background .2s;
  padding: 0;
}
.cn-carousel__dot.active { background: var(--gold); }

/* ══════════════════════════════════════════════════════
   LIGHTBOX
══════════════════════════════════════════════════════ */
.cn-lightbox {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(0,0,0,0.95);
  display: flex !important;
  align-items: center;
  justify-content: center;
  gap: 20px;
  padding: 20px;
}
.cn-lightbox[style*="display:none"] { display: none !important; }
.cn-lightbox__inner {
  max-width: 90vw;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
}
.cn-lightbox__inner img {
  max-width: 85vw;
  max-height: 80vh;
  object-fit: contain;
  border-radius: 12px 0 12px 0;
  border: 1px solid var(--gold);
}
.cn-lightbox__tags {
  justify-content: center;
}
.cn-lightbox__close {
  position: fixed;
  top: 20px;
  right: 28px;
  background: rgba(201,168,76,0.15);
  border: 1px solid var(--gold);
  color: var(--gold);
  font-size: 20px;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .2s;
  z-index: 10000;
}
.cn-lightbox__close:hover { background: rgba(201,168,76,0.35); }
.cn-lightbox__prev,
.cn-lightbox__next {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  background: rgba(201,168,76,0.12);
  border: 1px solid var(--gold);
  color: var(--gold);
  font-size: 28px;
  cursor: pointer;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .2s;
}
.cn-lightbox__prev:hover,
.cn-lightbox__next:hover { background: rgba(201,168,76,0.3); }

@media(max-width:600px) {
  .cn-carousel__item { width: 85vw; }
  .cn-lightbox__inner img { max-width: 96vw; max-height: 70vh; }
  .cn-lightbox__prev, .cn-lightbox__next { width: 36px; height: 36px; font-size: 22px; }
}

/* ══════════════════════════════════════════════════════
   HERO BANNER
══════════════════════════════════════════════════════ */
.cn-hero-banner {
  position: relative;
  width: 100%;
  min-height: 320px;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  border-bottom: 2px solid var(--gold);
  overflow: hidden;
  display: flex;
  align-items: center;
}
.cn-hero-banner__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.35);
  transition: background .35s ease;
}
.cn-hero-banner:hover .cn-hero-banner__overlay {
  background: rgba(0,0,0,0.62);
}
.cn-hero-banner__inner {
  position: relative;
  z-index: 2;
  padding: 50px;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.cn-hero-banner__title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(42px, 6vw, 78px);
  font-weight: 400;
  line-height: 1.0;
  letter-spacing: .03em;
  text-transform: uppercase;
  margin: 0;
  text-shadow: 0 2px 12px rgba(0,0,0,0.5);
}
.cn-hero-banner__btn {
  align-self: auto;
  width: fit-content;
}

/* ══════════════════════════════════════════════════════
   BILD GRID
══════════════════════════════════════════════════════ */
.cn-bild-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 0;
  border-bottom: 2px solid var(--gold);
  overflow: hidden;
}
.cn-bild-grid__item {
  position: relative;
  aspect-ratio: 1 / 1;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  border: 1px solid var(--bd);
  border-radius: 12px 0 12px 0;
  display: flex;
  align-items: center;
  overflow: hidden;
  cursor: pointer;
}
.cn-bild-grid__item:last-child {
  border-right: 1px solid var(--bd);
}
/* Auf Mobile: Trennlinie unten statt rechts */
@media(max-width:600px) {
  .cn-bild-grid {
    grid-template-columns: 1fr;
  }
  .cn-bild-grid__item {
    border: 1px solid var(--bd);
    border-radius: 12px 0 12px 0;
  }
}
.cn-bild-grid__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.3);
  transition: background .3s ease;
}
.cn-bild-grid__item:hover .cn-bild-grid__overlay {
  background: rgba(0,0,0,0.58);
}
.cn-bild-grid__inner {
  position: relative;
  z-index: 2;
  padding: 20px;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.cn-bild-grid__title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 20px;
  font-weight: 400;
  letter-spacing: .05em;
  text-transform: uppercase;
  margin: 0;
  line-height: 1.15;
  text-shadow: 0 1px 6px rgba(0,0,0,0.6);
}
.cn-bild-grid__btn {
  width: fit-content;
  font-size: 12px;
  padding: 6px 16px;
}

/* bild-grid border fix */
.cn-bild-grid__item { border:1px solid var(--bd) !important; border-radius:12px 0 12px 0 !important; }

/* ══════════════════════════════════════════════════════
   NEUE INHALTSBLÖCKE v13
══════════════════════════════════════════════════════ */

/* ── PERSONAS ── */
.cn-personas { width:100%; }
.cn-personas .personas-nav { display:flex; gap:7px; flex-wrap:wrap; margin-bottom:24px; }
.cn-personas .persona-tab { padding:6px 16px; border-radius:20px; font-size:11px; font-weight:500; cursor:pointer; border:1px solid var(--bd); background:transparent; color:var(--text2); font-family:var(--font-body); transition:all .15s; }
.cn-personas .persona-tab.active, .cn-personas .persona-tab:hover { background:var(--gold); border-color:var(--gold); color:#1c0000; }
.cn-personas__panel { display:none; }
.cn-personas__panel.active { display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:center; }
.cn-personas__left { display:flex; flex-direction:column; gap:16px; }
.cn-personas__eyebrow { font-size:10px; font-weight:600; text-transform:uppercase; letter-spacing:.12em; color:var(--gold); }
.cn-personas__title { font-family:var(--font-head); font-size:clamp(20px,2.5vw,28px); font-weight:400; letter-spacing:.03em; text-transform:uppercase; }
.cn-personas__text { font-size:13px; color:var(--text2); line-height:1.75; }
.cn-personas__btn { display:inline-flex; align-items:center; gap:8px; background:transparent; border:1px solid var(--gold); color:var(--gold); padding:8px 18px; font-family:var(--font-head); font-size:12px; font-weight:400; letter-spacing:.08em; text-transform:uppercase; cursor:pointer; border-radius:20px 0 20px 0; transition:all .2s; }
.cn-personas__btn:hover { background:var(--gold); color:#1c0000; }
.cn-personas__right { position:relative; }
.cn-personas__img-wrap { width:100%; aspect-ratio:4/3; overflow:hidden; border-radius:12px 0 12px 0; }
.cn-personas__img-wrap img { width:100%; height:100%; object-fit:cover; }
.cn-personas__img-placeholder { width:100%; aspect-ratio:4/3; background:var(--surf2); border-radius:12px 0 12px 0; display:flex; align-items:center; justify-content:center; font-size:48px; opacity:.3; }

/* Personas Overlay */
.cn-personas__overlay { position:fixed; inset:0; z-index:9999; background:rgba(0,0,0,.95); display:none; align-items:center; justify-content:center; padding:20px; }
.cn-personas__overlay.active { display:flex; }
.cn-personas__overlay-inner { position:relative; max-width:92vw; max-height:92vh; }
.cn-personas__overlay-img { max-width:90vw; max-height:88vh; object-fit:contain; border-radius:12px 0 12px 0; }
.cn-personas__overlay-close { position:fixed; top:20px; right:28px; background:rgba(201,168,76,.15); border:1px solid var(--gold); color:var(--gold); font-size:18px; width:40px; height:40px; border-radius:50%; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all .2s; z-index:10001; }
.cn-personas__overlay-close:hover { background:var(--gold); color:#1c0000; }

/* ── REVENUE GRID ── */
.cn-rev-card::after { content:''; position:absolute; bottom:0; left:0; right:0; height:2px; }
.cn-rev-card--1::after { background:var(--green); }
.cn-rev-card--2::after { background:var(--gold); }
.cn-rev-card--3::after { background:var(--orange); }
.cn-rev-card--4::after { background:var(--purple,#a080e0); }
.cn-rev-stream { font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:.1em; color:var(--text3); margin-bottom:7px; }
.cn-rev-name { font-family:var(--font-head); font-size:14px; font-weight:400; letter-spacing:.04em; text-transform:uppercase; margin-bottom:4px; }
.cn-rev-price { font-family:var(--font-head); font-size:20px; font-weight:400; color:var(--gold); margin-bottom:4px; letter-spacing:.03em; }
.cn-rev-detail { font-size:11px; color:var(--text2); line-height:1.5; margin-bottom:12px; flex:1; }
.cn-rev-btn { display:inline-flex; align-items:center; gap:6px; background:transparent; border:1px solid var(--gold); color:var(--gold); padding:6px 14px; font-family:var(--font-head); font-size:11px; letter-spacing:.06em; text-transform:uppercase; border-radius:20px 0 20px 0; text-decoration:none; transition:all .2s; margin-top:auto; width:fit-content; }
.cn-rev-btn:hover { background:var(--gold); color:#1c0000; }

/* ── SOLUTION BOX SHORTCODE ── */
.cn-solution-box { background:linear-gradient(135deg,var(--bg2),var(--bg3)); border:1px solid var(--bd2); border-radius:var(--r); padding:36px; margin-bottom:0; position:relative; overflow:hidden; }
.cn-solution-box::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 60% 60% at 80% 50%,var(--blue-g,rgba(201,168,76,.05)),transparent); pointer-events:none; }
.cn-solution-box__quote { font-family:var(--font-head); font-size:clamp(14px,2.2vw,26px); font-weight:400; letter-spacing:.03em; text-transform:uppercase; line-height:1.2; margin-bottom:16px; position:relative; z-index:1; }
.cn-solution-box__quote em { font-style:normal; color:var(--gold); }
.cn-solution-box__sub { font-size:13px; color:var(--text2); font-weight:400; line-height:1.75; max-width:660px; position:relative; z-index:1; margin-bottom:16px; }
.cn-solution-box__btn { display:inline-flex; align-items:center; gap:6px; background:var(--orange); color:#fff; padding:10px 22px; font-family:var(--font-head); font-size:13px; letter-spacing:.08em; text-transform:uppercase; border-radius:20px 0 20px 0; text-decoration:none; transition:all .2s; position:relative; z-index:1; }
.cn-solution-box__btn:hover { background:var(--gold); color:#1c0000; }

/* ── VIS STEPS ── */
.cn-vis-steps { display:flex; flex-direction:column; gap:8px; }
.cn-vis-step { display:flex; gap:14px; align-items:flex-start; padding:14px; background:var(--surf); border:1px solid var(--bd); border-radius:var(--r); }
.cn-vis-step__img { width:36px; height:36px; border-radius:var(--r); overflow:hidden; flex-shrink:0; display:flex; align-items:center; justify-content:center; background:rgba(201,168,76,.1); }
.cn-vis-step__img img { width:100%; height:100%; object-fit:cover; border-radius:var(--r); }
.cn-vis-step__img-ph { width:100%; height:100%; display:flex; align-items:center; justify-content:center; font-size:16px; }
.cn-vis-step__content { flex:1; }
.cn-vis-step__title { font-size:13px; font-weight:500; margin-bottom:3px; color:var(--text); }
.cn-vis-step__body { font-size:11px; color:var(--text2); line-height:1.55; margin-bottom:8px; }
.cn-vis-step__btn { display:inline-flex; align-items:center; gap:5px; background:transparent; border:1px solid var(--gold); color:var(--gold); padding:4px 12px; font-family:var(--font-head); font-size:10px; letter-spacing:.06em; text-transform:uppercase; border-radius:20px 0 20px 0; text-decoration:none; transition:all .2s; }
.cn-vis-step__btn:hover { background:var(--gold); color:#1c0000; }

/* ── MASTERBOARD ── */
.cn-masterboard { background:var(--surf); border:1px solid var(--bd2); border-radius:var(--r); overflow:hidden; }
.cn-masterboard__header { background:var(--bg3); border-bottom:1px solid var(--bd); padding:12px 16px; display:flex; align-items:center; gap:10px; }
.cn-masterboard__avatar { width:30px; height:30px; border-radius:50%; overflow:hidden; flex-shrink:0; background:var(--gold); display:flex; align-items:center; justify-content:center; font-size:12px; color:#1c0000; font-weight:700; }
.cn-masterboard__avatar img { width:100%; height:100%; object-fit:cover; }
.cn-masterboard__name { font-size:11px; font-weight:600; }
.cn-masterboard__sub { font-size:9px; color:var(--text2); }
.cn-masterboard__follow { margin-left:auto; background:var(--orange); color:#fff; border:none; padding:4px 11px; border-radius:10px; font-size:9px; font-weight:600; cursor:pointer; font-family:var(--font-body); }
.cn-masterboard__list { padding:10px; display:flex; flex-direction:column; gap:5px; }
.cn-masterboard__item { background:var(--bg2); border:1px solid var(--bd); border-radius:var(--r); padding:9px 11px; display:flex; align-items:center; justify-content:space-between; }
.cn-masterboard__item a { text-decoration:none; color:inherit; }
.cn-masterboard__item a:hover .cn-masterboard__board-name { color:var(--gold); }
.cn-masterboard__board-name { font-size:11px; font-weight:500; }
.cn-masterboard__board-sub { font-size:9px; color:var(--text2); margin-top:1px; }
.cn-masterboard__vis { font-size:8px; padding:2px 6px; border-radius:9px; font-weight:600; white-space:nowrap; flex-shrink:0; margin-left:8px; }
.cn-mb-vis-public { background:var(--green-d,rgba(76,175,125,.12)); color:var(--green,#4CAF7D); }
.cn-mb-vis-follower { background:rgba(201,168,76,.15); color:var(--gold); }
.cn-mb-vis-collab { background:rgba(248,102,19,.12); color:var(--orange); }
.cn-mb-vis-private { background:rgba(255,255,255,.06); color:var(--text3); }

/* ── PERSONA BOARD ── */
.cn-persona-board { display:grid; grid-template-columns:repeat(3,1fr); gap:0; }
.cn-persona-board__tile { position:relative; aspect-ratio:1/1; background-size:cover; background-position:center; overflow:hidden; display:flex; align-items:flex-end; cursor:pointer; }
.cn-persona-board__tile-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,.6) 0%,rgba(0,0,0,.1) 60%,transparent 100%); transition:background .3s; }
.cn-persona-board__tile:hover .cn-persona-board__tile-overlay { background:linear-gradient(to top,rgba(0,0,0,.75) 0%,rgba(0,0,0,.3) 60%,rgba(0,0,0,.1) 100%); }
.cn-persona-board__tile-inner { position:relative; z-index:2; padding:10px 12px; width:100%; }
.cn-persona-board__subhead { font-family:'Bebas Neue', sans-serif; font-size:11px; font-weight:400; letter-spacing:.14em; text-transform:uppercase; color:#ffffff; line-height:1.3; }
.cn-persona-board__subhead a { color:#ffffff; text-decoration:none; }
.cn-persona-board__subhead a:hover { color:var(--gold); }
.cn-persona-board__badge { position:absolute; top:8px; right:8px; font-size:7px; font-weight:700; padding:2px 5px; border-radius:3px; z-index:3; }
@media(max-width:600px) { .cn-persona-board { grid-template-columns:1fr 1fr; } }

/* ── MEDIA BLOCK ── */
.cn-media-block { width:100%; display:flex; align-items:center; gap:clamp(20px,4vw,60px); padding:clamp(20px,4vw,60px) 0; }
.cn-media-block--reverse { flex-direction:row-reverse; }
.cn-media-block__media { flex-shrink:0; display:flex; align-items:center; justify-content:center; }
/* Medien-Größen */
.cn-media-block__media--full { flex:0 0 92%; max-width:92%; }
.cn-media-block__media--half { flex:0 0 50%; max-width:50%; }
.cn-media-block__media--third { flex:0 0 33.333%; max-width:33.333%; }
.cn-media-block__media--quarter { flex:0 0 25%; max-width:25%; }
.cn-media-block__media--fifth { flex:0 0 20%; max-width:20%; }
.cn-media-block__media--sixth { flex:0 0 16.666%; max-width:16.666%; }
.cn-media-block__media--seventh { flex:0 0 14.285%; max-width:14.285%; }
.cn-media-block__media img,
.cn-media-block__media video,
.cn-media-block__media gif { width:100%; height:auto; border-radius:var(--r); display:block; }
.cn-media-block__content { flex:1; display:flex; flex-direction:column; gap:14px; }
.cn-media-block__headline { margin:0; line-height:1.15; }
.cn-media-block__text { font-size:14px; color:var(--text2); line-height:1.75; }
.cn-media-block__btn { display:inline-flex; align-items:center; gap:6px; background:var(--gold,#C9A84C); color:#1c0000; padding:10px 22px; font-family:'Bebas Neue', sans-serif; font-size:14px; letter-spacing:.08em; text-transform:uppercase; border-radius:20px 0 20px 0; text-decoration:none; transition:all .2s; width:fit-content; }
.cn-media-block__btn:hover { background:var(--orange,#f86613); color:#fff; transform:translateY(-1px); }
/* Positionierung */
.cn-media-block--pos-ll .cn-media-block__media { margin-right:auto; }
.cn-media-block--pos-lm { justify-content:flex-start; }
.cn-media-block--pos-mm { justify-content:center; flex-direction:column; text-align:center; }
.cn-media-block--pos-rm { justify-content:flex-end; }
.cn-media-block--pos-rr .cn-media-block__media { margin-left:auto; }
@media(max-width:600px) {
  .cn-media-block, .cn-media-block--reverse { flex-direction:column; }
  .cn-media-block__media--full,
  .cn-media-block__media--half,
  .cn-media-block__media--third,
  .cn-media-block__media--quarter,
  .cn-media-block__media--fifth,
  .cn-media-block__media--sixth,
  .cn-media-block__media--seventh { flex:0 0 100%; max-width:100%; }
}

/* ══════════════════════════════════════════════════════
   NEUE BLÖCKE v2 – nur Layout-CSS, keine Farben
   Alle Farben via CSS-Variablen mit Fallback
══════════════════════════════════════════════════════ */

/* Galerie X-Button Fix */
.cn-lightbox__close { pointer-events: all !important; cursor: pointer !important; }

/* cn-vis-step__img größer */
.cn-vis-step__img {
  width: 40px !important;
  height: 40px !important;
  padding: 1px !important;
  border-radius: var(--r) !important;
}
.cn-vis-step__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: var(--r);
}

/* solution-box btn transparent */
.cn-solution-box__btn {
  background: transparent !important;
  border: 1px solid var(--gold, #C9A84C) !important;
  color: var(--gold, #C9A84C) !important;
}
.cn-solution-box__btn:hover {
  background: var(--gold, #C9A84C) !important;
  color: #1c0000 !important;
}

/* phase-dot: Text statt Icon */
.phase-dot {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: clamp(14px, 1.8vw, 18px) !important;
  color: var(--gold, #C9A84C) !important;
  background: rgba(201,168,76,.12) !important;
  border: 1px solid rgba(201,168,76,.2) !important;
}

/* bild-grid border fix */
.cn-bild-grid__item {
  border: 1px solid var(--bd, rgba(255,255,255,.1)) !important;
}

/* Fortschrittsbalken */
.cn2-fortschritt { width: 100%; }
.cn2-fs-row { display: flex; align-items: center; gap: clamp(12px,2vw,24px); margin-bottom: clamp(10px,1.5vw,18px); }

/* Mindmap */
.cn2-mindmap { width: 100%; }
.cn2-mm-canvas { position: relative; }
.cn2-mm-node { transition: transform .2s; }
.cn2-mm-node:hover { transform: translate(-50%,-50%) scale(1.08); }

/* Pyramide */
.cn2-pyramide { width: 100%; }

/* Moodboard */
.cn2-moodboard { width: 100%; box-sizing: border-box; }

/* Kotter */
.cn2-kotter { width: 100%; }

/* Typowolke */
.cn2-typowolke { width: 100%; overflow: hidden; }

/* Vita */
.cn2-vita-info, .cn2-vita-cv { width: 100%; }

/* Info-list Abstände 4× */
.info-row { margin-bottom: clamp(8px,2vw,24px) !important; }

/* Responsive neue Blöcke */
@media(max-width:600px) {
  .cn2-fs-row { flex-direction: column; align-items: flex-start; }
  .cn2-fs-label { text-align: left !important; width: 100% !important; }
}

/* ══════════════════════════════════════════════════════
   v15 FIXES
══════════════════════════════════════════════════════ */

/* Info-List: 4× größere Abstände */
.info-list { gap: clamp(12px,3vw,32px) !important; }
.info-row {
  margin-bottom: 0 !important;
  padding: clamp(10px,1.5vw,18px) clamp(12px,2vw,20px) !important;
}

/* Info-Key: Bebas Neue + Gold + Uppercase */
.info-key {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 9px !important;
  font-weight: 400 !important;
  letter-spacing: .14em !important;
  color: var(--gold, #C9A84C) !important;
  text-transform: uppercase !important;
  width: 90px !important;
}

/* CV Timeline: 4× größere Abstände */
.cv-row { margin-bottom: clamp(12px,3vw,32px) !important; }
.cv-card { margin-bottom: 0 !important; }

/* CV Title: Bebas Neue, mehr letter-spacing */
.cv-title {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
}

/* CV Year: Gold */
.cv-year { color: var(--gold, #C9A84C) !important; }

/* Persona board: Kacheln mit Rev-Card unten */
.cn-persona-board__tile {
  flex: 0 0 auto;
  min-height: clamp(120px, 20vw, 240px);
}

/* Masterboard Tags */
.cn-masterboard__item { flex-wrap: wrap; align-items: flex-start; }

/* Galerie X-Button nochmal sicherstellen */
#cn-lightbox .cn-lightbox__close {
  position: fixed !important;
  top: 20px !important;
  right: 28px !important;
  z-index: 10001 !important;
  pointer-events: all !important;
  cursor: pointer !important;
  background: rgba(201,168,76,.15) !important;
  border: 1px solid var(--gold, #C9A84C) !important;
  color: var(--gold, #C9A84C) !important;
}

/* ══════════════════════════════════════════════════════
   v16 FIXES
══════════════════════════════════════════════════════ */

/* Desktop max-width override (sicher) */
@media(min-width:900px) {
  .wrap { max-width:1210px !important; }
  .wrap--narrow { max-width:800px !important; }
}

/* Revenue Grid: 4-spaltig Desktop, 2-spaltig Mobil */
.cn-revenue-grid { display:grid; grid-template-columns:repeat(4,1fr) !important; gap:12px; }
@media(max-width:900px) {
  .cn-revenue-grid { grid-template-columns:1fr 1fr !important; }
  .revenue-grid    { grid-template-columns:1fr 1fr !important; }
}
@media(max-width:480px) {
  .cn-revenue-grid { grid-template-columns:1fr !important; }
  .revenue-grid    { grid-template-columns:1fr !important; }
}
/* Revenue font minimum */
.cn-rev-stream  { font-size:max(9px,11px) !important; letter-spacing:.1em; }
.cn-rev-name    { font-size:max(9px,14px) !important; }
.cn-rev-price   { font-size:max(9px,20px) !important; }
.cn-rev-detail  { font-size:max(9px,11px) !important; }

/* Phasen: alles min 10px */
.phase-label { font-size:max(10px,.7em) !important; }
.phase-body  { font-size:max(10px,14px) !important; }
.ptag        { font-size:max(10px,.7em) !important; }

/* Tables: min 10px */
.competition-table th { font-size:max(10px,11px) !important; }
.competition-table td { font-size:max(10px,13px) !important; }

/* Masterboard: min 9px */
.cn-masterboard__name       { font-size:max(9px,11px) !important; }
.cn-masterboard__sub        { font-size:max(9px,9px)  !important; }
.cn-masterboard__board-name { font-size:max(9px,11px) !important; }
.cn-masterboard__board-sub  { font-size:max(9px,9px)  !important; }
.cn-masterboard__vis        { font-size:max(9px,8px)  !important; }

/* Vis Steps: Button rechtsbündig */
.cn-vis-step__content { display:flex; flex-direction:column; }
.cn-vis-step__btn-row { display:flex; justify-content:flex-end; margin-top:6px; }

/* Media Block: Button gold outline→filled */
.cn-media-block__btn {
  background: transparent !important;
  border: 1px solid var(--gold,#C9A84C) !important;
  color: var(--gold,#C9A84C) !important;
}
.cn-media-block__btn:hover {
  background: var(--gold,#C9A84C) !important;
  color: #1c0000 !important;
}

/* Alle Buttons orange→gold */
.btn--primary { background:var(--gold,#C9A84C) !important; color:#1c0000 !important; }
.btn--primary:hover { background:var(--orange,#f86613) !important; color:#fff !important; }

/* Vita Info: Key als goldener Badge */
.info-key {
  background: var(--gold,#C9A84C) !important;
  color: #1c0000 !important;
  font-family: 'Bebas Neue',sans-serif !important;
  font-size: 11px !important;
  font-weight: 400 !important;
  letter-spacing: .1em !important;
  padding: 2px 8px !important;
  border-radius: 3px 0 3px 0 !important;
  display: inline-block !important;
  width: auto !important;
  min-width: 80px !important;
  text-align: center !important;
  flex-shrink: 0 !important;
}

/* Vita CV: Jahreszahl größer, Schriftart per Inline überschreibbar */
.cv-year { font-size:max(10px,12px) !important; }

/* Kotter: kein Strich durch Kreis, größer */
.cn2-kotter [style*="border-radius:50%"] {
  /* Verbindungslinien dürfen nicht DURCH den Kreis gehen - per JS fix */
}
/* Kotter Legende */
.cn2-kotter-legend { margin-top:20px; border-top:1px solid var(--gold,#C9A84C); padding-top:14px; }
.cn2-kotter-legend-title { font-family:'Bebas Neue',sans-serif; font-size:13px; color:var(--gold,#C9A84C); letter-spacing:.1em; margin-bottom:10px; }
.cn2-kotter-legend-item { display:flex; align-items:flex-start; gap:10px; margin-bottom:8px; font-size:max(10px,12px); }
.cn2-kotter-legend-dot { width:22px; height:22px; border-radius:50%; border:1.5px solid var(--gold,#C9A84C); display:flex; align-items:center; justify-content:center; flex-shrink:0; font-size:9px; font-family:'Bebas Neue',sans-serif; color:var(--gold,#C9A84C); }

/* Mindmap Legende min 10px */
.cn2-mm-legend { }
.cn2-mm-legend div { font-size:max(10px,.75em) !important; }

/* Pyramide: Legende / ALLE ANZEIGEN */
.cn2-pyr-legend { margin-top:20px; }
.cn2-pyr-toggle { display:inline-block; font-family:'Bebas Neue',sans-serif; font-size:13px; color:var(--gold,#C9A84C); letter-spacing:.1em; cursor:pointer; border-bottom:1px solid var(--gold,#C9A84C); margin-top:12px; text-decoration:none; }
.cn2-pyr-toggle:hover { color:var(--orange,#f86613); }
.cn2-pyr-all-items { display:none; margin-top:14px; }
.cn2-pyr-all-items.open { display:block; }
.cn2-pyr-legend-item { padding:12px 0; border-bottom:1px solid var(--bd,rgba(255,255,255,.08)); }
.cn2-pyr-legend-title { font-family:'Bebas Neue',sans-serif; font-size:max(10px,14px); color:var(--gold,#C9A84C); letter-spacing:.06em; margin-bottom:5px; }
.cn2-pyr-legend-text { font-size:max(10px,13px); color:var(--text2,rgba(255,255,255,.65)); line-height:1.7; }

/* Bild-Grid Lightbox */
.cn-bgrid-lightbox { position:fixed; inset:0; z-index:9999; background:rgba(0,0,0,.95); display:none; align-items:center; justify-content:center; }
.cn-bgrid-lightbox.open { display:flex; }
.cn-bgrid-lightbox__img { max-width:95vw; max-height:92vh; object-fit:contain; border-radius:var(--r,0); }
.cn-bgrid-lightbox__close { position:fixed; top:18px; right:24px; width:40px; height:40px; border-radius:50%; background:rgba(201,168,76,.15); border:1.5px solid var(--gold,#C9A84C); color:var(--gold,#C9A84C); font-size:18px; display:flex; align-items:center; justify-content:center; cursor:pointer; z-index:10000; }
.cn-bgrid-lightbox__close:hover { background:var(--gold,#C9A84C); color:#1c0000; }
.cn-bgrid-lightbox__prev,
.cn-bgrid-lightbox__next { position:fixed; top:50%; transform:translateY(-50%); width:44px; height:44px; border-radius:50%; background:rgba(201,168,76,.12); border:1.5px solid var(--gold,#C9A84C); color:var(--gold,#C9A84C); font-size:24px; display:flex; align-items:center; justify-content:center; cursor:pointer; z-index:10000; }
.cn-bgrid-lightbox__prev { left:16px; }
.cn-bgrid-lightbox__next { right:16px; }

/* Persona Board: Headline neben Block */

/* Table Icon Zelle */
.competition-table td .ct-icon { font-size:16px; margin-right:4px; }
.competition-table td .ct-cell { display:flex; align-items:center; gap:4px; }

/* Galerie – neue saubere Lightbox */
#cn-gallery-lb { position:fixed; inset:0; z-index:9998; background:rgba(0,0,0,.95); display:none; align-items:center; justify-content:center; gap:20px; }
#cn-gallery-lb.open { display:flex; }
#cn-gallery-lb-img { max-width:88vw; max-height:86vh; object-fit:contain; border-radius:4px; }
#cn-gallery-lb-close { position:fixed; top:18px; right:22px; z-index:9999; width:40px; height:40px; border-radius:50%; background:rgba(201,168,76,.15); border:1.5px solid var(--gold,#C9A84C); color:var(--gold,#C9A84C); font-size:18px; display:flex; align-items:center; justify-content:center; cursor:pointer; }
#cn-gallery-lb-close:hover { background:var(--gold,#C9A84C); color:#1c0000; }
#cn-gallery-lb-prev, #cn-gallery-lb-next { width:44px; height:44px; border-radius:50%; background:rgba(201,168,76,.12); border:1.5px solid rgba(201,168,76,.4); color:var(--gold,#C9A84C); font-size:26px; display:flex; align-items:center; justify-content:center; cursor:pointer; flex-shrink:0; }


/* ══════════════════════════════════════════════════════
   v17 FIXES
══════════════════════════════════════════════════════ */

/* section-label: nur Strich, kein Text */
.section-label { font-size:0 !important; color:transparent !important; height:2px !important; margin-bottom:16px !important; }
.section-label::before { width:32px !important; height:1px !important; }

/* section-title: conntxt.de als Logo-Text (per PHP ausgegeben) */
.conntxt-logo-title { font-family:'Bebas Neue',sans-serif; font-size:clamp(32px,5vw,60px); font-weight:400; letter-spacing:.04em; line-height:1; margin-bottom:16px; text-transform:uppercase; }
.conntxt-logo-title .gold { color:var(--gold,#C9A84C); }
.conntxt-logo-title .white { color:#ffffff; }

/* Revenue Grid: 4-spaltig IMMER auf Desktop, niemals überschreiben */
.revenue-grid,
.cn-revenue-grid {
  display: grid !important;
  grid-template-columns: repeat(4,1fr) !important;
  gap: 12px !important;
}
@media(max-width:860px) {
  .revenue-grid,
  .cn-revenue-grid { grid-template-columns: repeat(2,1fr) !important; }
}
@media(max-width:500px) {
  .revenue-grid,
  .cn-revenue-grid { grid-template-columns: 1fr !important; }
}

/* Persona Board: immer 3-spaltig auf Desktop */
.cn-persona-board {
  display: grid !important;
  grid-template-columns: repeat(3,1fr) !important;
  gap: 0 !important;
  width: 100% !important;
}
.cn-persona-board-wrap {
  display: grid !important;
  grid-template-columns: 1fr 260px !important;
  gap: 24px !important;
  align-items: start !important;
  width: 100% !important;
}
@media(max-width:860px) {
  .cn-persona-board { grid-template-columns: repeat(2,1fr) !important; }
  .cn-persona-board-wrap { grid-template-columns: 1fr !important; }
}
@media(max-width:480px) {
  .cn-persona-board { grid-template-columns: 1fr 1fr !important; }
}

/* Galerie Grid */
.cn-galerie-grid {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 2px;
  background: rgba(255,255,255,.05);
}
.cn-galerie-grid__item {
  position: relative;
  aspect-ratio: 1/1;
  overflow: hidden;
  cursor: pointer;
  background: var(--surf,#2a0000);
}
.cn-galerie-grid__item img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .3s ease;
}
.cn-galerie-grid__item:hover img { transform: scale(1.04); }
.cn-galerie-grid__item-overlay {
  position: absolute; inset: 0;
  background: rgba(0,0,0,0);
  transition: background .25s;
  display: flex; align-items: center; justify-content: center;
}
.cn-galerie-grid__item:hover .cn-galerie-grid__item-overlay {
  background: rgba(201,168,76,.18);
}
.cn-galerie-grid__zoom {
  font-size: 22px; color: rgba(255,255,255,.9);
  opacity: 0; transition: opacity .2s;
}
.cn-galerie-grid__item:hover .cn-galerie-grid__zoom { opacity: 1; }
.cn-galerie-grid__tags {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: 8px;
  background: linear-gradient(to top, rgba(0,0,0,.6), transparent);
  display: flex; flex-wrap: wrap; gap: 3px;
}

/* Galerie Einzelansicht */
.cn-galerie-single {
  display: none;
  position: relative;
}
.cn-galerie-single.active { display: block; }
.cn-galerie-single__back {
  position: absolute; top: 12px; left: 12px; z-index: 10;
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(0,0,0,.6); border: 1px solid var(--gold,#C9A84C);
  color: var(--gold,#C9A84C); padding: 7px 14px;
  font-family: 'Bebas Neue',sans-serif; font-size: 13px; letter-spacing:.06em;
  cursor: pointer; border-radius: 20px 0 20px 0;
  text-decoration: none;
}
.cn-galerie-single__back:hover { background:var(--gold,#C9A84C); color:#1c0000; }
.cn-galerie-single__img {
  width: 100%; max-height: 80vh;
  object-fit: contain;
  display: block;
  background: var(--bg,#1c0000);
}
.cn-galerie-single__tags {
  padding: 12px 0;
  display: flex; flex-wrap: wrap; gap: 6px;
}

/* Mindmap: statisches SVG-Layout */
.cn2-mindmap-svg-wrap {
  width: 100%; overflow: visible;
}
.cn2-mm-svg { width: 100%; display: block; }
.cn2-mm-svg text { font-family: 'Bebas Neue',sans-serif; }

/* Pyramide Legende wie Mindmap Legende */
.cn2-pyr-all-items { display:none; }
.cn2-pyr-all-items.open { display:flex !important; flex-direction:column; gap:8px; margin-top:16px; }
.cn2-pyr-legend-item { display:flex; flex-direction:column; padding:12px 0; border-bottom:1px solid var(--bd,rgba(255,255,255,.08)); }
.cn2-pyr-legend-item.open .cn2-pyr-legend-text { display:block; }

/* Kotter Legende wie Mindmap Legende */
.cn2-kotter-legend {
  margin-top: clamp(20px,3vw,36px);
  border-top: 1px solid var(--gold,#C9A84C);
  padding-top: 16px;
}
.cn2-kotter-legend-title {
  font-family: 'Bebas Neue',sans-serif;
  font-size: 13px; color: var(--gold,#C9A84C);
  letter-spacing: .1em; margin-bottom: 12px;
}
.cn2-kotter-legend-item {
  display: flex; align-items: flex-start; gap: 12px;
  margin-bottom: 10px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--bd,rgba(255,255,255,.06));
}
.cn2-kotter-legend-item:last-child { border-bottom: none; }
.cn2-kotter-legend-dot {
  width: 24px; height: 24px; border-radius: 50%;
  border: 1.5px solid var(--gold,#C9A84C);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; font-size: 10px;
  font-family: 'Bebas Neue',sans-serif;
  color: var(--gold,#C9A84C);
}
.cn2-kotter-legend-content { flex: 1; }
.cn2-kotter-legend-head { font-family:'Bebas Neue',sans-serif; font-size:max(10px,13px); color:var(--gold,#C9A84C); letter-spacing:.04em; margin-bottom:3px; }
.cn2-kotter-legend-text { font-size:max(10px,12px); color:var(--text2,rgba(255,255,255,.65)); line-height:1.6; margin-bottom:6px; }
.cn2-kotter-legend-url  { font-size:11px; color:var(--gold,#C9A84C); text-decoration:underline; }
.cn2-kotter-legend-tags { display:flex; flex-wrap:wrap; gap:4px; margin-top:6px; }
.cn2-kotter-legend-tag  { font-size:10px; font-weight:600; text-transform:uppercase; letter-spacing:.06em; padding:2px 8px; border-radius:10px; }

@media(max-width:600px) {
  .cn-galerie-grid { grid-template-columns:1fr 1fr; }
}

/* ══════════════════════════════════════════════════════
   v17c FIXES
══════════════════════════════════════════════════════ */

/* Revenue Grid: inline-style als letzter Ausweg */
.cn-revenue-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 12px !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
.cn-rev-card {
  background: var(--surf, #2a0000) !important;
  border: 1px solid var(--bd, rgba(255,255,255,.12)) !important;
  border-radius: var(--r, 12px 0 12px 0) !important;
  padding: 20px !important;
  position: relative !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  box-sizing: border-box !important;
}
/* Sicherstellen dass kein p-Tag das Grid bricht */
.cn-revenue-grid > p { display: none !important; }
p > .cn-revenue-grid { display: grid !important; }

/* Persona Board: sicher 3-spaltig */
.cn-persona-board {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 0 !important;
  width: 100% !important;
}
/* Kein p-Tag im Grid */
.cn-persona-board > p { display: none !important; }

/* Galerie Lightbox HTML verstecken solange nicht aktiv */
#cn-bgrid-lb { display: none !important; }
#cn-bgrid-lb.open { display: flex !important; }

/* Fortschrittsbalken: kein Code-Block-Look */
.cn2-fortschritt { display: block !important; }
.cn2-fortschritt * { font-family: var(--font-body, 'Roboto', sans-serif) !important; }

/* Vita Info: Badge sicherstellen */
.cn2-vita-info .info-key,
.info-key {
  background: var(--gold, #C9A84C) !important;
  color: #1c0000 !important;
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 11px !important;
  padding: 3px 8px !important;
  border-radius: 3px 0 3px 0 !important;
  display: inline-block !important;
  min-width: 80px !important;
  text-align: center !important;
  flex-shrink: 0 !important;
  align-self: flex-start !important;
}

/* Mindmap SVG: sicherstellen dass es sichtbar ist */
.cn2-mindmap svg { overflow: visible !important; display: block !important; }
.cn2-mindmap circle { stroke: none; }

@media(max-width:860px) {
  .cn-revenue-grid { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
  .cn-persona-board { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}
@media(max-width:480px) {
  .cn-revenue-grid { grid-template-columns: 1fr !important; }
  .cn-persona-board { grid-template-columns: 1fr 1fr !important; }
}

/* ══════════════════════════════════════════════════════
   v17c FIXES
══════════════════════════════════════════════════════ */

/* Pyramide: ALLE ANZEIGEN Button – Gold-Outline-Stil */
.cn2-pyr-toggle {
  display: inline-flex !important;
  align-items: center;
  padding: 8px 20px !important;
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 13px !important;
  letter-spacing: .08em !important;
  cursor: pointer !important;
  text-decoration: none !important;
  border-bottom: none !important;
  background: transparent !important;
  border: 1px solid var(--gold, #C9A84C) !important;
  color: var(--gold, #C9A84C) !important;
  border-radius: 20px 0 20px 0 !important;
  transition: all .2s !important;
  margin-top: 14px !important;
}
.cn2-pyr-toggle:hover,
.cn2-pyr-toggle.active {
  background: var(--gold, #C9A84C) !important;
  color: #1c0000 !important;
}

/* Pyramide Legende: Schicht-Titel wiederholen */
.cn2-pyr-legend-link {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 11px;
  color: var(--gold, #C9A84C);
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: 4px;
  display: block;
}

/* Galerie: Einzelansicht korrekt versteckt */
.cn-galerie-single { display: none !important; }
.cn-galerie-single.active { display: block !important; }
/* Galerie Lightbox-Reste verstecken */
#cn-gallery-lb:not(.open),
#cn-bgrid-lb:not(.open) { display: none !important; }

/* Masterboard: alle Fontgrößen +2px */
.cn-masterboard__name       { font-size: 13px !important; }
.cn-masterboard__sub        { font-size: 11px !important; }
.cn-masterboard__board-name { font-size: 13px !important; }
.cn-masterboard__board-sub  { font-size: 11px !important; }
.cn-masterboard__vis        { font-size: 10px !important; }
.cn-masterboard__follow     { font-size: 11px !important; }

/* Mindmap Legende: alle Fontgrößen +2px */
.cn2-mm-legend > div { font-size: max(12px, 15px) !important; }
.cn2-mm-legend [style*="font-size:13px"],
.cn2-mm-legend [style*="font-size:max(10px,13px)"] { font-size: 15px !important; }
.cn2-mm-legend [style*="font-size:11px"],
.cn2-mm-legend [style*="font-size:max(10px,11px)"] { font-size: 13px !important; }
.cn2-mm-legend [style*="font-size:10px"],
.cn2-mm-legend [style*="font-size:max(10px"] { font-size: 12px !important; }

/* Vita Info: Labels zentriert, 1px größer, fett, 2/3 Breite */
.cn2-vita-info {
  max-width: 66.666% !important;
}
.cn2-vita-info .info-key,
.cn2-vita-info span[style*="background:var(--gold"] {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  min-height: 28px !important;
  padding: 3px 10px !important;
}
/* Fallback für inline-style Labels im vita_info shortcode */
.cn2-vita-info > div > div > span {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 12px !important;
  font-weight: 700 !important;
}

/* Kotter: nur Zeile 1 im Kreis, Zeilen 2+3 nur in Legende */
.cn2-kotter-circle-l2,
.cn2-kotter-circle-l3 { display: none !important; }

/* Vis Steps: Fontgrößen +2px, 2/3 Breite, Button außerhalb */
.cn-vis-steps {
  max-width: 66.666% !important;
}
.cn-vis-step__title { font-size: 15px !important; }
.cn-vis-step__body  { font-size: 13px !important; }
.cn-vis-step__btn   { font-size: 12px !important; }
.cn-vis-step__btn-row {
  display: flex !important;
  justify-content: flex-end !important;
  margin-top: 6px !important;
  padding: 0 !important;
  /* außerhalb der Box → kein Hintergrund */
  background: transparent !important;
  border: none !important;
}

/* Revenue Grid: sicherstellen dass cn-rev-card flex-direction:row-Kinder hat */
.cn-revenue-grid > .cn-rev-card {
  display: flex !important;
  flex-direction: column !important;
  min-width: 0 !important;
}

@media(max-width:700px) {
  .cn2-vita-info { max-width: 100% !important; }
  .cn-vis-steps  { max-width: 100% !important; }
}

/* ============================================================
   conntxt-wp v19 – Korrekturen
   ============================================================ */

/* ----------------------------------------------------------
   3. PHASEN – label + "Phase"-Text +2px
   ---------------------------------------------------------- */
.phase-label { font-size: 12px !important; }
.ptag        { font-size: 11px !important; }
/* "Phase X" Zahl im Dot */
.phase-dot   { font-size: 14px !important; }

/* ----------------------------------------------------------
   4. COMPETITION TABLE – Header volle Breite + Farbe + +2px
   ---------------------------------------------------------- */
.competition-table thead tr th {
  background: var(--surf2, #4a0000) !important;
  color: var(--gold, #C9A84C) !important;
  font-size: 12px !important;
  text-align: center !important;
  padding: 12px 14px !important;
  width: auto;
}
/* Sicherstellen: Table nimmt volle Breite */
.competition-table { width: 100% !important; table-layout: auto; }

/* ----------------------------------------------------------
   5. GALERIE – Slideshow Thumbnails zentriert + Hintergrund hellrot
   ---------------------------------------------------------- */
/* Galerie: volle Breite hellrot (wie Kontaktformular) */
.cn-galerie-wrap,
.cn-galerie-slideshow {
  background: var(--surf2, #4a0000);
  width: 100vw;
  margin-left: calc(-50vw + 50%);
  padding: clamp(20px,4vw,48px) clamp(20px,4vw,60px);
  box-sizing: border-box;
}

/* Grid-Variante: Vollbild-Overlay auf Item */
.cn-galerie-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; }
.cn-galerie-grid__item {
  position: relative;
  cursor: pointer;
  overflow: hidden;
  aspect-ratio: 1;
  border-radius: var(--r, 0);
  background: var(--surf, rgba(255,255,255,.06));
}
.cn-galerie-grid__item img { width: 100%; height: 100%; object-fit: cover; display: block; }
.cn-galerie-grid__item-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.45);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity .2s;
}
.cn-galerie-grid__item:hover .cn-galerie-grid__item-overlay { opacity: 1; }
.cn-galerie-grid__zoom {
  font-size: 32px;
  color: var(--gold, #C9A84C);
  line-height: 1;
}
.cn-galerie-grid__tags {
  position: absolute;
  bottom: 6px;
  left: 6px;
  right: 6px;
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

/* Einzelansicht */
.cn-galerie-single { display: none; }
.cn-galerie-single.active { display: block; }
.cn-galerie-single__back {
  background: transparent;
  border: 1px solid var(--gold, #C9A84C);
  color: var(--gold, #C9A84C);
  padding: 6px 14px;
  border-radius: 20px 0 20px 0;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 13px;
  letter-spacing: .06em;
  cursor: pointer;
  margin-bottom: 12px;
  display: inline-block;
}

/* Slideshow Thumbnails: zentriert, klickbar */
.cn-galerie-slideshow__main {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 200px;
}
.cn-galerie-slideshow__img {
  max-width: 100%;
  max-height: 65vh;
  object-fit: contain;
  display: block;
  margin: 0 auto;
}
.cn-galerie-slideshow__thumbs {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  margin-top: 16px;
}
.cn-galerie-slideshow__thumb {
  width: 64px;
  height: 48px;
  object-fit: cover;
  border-radius: 6px 0 6px 0;
  cursor: pointer;
  opacity: 0.55;
  border: 2px solid transparent;
  transition: opacity .2s, border-color .2s;
}
.cn-galerie-slideshow__thumb:hover,
.cn-galerie-slideshow__thumb.active {
  opacity: 1;
  border-color: var(--gold, #C9A84C);
}

/* ----------------------------------------------------------
   6. HERO BANNER – Ghost-Button (kein oranger Vollflächig-Button)
   ---------------------------------------------------------- */
.cn-hero-banner__btn {
  background: transparent !important;
  border: 1.5px solid var(--gold, #C9A84C) !important;
  color: var(--gold, #C9A84C) !important;
  border-radius: 20px 0 20px 0 !important;
  padding: 10px 24px !important;
}
.cn-hero-banner__btn:hover {
  background: var(--gold, #C9A84C) !important;
  color: #1c0000 !important;
}

/* ----------------------------------------------------------
   7. BILD GRID – Leere Felder ohne Hintergrundfarbe
   ---------------------------------------------------------- */
/* Alle Items bekommen keinen BG mehr per default */
.cn-bild-grid__item {
  background: transparent !important;
}
/* Items MIT Hintergrundbild bekommen den Overlay zurück */
.cn-bild-grid__item[style*="background-image"] {
  background: transparent !important; /* Image übernimmt */
}

/* ----------------------------------------------------------
   8. PERSONAS – Mobile
   ---------------------------------------------------------- */
@media (max-width: 768px) {
  .cn-personas__panel.active {
    display: flex !important;
    flex-direction: column;
    gap: 24px;
  }
  .cn-personas__right { width: 100%; }
  .cn-personas__img-wrap { width: 100%; }
}

/* ----------------------------------------------------------
   9. REVENUE GRID – +1px auf Stream-Label + Name-Zeile
   ---------------------------------------------------------- */
.cn-rev-stream { font-size: 12px !important; }
.cn-rev-name   { font-size: 15px !important; }

/* ----------------------------------------------------------
   10. SOLUTION BOX – Headline +1px
   ---------------------------------------------------------- */
.cn-solution-box__quote {
  font-size: clamp(15px, 2.3vw, 27px) !important;
}

/* ----------------------------------------------------------
   12. MASTERBOARD – Sub-Zeilen +1px, Öffentlich/Kollaboration +1px
   ---------------------------------------------------------- */
.cn-masterboard__sub       { font-size: 10px !important; }
.cn-masterboard__board-sub { font-size: 10px !important; }
.cn-masterboard__vis       { font-size: 9px !important; }

/* ----------------------------------------------------------
   14. MEDIA BLOCK – Hintergrund hellrot, volle Breite
   ---------------------------------------------------------- */
.cn-media-block {
  background: var(--surf2, #4a0000);
  width: 100vw;
  margin-left: calc(-50vw + 50%);
  padding-left:  clamp(20px, 5vw, 80px);
  padding-right: clamp(20px, 5vw, 80px);
  padding-top:   clamp(20px, 4vw, 60px);
  padding-bottom:clamp(20px, 4vw, 60px);
  box-sizing: border-box;
}

/* ----------------------------------------------------------
   16. MINDMAP – Button Eckenkonzept 20px 0 20px 0, Höhe konsistent
   ---------------------------------------------------------- */
.cn2-mindmap a,
.cn2-mindmap button,
.cn2-mm-legend a {
  border-radius: 20px 0 20px 0 !important;
}
/* Legende Sub-Ast Chips */
.cn2-mm-legend span {
  border-radius: 3px !important; /* Diese sind keine Buttons → eckig */
}
/* Alle Buttons in Pyramide + Mindmap: einheitliche Höhe */
.cn2-pyr-toggle,
.cn2-pyr-legend-item a {
  border-radius: 20px 0 20px 0 !important;
  min-height: 36px;
  display: inline-flex;
  align-items: center;
}

/* ----------------------------------------------------------
   17. MOODBOARD – Bilder zentriert (object-position center), 
       Hintergrund hellrot volle Breite
   ---------------------------------------------------------- */
.cn2-moodboard {
  background: var(--surf2, #4a0000) !important;
  width: 100vw;
  margin-left: calc(-50vw + 50%);
  padding: clamp(20px,4vw,48px) clamp(20px,5vw,80px);
  box-sizing: border-box;
}
/* Alle Bilder im Moodboard: zentriert, vollflächig */
.cn2-moodboard img {
  object-fit: cover !important;
  object-position: center center !important;
  width: 100% !important;
  height: 100% !important;
  display: block !important;
}
/* Leere Felder: vollflächig gefüllt mit Surf-Farbe */
.cn2-moodboard > div > div {
  overflow: hidden;
}

/* ----------------------------------------------------------
   18. KOTTER – Kreistext zweizeilig (line-clamp aufheben)
   ---------------------------------------------------------- */
.cn2-kotter > div > div > div span {
  white-space: normal !important;
  overflow: visible !important;
  display: -webkit-box !important;
  -webkit-line-clamp: unset !important;
  line-clamp: unset !important;
  -webkit-box-orient: vertical;
  font-size: max(9px, clamp(8px, .9vw, 11px)) !important;
  line-height: 1.3;
  text-align: center;
}
/* Kreis-Divs: flex-wrap erlauben für mehrzeilige Texte */
.cn2-kotter > div > div > div {
  padding: 5px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 1px;
}

/* ----------------------------------------------------------
   19. TYPOWOLKE – Links immer rechtsbündig, Rechts immer linksbündig
   ---------------------------------------------------------- */
/* r1l r2l r3l r4l = linke Spalte → text-align: right */
/* r1r r2r r3r r4r = rechte Spalte → text-align: left  */
/* Die PHP-Defs haben das schon korrekt gesetzt (r1l=left, r2l=right, etc.)
   Aber laut Bug-Report ist es umgekehrt. Wir überschreiben explizit per nth-child: */
.cn2-typowolke > div > div:first-child  { text-align: right !important; }
.cn2-typowolke > div > div:last-child   { text-align: left  !important; }

/* ----------------------------------------------------------
   TAB NAVIGATION – Overlay/Lightbox-Fix (innerhalb Tabs)
   ---------------------------------------------------------- */
/* Kein overflow:hidden auf Tab-Panels – würde fixed-Overlays killen */
.ov-panel,
.conntxt-tabs-wrap .ov-panel {
  overflow: visible !important;
}
/* Lightbox/Overlay immer über allem, auch innerhalb Tabs */
.cn-personas__overlay,
.cn-bgrid-lightbox,
.cn-galerie-single {
  position: fixed !important;
  z-index: 99999 !important;
}
.cn-personas__overlay-close,
.cn-bgrid-lightbox__close {
  pointer-events: all !important;
  z-index: 100001 !important;
}

/* ----------------------------------------------------------
   MOBILE – Allgemein
   ---------------------------------------------------------- */
@media (max-width: 600px) {
  /* Galerie Grid: 2 Spalten auf Mobile */
  .cn-galerie-grid { grid-template-columns: repeat(2, 1fr) !important; }
  /* Revenue Grid: 2 Spalten auf Mobile */
  .cn-revenue-grid { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
  /* Persona Board Mobile */
  .cn-persona-board { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
  /* Media Block: kein negatives Margin auf sehr kleinen Screens */
  .cn-media-block,
  .cn-galerie-wrap,
  .cn-galerie-slideshow,
  .cn2-moodboard {
    margin-left: -16px !important;
    margin-right: -16px !important;
    width: calc(100% + 32px) !important;
    padding-left: 16px !important;
    padding-right: 16px !important;
  }
}

/* ============================================================
   v24 – Globale Korrekturen
   ============================================================ */

/* 1. EINHEITLICHE CONTENT-BREITE – alle Blöcke am selben Raster */
.wrap {
  max-width: 1210px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: clamp(16px, 5vw, 60px) !important;
  padding-right: clamp(16px, 5vw, 60px) !important;
  box-sizing: border-box !important;
}
/* Mobile: fast volle Breite */
@media (max-width: 768px) {
  .wrap {
    padding-left: 14px !important;
    padding-right: 14px !important;
  }
}

/* 2. BUTTONS – einheitlich: passiv=gold outline, aktiv/hover=gold vollflächig */
/* Kein Orange mehr auf Buttons */
.btn,
.btn--primary,
.btn--ghost,
.cn-btn,
.cn-hero-banner__btn,
.cn-media-block__btn,
.cn-solution-box__btn,
.cn-galerie-single__back,
.project-tab,
.cn2-pyr-toggle,
.cn2-mm-legend a,
.mb-follow,
.cn-masterboard__follow,
.cn-personas__overlay-close,
.cn-bgrid-lightbox__close,
.cn-bgrid-lightbox__prev,
.cn-bgrid-lightbox__next {
  background: transparent !important;
  border: 1.5px solid var(--gold, #C9A84C) !important;
  color: var(--gold, #C9A84C) !important;
  border-radius: 20px 0 20px 0 !important;
  transition: background .2s, color .2s !important;
  cursor: pointer !important;
}
.btn:hover,
.btn--primary:hover,
.btn--ghost:hover,
.cn-btn:hover,
.cn-hero-banner__btn:hover,
.cn-media-block__btn:hover,
.cn-solution-box__btn:hover,
.cn-galerie-single__back:hover,
.project-tab:hover,
.cn2-pyr-toggle:hover,
.cn2-mm-legend a:hover,
.mb-follow:hover,
.cn-masterboard__follow:hover {
  background: var(--gold, #C9A84C) !important;
  color: #1c0000 !important;
}
/* Aktiver Tab */
.project-tab.active {
  background: var(--gold, #C9A84C) !important;
  color: #1c0000 !important;
}
/* Step-Nummern: gold statt orange */
.step-num {
  background: transparent !important;
  border: 1.5px solid var(--gold, #C9A84C) !important;
  color: var(--gold, #C9A84C) !important;
}

/* 3. ORANGE KOMPLETT ENTFERNEN – durch gold ersetzen */
.chip--orange { background: rgba(201,168,76,.15) !important; color: var(--gold,#C9A84C) !important; border-color: rgba(201,168,76,.3) !important; }
.vis-collab, .cn-mb-vis-collab { background: rgba(201,168,76,.1) !important; color: var(--gold,#C9A84C) !important; }
.pb-bar__status { color: var(--gold,#C9A84C) !important; }
.badge-a { background: rgba(201,168,76,.2) !important; color: var(--gold,#C9A84C) !important; }
.pc-red::before { background: var(--gold,#C9A84C) !important; }
.cn-rev-card--3::after { background: var(--green,#4caf7d) !important; }

/* 4. BLAU ENTFERNEN – durch grün ersetzen */
.fc-badge--blue, .fc-badge--purple {
  background: rgba(76,175,125,.12) !important;
  color: var(--green, #4caf7d) !important;
  border-color: rgba(76,175,125,.25) !important;
}
/* Blaue Links nur in Fließtext-Bereichen auf gold setzen – nicht in Inhaltsblöcken */
.project-content a,
.entry-content a,
.page-content a,
.post-content a {
  color: var(--gold, #C9A84C);
}
.project-content a:hover,
.entry-content a:hover,
.page-content a:hover,
.post-content a:hover {
  color: #fff;
}

/* 5. BILDER IN INHALTSBLÖCKEN – transparenter Hintergrund */
/* Kein eigener Background hinter Bildern – Block-BG scheint durch */
.cn-galerie-grid__item,
.cn-bild-grid__item,
.cn-personas__img-wrap,
.cn2-moodboard > div > div,
.cn-bild-grid__item[style*="background-image"] {
  background: transparent !important;
}
/* Leere Bild-Slots: ebenfalls transparent */
.cn-bild-grid__item:not([style*="background-image"]):not(:has(img)) {
  background: transparent !important;
  border-color: transparent !important;
}

/* 6. LEGENDEN – immer linksbündig */
.cn2-kotter-legend,
.cn2-kotter-legend-title,
.cn2-kotter-legend-item,
.cn2-mm-legend,
.cn2-pyr-legend,
.cn2-pyr-legend-item,
.competition-table caption,
.cn-personas__legend,
.phase-labels,
.phase-label {
  text-align: left !important;
}

/* ============================================================
   v24b – Korrekturen: Labels, Boxed Bilder
   ============================================================ */

/* KONTAKT – Label statt Heading */
.profile-card__kontakt-heading {
  font-family: var(--font-head, 'Bebas Neue', sans-serif) !important;
  font-size: 10px !important;
  letter-spacing: .12em !important;
  color: var(--gold, #C9A84C) !important;
  text-transform: uppercase !important;
  background: transparent !important;
  border: 1.5px solid var(--gold, #C9A84C) !important;
  border-radius: 3px 0 3px 0 !important;
  padding: 3px 10px !important;
  display: inline-flex !important;
  align-items: center !important;
  margin-bottom: 10px !important;
  width: auto !important;
  gap: 0 !important;
}

/* MOODBOARD Legende – Links als Labels, nicht als Buttons */
.cn2-mm-legend a {
  background: transparent !important;
  border: 1px solid var(--gold, #C9A84C) !important;
  color: var(--gold, #C9A84C) !important;
  border-radius: 3px 0 3px 0 !important;
  padding: 2px 10px !important;
  font-size: 10px !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  font-family: var(--font-head, 'Bebas Neue', sans-serif) !important;
  text-decoration: none !important;
  display: inline-block !important;
  transition: background .2s, color .2s !important;
}
.cn2-mm-legend a:hover {
  background: var(--gold, #C9A84C) !important;
  color: #1c0000 !important;
}

/* VITA – Badge/Label Schrift: gold auf transparent (bereits in PHP gefixt) */
/* Zusätzlich: fc-badge und badge-pill – weiße/gold Schrift, kein schwarzer Text */
.fc-badge,
.fc-badge--amber,
.badge-pill {
  color: var(--gold, #C9A84C) !important;
  background: rgba(201,168,76,.1) !important;
  border-color: rgba(201,168,76,.25) !important;
  font-weight: 400 !important;
  -webkit-font-smoothing: auto !important;
  font-smooth: auto !important;
}

/* BOXED LAYOUT – Bilder in Inhaltsblöcken nicht breiter als Content */
/* Alle Bild-Grids, Galerien, Moodboards auf max Content-Breite begrenzen */
.cn-bild-grid,
.cn-galerie-grid,
.cn2-moodboard,
.cn-personas__img-wrap img,
.cn-media-block img {
  max-width: 100% !important;
  box-sizing: border-box !important;
}

/* Galerie Wrap: Hintergrund volle Breite, Grid selbst bleibt in wrap */
.cn-galerie-wrap {
  width: 100vw !important;
  margin-left: calc(-50vw + 50%) !important;
  background: #4a0000 !important;
  padding: clamp(16px,3vw,40px) clamp(20px,5vw,80px) !important;
  box-sizing: border-box !important;
}
.cn-galerie-grid {
  max-width: 1210px !important;
  margin: 0 auto !important;
  width: 100% !important;
}

/* Media Block: volle Breite Hintergrund, Inhalt bleibt in wrap */
.cn-media-block {
  width: 100vw !important;
  margin-left: calc(-50vw + 50%) !important;
  background: #4a0000 !important;
  padding-left:  clamp(20px,5vw,80px) !important;
  padding-right: clamp(20px,5vw,80px) !important;
  box-sizing: border-box !important;
}
/* Innerer Content des Media Blocks auf wrap-Breite */
.cn-media-block > * {
  max-width: 1210px;
  margin-left: auto;
  margin-right: auto;
}

/* Bild Grid: immer in Content-Breite */
.cn-bild-grid {
  width: 100% !important;
  max-width: 100% !important;
  overflow: hidden !important;
}

/* Mobile: padding reduzieren */
@media (max-width: 600px) {
  .cn-galerie-wrap {
    padding: 12px !important;
  }
  .cn-media-block {
    padding-left: 14px !important;
    padding-right: 14px !important;
  }
}

/* ============================================================
   v25 – Tabs als Chips, Labels/Badges nie wie Buttons,
          Vita gold-flächig, Moodboard zentriert, Kotter links
   ============================================================ */

/* 1. TABS – als Chips/Labels gestalten, nicht wie Buttons */
.project-nav {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  border-bottom: none !important;
  padding-bottom: 8px !important;
  margin-bottom: 20px !important;
  overflow-x: visible !important;
}
.project-tab {
  background: transparent !important;
  border: 1px solid var(--gold, #C9A84C) !important;
  border-bottom: 1px solid var(--gold, #C9A84C) !important;
  color: var(--gold, #C9A84C) !important;
  border-radius: 20px !important;
  padding: 3px 12px !important;
  font-family: var(--font-head, 'Bebas Neue', sans-serif) !important;
  font-size: 11px !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  transition: background .15s, color .15s !important;
  white-space: nowrap !important;
  line-height: 1.6 !important;
}
.project-tab:hover {
  background: rgba(201,168,76,.15) !important;
  color: var(--gold, #C9A84C) !important;
}
.project-tab.active {
  background: var(--gold, #C9A84C) !important;
  color: #1c0000 !important;
  border-color: var(--gold, #C9A84C) !important;
}

/* 2. VITA Zertifikate / Labels – flächig gold, Schrift schwarz */
.cn2-vita-info .info-key,
.cn2-vita-info span[style*="background"],
.cn2-vita-cv .cv-badge,
.cn2-vita-cv .cv-label {
  background: var(--gold, #C9A84C) !important;
  color: #1c0000 !important;
  border: none !important;
  border-radius: 3px 0 3px 0 !important;
  font-weight: 600 !important;
  -webkit-font-smoothing: antialiased !important;
  font-smooth: always !important;
}

/* 3. MOODBOARD – zentrieren */
.cn2-moodboard {
  margin-left: auto !important;
  margin-right: auto !important;
  max-width: 100% !important;
}

/* 4. KOTTER LEGENDE – linksbündig */
.cn2-kotter-legend,
.cn2-kotter-legend * {
  text-align: left !important;
}

/* 5. ALLE CHIPS / LABELS / BADGES – nie wie Buttons
   Kein border-radius 20px 0 20px 0, keine hover-Transformation */
.chip,
.chip--yellow,
.chip--green,
.chip--white,
.chip--orange,
.badge-pill,
.fc-badge,
.fc-badge--green,
.fc-badge--amber,
.fc-badge--blue,
.badge-card,
.badge-g,
.badge-b,
.badge-a,
.profile-card__kontakt-heading,
.cn-masterboard__tag,
.cn-masterboard__board-tag,
.phase-label,
.ptag {
  border-radius: 3px 0 3px 0 !important;
  cursor: default !important;
  pointer-events: none !important;
  /* Kein hover-Hintergrundwechsel */
  transition: none !important;
}
/* Links in Legende dürfen noch klickbar sein */
.cn2-mm-legend a,
.cn2-pyr-legend a {
  pointer-events: auto !important;
  cursor: pointer !important;
}

/* Bild Grid CSS entfernen */
.cn-bild-grid,
.cn-bild-grid__item,
.cn-bild-grid__overlay,
.cn-bgrid-lightbox { display: none !important; }

/* ============================================================
   v26 – Fixes
   ============================================================ */

/* 1. info-key Stil (wird jetzt auch von vita_info flex-shrink:0 genutzt) */
.info-key {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: var(--gold, #C9A84C) !important;
  color: #1c0000 !important;
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 11px !important;
  font-weight: 400 !important;
  letter-spacing: .1em !important;
  text-transform: uppercase !important;
  padding: 4px 10px !important;
  border-radius: 3px 0 3px 0 !important;
  min-width: 90px !important;
  min-height: 26px !important;
  text-align: center !important;
  border: none !important;
  cursor: default !important;
  pointer-events: none !important;
  -webkit-font-smoothing: antialiased !important;
}

/* 2. KONTAKT-Badge – links über der Headline, wie Label */
.profile-card__kontakt-heading {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 11px !important;
  letter-spacing: .12em !important;
  color: #1c0000 !important;
  text-transform: uppercase !important;
  background: var(--gold, #C9A84C) !important;
  border: none !important;
  border-radius: 3px 0 3px 0 !important;
  padding: 3px 10px !important;
  display: inline-flex !important;
  align-items: center !important;
  margin-bottom: 10px !important;
  width: auto !important;
  gap: 0 !important;
  cursor: default !important;
  pointer-events: none !important;
  -webkit-font-smoothing: antialiased !important;
}

/* 3. KOTTER LEGENDE – linksbündig, alle Kinder */
.cn2-kotter-legend { text-align: left !important; }
.cn2-kotter-legend * { text-align: left !important; }
.cn2-kotter-legend-title { text-align: left !important; }
.cn2-kotter-legend-item { text-align: left !important; }

/* 4. GALERIE GRID – kein Shadow, keine Transparenzen, nur Bild + Label */
.cn-galerie-grid {
  background: transparent !important;
  gap: 4px !important;
}
.cn-galerie-grid__item {
  background: transparent !important;
  box-shadow: none !important;
}
.cn-galerie-grid__item img {
  transition: none !important;
}
.cn-galerie-grid__item:hover img {
  transform: none !important;
}
/* Overlay komplett weg – kein Hover-Effekt */
.cn-galerie-grid__item-overlay {
  display: none !important;
}
/* Tags/Labels: unten direkt am Bild, kein Gradient-Hintergrund */
.cn-galerie-grid__tags {
  background: transparent !important;
  padding: 4px 6px !important;
  position: absolute !important;
  bottom: 0 !important;
}
.cn-galerie-grid__tags .chip {
  background: var(--gold, #C9A84C) !important;
  color: #1c0000 !important;
  border: none !important;
  font-size: 9px !important;
}

/* ============================================================
   v26b – Kotter Legende linksbündig, Galerie Einzelansicht transparent
   ============================================================ */

/* Kotter Legende – linksbündig erzwingen */
.cn2-kotter-legend,
.cn2-kotter-legend-title,
.cn2-kotter-legend-item,
.cn2-kotter-legend-content,
.cn2-kotter-legend-content div,
.cn2-kotter-legend-head,
.cn2-kotter-legend-text {
  text-align: left !important;
}

/* Galerie Einzelansicht – transparenter Hintergrund */
.cn-galerie-single__img {
  background: transparent !important;
}
.cn-galerie-single {
  background: transparent !important;
}


.cn-galerie-slideshow {
  background: transparent !important;
}

.cn-galerie-slideshow__main {
  background: transparent !important;
}