/* ===========================================================================
   imagenimble.com — Theme (Tenant `in`)
   Voll-Custom Bild-Tool-Portal. Dark/Light-Toggle. Scoped auf .in-Wrapper,
   erbt NICHT das Magazin-CSS. Fonts lokal (DSGVO). WCAG-AA.
   Designvorlage: Claude-Design-Bundle (scratchpad/design.html).
   =========================================================================== */

/* ----------------------------------------------------------------- Fonts (lokal) */
@font-face{font-family:'Anton';font-style:normal;font-weight:400;font-display:swap;src:url('/css/fonts/anton-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+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Schibsted Grotesk';font-style:normal;font-weight:400;font-display:swap;src:url('/css/fonts/schibsted-grotesk-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+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Schibsted Grotesk';font-style:normal;font-weight:500;font-display:swap;src:url('/css/fonts/schibsted-grotesk-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+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Schibsted Grotesk';font-style:normal;font-weight:600;font-display:swap;src:url('/css/fonts/schibsted-grotesk-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+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Schibsted Grotesk';font-style:normal;font-weight:700;font-display:swap;src:url('/css/fonts/schibsted-grotesk-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+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Schibsted Grotesk';font-style:normal;font-weight:800;font-display:swap;src:url('/css/fonts/schibsted-grotesk-700-latin.woff2') format('woff2');}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:400;font-display:swap;src:url('/css/fonts/jetbrains-mono-400-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2074,U+20AC,U+2122,U+2212,U+FEFF,U+FFFD;}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:600;font-display:swap;src:url('/css/fonts/jetbrains-mono-600-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2074,U+20AC,U+2122,U+2212,U+FEFF,U+FFFD;}
/* Oswald — nur als Meme-Schrift (Canvas-Rendering im Meme-Generator). */
@font-face{font-family:'Oswald';font-style:normal;font-weight:700;font-display:swap;src:url('/css/fonts/oswald-700-latin.woff2') format('woff2');}

/* ----------------------------------------------------------------- Design-Tokens */
/* AA-getunte Werte: --dim/--faint dunkler (light) bzw. heller (dark) als die
   reine Vorlage, damit Fließ-/Label-Text ≥4,5:1 erreicht. */
.in[data-theme="dark"]{
  --bg:#0a0e17; --bg2:#0d1220; --surface:#141a27; --surface2:#1b2231; --elevated:#1f2735;
  --border:#262e3f; --border2:#323b4f;
  --text:#e9ecf4; --dim:#a7b0c2; --faint:#8b93a8;
  --primary:#6d6ff5; --primary-soft:#a9aefc; --primary-bg:rgba(109,111,245,0.16);
  --accent:#f6a318; --accent-press:#e0900a; --on-accent:#241803;
  --success:#37d39a; --success-bg:rgba(55,211,154,0.14); --success-ink:#3fdca2;
  --error:#f87171; --error-bg:rgba(248,113,113,0.14);
  --shadow:0 1px 2px rgba(0,0,0,.4),0 8px 30px rgba(0,0,0,.32);
  --checker:#1b2231;
}
.in[data-theme="light"]{
  --bg:#f6f7fa; --bg2:#eef1f6; --surface:#ffffff; --surface2:#f4f6fa; --elevated:#ffffff;
  --border:#e4e8f0; --border2:#d6dbe6;
  --text:#161b27; --dim:#515a6e; --faint:#6b7280;
  --primary:#4f46e5; --primary-soft:#4338ca; --primary-bg:rgba(79,70,229,0.08);
  --accent:#b45309; --accent-press:#92400e; --on-accent:#ffffff;
  --success:#0d9f6e; --success-bg:rgba(13,159,110,0.12); --success-ink:#0a7d56;
  --error:#dc3535; --error-bg:rgba(220,53,53,0.09);
  --shadow:0 1px 2px rgba(20,30,60,.06),0 10px 34px rgba(20,30,60,.07);
  --checker:#e7ebf2;
}

/* ----------------------------------------------------------------- Reset / Base */
.in *{box-sizing:border-box}
.in{
  font-family:'Schibsted Grotesk',system-ui,-apple-system,sans-serif;
  background:var(--bg); color:var(--text); min-height:100vh;
  display:flex; flex-direction:column; -webkit-font-smoothing:antialiased;
  font-size:16px; line-height:1.5;
}
.in img{max-width:100%}
.in a{color:inherit;text-decoration:none}
.in button{font-family:inherit}
.in ::selection{background:var(--primary);color:#fff}
.in :focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:6px}
.in-mono{font-family:'JetBrains Mono','Courier New',monospace}
.in-wrap{max-width:1180px;margin:0 auto;padding:0 28px;width:100%}
@keyframes in-spin{to{transform:rotate(360deg)}}
@keyframes in-menuin{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
@keyframes in-drawerin{from{transform:translateX(100%)}to{transform:none}}

/* ----------------------------------------------------------------- Header */
.in-header{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--bg) 86%,transparent);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}
.in-header__inner{max-width:1180px;margin:0 auto;padding:0 28px;height:64px;display:flex;align-items:center;gap:14px}
.in-logo{display:flex;align-items:center;gap:10px;background:none;border:none;cursor:pointer;padding:0;color:var(--text)}
.in-logo__mark{display:grid;place-items:center;width:30px;height:30px;border-radius:8px;background:var(--primary);box-shadow:0 2px 8px var(--primary-bg);color:#fff}
.in-logo__mark svg rect:first-child{stroke:#fff}
.in-logo__txt{font-weight:800;font-size:18px;letter-spacing:-0.02em}
.in-logo__txt span{color:var(--primary)}
.in-search{flex:1;display:flex;justify-content:center;max-width:420px;margin:0 auto}
.in-search__field{position:relative;display:flex;align-items:center;width:100%}
.in-search__field svg{position:absolute;left:13px;pointer-events:none;color:var(--faint)}
.in-search__input{width:100%;height:38px;padding:0 14px 0 36px;border-radius:9px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-family:inherit;font-size:13.5px;outline:none}
.in-hnav{display:flex;align-items:center;gap:8px}
.in-hbtn{height:38px;display:grid;place-items:center;border-radius:9px;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer}
.in-hbtn--icon{width:38px}
.in-hbtn--lang{display:flex;align-items:center;gap:7px;padding:0 10px 0 11px;font-size:13.5px;font-weight:600}
.in-langwrap{position:relative}
.in-langmenu{position:absolute;top:calc(100% + 9px);right:0;z-index:50;width:240px;background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);overflow:hidden;animation:in-menuin .14s ease}
.in-langmenu__list{max-height:296px;overflow-y:auto;padding:6px}
.in-langmenu__item{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 11px;border-radius:9px;border:none;background:none;color:var(--text);cursor:pointer;text-align:left}
.in-langmenu__item:hover{background:var(--surface2)}
.in-langmenu__item .nat{font-weight:600;font-size:14px}
.in-langmenu__item .nam{font-size:12px;color:var(--faint)}
.in-langmenu__note{padding:9px 12px;border-top:1px solid var(--border);font-size:11.5px;color:var(--faint)}
.in-burger{display:none}
@media (max-width:760px){
  .in-search{order:3;flex-basis:100%;max-width:none;margin-top:0}
  .in-hide-mobile{display:none !important}
  .in-burger{display:grid}
}

/* Mobile Drawer */
.in-drawer-backdrop{position:fixed;inset:0;z-index:60;background:rgba(8,11,18,.5);backdrop-filter:blur(2px)}
.in-drawer{position:fixed;top:0;right:0;bottom:0;z-index:70;width:296px;max-width:85vw;background:var(--surface);border-left:1px solid var(--border);box-shadow:var(--shadow);overflow-y:auto;animation:in-drawerin .2s ease}
.in-drawer__head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--border)}
.in-drawer__brand{display:flex;align-items:center;gap:9px;font-weight:800;font-size:17px;letter-spacing:-0.02em}
.in-drawer__brand span{color:var(--primary)}
.in-drawer__close{width:30px;height:30px;border:none;background:var(--surface2);border-radius:8px;color:var(--dim);cursor:pointer;font-size:16px}
.in-drawer__nav{padding:14px 12px}
.in-drawer__group{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;color:var(--faint);padding:16px 12px 7px}
.in-drawer__link{width:100%;display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;border:none;background:none;color:var(--text);cursor:pointer;font-family:inherit;font-size:14.5px;font-weight:500;text-align:left}
.in-drawer__link:hover{background:var(--surface2)}
.in-drawer__link--sub{color:var(--dim);font-size:14px;font-weight:400;padding-left:14px}
.in-drawer__chips{display:flex;flex-wrap:wrap;gap:6px;padding:4px 8px 8px}
.in-langchip{display:flex;align-items:center;gap:6px;padding:7px 11px;border-radius:100px;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;font-family:inherit;font-size:13px;font-weight:600}
.in-langchip.is-active{border-color:var(--primary);background:var(--primary-bg);color:var(--primary)}

/* ----------------------------------------------------------------- Badges/Buttons */
.in-localbadge{display:inline-flex;align-items:center;gap:8px;padding:6px 13px;border-radius:100px;background:var(--success-bg);color:var(--success-ink);font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:600}
.in-chip-local{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:100px;background:var(--success-bg);color:var(--success-ink);font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:600}
.in-btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;border:none;border-radius:12px;font-family:inherit;font-weight:700;cursor:pointer;text-decoration:none;transition:background .15s}
.in-btn--cta{background:var(--accent);color:var(--on-accent);padding:14px 18px;font-size:16px;box-shadow:0 4px 14px var(--primary-bg);width:100%}
.in-btn--cta:hover{background:var(--accent-press)}
.in-btn--ghost{background:var(--surface);color:var(--text);border:1px solid var(--border);padding:11px 16px;font-size:14px;font-weight:600}
.in-btn--ghost:hover{border-color:var(--primary)}
.in-pill{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:100px;border:1px solid var(--border);background:var(--surface);color:var(--dim);cursor:pointer;font-family:inherit;font-size:13.5px;text-decoration:none}
.in-pill:hover{border-color:var(--primary);color:var(--primary)}

/* ----------------------------------------------------------------- Home */
.in-hero{text-align:center;padding:64px 0 36px}
.in-hero h1{font-size:clamp(34px,6vw,52px);line-height:1.05;font-weight:800;letter-spacing:-0.03em;margin:22px auto 18px;max-width:760px}
.in-hero h1 .alt{color:var(--primary)}
.in-hero__sub{font-size:18px;color:var(--dim);max-width:560px;margin:0 auto 28px;line-height:1.5}
.in-hero__search{position:relative;display:flex;align-items:center;max-width:520px;margin:0 auto}
.in-hero__search svg{position:absolute;left:17px;pointer-events:none;color:var(--faint)}
.in-hero__search input{width:100%;height:54px;padding:0 18px 0 46px;border-radius:13px;border:1px solid var(--border2);background:var(--surface);color:var(--text);font-family:inherit;font-size:16px;outline:none;box-shadow:var(--shadow)}
.in-secthead{display:flex;align-items:center;justify-content:space-between;margin:26px 0 12px}
.in-secthead h2{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;color:var(--dim);margin:0}
.in-secthead__dot{width:7px;height:7px;border-radius:2px;background:var(--primary)}
.in-secthead__dot--accent{background:var(--accent)}
.in-secthead__dot--success{background:var(--success)}
.in-secthead__more{display:flex;align-items:center;gap:5px;background:none;border:none;cursor:pointer;font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--primary);font-weight:600;text-decoration:none}
.in-secthead__count{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--faint)}
.in-grid-tools{display:grid;grid-template-columns:repeat(auto-fill,minmax(258px,1fr));gap:10px}
.in-toolcard{display:flex;align-items:center;gap:13px;text-align:left;padding:13px 14px;border-radius:13px;border:1px solid var(--border);background:var(--surface);cursor:pointer;color:var(--text);transition:border-color .15s,background .15s}
.in-toolcard:hover{border-color:var(--primary);background:var(--surface2)}
.in-toolcard__ico{flex:none;display:grid;place-items:center;width:38px;height:38px;border-radius:10px;background:var(--primary-bg);color:var(--primary)}
.in-toolcard__b{flex:1;min-width:0}
.in-toolcard__t{display:block;font-weight:600;font-size:14.5px}
.in-toolcard__s{display:block;font-size:12.5px;color:var(--dim);line-height:1.35;margin-top:1px}
.in-toolcard__soon{flex:none;font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:600;color:var(--faint);border:1px solid var(--border);border-radius:6px;padding:3px 6px}

