/* =========================================================
   Würzburger Kochschule – Demo Design System
   Farben aus alter Website abgenommen (echte Computed-Werte):
   Beige #DCD5C6 · Headings #362F2D · Font-Gefühl: warm/serif
   ========================================================= */

:root{
  /* Grundstimmung – aus alter Seite abgeleitet */
  --beige:        #DCD5C6;   /* echter Body-Hintergrund alte Seite */
  --beige-soft:   #E7E1D4;
  --cream:        #F7F2E8;   /* Karten / Elfenbein */
  --cream-2:      #FBF8F1;
  --ink:          #362F2D;   /* echte Heading-Farbe alte Seite */
  --text:         #463E3A;
  --text-soft:    #6B615B;
  --red:          #C2401C;   /* vermillion – Kreuz-Akzent alte Seite */
  --red-dark:     #9E2E12;
  --red-soft:     #D9572E;
  --gold:         #C8A24B;   /* dezenter warmer Zweitakzent */
  --line:         rgba(54,47,45,.12);
  --line-soft:    rgba(54,47,45,.07);
  --shadow-sm:    0 2px 10px rgba(54,47,45,.06);
  --shadow:       0 10px 30px rgba(54,47,45,.10);
  --shadow-lg:    0 22px 50px rgba(54,47,45,.16);

  --maxw: 1180px;
  --gap: clamp(1.1rem, 2.4vw, 2rem);
  --radius: 14px;
  --radius-lg: 22px;

  --serif: 'Cormorant Garamond', 'Playfair Display', Georgia, 'Times New Roman', serif;
  --sans:  'Montserrat', 'Helvetica Neue', Helvetica, Arial, sans-serif;

  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset / Base ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--sans);
  color:var(--text);
  background:var(--beige);
  line-height:1.7;
  font-size:clamp(15.5px,1.05vw,17px);
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:var(--red-dark); text-decoration:none; transition:color .2s var(--ease); }
a:hover{ color:var(--red); }

h1,h2,h3,h4{ font-family:var(--serif); color:var(--ink); line-height:1.12; font-weight:600; margin:0 0 .5em; }
h1{ font-size:clamp(2.3rem,5.2vw,3.7rem); letter-spacing:.3px; }
h2{ font-size:clamp(1.8rem,3.6vw,2.7rem); }
h3{ font-size:clamp(1.25rem,2vw,1.55rem); }
p{ margin:0 0 1rem; }
.lead{ font-size:clamp(1.05rem,1.7vw,1.3rem); color:var(--text-soft); }

/* ---------- Layout helpers ---------- */
.container{ width:min(var(--maxw),92vw); margin-inline:auto; }
.section{ padding:clamp(3.2rem,7vw,6rem) 0; }
.section--tight{ padding:clamp(2.2rem,4vw,3.4rem) 0; }
.center{ text-align:center; }
.eyebrow{
  font-family:var(--sans); font-weight:600; letter-spacing:3.5px;
  text-transform:uppercase; font-size:.74rem; color:var(--red);
  display:inline-block; margin-bottom:.9rem;
}
.section-head{ max-width:620px; margin:0 auto clamp(2rem,4vw,3rem); }
.section-head.left{ margin-left:0; text-align:left; }
.divider{ width:54px; height:3px; background:var(--red); border-radius:3px; margin:.2rem auto 0; }
.section-head.left .divider{ margin-left:0; }

