/* ============================================================
   SakuraHara-Werk — Stylesheet
   Ästhetik: Japanese Editorial / Washi-Paper
   Typographie: Shippori Mincho (Display) + Noto Sans JP (Body)
   ============================================================ */

/* Lokale Schriften (selbst gehostet, kein Google-Server-Kontakt) — siehe assets/fonts/ANLEITUNG.md */
@import url('../fonts/fonts.css');

:root {
    /* Palette: Washi-Papier & Tusche, mit Sakura- und Hanko-Akzenten */
    --color-paper:        #F6F1E8;   /* Washi-Creme */
    --color-paper-deep:   #EDE5D3;   /* tieferer Cremeton */
    --color-ink:          #1A1A1A;   /* Sumi-Tusche */
    --color-ink-soft:     #3D3D3D;
    --color-ink-muted:    #8A8377;
    --color-sakura:       #E8A5B4;   /* Sakura-Rosa */
    --color-sakura-deep:  #D4829A;
    --color-hanko:        #B44A4A;   /* Siegel-Rot */
    --color-hanko-dark:   #8E3333;
    --color-gold:         #C9A95C;   /* dezentes Gold */
    --color-line:         #D9D1BE;

    /* Typography */
    --font-display: 'Shippori Mincho', 'Noto Serif JP', Georgia, serif;
    --font-body:    'Noto Sans JP', system-ui, sans-serif;
    --font-mono:    'IBM Plex Mono', ui-monospace, monospace;

    /* Rhythm */
    --unit: 8px;
    --radius: 2px;
    --max-width: 1200px;

    /* Motion */
    --ease: cubic-bezier(.22,.61,.36,1);
    --ease-out: cubic-bezier(.16,1,.3,1);
}

/* -----------------------------------------------------
   Reset + Basis
   ----------------------------------------------------- */
*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
    background: var(--color-paper);
    color: var(--color-ink);
    font-family: var(--font-body);
    font-weight: 400;
    line-height: 1.65;
    font-size: 16px;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    overflow-x: hidden;
    /* dezente Washi-Textur aus SVG-noise */
    background-image:
        radial-gradient(ellipse at top left, rgba(232,165,180,.08), transparent 55%),
        radial-gradient(ellipse at bottom right, rgba(180,74,74,.05), transparent 50%),
        url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 .1 0 0 0 0 .08 0 0 0 0 .05 0 0 0 .045 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { cursor: pointer; font: inherit; color: inherit; background: none; border: none; }

::selection { background: var(--color-sakura); color: var(--color-ink); }

/* -----------------------------------------------------
   Typografie-Helfer
   ----------------------------------------------------- */
.display {
    font-family: var(--font-display);
    font-weight: 600;
    letter-spacing: -.02em;
    line-height: 1.05;
}
.kicker {
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: var(--color-ink-muted);
    display: inline-flex;
    align-items: center;
    gap: 10px;
}
.kicker::before {
    content: '';
    width: 28px;
    height: 1px;
    background: var(--color-hanko);
}
.jp {
    font-family: var(--font-display);
    font-weight: 400;
}

/* -----------------------------------------------------
   Layout-Container
   ----------------------------------------------------- */
.container {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 0 clamp(20px, 5vw, 48px);
}

section { position: relative; padding: clamp(80px, 12vh, 140px) 0; }
section + section { border-top: 1px solid var(--color-line); }

/* Vertikale Kanji-Akzente (Dekoration) */
.vertical-accent {
    position: absolute;
    top: 50%;
    right: clamp(12px, 2vw, 32px);
    transform: translateY(-50%);
    writing-mode: vertical-rl;
    font-family: var(--font-display);
    font-size: clamp(80px, 14vw, 220px);
    color: var(--color-sakura);
    opacity: .08;
    pointer-events: none;
    letter-spacing: .3em;
    user-select: none;
    font-weight: 300;
    z-index: 0;
}

/* -----------------------------------------------------
   Navigation
   ----------------------------------------------------- */
