/* ═══════════════════════════════════════════════
   common.css — Praxis für Ernährungstherapie Aachen
   eventus webdesign · Juni 2026
   Einbinden in JEDE HTML-Seite:
   <link rel="stylesheet" href="common.css">
═══════════════════════════════════════════════ */

/* ── TOKENS ── */
:root{
  --p:#1a3a2a;
  --a:#5a9478;
  --a2:#7eb89a;
  --bg:#f4f9f6;
  --bg2:#eaf2ed;
  --text:#1a1a1a;
  --muted:#5a6b62;
  --border:#c8ddd3;
  --white:#ffffff;
  --cream:#fdfaf7;
  --r-sm:6px; --r-md:14px; --r-lg:28px;
  --shadow-sm:0 2px 8px rgba(26,58,42,.07);
  --shadow-md:0 8px 28px rgba(26,58,42,.11);
  --shadow-lg:0 20px 60px rgba(26,58,42,.14);
  --spring:cubic-bezier(.34,1.56,.64,1);
  --smooth:cubic-bezier(.25,.46,.45,.94);
  --display:'Merriweather',Georgia,serif;
  --body:'Source Sans 3',system-ui,sans-serif;
}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--body);color:var(--text);background:var(--bg);line-height:1.65;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}

/* ── SKIP LINK ── */
.skip-link{position:absolute;top:-100px;left:16px;background:var(--p);color:#fff;padding:8px 16px;border-radius:0 0 var(--r-sm) var(--r-sm);font-size:14px;font-weight:600;z-index:99999;transition:top .2s}
.skip-link:focus{top:0}

/* ── COOKIE BANNER ── */
#cookie-banner{position:fixed;bottom:0;left:0;right:0;background:var(--p);color:#fff;padding:20px 24px;z-index:9999;display:none;flex-wrap:wrap;gap:16px;align-items:center;box-shadow:0 -4px 24px rgba(0,0,0,.18)}
#cookie-banner.show{display:flex}
#cookie-banner p{font-size:13px;line-height:1.55;flex:1;min-width:260px;color:rgba(255,255,255,.88)}
#cookie-banner p a{color:var(--a2);text-decoration:underline}
.cookie-btns{display:flex;gap:10px;flex-shrink:0;flex-wrap:wrap}
.cookie-btns button{padding:9px 20px;border:none;border-radius:var(--r-sm);font-family:var(--body);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}
#cookie-accept{background:var(--a2);color:var(--p)}
#cookie-reject{background:transparent;color:rgba(255,255,255,.65);border:1px solid rgba(255,255,255,.3)}
#cookie-reject:hover{background:rgba(255,255,255,.1)}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(244,249,246,.95);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);transition:box-shadow .3s}
nav.scrolled{box-shadow:var(--shadow-md)}
.nav-inner{max-width:1140px;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:68px}
.nav-logo{display:flex;align-items:center;gap:10px}
.nav-logo img{height:40px;width:auto}
.nav-logo-text{font-family:var(--display);font-size:14px;font-weight:700;color:var(--p);line-height:1.2}
.nav-logo-text span{font-size:11px;font-weight:400;color:var(--muted);display:block}
.nav-links{display:none;gap:2px;align-items:center}
.nav-links a{font-size:13px;font-weight:500;color:var(--p);padding:6px 11px;border-radius:var(--r-sm);transition:all .2s;white-space:nowrap}
.nav-links a:hover,.nav-links a.active{background:var(--bg2);color:var(--a)}
.nav-links .has-sub{position:relative}
.nav-links .has-sub:hover .sub-menu{display:block}
.sub-menu{display:none;position:absolute;top:100%;left:0;background:var(--white);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-md);min-width:220px;padding:8px 0;z-index:100}
.sub-menu a{display:block;padding:9px 16px;font-size:13px;color:var(--p);transition:background .15s}
.sub-menu a:hover{background:var(--bg2)}
.nav-cta{background:var(--p) !important;color:#fff !important;border-radius:var(--r-sm) !important;padding:8px 16px !important;font-weight:600 !important}
.nav-cta:hover{background:var(--a) !important;color:#fff !important}
.hamburger{display:flex;flex-direction:column;gap:5px;cursor:pointer;padding:8px;border:none;background:none;border-radius:var(--r-sm)}
.hamburger span{display:block;width:22px;height:2px;background:var(--p);border-radius:2px;transition:all .3s}
.hamburger[aria-expanded="true"] span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger[aria-expanded="true"] span:nth-child(2){opacity:0;transform:translateX(-8px)}
.hamburger[aria-expanded="true"] span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Mobile nav */
.mobile-nav{position:fixed;inset:0;background:var(--p);z-index:999;display:flex;flex-direction:column;padding:88px 28px 32px;transform:translateX(100%);transition:transform .35s var(--smooth);overflow-y:auto}
.mobile-nav.open{transform:translateX(0)}
.mobile-nav a{font-family:var(--display);font-size:18px;font-weight:700;color:#fff;padding:13px 0;border-bottom:1px solid rgba(255,255,255,.1);display:block}
.mobile-nav .mobile-sub a{font-size:14px;font-weight:400;padding:9px 0 9px 16px;border-bottom:none;color:rgba(255,255,255,.75)}
.mobile-nav .mobile-cta{border:none;margin-top:16px;background:var(--a2);color:var(--p) !important;text-align:center;border-radius:var(--r-md);font-size:15px;padding:15px !important}

@media(min-width:900px){
  .nav-links{display:flex}
  .hamburger{display:none}
}

/* ── BUTTONS ── */
.btn-primary{display:inline-flex;align-items:center;gap:8px;background:var(--p);color:#fff;font-family:var(--body);font-size:15px;font-weight:600;padding:13px 26px;border-radius:var(--r-md);border:none;cursor:pointer;transition:all .25s var(--spring);text-decoration:none}
.btn-primary:hover{background:var(--a);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn-secondary{display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--p);font-size:15px;font-weight:500;padding:13px 22px;border-radius:var(--r-md);border:2px solid var(--border);cursor:pointer;transition:all .25s;text-decoration:none}
.btn-secondary:hover{border-color:var(--a);color:var(--a);background:rgba(90,148,120,.07)}
.btn-white{background:#fff;color:var(--p);font-size:15px;font-weight:600;padding:13px 26px;border-radius:var(--r-md);border:none;cursor:pointer;transition:all .25s var(--spring);display:inline-flex;align-items:center;gap:8px;text-decoration:none}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.15)}
.btn-outline-white{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.4);font-size:15px;font-weight:500;padding:13px 22px;border-radius:var(--r-md);cursor:pointer;transition:all .25s;display:inline-flex;align-items:center;gap:8px;text-decoration:none}
.btn-outline-white:hover{border-color:#fff;background:rgba(255,255,255,.1)}

/* ── SECTION SHARED ── */
section{padding:72px 24px}
.section-inner{max-width:1140px;margin:0 auto}
.section-label{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--a);margin-bottom:10px}
.section-title{font-family:var(--display);font-size:clamp(1.5rem,3.5vw,2.3rem);font-weight:700;color:var(--p);line-height:1.2;margin-bottom:14px}
.section-sub{font-size:16px;color:var(--muted);max-width:600px;line-height:1.7}
.section-head{margin-bottom:44px}

/* ── PAGE HERO (Unterseiten) ── */
.page-hero{padding:120px 24px 60px;background:linear-gradient(155deg,#eaf4ee 0%,#f4f9f6 60%,#e8f0eb 100%)}
.page-hero-inner{max-width:1140px;margin:0 auto}
.page-hero .breadcrumb{font-size:12px;color:var(--muted);margin-bottom:16px;display:flex;gap:6px;align-items:center}
.page-hero .breadcrumb a{color:var(--a);transition:color .2s}
.page-hero .breadcrumb a:hover{color:var(--p)}
.page-hero .breadcrumb span{color:var(--border)}
.page-hero h1{font-family:var(--display);font-size:clamp(1.8rem,4vw,2.8rem);font-weight:900;color:var(--p);line-height:1.15;margin-bottom:16px}
.page-hero .hero-sub{font-size:17px;color:var(--muted);max-width:620px;line-height:1.7}

/* ── PROSE CONTENT ── */
.prose{max-width:760px}
.prose h2{font-family:var(--display);font-size:1.4rem;font-weight:700;color:var(--p);margin:36px 0 12px}
.prose h3{font-family:var(--display);font-size:1.1rem;font-weight:700;color:var(--p);margin:24px 0 10px}
.prose p{font-size:16px;color:var(--text);line-height:1.75;margin-bottom:16px}
.prose ul{margin:12px 0 20px 0;display:flex;flex-direction:column;gap:8px}
.prose ul li{font-size:15px;color:var(--text);line-height:1.6;padding-left:20px;position:relative}
.prose ul li::before{content:'→';position:absolute;left:0;color:var(--a);font-weight:700}
.prose strong{color:var(--p);font-weight:600}
.prose a{color:var(--a);text-decoration:underline}

/* ── INFO BOX ── */
.info-box{background:var(--white);border-left:3px solid var(--a);border-radius:0 var(--r-md) var(--r-md) 0;padding:20px 24px;margin:24px 0}
.info-box p{margin:0;font-size:15px;color:var(--text);line-height:1.65}

/* ── CARDS ── */
.cards{display:grid;grid-template-columns:1fr;gap:20px}
.card{background:var(--white);border-radius:var(--r-md);padding:26px;border:1px solid var(--border);transition:all .3s var(--spring);position:relative;overflow:hidden}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--a) 0%,var(--a2) 100%);transform:scaleX(0);transform-origin:left;transition:transform .35s var(--smooth)}
.card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.card:hover::before{transform:scaleX(1)}
.card-icon{font-size:28px;margin-bottom:14px}
.card-h{font-family:var(--display);font-size:16px;font-weight:700;color:var(--p);margin-bottom:8px}
.card-p{font-size:14px;color:var(--muted);line-height:1.65}
.card-tag{display:inline-block;margin-top:12px;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--a);background:rgba(90,148,120,.1);padding:4px 10px;border-radius:20px}
@media(min-width:600px){.cards{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){.cards{grid-template-columns:repeat(3,1fr)}}

/* ── TEAM CARDS ── */
.team-grid{display:grid;grid-template-columns:1fr;gap:20px}
.team-card{background:var(--white);border-radius:var(--r-md);padding:22px;display:flex;gap:18px;align-items:flex-start;border:1px solid var(--border);transition:box-shadow .3s}
.team-card:hover{box-shadow:var(--shadow-md)}
.team-img{width:70px;height:70px;border-radius:50%;object-fit:cover;flex-shrink:0;background:var(--bg2)}
.per-name{font-family:var(--display);font-size:15px;font-weight:700;color:var(--p)}
.per-role{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--a);margin:3px 0 7px}
.per-qual{font-size:13px;color:var(--muted);line-height:1.55}
@media(min-width:768px){.team-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.team-grid{grid-template-columns:repeat(3,1fr)}}

/* ── BEWERTUNGEN ── */
.rev-grid{display:grid;grid-template-columns:1fr;gap:18px}
.rev-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-md);padding:22px}
.rev-stars{color:#e8a020;font-size:14px;margin-bottom:10px;letter-spacing:1px}
.rev-txt{font-size:14px;color:rgba(255,255,255,.82);line-height:1.7;font-style:italic}
.rev-nm{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--a2);margin-top:14px}
.rev-dt{font-size:11px;color:rgba(255,255,255,.35);margin-top:2px}
@media(min-width:768px){.rev-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.rev-grid{grid-template-columns:repeat(3,1fr)}}