/* ---------- Buttons ---------- */
.btn{
  --b:var(--red);
  display:inline-flex; align-items:center; gap:.55rem;
  font-family:var(--sans); font-weight:600; font-size:.92rem; letter-spacing:.3px;
  padding:.85rem 1.6rem; border-radius:50px; border:1.6px solid var(--b);
  background:var(--b); color:#fff; cursor:pointer;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease);
  box-shadow:var(--shadow-sm);
}
.btn:hover{ transform:translateY(-2px); box-shadow:var(--shadow); background:var(--red-dark); color:#fff; }
.btn--ghost{ background:transparent; color:var(--ink); border-color:var(--line); }
.btn--ghost:hover{ background:var(--cream); color:var(--ink); border-color:var(--ink); }
.btn--light{ background:var(--cream); color:var(--ink); border-color:transparent; }
.btn--light:hover{ background:#fff; color:var(--ink); }
.btn .arr{ transition:transform .25s var(--ease); }
.btn:hover .arr{ transform:translateX(3px); }

/* ---------- Header / Nav ---------- */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(247,242,232,.86); backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line-soft);
  transition:box-shadow .3s var(--ease);
}
.site-header.scrolled{ box-shadow:var(--shadow-sm); }
.nav{ display:flex; align-items:center; justify-content:space-between; gap:1rem; padding:.7rem 0; }
.brand{ display:flex; align-items:center; }
.brand img{ height:54px; width:auto; }
.nav-links{ display:flex; align-items:center; gap:.3rem; list-style:none; margin:0; padding:0; }
.nav-links a:not(.btn){
  font-family:var(--sans); font-weight:500; font-size:.9rem; color:var(--ink);
  padding:.5rem .8rem; border-radius:8px; position:relative;
}
.nav-links a:not(.btn)::after{
  content:''; position:absolute; left:.8rem; right:.8rem; bottom:.32rem; height:2px;
  background:var(--red); transform:scaleX(0); transform-origin:left; transition:transform .25s var(--ease);
}
.nav-links a:not(.btn):hover::after, .nav-links a.active::after{ transform:scaleX(1); }
.nav-links a.active{ color:var(--red-dark); }
.nav-cta{ margin-left:.4rem; }
.nav-toggle{
  display:none; background:none; border:0; cursor:pointer; padding:.4rem;
  width:44px; height:44px; color:var(--ink);
}
.nav-toggle span{ display:block; width:24px; height:2px; background:currentColor; margin:5px auto; transition:.3s var(--ease); }
.nav-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ---------- Hero ---------- */
.hero{ position:relative; overflow:hidden; }
.hero-media{ position:absolute; inset:0; z-index:0; }
.hero-media img{ width:100%; height:100%; object-fit:cover; }
.hero-media::after{
  content:''; position:absolute; inset:0;
  background:linear-gradient(110deg, rgba(40,32,30,.78) 0%, rgba(40,32,30,.55) 42%, rgba(40,32,30,.18) 100%);
}
.hero-inner{ position:relative; z-index:1; padding:clamp(4.5rem,12vw,8.5rem) 0 clamp(4rem,9vw,7rem); max-width:680px; }
.hero h1{ color:var(--cream); }
.hero p{ color:rgba(247,242,232,.92); font-size:clamp(1.05rem,1.8vw,1.32rem); max-width:560px; }
.hero .eyebrow{ color:var(--gold); }
.hero-actions{ display:flex; flex-wrap:wrap; gap:.8rem; margin-top:1.8rem; }
.hero-facts{ display:flex; flex-wrap:wrap; gap:1.6rem 2.2rem; margin-top:2.4rem; }
.hero-fact{ color:var(--cream); }
.hero-fact b{ display:block; font-family:var(--serif); font-size:1.7rem; color:#fff; line-height:1; }
.hero-fact span{ font-size:.82rem; letter-spacing:.5px; color:rgba(247,242,232,.8); }

/* ---------- Page hero (Unterseiten) ---------- */
.page-hero{ background:linear-gradient(180deg,var(--cream) 0%, var(--beige) 100%); padding:clamp(2.8rem,6vw,4.5rem) 0 clamp(2rem,4vw,3rem); border-bottom:1px solid var(--line-soft); }
.page-hero .eyebrow{ margin-bottom:.6rem; }
.breadcrumb{ font-size:.82rem; color:var(--text-soft); margin-top:.8rem; }
.breadcrumb a{ color:var(--text-soft); }

/* ---------- Cards / Grids ---------- */
.grid{ display:grid; gap:var(--gap); }
.grid-2{ grid-template-columns:repeat(2,1fr); }
.grid-3{ grid-template-columns:repeat(3,1fr); }
.grid-4{ grid-template-columns:repeat(4,1fr); }

.card{
  background:var(--cream); border:1px solid var(--line-soft); border-radius:var(--radius-lg);
  padding:1.8rem; box-shadow:var(--shadow-sm);
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
  display:flex; flex-direction:column;
}
.card:hover{ transform:translateY(-5px); box-shadow:var(--shadow); }
.card .ic{
  width:52px; height:52px; border-radius:14px; display:grid; place-items:center;
  background:rgba(194,64,28,.10); color:var(--red); margin-bottom:1rem; flex:none;
}
.card h3{ margin-bottom:.4rem; }
.card p{ color:var(--text-soft); margin-bottom:0; }

/* Angebots-/Kurskarten mit Bild */
.course-card{ padding:0; overflow:hidden; }
.course-card .thumb{ aspect-ratio:4/3; overflow:hidden; }
.course-card .thumb img{ width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.course-card:hover .thumb img{ transform:scale(1.05); }
.course-card .body{ padding:1.4rem 1.5rem 1.6rem; }
.course-card .tag{ display:inline-block; font-size:.7rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--red); font-weight:600; margin-bottom:.5rem; }

/* ---------- Termine ---------- */
.termin{
  display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:1.4rem;
  background:var(--cream); border:1px solid var(--line-soft); border-radius:var(--radius);
  padding:1.2rem 1.5rem; box-shadow:var(--shadow-sm);
  transition:transform .25s var(--ease), box-shadow .25s var(--ease);
}
.termin:hover{ transform:translateY(-3px); box-shadow:var(--shadow); }
.termin .date{
  text-align:center; min-width:74px; padding:.55rem .4rem; border-radius:12px;
  background:var(--ink); color:var(--cream); line-height:1;
}
.termin .date .d{ font-family:var(--serif); font-size:1.7rem; display:block; }
.termin .date .m{ font-size:.68rem; letter-spacing:1.5px; text-transform:uppercase; margin-top:.25rem; display:block; opacity:.85; }
.termin .info h3{ margin:0 0 .25rem; font-size:1.2rem; }
.termin .info p{ margin:0; color:var(--text-soft); font-size:.92rem; }
.termin .meta{ text-align:right; display:flex; flex-direction:column; align-items:flex-end; gap:.5rem; }
.price{ font-family:var(--serif); font-size:1.35rem; color:var(--ink); font-weight:600; }
.badge{ font-size:.72rem; font-weight:600; letter-spacing:.5px; padding:.28rem .7rem; border-radius:50px; }
.badge--free{ background:rgba(76,123,74,.14); color:#3f6e3d; }
.badge--full{ background:rgba(194,64,28,.12); color:var(--red-dark); }

/* ---------- Galerie ---------- */
.gallery{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(.7rem,1.4vw,1rem); }
.gallery .tile{
  position:relative; aspect-ratio:1/1; border-radius:var(--radius); overflow:hidden;
  box-shadow:var(--shadow-sm); cursor:pointer; background:var(--beige-soft);
}
.gallery .tile img{ width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.gallery .tile:hover img{ transform:scale(1.07); }
.gallery .tile::after{
  content:''; position:absolute; inset:0; background:linear-gradient(0deg,rgba(54,47,45,.35),transparent 55%);
  opacity:0; transition:opacity .3s var(--ease);
}
.gallery .tile:hover::after{ opacity:1; }
.tile-cap{ position:absolute; left:0; right:0; bottom:0; z-index:1; padding:.8rem 1rem; color:#fff; font-size:.8rem; font-weight:600; letter-spacing:.4px; opacity:0; transform:translateY(8px); transition:.3s var(--ease); }
.gallery .tile:hover .tile-cap{ opacity:1; transform:none; }
/* Platzhalter-Kachel (echtes Foto folgt) */
.tile--ph{ display:grid; place-items:center; background:linear-gradient(135deg,var(--cream) 0%, var(--beige-soft) 100%); border:1px dashed var(--line); }
.tile--ph span{ color:var(--text-soft); font-size:.78rem; text-align:center; padding:1rem; }
.tile--ph svg{ width:30px; height:30px; opacity:.4; margin-bottom:.4rem; }

/* ---------- Split (Bild + Text) ---------- */
.split{ display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(1.6rem,4vw,3.4rem); align-items:center; }
.split.rev .split-media{ order:2; }
.split-media img{ border-radius:var(--radius-lg); box-shadow:var(--shadow); width:100%; aspect-ratio:4/3; object-fit:cover; }
.split-body .check{ list-style:none; padding:0; margin:1rem 0 0; }
.split-body .check li{ position:relative; padding-left:1.9rem; margin-bottom:.7rem; color:var(--text); }
.split-body .check li::before{
  content:''; position:absolute; left:0; top:.45em; width:14px; height:8px;
  border-left:2.5px solid var(--red); border-bottom:2.5px solid var(--red); transform:rotate(-45deg);
}

/* ---------- Banner / CTA ---------- */
.cta-band{ background:var(--ink); color:var(--cream); border-radius:var(--radius-lg); padding:clamp(2.2rem,5vw,3.6rem); text-align:center; box-shadow:var(--shadow); }
.cta-band h2{ color:var(--cream); }
.cta-band p{ color:rgba(247,242,232,.85); max-width:560px; margin:0 auto 1.6rem; }
.gutschein-band{ background:linear-gradient(120deg,var(--red) 0%, var(--red-dark) 100%); color:#fff; border-radius:var(--radius-lg); padding:clamp(2rem,4vw,3rem); display:grid; grid-template-columns:1fr auto; gap:1.5rem; align-items:center; box-shadow:var(--shadow); }
.gutschein-band h2{ color:#fff; margin-bottom:.3rem; }
.gutschein-band p{ color:rgba(255,255,255,.9); margin:0; }

/* ---------- Kontakt ---------- */
.contact-card{ background:var(--cream); border:1px solid var(--line-soft); border-radius:var(--radius-lg); padding:1.8rem; box-shadow:var(--shadow-sm); }
.contact-card h3{ display:flex; align-items:center; gap:.6rem; }
.contact-list{ list-style:none; padding:0; margin:0; }
.contact-list li{ display:flex; gap:.7rem; padding:.55rem 0; border-bottom:1px solid var(--line-soft); }
.contact-list li:last-child{ border-bottom:0; }
.contact-list .k{ color:var(--text-soft); min-width:78px; font-size:.86rem; }
.map-embed{ aspect-ratio:16/10; border-radius:var(--radius); overflow:hidden; background:var(--beige-soft); border:1px solid var(--line-soft); display:grid; place-items:center; text-align:center; color:var(--text-soft); }
.map-embed a{ font-weight:600; }

/* ---------- Form (Demo, kein Versand) ---------- */
.form-grid{ display:grid; gap:1rem; }
.field label{ display:block; font-size:.82rem; font-weight:600; color:var(--ink); margin-bottom:.35rem; }
.field input,.field textarea,.field select{
  width:100%; font-family:var(--sans); font-size:.95rem; color:var(--text);
  background:var(--cream-2); border:1px solid var(--line); border-radius:10px; padding:.75rem .9rem;
  transition:border-color .2s var(--ease), box-shadow .2s var(--ease);
}
.field input:focus,.field textarea:focus,.field select:focus{ outline:0; border-color:var(--red); box-shadow:0 0 0 3px rgba(194,64,28,.12); }
.form-note{ font-size:.8rem; color:var(--text-soft); }

/* ---------- Prose (Impressum/Datenschutz) ---------- */
.prose{ max-width:760px; }
.prose h2{ margin-top:2rem; }
.prose h3{ margin-top:1.4rem; font-size:1.15rem; }
.prose p, .prose li{ color:var(--text); }
.prose .box{ background:var(--cream); border:1px solid var(--line-soft); border-left:3px solid var(--red); border-radius:10px; padding:1.1rem 1.3rem; margin:1.2rem 0; }

/* ---------- Footer ---------- */
.site-footer{ background:var(--ink); color:rgba(247,242,232,.8); padding:clamp(2.6rem,5vw,3.6rem) 0 1.4rem; margin-top:2rem; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:2rem; }
.site-footer h4{ color:var(--cream); font-family:var(--sans); font-size:.82rem; letter-spacing:2px; text-transform:uppercase; margin-bottom:1rem; }
.site-footer a{ color:rgba(247,242,232,.78); }
.site-footer a:hover{ color:#fff; }
.foot-links{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:.5rem; font-size:.92rem; }
.foot-brand img{ height:60px; filter:brightness(0) invert(1); opacity:.92; margin-bottom:.8rem; }
.foot-brand p{ font-size:.9rem; max-width:280px; }
.foot-bottom{ border-top:1px solid rgba(247,242,232,.14); margin-top:2.2rem; padding-top:1.2rem; display:flex; justify-content:space-between; flex-wrap:wrap; gap:.6rem; font-size:.8rem; color:rgba(247,242,232,.6); }

/* ---------- Lightbox ---------- */
.lightbox{ position:fixed; inset:0; z-index:100; background:rgba(28,22,21,.92); display:none; place-items:center; padding:4vw; }
.lightbox.open{ display:grid; }
.lightbox img{ max-width:92vw; max-height:86vh; border-radius:10px; box-shadow:var(--shadow-lg); }
.lightbox .close{ position:absolute; top:1.2rem; right:1.4rem; background:none; border:0; color:#fff; font-size:2rem; cursor:pointer; line-height:1; }

/* ---------- Animation (reveal) ---------- */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; } .reveal.d2{ transition-delay:.16s; } .reveal.d3{ transition-delay:.24s; } .reveal.d4{ transition-delay:.32s; }

/* ---------- Responsive ---------- */
@media (max-width:920px){
  .nav-links{
    position:fixed; inset:0 0 0 auto; width:min(82vw,330px); flex-direction:column; align-items:flex-start;
    background:var(--cream); padding:5rem 1.6rem 2rem; gap:.2rem; box-shadow:var(--shadow-lg);
    opacity:0; visibility:hidden; transform:translateY(-10px); pointer-events:none;
    transition:opacity .3s var(--ease), transform .3s var(--ease), visibility .3s var(--ease);
  }
  .nav-links.open{ opacity:1; visibility:visible; transform:none; pointer-events:auto; }
  .nav-links a:not(.btn){ width:100%; padding:.8rem .6rem; font-size:1rem; border-bottom:1px solid var(--line-soft); }
  .nav-links a:not(.btn)::after{ display:none; }
  .nav-cta{ margin:.8rem 0 0; width:100%; }
  .nav-cta .btn{ width:100%; justify-content:center; }
  .nav-toggle{ display:block; z-index:60; }
  .grid-3,.grid-4{ grid-template-columns:repeat(2,1fr); }
  .split{ grid-template-columns:1fr; }
  .split.rev .split-media{ order:0; }
  .gutschein-band{ grid-template-columns:1fr; text-align:center; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
  .foot-brand{ grid-column:1/-1; }
}
@media (max-width:560px){
  .grid-2,.grid-3,.grid-4{ grid-template-columns:1fr; }
  .gallery{ grid-template-columns:repeat(2,1fr); }
  .termin{ grid-template-columns:auto 1fr; }
  .termin .meta{ grid-column:1/-1; flex-direction:row; justify-content:space-between; align-items:center; border-top:1px solid var(--line-soft); padding-top:.7rem; }
  .footer-grid{ grid-template-columns:1fr; }
  .hero-facts{ gap:1.2rem 1.6rem; }
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; }
}

/* =========================================================
   Ergänzungen aus Screenshot-Analyse der alten Website
   (Script-Logo · Papier-Textur · Ornament-Trenner)
   ========================================================= */

:root{ --script:'Great Vibes', 'Pinyon Script', cursive; }

/* ---------- Papier-/Leinwand-Textur (wie alte Seite) ---------- */
body::before{
  content:''; position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E");
}

/* ---------- Logo-Schriftzug (modernisierte Script wie alt) ---------- */
.brand{ gap:.7rem; }
.brand-icon{ height:50px; width:auto; flex:none; }
.brand-text{ display:flex; flex-direction:column; line-height:1; }
.brand-name{
  font-family:var(--script); font-size:2rem; color:var(--ink);
  line-height:.9; letter-spacing:.5px;
}
.brand-name .r{ color:var(--red); }
.brand-sub{
  font-family:var(--sans); font-size:.6rem; letter-spacing:3px; text-transform:uppercase;
  color:var(--red); font-weight:600; margin-top:.25rem; padding-left:.15rem;
}
@media (max-width:560px){
  .brand-icon{ height:42px; }
  .brand-name{ font-size:1.6rem; }
}

/* ---------- Script-Akzent (z.B. „Herzlich willkommen") ---------- */
.script{ font-family:var(--script); color:var(--red); font-weight:400;
  font-size:clamp(1.7rem,3vw,2.4rem); line-height:1; display:inline-block; }
.hero .script{ color:var(--gold); }

/* ---------- Ornament-Trenner (Footer-Motiv der alten Seite) ---------- */
.ornament{ display:flex; align-items:center; justify-content:center; gap:.8rem; margin:clamp(2rem,4vw,3rem) auto; max-width:340px; color:var(--red); }
.ornament::before,.ornament::after{ content:''; height:2px; flex:1; background:linear-gradient(90deg,transparent,var(--line),transparent); }
.ornament .marks{ font-size:.9rem; letter-spacing:.5rem; color:var(--red); opacity:.8; }
.ornament--dark{ color:var(--cream); }
.ornament--dark::before,.ornament--dark::after{ background:linear-gradient(90deg,transparent,rgba(247,242,232,.25),transparent); }

/* page-hero immer zentriert (wie alte Seite) */
.page-hero .container{ text-align:center; }
.page-hero .breadcrumb{ text-align:center; }

/* wiederverwendbarer Karten-Tag */
.card .tag{ display:inline-block; color:var(--red); font-weight:600; letter-spacing:1.5px; text-transform:uppercase; font-size:.7rem; margin-bottom:.5rem; }
.price .ct{ font-size:.8rem; color:var(--text-soft); font-weight:500; }

/* Galerie-Platzhalter Feinschliff */
.gallery .tile[data-full]{ cursor:zoom-in; }
.tile--ph{ cursor:default; flex-direction:column; gap:.4rem; text-align:center; }
.tile--ph small{ display:inline-block; margin-top:.2rem; font-size:.7rem; opacity:.7; letter-spacing:.5px; }
.tile--ph .ph-ico{ width:30px; height:30px; opacity:.4; background:currentColor;
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5'%3E%3Crect x='3' y='6' width='18' height='14' rx='2'/%3E%3Ccircle cx='12' cy='13' r='3.2'/%3E%3Cpath d='M8 6l1.5-2h5L16 6'/%3E%3C/svg%3E") center/contain no-repeat;
          mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.5'%3E%3Crect x='3' y='6' width='18' height='14' rx='2'/%3E%3Ccircle cx='12' cy='13' r='3.2'/%3E%3Cpath d='M8 6l1.5-2h5L16 6'/%3E%3C/svg%3E") center/contain no-repeat; }

/* Kontaktkarten-Icon */
.contact-card .ic{ display:inline-grid; place-items:center; background:rgba(194,64,28,.10); color:var(--red); font-size:1.05rem; vertical-align:middle; }
.contact-card h3{ font-size:1.25rem; }