.nav {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 100;
    backdrop-filter: blur(14px) saturate(140%);
    -webkit-backdrop-filter: blur(14px) saturate(140%);
    background: rgba(246, 241, 232, .78);
    border-bottom: 1px solid transparent;
    transition: border-color .3s var(--ease), background .3s var(--ease);
}
.nav.scrolled {
    border-bottom-color: var(--color-line);
    background: rgba(246, 241, 232, .92);
}
.nav-inner {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 18px clamp(20px, 5vw, 48px);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 32px;
}
.nav-logo {
    display: flex;
    align-items: baseline;
    gap: 10px;
    font-family: var(--font-display);
    font-weight: 600;
}
.nav-logo .kanji {
    font-size: 22px;
    color: var(--color-hanko);
    letter-spacing: .05em;
}
.nav-logo .latin {
    font-size: 14px;
    letter-spacing: .1em;
}
.nav-menu {
    display: flex;
    gap: clamp(12px, 2.4vw, 28px);
    list-style: none;
    align-items: center;
}
/* Container <nav> selbst als Flex, damit nav-menu + customer-login + nav-toggle in einer Reihe */
.nav-inner > nav {
    display: flex;
    align-items: center;
    gap: 0;
}
.nav-menu a {
    font-size: 13px;
    letter-spacing: .05em;
    color: var(--color-ink-soft);
    position: relative;
    padding: 6px 0;
    transition: color .2s var(--ease);
}
.nav-menu a:hover { color: var(--color-ink); }
.nav-menu a::after {
    content: '';
    position: absolute;
    left: 0; bottom: 0;
    width: 0; height: 1px;
    background: var(--color-hanko);
    transition: width .25s var(--ease);
}
.nav-menu a:hover::after { width: 100%; }
.nav-toggle { display: none !important; }

/* Customer-Login-Link in der Nav */
.customer-login-link {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 8px 16px;
    border: 1px solid var(--color-line);
    border-radius: var(--radius);
    color: var(--color-ink);
    text-decoration: none;
    font-size: 12px;
    font-family: var(--font-mono);
    letter-spacing: .12em;
    text-transform: uppercase;
    transition: all .2s var(--ease);
    margin-left: 28px;
}
.customer-login-link:hover {
    background: var(--color-hanko);
    color: white;
    border-color: var(--color-hanko);
}
.customer-login-link .kanji-small {
    font-family: var(--font-display);
    font-size: 16px;
    line-height: 1;
    color: var(--color-hanko);
    transition: color .2s var(--ease);
}
.customer-login-link:hover .kanji-small { color: white; }
@media (max-width: 860px) {
    .customer-login-link .label { display: none; }
    .customer-login-link { padding: 8px 10px; margin-left: 12px; }
}

/* -----------------------------------------------------
   Buttons
   ----------------------------------------------------- */
.btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 28px;
    font-family: var(--font-body);
    font-size: 13px;
    font-weight: 500;
    letter-spacing: .08em;
    text-transform: uppercase;
    border-radius: var(--radius);
    transition: all .25s var(--ease);
    border: 1px solid transparent;
    position: relative;
    overflow: hidden;
}
.btn-primary {
    background: var(--color-ink);
    color: var(--color-paper);
}
.btn-primary:hover {
    background: var(--color-hanko);
    transform: translateY(-1px);
    box-shadow: 0 12px 28px -12px rgba(180,74,74,.55);
}
.btn-secondary {
    background: transparent;
    color: var(--color-ink);
    border-color: var(--color-ink);
}
.btn-secondary:hover {
    background: var(--color-ink);
    color: var(--color-paper);
}
.btn .arrow { transition: transform .25s var(--ease); }
.btn:hover .arrow { transform: translateX(4px); }

/* -----------------------------------------------------
   HERO
   ----------------------------------------------------- */
.hero {
    min-height: 100vh;
    display: flex;
    align-items: center;
    padding: 140px 0 80px;
    position: relative;
    overflow: hidden;
}
.hero::before {
    /* Großer Kanji-Wasserzeichen */
    content: attr(data-kanji);
    position: absolute;
    top: 50%; right: -2vw;
    transform: translateY(-50%);
    font-family: var(--font-display);
    font-size: clamp(280px, 42vw, 700px);
    color: var(--color-sakura);
    opacity: .12;
    font-weight: 300;
    line-height: .85;
    pointer-events: none;
    z-index: 0;
    user-select: none;
}
.hero-grid {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 48px;
    max-width: 900px;
}
.hero .kicker { margin-bottom: 32px; }
.hero h1 {
    font-family: var(--font-display);
    font-size: clamp(44px, 7.5vw, 96px);
    font-weight: 500;
    line-height: 1.02;
    letter-spacing: -.02em;
    margin-bottom: 36px;
}
.hero h1 .accent {
    color: var(--color-hanko);
    font-style: italic;
    font-weight: 400;
}
.hero p.lead {
    font-size: clamp(17px, 1.8vw, 20px);
    color: var(--color-ink-soft);
    max-width: 640px;
    line-height: 1.6;
    margin-bottom: 48px;
}
.hero-ctas {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
}