/* ----------------------------------------------------------------- Tool page */
.in-main{max-width:1180px;margin:0 auto;padding:0 28px 80px;width:100%}
.in-crumbs{display:flex;align-items:center;gap:8px;padding:22px 0 8px;font-size:13px;color:var(--faint);font-family:'JetBrains Mono',monospace;flex-wrap:wrap}
.in-crumbs a{color:var(--dim)}
.in-crumbs a:hover{color:var(--primary)}
.in-crumbs .cur{color:var(--text)}
.in-toolhead{text-align:center;max-width:640px;margin:18px auto 30px}
.in-toolhead__ico{display:inline-grid;place-items:center;width:58px;height:58px;border-radius:16px;background:var(--primary-bg);color:var(--primary);margin-bottom:16px}
.in-toolhead h1{font-size:clamp(28px,5vw,38px);font-weight:800;letter-spacing:-0.025em;margin:0 0 12px}
.in-toolhead__sub{font-size:17px;color:var(--dim);line-height:1.5;margin:0}
.in-card{max-width:760px;margin:0 auto;background:var(--surface);border:1px solid var(--border);border-radius:20px;box-shadow:var(--shadow);overflow:hidden}
.in-card__top{padding:26px 26px 0;display:flex;align-items:center;justify-content:space-between;gap:12px}
.in-card__body{padding:18px 26px 26px}
.in-drop{border:2px dashed var(--border2);background:var(--surface2);border-radius:16px;padding:54px 24px;text-align:center;cursor:pointer;transition:border-color .15s,background .15s}
.in-drop.is-over{border-color:var(--primary);background:var(--primary-bg)}
.in-drop__ico{display:grid;place-items:center;width:60px;height:60px;border-radius:16px;background:var(--primary-bg);color:var(--primary);margin:0 auto 18px}
.in-drop__t{font-size:19px;font-weight:700;margin-bottom:6px}
.in-drop__h{font-size:14px;color:var(--dim)}
.in-drop__btn{display:inline-block;margin-top:18px;padding:9px 18px;border-radius:10px;background:var(--surface);border:1px solid var(--border);font-size:14px;font-weight:600}
.in-ws{display:grid;grid-template-columns:1.3fr 1fr;gap:20px;align-items:start}
.in-preview{border:1px solid var(--border);border-radius:14px;overflow:hidden;background:repeating-conic-gradient(var(--checker) 0% 25%,transparent 0% 50%) 50% / 20px 20px}
.in-preview__frame{aspect-ratio:4/3;display:grid;place-items:center;position:relative}
.in-preview__frame img,.in-preview__frame canvas{max-width:100%;max-height:100%;object-fit:contain}
.in-preview__meta{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-top:1px solid var(--border);background:var(--surface);font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--dim);gap:10px}
.in-preview__meta .nm{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60%}
.in-spin{position:absolute;inset:0;background:color-mix(in srgb,var(--bg) 60%,transparent);display:grid;place-items:center;backdrop-filter:blur(2px)}
.in-spin svg{animation:in-spin .8s linear infinite}
.in-opts__label{display:block;font-size:13px;color:var(--dim);margin-bottom:7px}
.in-opts__h{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:0.06em;color:var(--dim);margin-bottom:14px}
.in-segrow{display:flex;gap:7px;margin-bottom:18px}
.in-seg{flex:1;padding:9px;border-radius:9px;border:1px solid var(--border);background:var(--surface);color:var(--dim);font-family:'JetBrains Mono',monospace;font-weight:600;font-size:13px;cursor:pointer}
.in-seg.is-active{border-color:var(--primary);background:var(--primary-bg);color:var(--primary)}
.in-range{width:100%;accent-color:var(--primary)}
.in-estimate{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--faint);margin:8px 0 20px;background:var(--bg2);border-radius:8px;padding:8px 10px}
.in-estimate b{color:var(--success-ink)}
.in-done__h{display:flex;align-items:center;gap:9px;color:var(--success-ink);font-weight:700;font-size:16px;margin-bottom:6px}
.in-error{border:1px solid var(--error);background:var(--error-bg);border-radius:14px;padding:24px;display:flex;gap:14px;align-items:flex-start}
.in-steps{max-width:760px;margin:44px auto 0;display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.in-step{text-align:center;padding:8px}
.in-step:nth-child(2){border-left:1px solid var(--border);border-right:1px solid var(--border)}
.in-step__n{font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:600;color:var(--primary);margin-bottom:10px}
.in-step__t{font-weight:600;font-size:15px;margin-bottom:5px}
.in-step__d{font-size:13px;color:var(--dim);line-height:1.45}

/* SEO content + modules */
.in-prose{max-width:680px;margin:56px auto 0}
.in-prose h2{font-size:24px;font-weight:700;letter-spacing:-0.02em;margin:0 0 14px}
.in-prose p{font-size:16px;color:var(--dim);line-height:1.65;margin:0 0 16px}
.in-mod{max-width:680px;margin:44px auto 0}
.in-mod h2{font-size:24px;font-weight:700;letter-spacing:-0.02em;margin:0 0 16px}
.in-cmp{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.in-cmp__c{border:1px solid var(--border);border-radius:13px;padding:16px;background:var(--surface)}
.in-cmp__h{display:flex;align-items:center;gap:8px;font-weight:700;font-size:15px;margin-bottom:10px}
.in-cmp__dot{width:8px;height:8px;border-radius:2px}
.in-cmp__l{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.08em;text-transform:uppercase;color:var(--faint);margin-bottom:4px}
.in-cmp__d{font-size:13.5px;color:var(--dim);line-height:1.5}
.in-privacy{display:flex;gap:14px;align-items:flex-start;border:1px solid var(--success);background:var(--success-bg);border-radius:14px;padding:20px}
.in-privacy__t{font-weight:700;font-size:16px;margin-bottom:4px}
.in-privacy__d{font-size:14.5px;color:var(--dim);line-height:1.55}
.in-faq{max-width:680px;margin:48px auto 0}
.in-faq h2{font-size:24px;font-weight:700;letter-spacing:-0.02em;margin:0 0 16px}
.in-faq__item{border-bottom:1px solid var(--border);padding:18px 2px}
.in-faq__q{font-size:16px;font-weight:600;margin-bottom:8px}
.in-faq__a{font-size:15px;color:var(--dim);line-height:1.6;margin:0}
.in-chips{display:flex;flex-wrap:wrap;gap:8px}
.in-related{max-width:760px;margin:52px auto 0}
.in-related h2{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;color:var(--dim);margin:0 0 14px}
.in-related__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}
.in-relcard{display:flex;align-items:center;gap:11px;text-align:left;padding:12px 13px;border-radius:12px;border:1px solid var(--border);background:var(--surface);cursor:pointer;color:var(--text)}
.in-relcard:hover{border-color:var(--primary)}
.in-relcard__ico{flex:none;display:grid;place-items:center;width:34px;height:34px;border-radius:9px;background:var(--primary-bg);color:var(--primary)}

/* ----------------------------------------------------------------- Hub */
.in-hub__groups{display:flex;flex-direction:column;gap:26px}
.in-hub__from{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.in-hub__badge{font-family:'JetBrains Mono',monospace;font-weight:600;font-size:14px;color:var(--text);padding:5px 11px;border:1px solid var(--border);border-radius:8px;background:var(--surface)}
.in-hub__lbl{font-size:13px;color:var(--faint)}
.in-hub__rule{flex:1;height:1px;background:var(--border)}
.in-hub__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}
.in-hub__item{display:flex;align-items:center;justify-content:space-between;gap:10px;text-align:left;padding:13px 15px;border-radius:12px;border:1px solid var(--border);background:var(--surface);cursor:pointer;color:var(--text);font-family:inherit;font-weight:600;font-size:14px}
.in-hub__item:hover{border-color:var(--primary);background:var(--surface2)}
.in-hub__item svg{opacity:.5;flex:none}

/* ----------------------------------------------------------------- Generators (QR/Barcode/Meme/Collage) */
.in-gen{max-width:880px;margin:0 auto;background:var(--surface);border:1px solid var(--border);border-radius:20px;box-shadow:var(--shadow);overflow:hidden}
.in-gen__split{display:grid;grid-template-columns:1fr 320px;gap:0}
.in-gen__ctrl{padding:26px;border-right:1px solid var(--border)}
.in-gen__prev{padding:26px;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg2);gap:18px}
.in-input{width:100%;height:42px;padding:0 13px;border-radius:10px;border:1px solid var(--border);background:var(--bg2);color:var(--text);font-family:inherit;font-size:14px;outline:none;box-sizing:border-box}
.in-input--mono{font-family:'JetBrains Mono',monospace}
.in-textarea{width:100%;min-height:84px;padding:10px 13px;border-radius:10px;border:1px solid var(--border);background:var(--bg2);color:var(--text);font-family:inherit;font-size:14px;outline:none;box-sizing:border-box;resize:vertical}
.in-qrbox{background:#fff;padding:16px;border-radius:14px;box-shadow:0 8px 30px rgba(0,0,0,.18)}
.in-colorrow{display:flex;gap:18px;align-items:center;flex-wrap:wrap}
.in-colorrow label{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--dim);cursor:pointer}
.in-color{width:34px;height:30px;border:1px solid var(--border);border-radius:7px;background:none;cursor:pointer;padding:2px}