/* ── TRUST BAR ── */
.trust-bar{background:var(--p);padding:28px 24px}
.trust-bar-inner{max-width:1140px;margin:0 auto;display:flex;flex-wrap:wrap;gap:28px;justify-content:center;align-items:center}
.tb-item{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.85);font-size:13px;font-weight:500}
.tb-item strong{color:#fff;font-size:14px;display:block}
.tb-icon{font-size:20px;opacity:.8}

/* ── CTA SECTION ── */
.cta-section{background:linear-gradient(135deg,var(--p) 0%,#0d2318 100%);padding:72px 24px;text-align:center}
.cta-section h2{font-family:var(--display);font-size:clamp(1.5rem,3.5vw,2.2rem);font-weight:700;color:#fff;margin-bottom:14px}
.cta-section p{font-size:16px;color:rgba(255,255,255,.75);max-width:520px;margin:0 auto 28px;line-height:1.7}
.cta-actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}

/* ── FOOTER ── */
footer{background:var(--p);color:rgba(255,255,255,.8);padding:52px 24px 24px}
.footer-inner{max-width:1140px;margin:0 auto}
.footer-top{display:grid;grid-template-columns:1fr;gap:36px;margin-bottom:44px}
.footer-brand{font-family:var(--display);font-size:15px;font-weight:700;color:#fff;margin-bottom:10px}
.footer-brand span{font-size:12px;font-weight:400;color:rgba(255,255,255,.5);display:block;margin-top:3px}
.footer-desc{font-size:13px;line-height:1.65;color:rgba(255,255,255,.65);max-width:280px}
.footer-col h4{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--a2);margin-bottom:14px}
.footer-col ul li{margin-bottom:9px}
.footer-col ul li a{font-size:13px;color:rgba(255,255,255,.65);transition:color .2s}
.footer-col ul li a:hover{color:var(--a2)}
.footer-col address{font-style:normal;font-size:13px;color:rgba(255,255,255,.65);line-height:1.8}
.footer-col address a{transition:color .2s}
.footer-col address a:hover{color:var(--a2)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:22px;display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between;font-size:12px;color:rgba(255,255,255,.35)}
.footer-bottom a{color:rgba(255,255,255,.5);transition:color .2s}
.footer-bottom a:hover{color:rgba(255,255,255,.8)}
.footer-links{display:flex;gap:18px;flex-wrap:wrap}
@media(min-width:768px){.footer-top{grid-template-columns:2fr 1fr 1fr 1fr}}

/* ── OEFFNUNGSZEITEN ── */
.oz-table{width:100%;border-collapse:collapse;font-size:14px}
.oz-table tr{border-bottom:1px solid var(--border)}
.oz-table tr:last-child{border-bottom:none}
.oz-table td{padding:10px 0;color:var(--text)}
.oz-table td:first-child{font-weight:600;color:var(--p);width:120px}
.oz-table td:last-child{color:var(--muted)}

/* ── SCROLL REVEAL ── */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .5s var(--smooth),transform .5s var(--smooth)}
.reveal.visible{opacity:1;transform:none}
.reveal-delay-1{transition-delay:.08s}
.reveal-delay-2{transition-delay:.16s}
.reveal-delay-3{transition-delay:.24s}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important}
  .reveal{opacity:1;transform:none}
}