/* Hero-Meta-Zeile mit Strich */
.hero-meta {
    position: absolute;
    left: clamp(20px, 5vw, 48px);
    bottom: 48px;
    display: flex;
    align-items: center;
    gap: 16px;
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: .18em;
    color: var(--color-ink-muted);
    text-transform: uppercase;
    z-index: 2;
}
.hero-meta::before {
    content: '';
    width: 40px; height: 1px;
    background: var(--color-ink-muted);
}

/* Hanko-Siegel Dekoration */
.hanko-seal {
    position: absolute;
    width: 72px; height: 72px;
    border: 2px solid var(--color-hanko);
    color: var(--color-hanko);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-display);
    font-size: 28px;
    transform: rotate(-4deg);
    border-radius: 6px;
}
.hanko-seal::after {
    content: '';
    position: absolute;
    inset: -4px;
    border: 1px solid var(--color-hanko);
    opacity: .3;
    border-radius: 8px;
}

/* -----------------------------------------------------
   SECTION-HEADER (wiederverwendbar)
   ----------------------------------------------------- */
.section-head {
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
    max-width: 780px;
    margin-bottom: 72px;
    position: relative;
    z-index: 2;
}
.section-head h2 {
    font-family: var(--font-display);
    font-size: clamp(34px, 4.8vw, 60px);
    font-weight: 500;
    line-height: 1.1;
    letter-spacing: -.02em;
}

/* -----------------------------------------------------
   FEATURES
   ----------------------------------------------------- */
.features-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(270px, 1fr));
    gap: 0;
    position: relative;
    z-index: 2;
    border-top: 1px solid var(--color-line);
    border-left: 1px solid var(--color-line);
}
.feature-card {
    padding: 40px 36px;
    border-right: 1px solid var(--color-line);
    border-bottom: 1px solid var(--color-line);
    background: rgba(246, 241, 232, 0);
    transition: background .4s var(--ease);
    position: relative;
}
.feature-card:hover {
    background: rgba(232,165,180,.08);
}
.feature-icon {
    width: 46px; height: 46px;
    color: var(--color-hanko);
    margin-bottom: 28px;
}
.feature-card h3 {
    font-family: var(--font-display);
    font-size: 22px;
    font-weight: 600;
    margin-bottom: 14px;
    letter-spacing: -.01em;
}
.feature-card p {
    font-size: 15px;
    color: var(--color-ink-soft);
    line-height: 1.65;
}

/* -----------------------------------------------------
   PRICING
   ----------------------------------------------------- */
.pricing-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 24px;
    position: relative;
    z-index: 2;
}
.plan {
    background: var(--color-paper-deep);
    padding: 48px 36px 40px;
    position: relative;
    border: 1px solid var(--color-line);
    transition: transform .35s var(--ease), box-shadow .35s var(--ease);
}
.plan:hover {
    transform: translateY(-4px);
    box-shadow: 0 24px 60px -30px rgba(26,26,26,.4);
}
.plan.highlighted {
    background: var(--color-ink);
    color: var(--color-paper);
    border-color: var(--color-ink);
}
.plan-name {
    display: flex;
    align-items: baseline;
    gap: 12px;
    margin-bottom: 32px;
}
.plan-name .latin {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 22px;
    letter-spacing: -.01em;
}
.plan-name .jp-label {
    font-family: var(--font-display);
    font-size: 14px;
    color: var(--color-ink-muted);
}
.plan.highlighted .jp-label { color: var(--color-sakura); }
.plan-price {
    font-family: var(--font-display);
    font-size: 44px;
    font-weight: 500;
    letter-spacing: -.025em;
    margin-bottom: 4px;
}
.plan-period {
    font-family: var(--font-mono);
    font-size: 12px;
    color: var(--color-ink-muted);
    text-transform: uppercase;
    letter-spacing: .15em;
    margin-bottom: 36px;
}
.plan.highlighted .plan-period { color: var(--color-sakura); }
.plan ul {
    list-style: none;
    margin-bottom: 36px;
}
.plan ul li {
    padding: 12px 0;
    font-size: 14px;
    border-top: 1px solid var(--color-line);
    display: flex;
    align-items: center;
    gap: 12px;
}
.plan.highlighted ul li {
    border-color: rgba(255,255,255,.12);
}
.plan ul li::before {
    content: '';
    width: 14px; height: 1px;
    background: var(--color-hanko);
    flex-shrink: 0;
}
.plan.highlighted ul li::before { background: var(--color-sakura); }
.plan .btn { width: 100%; justify-content: center; }
.plan.highlighted .btn-primary {
    background: var(--color-sakura);
    color: var(--color-ink);
}
.plan.highlighted .btn-primary:hover {
    background: var(--color-paper);
}