/* Meme (mobile-first) */
.in-meme{max-width:460px;margin:0 auto;padding:0 18px 64px;width:100%}
.in-meme__stage{position:relative;border:1px solid var(--border);border-radius:16px;overflow:hidden;background:repeating-conic-gradient(var(--checker) 0% 25%,transparent 0% 50%) 50% / 20px 20px;margin-bottom:14px}
.in-meme__stage canvas{width:100%;height:auto;display:block;cursor:grab;touch-action:none}
.in-meme__box{border:1px solid var(--border);border-radius:13px;padding:13px;margin-bottom:12px;background:var(--surface)}

/* Barcode-Vergleich */
.in-bc-cmp{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}

/* Collage-Export-Modal: Anzeige NUR über [hidden] steuern (kein inline display,
   sonst lässt sich das Modal nicht schließen). hidden → none, sonst grid. */
.in [data-in-c-modal]{display:none}
.in [data-in-c-modal]:not([hidden]){display:grid}

/* ----------------------------------------------------------------- Ads */
.in-ad{display:flex;justify-content:center;margin:40px auto 0}
.in-ad__box{width:100%;border:1px dashed var(--border2);border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--surface);color:var(--faint);min-height:90px;padding:10px}
.in-ad__box .lab{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.12em;text-transform:uppercase}
.in-ad__box .siz{font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--dim);margin-top:2px}
.in-ad--leaderboard .in-ad__box{max-width:728px;height:90px}
.in-ad--rect .in-ad__box{max-width:336px;height:280px}
.in-ad--mpu .in-ad__box{max-width:300px;height:250px}
.in-ad--halfpage .in-ad__box{max-width:300px;height:600px}
/* Backend-Schalter „no-ad-placeholders": leere Platzhalter ausblenden. Die
   Magazin-CSS-Regel dafür laden Custom-Tenants nicht → hier nachziehen. Nur
   unbefüllte Slots (.ad-placeholder); echte Creatives bleiben sichtbar. */
