/*
Theme Name: interatmedia
Theme URI: https://www.interatmedia.de/
Author: interatmedia
Description: Eigenes, barrierefreies Theme (WCAG 2.1 AA) fuer interatmedia – Internetagentur im Westerwald.
Version: 1.1.0
Requires at least: 6.0
Requires PHP: 7.4
License: GPL-2.0-or-later
Text Domain: interatmedia
*/

/* Lokal gehostete Schriften (DSGVO-konform) */
@font-face{font-family:'Poppins';font-style:normal;font-weight:200;font-display:swap;src:url('assets/fonts/poppins-200-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Poppins';font-style:normal;font-weight:200;font-display:swap;src:url('assets/fonts/poppins-200-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Poppins';font-style:normal;font-weight:300;font-display:swap;src:url('assets/fonts/poppins-300-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Poppins';font-style:normal;font-weight:300;font-display:swap;src:url('assets/fonts/poppins-300-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Poppins';font-style:normal;font-weight:400;font-display:swap;src:url('assets/fonts/poppins-400-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Poppins';font-style:normal;font-weight:400;font-display:swap;src:url('assets/fonts/poppins-400-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Poppins';font-style:normal;font-weight:500;font-display:swap;src:url('assets/fonts/poppins-500-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Poppins';font-style:normal;font-weight:500;font-display:swap;src:url('assets/fonts/poppins-500-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Poppins';font-style:normal;font-weight:600;font-display:swap;src:url('assets/fonts/poppins-600-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Poppins';font-style:normal;font-weight:600;font-display:swap;src:url('assets/fonts/poppins-600-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Poppins';font-style:normal;font-weight:700;font-display:swap;src:url('assets/fonts/poppins-700-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Poppins';font-style:normal;font-weight:700;font-display:swap;src:url('assets/fonts/poppins-700-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Syncopate';font-style:normal;font-weight:400;font-display:swap;src:url('assets/fonts/syncopate-400-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Syncopate';font-style:normal;font-weight:400;font-display:swap;src:url('assets/fonts/syncopate-400-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Syncopate';font-style:normal;font-weight:700;font-display:swap;src:url('assets/fonts/syncopate-700-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Syncopate';font-style:normal;font-weight:700;font-display:swap;src:url('assets/fonts/syncopate-700-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}


  /* ============ Brand Tokens ============ */
  :root{
    --accent:#F71873;            /* Signatur-Magenta – nur für Flächen/Icons/große Schrift */
    --accent-soft:rgba(247,24,115,.12);
    --accent-2:#397E96;
    --radius:16px;
    --maxw:1180px;
    --font-head:'Syncopate',sans-serif;
    --font-body:'Poppins',sans-serif;
    --ease:cubic-bezier(.22,.61,.36,1);
  }
  /* Dark (Standard) */
  [data-theme="dark"]{
    --bg:#121212; --bg-2:#1b1b1b; --surface:#1e1e1e; --surface-2:#242424;
    --border:rgba(255,255,255,.12);
    --field-border:#727272;      /* sichtbarer Rahmen für Formfelder/Buttons (WCAG 1.4.11 ≥3:1) */
    --text:#f3f3f3; --text-dim:#a9a9a9;
    --accent-ink:#F71873;        /* Magenta-Text: 4,76:1 auf Dark – AA ok */
    --btn:#d50f63; --btn-hover:#b80b53;   /* weißer Text: 5,15:1 / 6,5:1 – AA ok */
    --shadow:0 18px 50px -20px rgba(0,0,0,.7);
  }
  /* Light */
  [data-theme="light"]{
    --bg:#ffffff; --bg-2:#f5f6f8; --surface:#ffffff; --surface-2:#f3f4f6;
    --border:rgba(20,20,20,.16);
    --field-border:#8a8a8a;
    --text:#161616; --text-dim:#55606e;
    --accent-ink:#b80b53;        /* Magenta-Text auf Hell: 6,5:1 – AA ok */
    --btn:#d50f63; --btn-hover:#a8074a;
    --shadow:0 18px 50px -24px rgba(20,30,60,.25);
  }

  *{box-sizing:border-box}
  html{scroll-behavior:smooth;background:var(--bg);transition:background .4s var(--ease)}
  body{
    margin:0;font-family:var(--font-body);color:var(--text);position:relative;
    background:transparent;line-height:1.65;font-weight:300;
    -webkit-font-smoothing:antialiased;overflow-x:hidden;
    transition:color .4s var(--ease);
  }
  h1,h2,h3{font-family:var(--font-head);font-weight:700;line-height:1.15;letter-spacing:.01em}
  a{color:inherit;text-decoration:none}
  img{max-width:100%;display:block}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
  .accent{color:var(--accent-ink)}
  :where(section[id],main){scroll-margin-top:88px}

  /* Sichtbarer Tastatur-Fokus (theme-robust: nutzt Textfarbe) */
  :focus-visible{outline:3px solid var(--text);outline-offset:2px;border-radius:6px}
  /* Nur-visuell-versteckt (für Screenreader sichtbar) */
  .sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

  /* Skip-Link */
  .skip-link{position:absolute;left:12px;top:-100px;z-index:200;background:var(--btn);color:#fff;
    padding:12px 18px;border-radius:8px;font-weight:500;transition:top .2s var(--ease)}
  .skip-link:focus{top:12px}

  /* Reduced motion respektieren */
  @media (prefers-reduced-motion:reduce){
    *{animation:none!important;transition:none!important;scroll-behavior:auto}
    .reveal{opacity:1!important;transform:none!important}
  }

  /* ============ Buttons ============ */
  .btn{
    display:inline-flex;align-items:center;gap:.55em;
    font-family:var(--font-body);font-weight:500;font-size:.95rem;
    padding:.85em 1.5em;border-radius:999px;border:1px solid transparent;
    cursor:pointer;transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s,border-color .25s;
  }
  .btn-primary{background:var(--btn);color:#fff;box-shadow:0 4px 14px -6px rgba(0,0,0,.45)}
  .btn-primary:hover{background:var(--btn-hover);box-shadow:0 8px 20px -8px rgba(0,0,0,.5)}
  .btn-ghost{background:transparent;color:var(--text);border-color:var(--field-border)}
  .btn-ghost:hover{border-color:var(--accent);color:var(--accent-ink)}
  .btn svg{width:1em;height:1em}

  /* ============ Header ============ */
  header.site{
    position:sticky;top:0;z-index:50;
    background:var(--bg);
    background:color-mix(in srgb,var(--bg) 82%,transparent);
    backdrop-filter:blur(14px);border-bottom:1px solid var(--border);
  }
  .nav{display:flex;align-items:center;justify-content:space-between;height:72px}
  .logo{display:flex;align-items:center;gap:.1em}
  .nav-links{display:flex;gap:32px;align-items:center;list-style:none;margin:0;padding:0}
  .nav-links a{font-size:.92rem;color:var(--text-dim);font-weight:400;transition:color .2s}
  .nav-links a:hover{color:var(--text)}
  .nav-actions{display:flex;align-items:center;gap:14px}
  .theme-toggle{
    background:var(--surface-2);border:1px solid var(--field-border);color:var(--text);
    width:42px;height:42px;border-radius:50%;cursor:pointer;font-size:1rem;
    display:grid;place-items:center;transition:border-color .2s,transform .2s;
  }
  .theme-toggle:hover{border-color:var(--accent);transform:rotate(12deg)}
  .burger{display:none;background:none;border:none;color:var(--text);cursor:pointer;width:44px;height:44px}

  /* ============ Hero ============ */
  .hero{position:relative;padding:96px 0 80px;overflow:hidden}
  .hero::before{
    content:"";position:absolute;inset:0;z-index:-1;
    background:
      radial-gradient(720px 460px at 80% 0%,rgba(247,24,115,.06),transparent 62%),
      radial-gradient(560px 380px at 5% 95%,rgba(57,126,150,.05),transparent 62%);
  }
  .hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:56px;align-items:center}
  .eyebrow{
    display:inline-flex;align-items:center;gap:.6em;font-size:.78rem;font-weight:500;
    letter-spacing:.14em;text-transform:uppercase;color:var(--accent-ink);
    background:var(--accent-soft);padding:.5em 1em;border-radius:999px;margin-bottom:22px;
  }
  .eyebrow::before{content:"";width:.5em;height:.5em;border-radius:50%;background:currentColor;flex-shrink:0}
  .hero h1{font-size:clamp(2.1rem,4.6vw,3.5rem);margin:0 0 20px}
  .hero h1 .line{display:block}
  .hero p.lead{font-size:1.18rem;color:var(--text-dim);max-width:34ch;margin:0 0 32px;font-weight:300}
  .hero-cta{display:flex;gap:14px;flex-wrap:wrap}
  .hero-meta{margin-top:34px;display:flex;gap:28px;flex-wrap:wrap;color:var(--text-dim);font-size:.85rem}
  .hero-meta b{color:var(--text);font-family:var(--font-head);font-size:1.35rem;display:block;font-weight:700}
  .hero-visual{position:relative;aspect-ratio:1/1;display:grid;place-items:center}

  /* ============ Trust strip ============ */
  .trust{border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:26px 0;
    background:var(--bg-2);background:color-mix(in srgb,var(--bg-2) 70%,transparent)}
  .trust .wrap{display:flex;align-items:center;gap:34px;flex-wrap:wrap;justify-content:center}
  .trust .label{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim)}
  .trust .ref-logo{height:44px;width:auto;opacity:.72;filter:grayscale(.3);transition:opacity .25s,filter .25s,transform .25s}
  .trust .ref-logo:hover{opacity:1;filter:grayscale(0);transform:translateY(-2px)}
  [data-theme="light"] .trust .ref-logo{filter:invert(1) grayscale(.3)}
  [data-theme="light"] .trust .ref-logo:hover{filter:invert(1)}

  /* ============ Sections ============ */
  section{padding:96px 0}
  .sec-head{max-width:620px;margin-bottom:54px}
  .sec-head .tag{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-ink);font-weight:500}
  .sec-head h2{font-size:clamp(1.7rem,3.4vw,2.5rem);margin:14px 0 16px}
  .sec-head p{color:var(--text-dim);font-size:1.05rem;margin:0}

  /* Leistungen */
  .cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;list-style:none;margin:0;padding:0}
  .card{
    background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
    padding:30px 28px;transition:transform .3s var(--ease),border-color .3s,box-shadow .3s;
    position:relative;overflow:hidden;
  }
  .card::after{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;background:linear-gradient(135deg,var(--accent),transparent 45%);opacity:0;transition:opacity .3s;-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
  .card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
  .card:hover::after{opacity:1}
  .card .ico{width:48px;height:48px;border-radius:12px;background:var(--surface-2);border:1px solid var(--border);color:var(--accent-ink);display:grid;place-items:center;margin-bottom:20px}
  .card .ico svg{width:24px;height:24px}
  .card h3{font-size:1.05rem;margin:0 0 10px}
  .card p{color:var(--text-dim);font-size:.92rem;margin:0 0 18px}
  .card a.more{font-size:.86rem;font-weight:500;color:var(--accent-ink);display:inline-flex;align-items:center;gap:.4em;transition:gap .2s}
  .card a.more:hover{gap:.7em}

  /* Referenzen / Case Studies */
  .cases{display:grid;gap:22px;list-style:none;margin:0;padding:0}
  .case{
    display:grid;grid-template-columns:200px 1fr auto;gap:30px;align-items:center;
    background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:30px 32px;
    transition:border-color .3s,transform .3s var(--ease);
  }
  .case:hover{border-color:var(--accent);transform:translateX(4px)}
  .case .client-name{font-family:var(--font-head);font-weight:700;font-size:1rem;line-height:1.3}
  .case .client-name small{display:block;font-family:var(--font-body);font-weight:300;color:var(--text-dim);font-size:.8rem;margin-top:6px;letter-spacing:0}
  .case-logo{height:52px;width:auto;max-width:140px;object-fit:contain;display:block;margin-bottom:14px;opacity:.95}
  [data-theme="light"] .case-logo{filter:invert(1)}
  .logo-wall{margin-top:50px;padding-top:42px;border-top:1px solid var(--border);
    display:grid;grid-template-columns:repeat(5,1fr);gap:26px;align-items:start;list-style:none}
  .wall-item{margin:0;display:flex;flex-direction:column;align-items:center;text-align:center;gap:16px}
  .wall-item img{height:78px;width:auto;max-width:100%;object-fit:contain;opacity:.85;
    filter:grayscale(.25);transition:opacity .25s var(--ease),filter .25s var(--ease),transform .3s var(--ease)}
  .wall-item:hover img{opacity:1;filter:grayscale(0);transform:translateY(-4px)}
  [data-theme="light"] .wall-item img{filter:invert(1) grayscale(.25)}
  [data-theme="light"] .wall-item:hover img{filter:invert(1)}
  .wall-item figcaption{font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--text-dim);line-height:1.55;max-width:20ch}
  .case .case-body h3{font-size:1.05rem;margin:0 0 8px}
  .case .case-body p{color:var(--text-dim);font-size:.92rem;margin:0 0 14px}
  .case .result{display:flex;gap:24px;flex-wrap:wrap}
  .case .result div b{font-family:var(--font-head);color:var(--accent-ink);font-size:1.3rem;display:block}
  .case .result div span{font-size:.76rem;color:var(--text-dim)}
  .case .case-cta{white-space:nowrap}

  /* Über uns */
  .about{background:var(--bg-2);background:color-mix(in srgb,var(--bg-2) 68%,transparent)}
  .about-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
  .about ul{list-style:none;padding:0;margin:24px 0 0;display:grid;gap:16px}
  .about li{display:flex;gap:14px;align-items:flex-start;color:var(--text-dim);font-size:.95rem}
  .about li .check{color:var(--accent-ink);flex-shrink:0;margin-top:.15em;font-weight:700}
  .about-photo{background:linear-gradient(135deg,var(--surface),var(--surface-2));border:1px solid var(--border);border-radius:var(--radius);min-height:340px;display:grid;place-items:center;text-align:center;padding:40px;color:var(--text-dim)}
  .about-photo .big{font-family:var(--font-head);font-size:2.4rem;color:var(--accent-ink);margin-bottom:8px}

  /* Kontakt */
  .contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px}
  .contact-info{display:grid;gap:18px;align-content:start}
  .contact-item{display:flex;gap:16px;align-items:flex-start;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:18px 20px;transition:border-color .25s;color:inherit}
  .contact-item:hover{border-color:var(--accent)}
  .contact-item .ci-ico{width:42px;height:42px;border-radius:10px;background:var(--surface-2);border:1px solid var(--border);color:var(--accent-ink);display:grid;place-items:center;flex-shrink:0}
  .contact-item .ci-ico svg{width:21px;height:21px}
  .contact-item > span:last-child{display:flex;flex-direction:column;gap:3px;min-width:0}
  .contact-item .ci-l{font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim)}
  .contact-item .ci-v{font-weight:400;font-style:normal;line-height:1.4;word-break:break-word}
  form{display:grid;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:32px}
  .form-legend{font-size:.82rem;color:var(--text-dim);margin:0}
  .field{display:grid;gap:7px}
  .field label{font-size:.82rem;color:var(--text)}
  .req{color:var(--accent-ink)}
  .field input,.field textarea{
    background:var(--bg);border:1px solid var(--field-border);border-radius:10px;padding:12px 14px;
    color:var(--text);font-family:inherit;font-size:.95rem;font-weight:300;transition:border-color .2s;
  }
  .field input::placeholder,.field textarea::placeholder{color:var(--text-dim);opacity:1}
  .field input:focus,.field textarea:focus{border-color:var(--accent)}
  .field textarea{resize:vertical;min-height:110px}
  .row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
  .form-consent{font-size:.82rem;color:var(--text);display:flex;gap:9px;align-items:flex-start}
  .form-consent input{margin-top:.2em;width:18px;height:18px;flex-shrink:0}
  .form-status{font-size:.85rem;color:var(--accent-ink);margin:0;min-height:1.2em}

  /* Footer */
  footer.site{background:var(--bg-2);background:color-mix(in srgb,var(--bg-2) 80%,transparent);border-top:1px solid var(--border);padding:60px 0 30px}
  .foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;margin-bottom:40px}
  .foot-grid h2{font-family:var(--font-head);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-dim);margin:0 0 16px;font-weight:700}
  .foot-grid ul{list-style:none;padding:0;margin:0;display:grid;gap:10px}
  .foot-grid a{color:var(--text-dim);font-size:.9rem;transition:color .2s}
  .foot-grid a:hover{color:var(--accent-ink)}
  .foot-bottom{border-top:1px solid var(--border);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;color:var(--text-dim);font-size:.82rem}
  .foot-social{display:flex;gap:12px}
  .foot-social a{width:40px;height:40px;border-radius:50%;border:1px solid var(--field-border);display:grid;place-items:center;color:var(--text-dim);transition:border-color .2s,color .2s}
  .foot-social a:hover{border-color:var(--accent);color:var(--accent-ink)}
  .foot-social svg{width:18px;height:18px}

  /* Reveal on scroll – nur mit JS, damit ohne JS nichts versteckt bleibt */
  .js .reveal{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
  .js .reveal.in{opacity:1;transform:none}

  /* Brand-Logos */
  .brand-logo{height:30px;width:auto;display:block;transition:filter .4s var(--ease)}
  [data-theme="light"] .brand-logo{filter:invert(1) hue-rotate(180deg)}
  .logo:hover .brand-logo{opacity:.82}

  /* Hero-Visual: gerahmter Kopf */
  .art-glow{position:absolute;top:12%;left:10%;width:80%;aspect-ratio:1;border-radius:50%;z-index:0;
    background:radial-gradient(circle,rgba(0,0,0,.55) 0%,transparent 70%);filter:blur(40px);opacity:.6;will-change:transform}
  .canvas{position:relative;z-index:1;margin:0;width:100%;background:#3b3b3b;border-radius:22px;overflow:hidden;
    box-shadow:var(--shadow),0 0 0 1px var(--border);transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
  .canvas::after{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;box-shadow:inset 0 0 80px rgba(0,0,0,.45)}
  .canvas:hover{transform:translateY(-4px);box-shadow:var(--shadow),0 0 0 1px var(--border)}
  .art{display:block;width:100%;height:auto}
  .signature{position:absolute;right:22px;bottom:18px;width:42%;max-width:175px;height:auto;z-index:2;opacity:.95;filter:drop-shadow(0 2px 8px rgba(0,0,0,.6))}

  /* Scroll-Fortschritt */
  .scroll-progress{position:fixed;top:0;left:0;height:2px;width:0;z-index:100;background:var(--accent);opacity:.7}

  /* Pinselstrich-Hintergrund */
  .guide-paint{position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.26;will-change:transform}
  [data-theme="light"] .guide-paint{opacity:.2}
  .guide-paint svg{display:block}
  #guidePath{stroke-dasharray:1;stroke-dashoffset:1}
  @media (prefers-reduced-motion:reduce){
    #guidePath{stroke-dashoffset:0}
    .guide-paint{opacity:.32}
  }

  /* ============ Responsive ============ */
  @media (max-width:920px){
    .hero-grid,.about-grid,.contact-grid{grid-template-columns:1fr}
    .hero-visual{order:-1;max-width:360px;margin:0 auto}
    .cards{grid-template-columns:1fr 1fr}
    .case{grid-template-columns:1fr;text-align:left;gap:18px}
    .foot-grid{grid-template-columns:1fr 1fr}
    .logo-wall{grid-template-columns:repeat(3,1fr);gap:30px 20px}
    .trust .wrap{gap:24px}
    .trust .ref-logo{height:38px}
  }
  @media (max-width:680px){
    .nav-links{
      position:fixed;inset:72px 0 auto 0;flex-direction:column;background:var(--bg);
      padding:24px;gap:20px;border-bottom:1px solid var(--border);transform:translateY(-130%);
      visibility:hidden;transition:transform .35s var(--ease),visibility .35s;box-shadow:var(--shadow);
    }
    .nav-links.open{transform:none;visibility:visible}
    .burger{display:grid;place-items:center}
    .cards{grid-template-columns:1fr}
    .row2{grid-template-columns:1fr}
    .foot-grid{grid-template-columns:1fr}
    .logo-wall{grid-template-columns:repeat(2,1fr);gap:28px 16px}
    section{padding:72px 0}
  }

  /* ===== Mobile-Feinschliff ===== */
  @media (max-width:920px){
    .hero-visual{order:0}                         /* Überschrift zuerst, Bild darunter */
  }
  @media (max-width:680px){
    .nav-actions .btn-primary{display:none}       /* Header entlasten – Hero-CTA & Menü reichen */
    .nav-links a{display:block;padding:6px 2px}   /* größere Tap-Flächen */
    .nav-links{gap:14px}
  }
  @media (max-width:560px){
    .wrap{padding:0 18px}
    .hero{padding:72px 0 56px}
    .hero h1{font-size:clamp(1.85rem,9vw,2.4rem)}
    .hero p.lead{font-size:1.06rem}
    .hero-meta{gap:18px 22px}
    .hero-visual{max-width:300px}
    .sec-head{margin-bottom:40px}
    .sec-head h2{font-size:clamp(1.5rem,6.5vw,2rem)}
    .case{padding:24px 22px}
    .contact-item{padding:16px}
    form{padding:24px 20px}
    .logo-wall{grid-template-columns:1fr 1fr;gap:24px 14px}
    .foot-bottom{flex-direction:column;align-items:flex-start}
  }
  @media (max-width:380px){
    .hero h1{font-size:1.7rem}
    .sec-head h2{font-size:1.45rem}
  }

  /* ===== Referenzen-Seite ===== */
  .ref-intro{max-width:720px}
  .ref-jump{display:flex;flex-wrap:wrap;gap:10px;margin:26px 0 0;padding:0;list-style:none}
  .ref-jump a{display:inline-block;font-size:.85rem;padding:.5em 1.1em;border:1px solid var(--field-border);border-radius:999px;color:var(--text)}
  .ref-jump a:hover{border-color:var(--accent);color:var(--accent-ink)}
  .ref-cat{margin-top:64px;scroll-margin-top:88px}
  .ref-cat h2{font-size:clamp(1.4rem,3.4vw,2rem);margin:0 0 4px}
  .ref-cat .count{color:var(--text-dim);font-size:.9rem;margin:0 0 26px}
  .ref-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,240px),1fr));gap:14px;list-style:none;margin:0;padding:0}
  .ref-grid li{margin:0}
  .ref-grid a,.ref-grid .r-static{display:flex;flex-direction:column;gap:5px;height:100%;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px 18px;transition:border-color .2s,transform .2s var(--ease)}
  .ref-grid a:hover{border-color:var(--accent);transform:translateY(-2px)}
  .ref-grid .r-name{font-weight:500;font-size:.95rem;display:flex;align-items:flex-start;gap:.5em;justify-content:space-between;line-height:1.3}
  .ref-grid .r-name svg{width:15px;height:15px;flex-shrink:0;color:var(--text-dim);margin-top:.15em}
  .ref-grid a:hover .r-name svg{color:var(--accent-ink)}
  .ref-grid .r-dom{font-size:.8rem;color:var(--text-dim);word-break:break-word}
  .ref-more{margin-top:24px;color:var(--text-dim);font-size:.95rem}
  .ref-cta{margin-top:64px;text-align:center}