.plan-badge {
    position: absolute;
    top: -1px; right: 24px;
    padding: 6px 14px;
    background: var(--color-hanko);
    color: var(--color-paper);
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: .22em;
    text-transform: uppercase;
}

/* -----------------------------------------------------
   TESTIMONIALS
   ----------------------------------------------------- */
.testimonials-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 32px;
    position: relative;
    z-index: 2;
}
.testimonial {
    padding: 36px 32px;
    background: rgba(255,255,255,.35);
    border: 1px solid var(--color-line);
    position: relative;
}
.testimonial::before {
    content: '「';
    position: absolute;
    top: 12px; left: 16px;
    font-family: var(--font-display);
    font-size: 56px;
    color: var(--color-sakura);
    line-height: 1;
    opacity: .6;
}
.testimonial blockquote {
    font-family: var(--font-display);
    font-size: 19px;
    font-weight: 400;
    line-height: 1.45;
    margin: 32px 0 28px;
    color: var(--color-ink);
    letter-spacing: -.01em;
}
.testimonial-author {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding-top: 20px;
    border-top: 1px solid var(--color-line);
}
.testimonial-author strong {
    font-weight: 600;
    font-size: 14px;
}
.testimonial-author span {
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--color-ink-muted);
    letter-spacing: .08em;
}

/* -----------------------------------------------------
   CTA
   ----------------------------------------------------- */
.cta-section {
    background: var(--color-ink);
    color: var(--color-paper);
    position: relative;
    overflow: hidden;
}
.cta-section::before {
    content: '宿';
    position: absolute;
    top: 50%; right: -50px;
    transform: translateY(-50%);
    font-family: var(--font-display);
    font-size: clamp(300px, 38vw, 560px);
    color: var(--color-hanko);
    opacity: .08;
    font-weight: 300;
    line-height: .85;
    user-select: none;
}
.cta-section h2 {
    color: var(--color-paper);
    font-size: clamp(38px, 5.5vw, 72px);
}
.cta-section .kicker { color: var(--color-sakura); }
.cta-section .kicker::before { background: var(--color-sakura); }
.cta-section .lead { color: rgba(246, 241, 232, .75); }
.cta-section .btn-primary {
    background: var(--color-sakura);
    color: var(--color-ink);
}
.cta-section .btn-primary:hover { background: var(--color-paper); }

/* -----------------------------------------------------
   CONTACT
   ----------------------------------------------------- */
.contact-wrap {
    display: grid;
    grid-template-columns: 1fr 1.4fr;
    gap: 64px;
    position: relative;
    z-index: 2;
}
.contact-info dl {
    display: grid;
    gap: 24px;
}
.contact-info dt {
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: var(--color-ink-muted);
    margin-bottom: 6px;
}
.contact-info dd {
    font-family: var(--font-display);
    font-size: 18px;
    color: var(--color-ink);
}
form.contact-form {
    display: grid;
    gap: 20px;
}
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.form-group { display: flex; flex-direction: column; gap: 8px; }
.form-group label {
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: var(--color-ink-muted);
}
.form-group input,
.form-group textarea,
.form-group select {
    padding: 14px 0;
    border: none;
    border-bottom: 1px solid var(--color-ink);
    background: transparent;
    font-family: var(--font-body);
    font-size: 16px;
    color: var(--color-ink);
    transition: border-color .25s var(--ease);
    border-radius: 0;
}
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
    outline: none;
    border-color: var(--color-hanko);
}
.form-group textarea {
    min-height: 140px;
    resize: vertical;
    border: 1px solid var(--color-line);
    padding: 16px;
    border-radius: var(--radius);
}
.form-group textarea:focus { border-color: var(--color-hanko); }

