design: HOST-Frontend an rapport.openbureau.ch angeglichen

Echte Design-Tokens aus dem openbureau-Stylesheet übernommen:
- weißer Grund (#fff), warme Off-Whites (#fafafa/#fff8f0)
- near-black Text (#1a1a1a), warmes Braun als Akzent (#b07848)
- System-Font-Stack (-apple-system…) + SF Mono, Brand Krungthep
- Hero-CTA in Akzent-Braun, dunkle Sekundär-Buttons

Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
This commit is contained in:
2026-05-30 16:11:57 +02:00
parent 4b96e1a6b0
commit bd37b7f8bc
2 changed files with 59 additions and 39 deletions
+58 -38
View File
@@ -1,65 +1,85 @@
/* Design-Tokens 1:1 von rapport.openbureau.ch übernommen:
weißer Grund, near-black Text, warmes Braun als Akzent, System-Font-Stack. */
:root {
--bg: #ebe7e1;
--card: #fdfcfa;
--ink: #1a1a18;
--muted: #8c8880;
--line: #ddd8d0;
--accent: #9a7858;
--accent-ink: #f0ede8;
--bg: #ffffff;
--bg-warm: #fafafa; /* dezentes warmes Off-White für Sektionen */
--bg-tint: #fff8f0; /* warmer Akzent-Hintergrund */
--card: #ffffff;
--ink: #1a1a1a; /* near-black Text */
--ink-soft: #2a2a2a;
--muted: #666666;
--faint: #888888;
--line: #e8e8e8;
--line-soft: #f0f0f0;
--accent: #b07848; /* warmes Braun (openbureau) */
--accent-hover: #c88a5c;
--accent-deep: #9a6638;
--accent-ink: #ffffff;
--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
--font-mono: "SF Mono", Monaco, "Cascadia Code", monospace;
--brand-font: Krungthep, "Archivo Black", var(--font-sans);
}
* { box-sizing: border-box; }
body {
margin: 0;
background: var(--bg);
color: var(--ink);
font-family: "DM Mono", "Courier New", monospace;
font-family: var(--font-sans);
font-size: 16px;
line-height: 1.6;
-webkit-font-smoothing: antialiased;
}
a { color: var(--accent); }
.wrap { max-width: 1000px; margin: 0 auto; padding: 0 20px; }
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }
.wrap { max-width: 1040px; margin: 0 auto; padding: 0 24px; }
.center { min-height: 100vh; display: flex; align-items: center; justify-content: center; }
.brand { font-family: "Krungthep", "Archivo Black", sans-serif; font-size: 32px; letter-spacing: -0.02em; }
.brand { font-family: var(--brand-font); font-size: 28px; letter-spacing: 0.01em; color: var(--ink); }
.card {
background: var(--card);
border: 1px solid var(--line);
border-radius: 16px;
border-radius: 12px;
padding: 32px;
box-shadow: 0 8px 40px rgba(0,0,0,0.08);
box-shadow: 0 1px 2px rgba(0,0,0,0.03), 0 6px 24px rgba(0,0,0,0.04);
}
.card-sm { width: 100%; max-width: 380px; }
.card-sm { width: 100%; max-width: 400px; }
label { display: block; font-size: 9px; letter-spacing: 0.15em; color: var(--muted); margin-bottom: 6px; text-transform: uppercase; }
label { display: block; font-size: 11px; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; color: var(--muted); margin-bottom: 7px; }
input {
width: 100%; background: #f7f4f0; border: 1.5px solid var(--line);
border-radius: 10px; padding: 11px 14px; font-family: inherit; font-size: 13px;
color: var(--ink); outline: none; margin-bottom: 14px;
width: 100%; background: #fff; border: 1.5px solid var(--line);
border-radius: 8px; padding: 11px 14px; font-family: var(--font-sans); font-size: 15px;
color: var(--ink); outline: none; margin-bottom: 16px; transition: border-color .15s, box-shadow .15s;
}
input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(154,120,88,0.14); }
input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(176,120,72,0.14); }
button.primary {
width: 100%; padding: 13px; background: var(--ink); color: var(--accent-ink);
border: none; border-radius: 10px; font-family: inherit; font-size: 13px;
font-weight: 500; letter-spacing: 0.04em; cursor: pointer;
width: 100%; padding: 12px; background: var(--ink); color: var(--accent-ink);
border: none; border-radius: 8px; font-family: var(--font-sans); font-size: 15px;
font-weight: 600; cursor: pointer; transition: background .15s;
}
button.primary:hover { background: #2e2e28; }
button.primary:hover { background: var(--ink-soft); }
button.accent { background: var(--accent); }
button.accent:hover { background: var(--accent-hover); }
button.ghost {
background: none; border: none; color: var(--accent);
font-family: inherit; font-size: 12px; cursor: pointer; text-decoration: underline;
background: none; border: none; color: var(--muted);
font-family: var(--font-sans); font-size: 14px; cursor: pointer;
}
button.ghost:hover { color: var(--ink); }
.err { background: #fff5f0; border: 1px solid #f5c9b0; color: #b5621e;
padding: 9px 14px; border-radius: 8px; font-size: 11px; margin-bottom: 14px; }
.ok { background: #e8f5ee; border: 1px solid #b8dbc4; color: #2d6a4f;
padding: 9px 14px; border-radius: 8px; font-size: 11px; margin-bottom: 14px; }
.err { background: #fef2f2; border: 1px solid #fecaca; color: #b91c1c;
padding: 10px 14px; border-radius: 8px; font-size: 14px; margin-bottom: 16px; }
.ok { background: #fff8f0; border: 1px solid #e8c9a8; color: var(--accent-deep);
padding: 10px 14px; border-radius: 8px; font-size: 14px; margin-bottom: 16px; }
.nav { display: flex; justify-content: space-between; align-items: center; padding: 24px 0; }
.nav { display: flex; justify-content: space-between; align-items: center; padding: 22px 0; border-bottom: 1px solid var(--line-soft); }
.muted { color: var(--muted); }
.plan-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 16px; }
.plan { position: relative; }
.plan.rec { border-color: var(--accent); }
.plan .badge { position: absolute; top: -10px; right: 16px; background: var(--accent);
color: var(--accent-ink); font-size: 9px; padding: 3px 8px; border-radius: 6px; letter-spacing: 0.1em; }
.plan .price { font-size: 28px; margin: 8px 0; }
.plan ul { list-style: none; padding: 0; font-size: 12px; color: #555; }
.plan li { padding: 4px 0; border-bottom: 1px solid var(--line); }
.plan-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 18px; }
.plan { position: relative; display: flex; flex-direction: column; }
.plan.rec { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent), 0 8px 28px rgba(176,120,72,0.12); }
.plan .badge { position: absolute; top: -11px; right: 18px; background: var(--accent);
color: #fff; font-size: 10px; font-weight: 700; padding: 4px 10px; border-radius: 6px; letter-spacing: 0.06em; text-transform: uppercase; }
.plan .price { font-size: 32px; font-weight: 700; margin: 10px 0; letter-spacing: -0.02em; }
.plan ul { list-style: none; padding: 0; margin: 8px 0 0; font-size: 14px; color: var(--muted); flex: 1; }
.plan li { padding: 7px 0; border-bottom: 1px solid var(--line-soft); }
.plan li:last-child { border-bottom: none; }