/* === DSGVO-AUSKUNFT-GENERATOR === */

:root {
    --primary: #d97a1f;
    --primary-hover: #c06a14;
    --bg: #fafafa;
    --text: #1a1a1a;
    --dark: #333;
    --gray: #666;
    --gray-light: #999;
    --border: #e5e5e5;
    --white: #fff;
    --danger: #dc2626;
    --warning: #d97706;
    --info: #0284c7;
    --success: #16a34a;
    --ochre-light: #fff6ed;
    --font-body: 'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --font-heading: 'DM Serif Display', Georgia, serif;
    --font-letter: 'Times New Roman', Georgia, serif;
}

* { box-sizing: border-box; }
main#main-content { background: var(--bg); padding: 0; }

.liability-banner {
    background: #fef2f2;
    border-bottom: 2px solid #fecaca;
    padding: 12px 24px;
    font-size: 13px;
    line-height: 1.55;
    color: #7f1d1d;
    text-align: center;
}
.liability-banner strong { color: #7f1d1d; }

.container {
    display: grid;
    grid-template-columns: 460px 1fr;
    gap: 0;
    align-items: start;
    max-width: 1600px;
    margin: 0 auto;
}
@media (max-width: 900px) { .container { grid-template-columns: 1fr; } }

.panel { background: var(--white); border: 1px solid var(--border); display: flex; flex-direction: column; }
.input-panel { border-right: none; position: sticky; top: 0; max-height: 100vh; overflow-y: auto; }
.output-panel { overflow: visible; }
.panel-scroll { padding: 24px; flex: 1; }

.input-panel h1 {
    font-family: var(--font-heading);
    font-size: 1.5rem; color: var(--text);
    margin: 0 0 18px; line-height: 1.2;
}
.landing-intro h1 {
    font-family: var(--font-heading);
    font-size: 2rem; color: var(--text);
    margin: 0 0 14px; line-height: 1.15;
}
.landing-intro h2 {
    font-family: var(--font-heading);
    font-size: 1.2rem; color: var(--text);
    margin: 28px 0 10px;
}
.landing-intro p { color: var(--dark); line-height: 1.65; margin-bottom: 12px; }
.landing-intro ul, .landing-intro ol { margin-left: 22px; }
.landing-intro li { margin-bottom: 6px; line-height: 1.6; color: var(--dark); }

.api-key-section {
    background: #fffbeb;
    border: 1px solid #fde68a;
    padding: 14px;
    border-radius: 4px;
    margin-bottom: 20px;
}
.api-key-section label {
    display: block;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 4px;
}

.collapsible {
    border: 1px solid var(--border);
    margin-bottom: 12px;
    border-radius: 3px;
    background: var(--white);
}
.collapsible.warning-section { border-color: #fde68a; }
.collapsible.warning-section .c-head { background: #fffbeb; color: #92400e; }
.c-head {
    padding: 11px 14px;
    background: #f7f7f7;
    cursor: pointer;
    font-size: 13px;
    font-weight: 600;
    color: var(--dark);
    user-select: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.c-head:hover { filter: brightness(0.97); }
.c-head span { font-size: 11px; color: var(--gray); }
.c-body { display: none; padding: 14px; }
.c-body.active { display: block; }

.section-intro {
    font-size: 12px;
    color: var(--dark);
    margin: 0 0 14px;
    padding: 8px 12px;
    background: #f7f7f7;
    border-left: 3px solid var(--primary);
    border-radius: 2px;
    line-height: 1.5;
}

.form-group { margin-bottom: 14px; }
.form-group label {
    display: block;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--dark);
    margin-bottom: 4px;
}
.form-group label.required::after { content: ' *'; color: var(--danger); }
.form-group label.checkbox-row {
    display: flex !important;
    align-items: flex-start;
    gap: 8px;
    text-transform: none !important;
    letter-spacing: 0 !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    line-height: 1.45;
    color: var(--dark);
    cursor: pointer;
}
.form-group label.checkbox-row input { margin-top: 2px; }
.form-group input[type="text"], .form-group input[type="email"], .form-group input[type="password"],
.form-group input[type="number"], .form-group input[type="date"], .form-group select, .form-group textarea {
    width: 100%;
    padding: 9px 12px;
    border: 1px solid var(--border);
    border-radius: 3px;
    font-family: var(--font-body);
    font-size: 13px;
    background: var(--white);
    color: var(--text);
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
    outline: none; border-color: var(--primary);
}
.form-group textarea { resize: vertical; min-height: 60px; }
.help-text { font-size: 11px; color: var(--gray); margin: 4px 0 0; line-height: 1.4; }
.privacy-mini {
    font-size: 11px;
    color: var(--gray);
    margin-top: 14px;
    line-height: 1.5;
    padding: 10px 12px;
    background: #f7f7f7;
    border-radius: 3px;
}

/* System list */
.system-item {
    border: 1px solid var(--border);
    border-radius: 3px;
    margin-bottom: 8px;
    background: #fafafa;
}
.system-head {
    padding: 8px 12px;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.system-examples {
    font-size: 11px;
    color: var(--gray);
    padding-left: 22px;
}
.system-detail {
    padding: 8px 12px 12px;
    background: var(--white);
    border-top: 1px dashed var(--border);
}
.system-detail textarea, .system-detail input[type="text"] {
    width: 100%;
    margin-top: 6px;
    padding: 6px 9px;
    border: 1px solid var(--border);
    border-radius: 3px;
    font-size: 12px;
    font-family: var(--font-body);
}
.add-system-btn {
    width: 100%;
    padding: 10px;
    background: var(--white);
    border: 1px dashed var(--primary);
    color: var(--primary);
    cursor: pointer;
    border-radius: 3px;
    font-size: 12px;
    font-weight: 600;
    margin-top: 6px;
}
.add-system-btn:hover { background: var(--ochre-light); }

.btn-gen {
    width: 100%;
    background: var(--primary);
    color: var(--white);
    border: none;
    padding: 14px;
    font-size: 14px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    cursor: pointer;
    border-radius: 3px;
    margin-top: 6px;
}
.btn-gen:hover:not(:disabled) { background: var(--primary-hover); }
.btn-gen:disabled { background: var(--gray-light); cursor: not-allowed; }

/* Tabs */
.out-head {
    display: flex;
    gap: 0;
    background: #f7f7f7;
    border-bottom: 1px solid var(--border);
    flex-wrap: wrap;
}
.tab-btn {
    background: transparent;
    border: none;
    padding: 11px 16px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    color: var(--gray);
    border-bottom: 2px solid transparent;
    font-family: var(--font-body);
}
.tab-btn:hover { color: var(--text); }
.tab-btn.active { color: var(--text); border-bottom-color: var(--primary); background: var(--white); }
.tab-pane { display: none; }
.tab-pane.active { display: block; }

.landing-intro {
    background: var(--ochre-light);
    border: 1px solid var(--border);
    padding: 28px;
    border-radius: 4px;
    margin: 6px 0;
}
.cta-intro {
    margin-top: 20px;
    padding: 12px 16px;
    background: var(--white);
    border: 1px dashed var(--primary);
    text-align: center;
    color: var(--primary);
    font-weight: 600;
    font-size: 13px;
}

.loader-container { display: none; flex-direction: column; align-items: center; justify-content: center; padding: 60px 20px; text-align: center; }
.loader-content { max-width: 420px; }
.loader-spinner {
    width: 48px; height: 48px;
    border: 3px solid var(--ochre-light);
    border-top-color: var(--primary);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
    margin: 0 auto 22px;
}
@keyframes spin { to { transform: rotate(360deg); } }
.loader-status { font-size: 15px; font-weight: 600; color: var(--text); margin-bottom: 4px; }
.loader-substatus { font-size: 12px; color: var(--gray); margin-bottom: 18px; }
.loader-progress-bar { width: 100%; height: 4px; background: var(--ochre-light); border-radius: 2px; overflow: hidden; }
.loader-progress-fill { height: 100%; background: var(--primary); width: 0%; transition: width 0.6s ease; }

/* Frist banner */
.frist-banner {
    padding: 16px 20px;
    border-radius: 3px;
    margin-bottom: 14px;
    border: 1px solid;
}
.frist-banner.frist-ok       { background: #f0fdf4; border-color: #bbf7d0; color: #166534; }
.frist-banner.frist-warn     { background: #fefce8; border-color: #fde047; color: #854d0e; }
.frist-banner.frist-urgent   { background: #fff7ed; border-color: #fdba74; color: #9a3412; }
.frist-banner.frist-overdue  { background: #fef2f2; border-color: #fecaca; color: #991b1b; }
.frist-status {
    font-size: 18px;
    font-weight: 700;
    margin-bottom: 6px;
}
.frist-detail { font-size: 13px; line-height: 1.55; }

/* Audit blocks */
.audit-block {
    background: var(--white);
    border: 1px solid var(--border);
    padding: 18px 22px;
    margin-bottom: 14px;
    border-radius: 3px;
}
.audit-block h2 {
    font-family: var(--font-heading);
    font-size: 1.25rem;
    margin: 0 0 8px;
    color: var(--text);
}
.audit-intro { font-size: 13px; color: var(--gray); margin: 0 0 14px; line-height: 1.55; }
.audit-block.audit-blocker { background: #fef2f2; border-color: #fecaca; }
.audit-block.audit-blocker h2 { color: #991b1b; }
.audit-block.audit-warn { background: #fffbeb; border-color: #fde68a; }
.audit-block.audit-warn h2 { color: #92400e; }
.audit-block.audit-info { background: #f0f9ff; border-color: #bae6fd; }
.audit-block.audit-info h2 { color: #075985; }
.audit-block.audit-id { background: #f7f7f7; }
.audit-block.audit-disclaimer { background: #f7f7f7; font-size: 12px; color: var(--gray); padding: 12px 18px; line-height: 1.55; }

.audit-item {
    border-top: 1px solid rgba(0,0,0,0.08);
    padding: 12px 0 4px;
    margin-top: 12px;
}
.audit-item:first-of-type { border-top: none; padding-top: 0; margin-top: 0; }
.audit-item h3 { font-size: 14px; margin: 0 0 6px; color: var(--text); }
.audit-item p { line-height: 1.55; color: var(--dark); margin: 0 0 6px; font-size: 13px; }
.audit-item .paragraph { font-size: 11px; color: var(--gray); font-family: 'Courier New', monospace; }
.audit-item .action { font-size: 12px; padding: 6px 10px; background: rgba(0,0,0,0.04); border-radius: 3px; }

.id-level {
    display: inline-block;
    padding: 2px 10px;
    border-radius: 3px;
    font-size: 14px;
    font-weight: 700;
    margin-left: 8px;
}
.id-niedrig { background: #f0fdf4; color: #166534; }
.id-mittel  { background: #fefce8; color: #854d0e; }
.id-hoch    { background: #fef2f2; color: #991b1b; }

/* Action buttons */
.action-btns {
    display: flex;
    gap: 8px;
    align-items: center;
    margin-bottom: 12px;
    flex-wrap: wrap;
}
.action-btn {
    background: var(--white);
    border: 1px solid var(--border);
    padding: 9px 16px;
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    border-radius: 3px;
    color: var(--dark);
    font-family: var(--font-body);
}
.action-btn:hover { background: var(--ochre-light); border-color: var(--primary); }
.copy-success { color: var(--success); font-weight: 600; font-size: 12px; opacity: 0; transition: opacity 0.2s; }
.copy-success.show { opacity: 1; }

/* Letter */
.letter-paper {
    background: var(--white);
    padding: 60px 70px;
    max-width: 720px;
    margin: 0 auto;
    box-shadow: 0 1px 3px rgba(0,0,0,0.08);
    font-family: var(--font-letter);
    font-size: 13px;
    line-height: 1.65;
    color: #000;
}
.letter-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 30px;
}
.sender-block { font-size: 11px; line-height: 1.5; color: #555; }
.letter-date { font-size: 12px; }
.recipient-block { margin: 30px 0; font-size: 13px; line-height: 1.55; }
.letter-subject { font-weight: bold; font-size: 14px; margin: 30px 0 20px; font-family: var(--font-letter); }
.letter-salutation { margin: 0 0 18px; }
.letter-paper p { margin: 0 0 16px; text-align: justify; }
.letter-signature {
    font-family: var(--font-letter);
    font-size: 13px;
    line-height: 1.55;
    margin: 30px 0 0;
    white-space: pre-wrap;
}

/* Checklist */
.checklist-block {
    background: var(--white);
    border: 1px solid var(--border);
    padding: 20px 24px;
    margin-bottom: 14px;
    border-radius: 3px;
}
.checklist-block h2 {
    font-family: var(--font-heading);
    font-size: 1.25rem;
    margin: 0 0 8px;
    color: var(--text);
}
.checklist-block.info-block-soft { background: #f0f9ff; border-color: #bae6fd; }
.checklist-block.info-block-soft h2 { color: #075985; }

.checklist { list-style: none; padding: 0; margin: 14px 0 0; }
.checklist li {
    padding: 8px 12px;
    border-radius: 3px;
    margin-bottom: 6px;
    border-left: 3px solid var(--gray-light);
}
.checklist li.prio-blocker { background: #fef2f2; border-left-color: var(--danger); }
.checklist li.prio-high    { background: #fffbeb; border-left-color: var(--warning); }
.checklist li.prio-medium  { background: #f7f7f7; border-left-color: var(--gray); }
.checklist li.prio-low     { background: #f0f9ff; border-left-color: var(--info); }
.checklist label {
    display: flex;
    gap: 10px;
    align-items: flex-start;
    cursor: pointer;
    font-size: 13px;
    line-height: 1.55;
    color: var(--dark);
}
.checklist input[type="checkbox"] { margin-top: 4px; }

p.muted { color: var(--gray); font-size: 12px; }
.small { font-size: 11px; }

@media print {
    body * { visibility: hidden; }
    #letterRender, #letterRender * { visibility: visible; }
    .out-head, .action-btns, .input-panel, .liability-banner { display: none !important; }
    #letterRender { position: absolute; top: 0; left: 0; width: 100%; }
    .letter-paper { box-shadow: none; padding: 0; }
}

@media (max-width: 700px) {
    .letter-paper { padding: 30px 24px; }
    .container { grid-template-columns: 1fr; }
}