.form-message { padding: 16px; font-size: 14px; }
.form-message.success { background: rgba(201, 169, 92, .12); color: var(--color-ink); border-left: 3px solid var(--color-gold); }
.form-message.error   { background: rgba(180,74,74,.08); color: var(--color-hanko); border-left: 3px solid var(--color-hanko); }

/* -----------------------------------------------------
   FOOTER
   ----------------------------------------------------- */
footer {
    padding: 64px 0 40px;
    border-top: 1px solid var(--color-line);
    background: var(--color-paper-deep);
}
.footer-inner {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 18px 32px;
    align-items: end;
}
.footer-inner p {
    font-size: 12px;
    font-family: var(--font-mono);
    letter-spacing: .1em;
    color: var(--color-ink-muted);
}
.footer-menu {
    grid-column: 1 / -1;
    display: flex;
    flex-wrap: wrap;
    gap: 8px 22px;
    list-style: none;
    padding-top: 16px;
    border-top: 1px solid var(--color-border, rgba(0,0,0,.08));
    margin-top: 4px;
}
.footer-menu a {
    font-size: 12px;
    font-family: var(--font-mono);
    letter-spacing: .12em;
    color: var(--color-ink-soft);
    text-decoration: none;
    transition: color .2s var(--ease);
}
.footer-menu a:hover { color: var(--color-hanko); }
.social-links {
    display: flex; gap: 16px;
    list-style: none;
}
.social-links a {
    font-size: 12px;
    font-family: var(--font-mono);
    letter-spacing: .15em;
    text-transform: uppercase;
    color: var(--color-ink-soft);
    transition: color .2s var(--ease);
}
.social-links a:hover { color: var(--color-hanko); }

/* -----------------------------------------------------
   Einblend-Animationen (Intersection Observer)
   ----------------------------------------------------- */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .9s var(--ease-out), transform .9s var(--ease-out); }
.reveal.in { opacity: 1; transform: none; }
.reveal[data-delay="1"] { transition-delay: .08s; }
.reveal[data-delay="2"] { transition-delay: .16s; }
.reveal[data-delay="3"] { transition-delay: .24s; }
.reveal[data-delay="4"] { transition-delay: .32s; }

/* Fallende Sakura-Blüten */
.petals {
    position: fixed; inset: 0;
    pointer-events: none;
    z-index: 1;
    overflow: hidden;
}
.petal {
    position: absolute;
    top: -20px;
    width: 14px; height: 14px;
    background: radial-gradient(circle at 30% 30%, var(--color-sakura) 0%, var(--color-sakura-deep) 80%);
    border-radius: 150% 0 150% 0;
    opacity: .55;
    animation: fall linear infinite;
}
@keyframes fall {
    0%   { transform: translate3d(0,-20px,0) rotate(0deg); opacity: 0; }
    10%  { opacity: .5; }
    100% { transform: translate3d(40px, 110vh, 0) rotate(540deg); opacity: 0; }
}

/* -----------------------------------------------------
   Responsive
   ----------------------------------------------------- */
@media (max-width: 860px) {
    .nav-menu { display: none; }
    .nav-menu.open {
        display: flex;
        flex-direction: column;
        position: absolute;
        top: 100%; left: 0; right: 0;
        background: var(--color-paper);
        padding: 24px;
        border-bottom: 1px solid var(--color-line);
    }
    .nav-toggle { display: inline-flex !important; padding: 8px; }
    .contact-wrap { grid-template-columns: 1fr; gap: 40px; }
    .form-row { grid-template-columns: 1fr; }
    .hero-meta { display: none; }
}

/* -----------------------------------------------------
   Reduced motion
   ----------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: .01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: .01ms !important;
        scroll-behavior: auto !important;
    }
    .petal { display: none; }
}

/* ============================================================
   Customer-Panel-Drawer (Overlay über der Hauptseite)
   ============================================================ */

.cp-overlay {
    position: fixed;
    inset: 0;
    z-index: 1000;
    pointer-events: none;
    opacity: 0;
    visibility: hidden;
    transition: opacity .25s var(--ease), visibility .25s;
}
.cp-overlay.is-open {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.cp-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(26, 26, 26, .42);
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
    opacity: 0;
    transition: opacity .25s var(--ease);
}
.cp-overlay.is-open .cp-backdrop { opacity: 1; }