body.no-ad-placeholders .in-ad:has(.ad-placeholder){display:none}
body.no-ad-placeholders .in-ad__box.ad-placeholder{display:none}

/* ----------------------------------------------------------------- Soon / Static / Search / 404 */
.in-soon{max-width:640px;margin:0 auto;padding:60px 28px;text-align:center}
.in-soon__ico{display:inline-grid;place-items:center;width:64px;height:64px;border-radius:18px;background:var(--primary-bg);color:var(--primary);margin-bottom:18px}
.in-soon__badge{display:inline-block;font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:600;color:var(--accent);background:color-mix(in srgb,var(--accent) 14%,transparent);border-radius:100px;padding:5px 12px;margin-bottom:14px}
.in-static{max-width:740px;margin:0 auto;padding:32px 28px 80px}
.in-static h1{font-size:32px;font-weight:800;letter-spacing:-0.02em;margin:0 0 18px}
.in-static h2{font-size:21px;font-weight:700;margin:28px 0 10px}
.in-static p{color:var(--dim);line-height:1.7;margin:0 0 14px}
.in-static a{color:var(--primary)}
.in-404{max-width:560px;margin:0 auto;padding:80px 28px;text-align:center}
.in-404__code{font-family:'Anton',sans-serif;font-size:96px;line-height:1;color:var(--primary);letter-spacing:.02em}