/* ── ADMIN PANEL ── */
body.adm-on img:not([data-no-edit]){cursor:pointer;outline:2px dashed rgba(90,148,120,.5);outline-offset:3px}
body.adm-on img:not([data-no-edit]):hover{outline:2px solid var(--a)}
#adm-img-input{display:none}
.adm-btn-row{display:none;position:absolute;top:6px;right:6px;z-index:20;gap:4px;flex-wrap:wrap}
body.adm-on .adm-btn-row{display:flex}
.adm-cb{padding:4px 9px;font-size:9.5px;font-weight:700;font-family:inherit;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;border:none;border-radius:3px;color:#fff}
.adm-cb-dup{background:#27AE60}
.adm-cb-del{background:#B83232}
.adm-sec-btn{display:none;position:absolute;top:8px;left:8px;z-index:20;padding:4px 10px;font-size:9px;font-weight:700;font-family:inherit;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;border:none;border-radius:3px;background:rgba(26,58,42,.7);color:#fff}
body.adm-on section{position:relative}
body.adm-on .adm-sec-btn{display:block}
.adm-add-btn{display:none;margin:10px auto 0;padding:8px 18px;border:none;border-radius:3px;font-family:inherit;font-size:11px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;cursor:pointer;color:#fff}
body.adm-on .adm-add-btn{display:block}
.adm-add-green{background:#27AE60}
body.adm-on .cards .card{cursor:grab;position:relative}
body.adm-on .cards .card.dragging{opacity:.5}
#adm-modal{position:fixed;inset:0;background:rgba(5,15,8,.85);z-index:99000;display:none;align-items:center;justify-content:center}
#adm-modal.open{display:flex}
.adm-box{background:#F4F9F6;max-width:320px;width:100%}
.adm-box-hdr{background:#1a3a2a;padding:14px 20px;border-bottom:3px solid #5a9478;display:flex;align-items:center;gap:8px}
.adm-box-hdr .adm-ew{width:28px;height:28px;background:#5a9478;border-radius:5px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:11px;color:#fff;font-family:sans-serif}
.adm-box-hdr span{font-weight:700;font-size:13px;color:#fff}
.adm-box-hdr button{margin-left:auto;background:none;border:none;color:rgba(255,255,255,.5);font-size:20px;cursor:pointer}
.adm-box-body{padding:20px}
.adm-box-body label{display:block;font-size:9.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#6A6056;margin-bottom:5px}
.adm-box-body input{width:100%;border:1px solid #c8ddd3;padding:9px 11px;font-size:14px;outline:none;border-radius:2px;margin-bottom:11px}
.adm-box-body input:focus{border-color:#5a9478}
.adm-login-btn{width:100%;padding:10px;background:#27AE60;color:#fff;border:none;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;cursor:pointer;border-radius:2px}
.adm-err{font-size:12px;color:#C0392B;margin-top:6px;display:none}
#adm-bar{position:fixed;bottom:0;left:0;right:0;background:#1a3a2a;border-top:3px solid #5a9478;padding:8px 18px;display:none;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;z-index:9000}
#adm-bar.on{display:flex}
.adm-tl-txt{font-size:11px;color:rgba(255,255,255,.65)}
.adm-btns{display:flex;gap:8px}
.adm-btn{padding:7px 14px;font-family:inherit;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;cursor:pointer;border:none;border-radius:2px}
.adm-save{background:#7FC47A;color:#fff}
.adm-export{background:#5a9478;color:#fff}
.adm-exit{background:transparent;color:rgba(255,255,255,.5);border:1px solid rgba(255,255,255,.2)}
#adm-toast{position:fixed;top:16px;right:16px;padding:9px 16px;border-radius:3px;font-size:13px;font-weight:500;transform:translateY(-50px);opacity:0;transition:all .3s;z-index:99999;pointer-events:none}
#adm-toast.show{transform:translateY(0);opacity:1}
.toast-ok{background:#27AE60;color:#fff}
.toast-info{background:#5a9478;color:#fff}