.cp-drawer {
    position: absolute;
    top: 0; right: 0;
    height: 100vh;
    width: 100%;
    max-width: 480px;
    background: var(--color-paper);
    box-shadow: -20px 0 60px rgba(0,0,0,.15);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    transform: translateX(100%);
    transition: transform .35s cubic-bezier(.2, .7, .3, 1);
}
.cp-overlay.is-open .cp-drawer { transform: translateX(0); }

/* ---- Header ---- */
.cp-head {
    flex-shrink: 0;
    padding: 22px 28px 18px;
    border-bottom: 1px solid var(--color-line);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    background: var(--color-paper);
}
.cp-head-left {
    display: flex;
    align-items: center;
    gap: 14px;
    min-width: 0;
}
.cp-kanji {
    font-family: var(--font-display);
    font-size: 30px;
    color: var(--color-hanko);
    line-height: 1;
    flex-shrink: 0;
}
.cp-title {
    font-family: var(--font-display);
    font-size: 18px;
    color: var(--color-ink);
    line-height: 1.2;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.cp-subtitle {
    font-size: 12px;
    color: var(--color-text-soft, #6a655c);
    margin-top: 2px;
}
.cp-close {
    flex-shrink: 0;
    background: none;
    border: 1px solid var(--color-line);
    width: 38px; height: 38px;
    border-radius: 50%;
    cursor: pointer;
    font-size: 18px;
    line-height: 1;
    color: var(--color-ink);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all .15s var(--ease);
}
.cp-close:hover {
    background: var(--color-hanko);
    color: white;
    border-color: var(--color-hanko);
}

/* ---- Tabs ---- */
.cp-tabs {
    flex-shrink: 0;
    display: flex;
    gap: 2px;
    padding: 0 28px;
    border-bottom: 1px solid var(--color-line);
    background: var(--color-paper);
    overflow-x: auto;
}
.cp-tab {
    padding: 12px 16px;
    background: none;
    border: none;
    color: var(--color-text-soft, #6a655c);
    font-size: 13px;
    font-weight: 500;
    letter-spacing: .03em;
    border-bottom: 2px solid transparent;
    white-space: nowrap;
    cursor: pointer;
    transition: all .15s var(--ease);
}
.cp-tab:hover { color: var(--color-ink); }
.cp-tab.is-active {
    color: var(--color-hanko);
    border-bottom-color: var(--color-hanko);
}
.cp-tab-count {
    font-family: var(--font-mono);
    font-size: 10px;
    color: var(--color-text-soft);
    margin-left: 4px;
    background: rgba(0,0,0,.04);
    padding: 1px 6px;
    border-radius: 8px;
}
.cp-tab.is-active .cp-tab-count {
    color: var(--color-hanko);
    background: rgba(180,74,74,.08);
}

/* ---- Body ---- */
.cp-body {
    flex: 1 1 auto;
    overflow-y: auto;
    padding: 26px 28px;
    min-height: 0;
}
.cp-pane { display: none; }
.cp-pane.is-active { display: block; }

.cp-section-title {
    font-family: var(--font-display);
    font-size: 22px;
    margin-bottom: 6px;
    color: var(--color-ink);
}
.cp-section-subtitle {
    font-family: var(--font-display);
    font-size: 16px;
    margin-top: 26px;
    margin-bottom: 8px;
    color: var(--color-ink);
}
.cp-section-hint {
    font-size: 13px;
    color: var(--color-text-soft, #6a655c);
    margin-bottom: 22px;
    line-height: 1.5;
}

/* ---- Form ---- */
.cp-form .cp-field,
.cp-field { margin-bottom: 14px; }
.cp-field label {
    display: block;
    font-size: 11px;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--color-text-soft, #6a655c);
    margin-bottom: 6px;
}
.cp-field input,
.cp-field textarea {
    width: 100%;
    padding: 11px 14px;
    border: 1px solid var(--color-line);
    background: white;
    border-radius: var(--radius);
    font-family: var(--font-body);
    font-size: 14px;
    color: var(--color-ink);
    transition: border-color .15s;
    box-sizing: border-box;
}
.cp-field textarea {
    resize: vertical;
    min-height: 100px;
    font-family: var(--font-body);
}
.cp-field input:focus,
.cp-field textarea:focus {
    outline: none;
    border-color: var(--color-hanko);
}

.cp-honeypot {
    position: absolute !important;
    left: -9999px !important;
    opacity: 0 !important;
}

.cp-btn-primary {
    background: var(--color-ink);
    color: white;
    border: none;
    padding: 11px 22px;
    border-radius: var(--radius);
    font-family: var(--font-body);
    font-size: 13px;
    font-weight: 500;
    letter-spacing: .04em;
    cursor: pointer;
    transition: background .15s var(--ease);
}
.cp-btn-primary:hover { background: var(--color-hanko); }

.cp-btn-secondary {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: transparent;
    color: var(--color-ink);
    border: 1px solid var(--color-line);
    padding: 8px 14px;
    border-radius: var(--radius);
    font-family: var(--font-body);
    font-size: 12px;
    font-weight: 500;
    text-decoration: none;
    cursor: pointer;
    transition: all .15s var(--ease);
}
.cp-btn-secondary:hover {
    background: var(--color-hanko);
    color: white;
    border-color: var(--color-hanko);
}

/* ---- Cards ---- */
.cp-card {
    background: white;
    border: 1px solid var(--color-line);
    border-radius: var(--radius);
    padding: 18px 20px;
    margin-bottom: 12px;
}
.cp-card.cp-empty {
    text-align: center;
    color: var(--color-text-soft);
    padding: 36px 20px;
    background: transparent;
    border-style: dashed;
}

.cp-prod-name {
    font-family: var(--font-display);
    font-size: 17px;
    margin-bottom: 4px;
    color: var(--color-ink);
}
.cp-prod-desc {
    font-size: 13px;
    color: var(--color-text-soft, #6a655c);
    line-height: 1.55;
}

/* ---- Rechnungen ---- */
.cp-inv-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 0;
    border-bottom: 1px solid var(--color-line);
}
.cp-inv-row:last-child { border-bottom: none; }
.cp-inv-meta { flex: 1; }
.cp-inv-amount {
    font-family: var(--font-display);
    font-size: 16px;
    color: var(--color-ink);
}

/* ---- Tickets ---- */
.cp-ticket-row {
    display: block;
    padding: 14px 20px;
    border-bottom: 1px solid var(--color-line);
    text-decoration: none;
    color: inherit;
    transition: background .15s;
}
.cp-ticket-row:last-of-type { border-bottom: none; }
.cp-ticket-row:hover { background: rgba(232, 165, 180, .05); }
.cp-ticket-subject {
    font-weight: 600;
    color: var(--color-ink);
    margin-bottom: 4px;
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}
.cp-ticket-meta {
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--color-text-soft);
    letter-spacing: .04em;
}
.cp-ticket-status {
    display: inline-block;
    padding: 2px 8px;
    font-size: 9px;
    letter-spacing: .12em;
    text-transform: uppercase;
    border-radius: 2px;
    background: var(--color-line);
    color: var(--color-text-soft);
    font-weight: 500;
}
.cp-ticket-status.open {
    background: var(--color-hanko);
    color: white;
}
.cp-ticket-status.resolved {
    background: rgba(0,0,0,.06);
}

.cp-ticket-new {
    margin-top: 24px;
    border-top: 1px solid var(--color-line);
    padding-top: 20px;
}
.cp-ticket-new summary {
    display: inline-block;
    background: transparent;
    color: var(--color-ink);
    border: 1px solid var(--color-line);
    padding: 10px 18px;
    border-radius: var(--radius);
    font-family: var(--font-body);
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    list-style: none;
    transition: all .15s var(--ease);
}
.cp-ticket-new summary::-webkit-details-marker { display: none; }
.cp-ticket-new summary:hover {
    background: var(--color-hanko);
    color: white;
    border-color: var(--color-hanko);
}
.cp-ticket-new[open] summary {
    background: var(--color-hanko);
    color: white;
    border-color: var(--color-hanko);
}
.cp-ticket-sender {
    font-size: 11px;
    color: var(--color-text-soft);
    margin: 4px 0 14px;
    padding: 8px 12px;
    background: rgba(232,165,180,.06);
    border-radius: var(--radius);
}

/* ---- Messages ---- */
.cp-msg {
    padding: 11px 14px;
    border-radius: var(--radius);
    margin-bottom: 18px;
    font-size: 13px;
}
.cp-msg.success {
    background: rgba(74,138,114,.1);
    color: #2c5d44;
    border-left: 3px solid #4a8a72;
}
.cp-msg.error {
    background: rgba(180,74,74,.08);
    color: var(--color-hanko);
    border-left: 3px solid var(--color-hanko);
}

/* ---- Footer ---- */
.cp-footer-actions {
    flex-shrink: 0;
    padding: 16px 28px;
    border-top: 1px solid var(--color-line);
    text-align: center;
    background: var(--color-paper);
}
.cp-logout {
    color: var(--color-text-soft);
    font-size: 11px;
    letter-spacing: .14em;
    text-transform: uppercase;
    text-decoration: none;
    transition: color .15s var(--ease);
}
.cp-logout:hover { color: var(--color-hanko); }

/* ---- Mobile ---- */
@media (max-width: 540px) {
    .cp-drawer { max-width: 100%; }
    .cp-head, .cp-body, .cp-tabs, .cp-footer-actions { padding-left: 20px; padding-right: 20px; }
}

/* ---- Body-Lock wenn Drawer offen ---- */
body.cp-locked { overflow: hidden; }

/* ============================================================
   Sprach-Pills (DE | EN | JA)
   ============================================================ */

/* Public-Nav Pills — dezent, horizontal, im Sakura-Theme */
.site-lang-picker {
    display: inline-flex;
    gap: 2px;
    margin-left: 18px;
    align-items: center;
}
.site-lang-pill {
    display: inline-flex;
    flex-direction: row;
    align-items: center;
    gap: 6px;
    padding: 5px 9px;
    border: 1px solid transparent;
    border-radius: var(--radius);
    background: transparent;
    color: var(--color-text-soft, #6a655c);
    text-decoration: none;
    font-size: 11px;
    line-height: 1;
    white-space: nowrap;
    transition: all .15s var(--ease);
}
.site-lang-pill .flag {
    display: block;
    width: 16px;
    height: 11px;
    flex-shrink: 0;
    border-radius: 1.5px;
    overflow: hidden;
    opacity: .55;
    box-shadow: 0 0 0 1px rgba(0,0,0,.06);
    transition: opacity .15s var(--ease);
}
.site-lang-pill .flag svg {
    display: block;
    width: 16px;
    height: 11px;
    max-width: 16px;
    max-height: 11px;
}
.site-lang-pill .label {
    display: inline-block;
    font-family: var(--font-body);
    letter-spacing: .02em;
}
.site-lang-pill:hover {
    color: var(--color-ink);
    background: rgba(0,0,0,.03);
}
.site-lang-pill:hover .flag { opacity: .9; }
.site-lang-pill.is-active {
    color: var(--color-ink);
    border-color: var(--color-line);
    background: rgba(255,255,255,.6);
}
.site-lang-pill.is-active .flag { opacity: 1; }

@media (max-width: 1020px) {
    .site-lang-pill .label { display: none; }
    .site-lang-pill { padding: 5px 7px; gap: 0; }
}
@media (max-width: 860px) {
    .site-lang-picker { margin-left: 8px; }
}

/* Customer-Panel Pills — dezent, gleiche Sprache wie Nav-Pills */
.cp-lang-row {
    display: inline-flex;
    gap: 2px;
    flex-wrap: wrap;
}
.cp-lang-pill {
    display: inline-flex;
    flex-direction: row;
    align-items: center;
    gap: 6px;
    padding: 5px 9px;
    border: 1px solid transparent;
    border-radius: var(--radius);
    color: var(--color-text-soft, #6a655c);
    text-decoration: none;
    font-size: 11px;
    line-height: 1;
    white-space: nowrap;
    transition: all .15s var(--ease);
}
.cp-lang-pill .flag {
    display: block;
    width: 14px;
    height: 10px;
    flex-shrink: 0;
    border-radius: 1.5px;
    overflow: hidden;
    opacity: .55;
    box-shadow: 0 0 0 1px rgba(0,0,0,.06);
    transition: opacity .15s var(--ease);
}
.cp-lang-pill .flag svg {
    display: block;
    width: 14px;
    height: 10px;
    max-width: 14px;
    max-height: 10px;
}
.cp-lang-pill:hover {
    color: var(--color-ink);
    background: rgba(0,0,0,.03);
}
.cp-lang-pill:hover .flag { opacity: .9; }
.cp-lang-pill.is-active {
    color: var(--color-hanko);
    border-color: rgba(180,74,74,.3);
    background: rgba(180,74,74,.04);
}
.cp-lang-pill.is-active .flag { opacity: 1; }

/* Customer-Panel Footer */
.cp-footer-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}
@media (max-width: 540px) {
    .cp-footer-actions {
        flex-direction: column-reverse;
        gap: 12px;
    }
    .cp-lang-pill .label { display: none; }
}