/* ----------------------------------------------------------------- Footer */
.in-footer{margin-top:auto;border-top:1px solid var(--border);background:var(--bg2)}
.in-footer__inner{max-width:1180px;margin:0 auto;padding:40px 28px;display:flex;flex-wrap:wrap;gap:24px;align-items:center;justify-content:space-between}
.in-footer__trust{display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.in-footer__trust span{display:inline-flex;align-items:center;gap:8px;font-size:13.5px;color:var(--dim)}
.in-footer__trust svg{color:var(--success-ink)}
.in-footer__links{display:flex;gap:16px;flex-wrap:wrap}
.in-footer__links a{font-size:13px;color:var(--dim)}
.in-footer__links a:hover{color:var(--primary)}
.in-footer__copy{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--faint)}

/* ----------------------------------------------------------------- Responsive */
@media (max-width:880px){
  .in-gen__split{grid-template-columns:1fr}
  .in-gen__ctrl{border-right:none;border-bottom:1px solid var(--border)}
  .in-bc-cmp{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:720px){
  .in-wrap,.in-main,.in-header__inner{padding-left:18px;padding-right:18px}
  .in-ws{grid-template-columns:1fr}
  .in-cmp{grid-template-columns:1fr}
  .in-hero{padding:40px 0 28px}
}
@media (max-width:520px){
  .in-steps{grid-template-columns:1fr;gap:10px}
  .in-step:nth-child(2){border-left:none;border-right:none;border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:14px 8px}
  .in-bc-cmp{grid-template-columns:1fr}
}

/* ===========================================================================
   Consent-Banner (CMP). Liegt AUSSERHALB des .in-Wrappers → über body.in-page
   scopen und NUR literale Hex (keine --tenant-Vars; sonst weiß-auf-weiß).
   Behebt: fehlende Schriftart (erbte System-Font) + WCAG-Kontrast (Primär-/
   Equal-Button hatte Amber-Text #b45309 auf Navy #161b27 ≈ 2,5:1) + Fokus.
   =========================================================================== */
body.in-page .cmp-banner,
body.in-page .cmp-modal__dialog,
body.in-page .cmp-btn,
body.in-page .cmp-tab,
body.in-page .cmp-filter__btn,
body.in-page .cmp-noscript{font-family:'Schibsted Grotesk',system-ui,-apple-system,sans-serif}
/* Basis zuerst (Sekundär/Ghost): dunkler Text auf Weiß, ≥44px Touch */
body.in-page .cmp-btn{background:#ffffff;color:#161b27;border-color:#161b27;padding:12px 22px}
/* Primär-/Equal-Buttons DANACH (gleiche Spezifität → Quellreihenfolge gewinnt):
   Indigo + Weiß = 5,9:1 (AA), hebt „Akzeptieren" sichtbar hervor */
body.in-page .cmp-btn--primary,
body.in-page .cmp-btn--equal{background:#4f46e5;color:#ffffff;border-color:#4f46e5}
body.in-page .cmp-btn--primary:hover,
body.in-page .cmp-btn--equal:hover{background:#4338ca;color:#ffffff;border-color:#4338ca}
body.in-page .cmp-tab.is-active{color:#4f46e5;border-bottom-color:#4f46e5}
body.in-page .cmp-filter__btn.is-active{border-color:#4f46e5;color:#4f46e5;background:#eef1f6}
body.in-page .cmp-banner__links a,
body.in-page .cmp-modal__links a{color:#4338ca}
/* Sichtbarer Fokus-Ring (CMP außerhalb .in → eigene Regel) */
body.in-page .cmp-btn:focus-visible,
body.in-page .cmp-tab:focus-visible,
body.in-page .cmp-filter__btn:focus-visible,
body.in-page .cmp-modal__close:focus-visible,
body.in-page .cmp-expand:focus-visible,
body.in-page .cmp-switch input:focus-visible ~ .cmp-switch__track{outline:3px solid #4f46e5;outline-offset:2px}
