@import url("https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&family=Manrope:wght@400;500;600;700;800&family=Playfair+Display:wght@600;700&display=swap");

:root {
  --ink: #111311;
  --muted: #677069;
  --line: #dfe3df;
  --paper: #f5f6f3;
  --white: #fff;
  --accent: #c9ff38;
  --accent-dark: #a9df10;
  --dark: #141714;
  --radius: 22px;
  font-family: "DM Sans", Arial, sans-serif;
  color: var(--ink);
  background: var(--paper);
}

[data-active-package="start"] [data-package-feature="pro"] { display: none !important; }

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--paper); color: var(--ink); }
a { color: inherit; }
button, input, select, textarea { font: inherit; }
img { max-width: 100%; }

.action-toast { position: fixed; z-index: 1300; top: 22px; right: 22px; display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 12px; width: min(440px, calc(100vw - 32px)); padding: 14px 14px 14px 16px; color: #20300c; background: #f7fce9; border: 1px solid #b6d868; border-radius: 8px; box-shadow: 0 16px 36px rgba(31, 48, 19, .18); animation: toast-in .24s ease-out; }
.action-toast-icon { display: grid; place-items: center; width: 24px; height: 24px; color: #173200; background: var(--accent); border-radius: 50%; font-size: 14px; font-weight: 800; }
.action-toast p { margin: 0; font-size: 14px; font-weight: 700; line-height: 1.35; }
.action-toast button { width: 30px; min-height: 30px; padding: 0; color: #4c5d32; background: transparent; border: 0; border-radius: 4px; font-size: 23px; font-weight: 400; }
.action-toast button:hover { color: var(--ink); background: #e7f1ca; transform: none; }
@keyframes toast-in { from { opacity: 0; transform: translateY(-10px); } to { opacity: 1; transform: translateY(0); } }

.global-back-button {
  position: fixed;
  z-index: 900;
  top: 96px;
  left: 20px;
  min-height: 42px;
  padding: 0 15px;
  color: var(--ink);
  background: rgba(255,255,255,.94);
  border: 1px solid #d5dad5;
  box-shadow: 0 8px 28px rgba(20,30,20,.12);
  backdrop-filter: blur(12px);
}
.global-back-button span { font-size: 17px; }
.global-back-button:hover { background: var(--accent); border-color: var(--accent); }

.site-header {
  position: relative;
  z-index: 20;
  height: 86px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 30px;
  padding: 0 max(28px, calc((100vw - 1320px) / 2));
  background: rgba(17, 19, 17, .94);
  color: #fff;
}

.brand { display: inline-flex; align-items: center; gap: 11px; text-decoration: none; font: 800 17px/1 "Manrope"; letter-spacing: -.03em; }
.brand small { display: block; margin-top: 5px; color: #99a099; font: 600 9px/1 "DM Sans"; letter-spacing: .16em; text-transform: uppercase; }
.brand-mark { display: grid; place-items: center; width: 40px; height: 40px; border: 1px solid #5f655f; border-radius: 12px; color: var(--accent); font-size: 14px; letter-spacing: -.08em; }
.desktop-nav { display: flex; gap: clamp(18px, 2.5vw, 38px); }
.desktop-nav a { color: #c6cbc6; text-decoration: none; font-size: 13px; font-weight: 600; transition: .2s; }
.desktop-nav a:hover { color: var(--accent); }
.mobile-menu-toggle, .mobile-site-nav { display: none; }

.button, button {
  appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  min-height: 46px;
  padding: 0 20px;
  border: 1px solid var(--ink);
  border-radius: 999px;
  background: var(--ink);
  color: #fff;
  font-weight: 700;
  text-decoration: none;
  cursor: pointer;
  transition: transform .2s, background .2s, color .2s;
}
.button:hover, button:hover { transform: translateY(-2px); }
button:disabled, .button:disabled { cursor: wait; opacity: .7; transform: none; }
.button:focus-visible, button:focus-visible, a:focus-visible {
  outline: 3px solid rgba(76, 125, 255, .55);
  outline-offset: 3px;
}
.button-accent { border-color: var(--accent); background: var(--accent); color: var(--ink); }
.button-accent:hover { background: #ddff80; }
.button-dark { background: var(--dark); color: #fff; }
.button-large { min-height: 58px; padding: 0 28px; }
.button.ghost { background: transparent; color: var(--ink); border-color: #b7bdb7; }
.button.small { min-height: 38px; padding: 0 15px; font-size: 13px; }
.button-with-icon { justify-content: space-between; gap: 18px; padding: 6px 7px 6px 22px; }
.button-large.button-with-icon { min-height: 62px; padding-left: 27px; }
.button-icon {
  flex: 0 0 auto;
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  color: #fff;
  background: #151915;
  border-radius: 50%;
  font: 600 19px/1 "Manrope";
  transition: transform .22s ease, background .22s ease, color .22s ease;
}
.button-dark .button-icon { color: #172013; background: var(--accent); }
.button-with-icon:hover .button-icon { transform: translateX(3px); }
.header-cta.button-with-icon { gap: 12px; padding: 5px 6px 5px 17px; }
.header-cta .button-icon { width: 32px; height: 32px; font-size: 16px; }
.action-link {
  display: inline-flex;
  align-items: center;
  gap: 11px;
  width: fit-content;
  min-height: 40px;
  padding: 5px 6px 5px 13px;
  color: var(--ink);
  background: #f1f4ee;
  border: 1px solid #dce2d8;
  border-radius: 999px;
  text-decoration: none;
  transition: transform .2s ease, border-color .2s ease, background .2s ease;
}
.action-link i {
  display: grid;
  place-items: center;
  width: 27px;
  height: 27px;
  color: var(--ink);
  background: #eef1eb;
  border-radius: 50%;
  font: 700 14px/1 "Manrope";
  transition: transform .2s ease, background .2s ease;
}
.action-link:hover { background: #fff; border-color: #bfc9b9; transform: translateY(-2px); }
.action-link:hover i { background: var(--accent); transform: translateX(3px); }
.action-link-light i { color: #fff; background: rgba(255,255,255,.14); }
.action-link-light:hover i { color: var(--ink); }

.public-hero {
  position: relative;
  min-height: calc(100vh - 86px);
  display: flex;
  align-items: center;
  overflow: hidden;
  color: #fff;
  background: #1a1d1a url("/static/images/workshop-hero.webp") center/cover no-repeat;
}
.hero-shade { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(11,13,11,.98) 0%, rgba(11,13,11,.83) 44%, rgba(11,13,11,.2) 78%), linear-gradient(0deg, rgba(11,13,11,.55), transparent 50%); }
.hero-copy { position: relative; width: min(1320px, calc(100% - 56px)); margin: 0 auto; padding: 80px 0 54px; }
.hero-copy > * { max-width: 760px; }
.hero-proof { display: inline-flex; align-items: center; gap: 9px; width: auto; padding: 8px 13px; border: 1px solid #505550; border-radius: 999px; color: #d8ddd8; font-size: 12px; }
.live-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 0 5px rgba(201,255,56,.12); }
.kicker { margin: 34px 0 18px; color: var(--accent); text-transform: uppercase; letter-spacing: .2em; font-size: 11px; font-weight: 800; }
.kicker.dark { color: #4b554c; }
h1, h2, h3 { font-family: "Manrope"; }
.public-hero h1 { margin: 0; max-width: 850px; font-size: clamp(56px, 7.7vw, 118px); line-height: .88; letter-spacing: -.075em; }
h1 em, h2 em { color: var(--accent-dark); font-style: normal; }
.public-hero h1 em { color: var(--accent); }
.hero-copy > p:not(.kicker) { margin: 30px 0; max-width: 640px; color: #c4cac4; font-size: clamp(17px, 2vw, 21px); line-height: 1.6; }
.hero-actions { display: flex; align-items: center; gap: 30px; }
.text-link { color: #fff; text-decoration: none; border-bottom: 1px solid #727772; padding-bottom: 5px; font-weight: 700; font-size: 14px; }
.hero-stats { display: flex; gap: 55px; margin-top: 70px; }
.hero-stats div { display: flex; align-items: center; gap: 12px; }
.hero-stats strong { font: 700 28px "Manrope"; }
.hero-stats span { color: #9fa69f; font-size: 11px; line-height: 1.5; }

.trust-strip { display: flex; justify-content: center; align-items: center; gap: clamp(18px, 4vw, 62px); min-height: 70px; overflow: hidden; background: var(--accent); font-size: 11px; font-weight: 800; letter-spacing: .18em; white-space: nowrap; }
.trust-strip i { width: 5px; height: 5px; background: #111; border-radius: 50%; }
.section { padding: 120px max(28px, calc((100vw - 1320px) / 2)); }
.section-light { background: #f7f8f5; }
.section-dark { background: var(--dark); color: #fff; }
.section-heading { display: grid; grid-template-columns: 1.3fr .7fr; align-items: end; gap: 60px; margin-bottom: 65px; }
.section-heading h2, .process-intro h2, .about-copy h2, .contact-section h2 { margin: 0; font-size: clamp(46px, 6vw, 86px); line-height: .95; letter-spacing: -.06em; }
.section-heading > p { max-width: 500px; color: var(--muted); font-size: 16px; line-height: 1.8; }
.section-heading.inverted > p { color: #9ca39c; }

.service-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.service-card { position: relative; min-height: 420px; overflow: hidden; display: flex; flex-direction: column; justify-content: flex-end; background: #fff; border: 1px solid var(--line); border-radius: var(--radius); transition: transform .25s, box-shadow .25s; }
.service-card:hover { transform: translateY(-7px); box-shadow: 0 25px 60px rgba(20,30,20,.1); }
.service-photo { position: absolute; inset: 0 0 44%; background-size: cover; background-position: center; }
.photo-dent-removal { background-image: linear-gradient(180deg, transparent 42%, rgba(16,19,16,.55)), url("/static/images/service-dent-removal.webp"); background-position: center; }
.photo-scratch-paint { background-image: linear-gradient(180deg, transparent 42%, rgba(16,19,16,.55)), url("/static/images/service-scratch-paint.webp"); background-position: center; }
.photo-wheel-repair { background-image: linear-gradient(180deg, transparent 42%, rgba(16,19,16,.55)), url("/static/images/service-wheel-repair.webp"); background-position: center; }
.photo-plastic-repair { background-image: linear-gradient(180deg, transparent 42%, rgba(16,19,16,.55)), url("/static/images/service-plastic-repair.webp"); background-position: center; }
.photo-interior-repair { background-image: linear-gradient(180deg, transparent 42%, rgba(16,19,16,.55)), url("/static/images/service-interior-repair.webp"); background-position: center; }
.photo-leasing-return { background-image: linear-gradient(180deg, transparent 42%, rgba(16,19,16,.55)), url("/static/images/service-leasing-return.webp"); background-position: center; }
.service-featured { grid-column: span 2; }
.service-number { position: absolute; top: 18px; right: 18px; display: grid; place-items: center; width: 40px; height: 40px; background: rgba(255,255,255,.86); border-radius: 50%; font-size: 11px; font-weight: 800; backdrop-filter: blur(8px); }
.service-content { position: relative; padding: 28px; background: #fff; }
.service-content h3 { margin: 0 0 10px; font-size: 25px; letter-spacing: -.04em; }
.service-content p { color: var(--muted); line-height: 1.6; }
.service-content a { font-weight: 800; font-size: 13px; }
.service-visual { position: absolute; inset: 0 0 42%; display: grid; place-items: center; color: var(--accent); background: radial-gradient(circle at 50% 40%, #4b514b, #171a17 60%); font-size: 120px; }
.trim-visual { color: #fff; background: radial-gradient(circle, #575c57, #181a18 68%); }
.accent-card { background: var(--accent); }
.accent-card .service-content { background: var(--accent); padding-top: 100px; }
.mini-label { color: #465629 !important; text-transform: uppercase; letter-spacing: .14em; font-size: 10px; font-weight: 800; }

.compare-stage { position: relative; height: min(650px, 65vw); min-height: 420px; overflow: hidden; border-radius: 28px; background: #2c312c; }
.compare-after, .compare-before { position: absolute; inset: 0; background-position: center; background-size: cover; }
.compare-after { background-image: linear-gradient(0deg, rgba(0,0,0,.24), transparent 48%), url("/static/images/repair-after.webp"); }
.compare-before { width: 100%; clip-path: inset(0 48% 0 0); background-image: linear-gradient(0deg, rgba(0,0,0,.35), transparent 48%), url("/static/images/repair-before.webp"); will-change: clip-path; }
.compare-stage span { position: absolute; bottom: 22px; left: 22px; padding: 8px 12px; border-radius: 999px; background: rgba(15,17,15,.75); font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: .12em; }
.compare-after span { left: auto; right: 22px; }
.compare-stage input { position: absolute; inset: 0; z-index: 5; width: 100%; height: 100%; opacity: 0; cursor: ew-resize; }
.compare-line { position: absolute; z-index: 4; top: 0; bottom: 0; left: 52%; width: 2px; background: var(--accent); }
.compare-line b { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); display: grid; place-items: center; width: 52px; height: 52px; color: #111; background: var(--accent); border-radius: 50%; }
.industry-result-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.industry-result-grid article { min-height: 260px; padding: 30px; border: 1px solid rgba(255,255,255,.12); border-radius: 28px; background: linear-gradient(145deg, #202520, #151815); box-shadow: 0 24px 70px rgba(0,0,0,.22); }
.industry-result-grid span { display: inline-grid; place-items: center; width: 46px; height: 46px; margin-bottom: 52px; color: var(--ink); background: var(--accent); border-radius: 50%; font-size: 12px; font-weight: 900; }
.industry-result-grid h3 { margin: 0 0 12px; color: #fff; font-size: clamp(24px, 2.5vw, 34px); letter-spacing: -.05em; }
.industry-result-grid p { margin: 0; color: #cbd2c8; line-height: 1.65; }

.process-section { display: grid; grid-template-columns: .85fr 1.15fr; gap: 100px; background: var(--accent); }
.process-intro { position: sticky; top: 40px; align-self: start; }
.process-section h2 em { color: var(--ink); }
.process-intro > p:not(.kicker) { max-width: 460px; line-height: 1.7; }
.process-list { margin: 0; padding: 0; list-style: none; border-top: 1px solid rgba(17,19,17,.25); }
.process-list li { display: grid; grid-template-columns: 65px 1fr; gap: 24px; padding: 30px 0; border-bottom: 1px solid rgba(17,19,17,.25); }
.process-list b { font: 700 12px "Manrope"; }
.process-list h3 { margin: 0 0 8px; font-size: 25px; letter-spacing: -.03em; }
.process-list p { margin: 0; color: #46503d; line-height: 1.6; }

.testimonial-section { padding: 115px 28px; text-align: center; background: #ecefe9; }
.stars { color: #8bad16; letter-spacing: .22em; }
.testimonial-section blockquote { max-width: 960px; margin: 28px auto; font: 600 clamp(29px, 4vw, 52px)/1.25 "Manrope"; letter-spacing: -.045em; }
.testimonial-section > p:last-child { color: var(--muted); }
.about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 90px; align-items: center; }
.about-photo { position: relative; min-height: 650px; border-radius: 28px; background: linear-gradient(0deg, rgba(0,0,0,.35), transparent), url("/static/images/interior-care.webp") center/cover; }
.about-photo span { position: absolute; left: 24px; bottom: 24px; padding: 12px 16px; color: #111; background: var(--accent); border-radius: 999px; font-weight: 800; }
.about-copy > p:not(.kicker) { color: var(--muted); font-size: 17px; line-height: 1.8; }
.about-copy ul { padding: 0; list-style: none; }
.about-copy li { padding: 17px 0; border-bottom: 1px solid var(--line); font-weight: 700; }
.about-copy li::before { content: "✓"; margin-right: 12px; color: #7ca000; }
.contact-section { display: grid; grid-template-columns: 1.2fr .8fr; gap: 80px; padding: 110px max(28px, calc((100vw - 1320px) / 2)); color: #fff; background: var(--dark); }
.contact-section > div > p:not(.kicker) { color: #aab0aa; max-width: 600px; line-height: 1.7; }
.contact-card { padding: 34px; background: #232723; border: 1px solid #3d433d; border-radius: 24px; }
.contact-card h3 { font-size: 25px; }
.contact-card p { color: #aeb4ae; line-height: 1.7; }
.contact-card a { color: var(--accent); }
.contact-route-button {
  width: 100%;
  margin-top: 24px;
  color: #151915 !important;
  background: #fff;
  border-color: #fff;
  box-shadow: 0 10px 25px rgba(0,0,0,.14);
}
.contact-route-button:hover { background: var(--accent); border-color: var(--accent); }
.contact-route-button .button-icon { color: #fff; background: #151915; }
.site-footer { display: flex; align-items: center; justify-content: space-between; gap: 30px; padding: 38px max(28px, calc((100vw - 1320px) / 2)); color: #aeb3ae; background: #0e100e; border-top: 1px solid #2c302c; font-size: 12px; }
.site-footer nav { display: flex; gap: 25px; }

/* Anfrage-Wizard */
.form-header { background: #fff; color: var(--ink); border-bottom: 1px solid var(--line); }
.form-header .brand small { color: #747b74; }
.dark-link { color: var(--ink); }
.wizard-shell { min-height: calc(100vh - 86px); display: grid; grid-template-columns: .8fr 1.2fr; gap: 80px; padding: 70px max(28px, calc((100vw - 1220px) / 2)); background: #eef0eb; }
.wizard-intro { padding-top: 40px; }
.wizard-intro h1, .login-panel h1 { margin: 0; font: 700 clamp(45px, 5.5vw, 78px)/.95 "Manrope"; letter-spacing: -.06em; }
.wizard-intro > p:not(.kicker) { max-width: 470px; color: var(--muted); line-height: 1.7; }
.wizard-help { display: flex; align-items: center; gap: 14px; margin-top: 50px; color: var(--muted); font-size: 13px; }
.wizard-help > span { display: grid; place-items: center; width: 42px; height: 42px; border: 1px solid #bec4be; border-radius: 50%; font-weight: 800; }
.wizard-help a { color: var(--ink); font-weight: 800; }
.wizard-card { align-self: start; overflow: hidden; background: #fff; border-radius: 26px; box-shadow: 0 30px 90px rgba(24,35,24,.09); }
.wizard-top { display: flex; justify-content: space-between; padding: 22px 32px 16px; color: var(--muted); font-size: 12px; font-weight: 700; }
.wizard-top b { color: var(--ink); }
.progress-track { height: 3px; background: #e7eae7; }
.progress-track i { display: block; width: 20%; height: 100%; background: var(--accent-dark); transition: width .3s; }
.wizard-card form { margin: 0; padding: 0; border: 0; background: transparent; }
.wizard-error { margin: 20px 48px 0; padding: 13px 15px; color: #812720; background: #fff0ee; border: 1px solid #edc4c0; border-radius: 11px; font-size: 12px; font-weight: 700; line-height: 1.5; }
.wizard-step { display: none; min-height: 570px; padding: 42px 48px 30px; }
.wizard-step.active { display: block; animation: stepIn .28s ease; }
@keyframes stepIn { from { opacity: 0; transform: translateX(10px); } }
.step-kicker { color: #7ca000; text-transform: uppercase; letter-spacing: .16em; font-size: 10px; font-weight: 800; }
.wizard-step h2 { margin: 6px 0 8px; font-size: clamp(30px, 4vw, 46px); letter-spacing: -.05em; }
.wizard-step > p:not(.step-kicker) { margin: 0 0 30px; color: var(--muted); line-height: 1.6; }
.field-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
label { display: grid; gap: 8px; color: #3e463f; font-size: 12px; font-weight: 800; }
label.wide { grid-column: 1 / -1; }
.field-grid > .wide { grid-column: 1 / -1; }
.label-text { display: inline-flex; align-items: center; gap: 4px; }
.required-mark::after, .required-star { content: "*"; color: #a9382f; font-weight: 900; }
.required-star { font-size: .62em; vertical-align: top; }
input, select, textarea { width: 100%; padding: 14px 15px; color: var(--ink); background: #fafbf9; border: 1px solid #d4dad4; border-radius: 12px; outline: none; }
input:focus, select:focus, textarea:focus { border-color: #8daa28; box-shadow: 0 0 0 4px rgba(169,223,16,.12); }
textarea { resize: vertical; }
.voice-row { display: flex; align-items: center; gap: 12px; padding: 12px; background: #f4f6f1; border: 1px solid var(--line); border-radius: 14px; }
.voice-row span { color: var(--muted); font-size: 12px; font-weight: 700; }
.voice-row button:disabled { cursor: not-allowed; opacity: .55; transform: none; }

.dashboard-head-actions { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; }
.demo-sms-toggle { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.demo-sms-toggle small { color: var(--muted); font-size: 11px; font-weight: 800; }
.demo-sms-toggle a { color: var(--ink); font-size: 12px; font-weight: 800; text-decoration: none; }
.voice-test-shell { max-width: 960px; }
.voice-test-setup { margin: 0 0 20px; padding: 18px 20px; border: 1px solid #d9b86b; background: #fff8e8; border-radius: 16px; color: #5f471b; }
.voice-test-setup strong { display: block; margin-bottom: 6px; }
.voice-test-setup p { margin: 8px 0 0; line-height: 1.55; }
.voice-test-setup code { padding: 2px 5px; border-radius: 5px; background: rgba(255,255,255,.7); overflow-wrap: anywhere; }
.voice-test-panel { padding: 28px; border: 1px solid var(--line); border-radius: 20px; background: #fff; box-shadow: 0 18px 42px rgba(21, 32, 19, .08); }
.voice-test-status { display: flex; align-items: center; gap: 10px; font-weight: 800; }
.voice-test-status p { margin: 0; }
.status-dot { width: 11px; height: 11px; flex: 0 0 11px; border-radius: 99px; background: #9ba49a; }
.status-dot[data-state="connecting"] { background: #d69b18; animation: voice-test-pulse 1.2s ease-in-out infinite; }
.status-dot[data-state="active"] { background: #36a15b; }
.status-dot[data-state="error"] { background: #ca4545; }
.voice-test-actions { display: flex; flex-wrap: wrap; gap: 10px; margin: 22px 0; }
.voice-test-actions button:disabled { cursor: not-allowed; opacity: .48; filter: grayscale(1); }
.voice-test-keypad { display: grid; grid-template-columns: repeat(2, minmax(130px, 190px)); gap: 12px; margin: 18px 0; }
.voice-test-keypad[hidden], .voice-test-result[hidden] { display: none; }
.voice-test-keypad p { grid-column: 1 / -1; margin: 0; font-weight: 700; }
.voice-test-keypad button { display: flex; align-items: baseline; justify-content: center; gap: 8px; padding: 16px; border: 1px solid var(--line); border-radius: 14px; background: #f5f7f4; color: var(--ink); font-size: 24px; font-weight: 900; cursor: pointer; }
.voice-test-keypad button span { font-size: 13px; font-weight: 700; }
.voice-test-keypad button:hover { border-color: var(--ink); background: #ecf1e9; }
.voice-test-result { display: flex; flex-wrap: wrap; gap: 10px 18px; align-items: center; margin-top: 20px; padding: 15px; border-radius: 14px; background: #edf6eb; color: #174f2a; }
.voice-test-result a { color: inherit; font-weight: 800; }
.voice-test-result span { font-size: 14px; }
.voice-test-note { margin: 20px 0 0; color: var(--muted); font-size: 13px; line-height: 1.5; }
@keyframes voice-test-pulse { 50% { opacity: .35; } }
.availability-choice { margin: 0 0 16px; padding: 0; border: 0; }
.availability-choice legend { margin-bottom: 10px; color: #3e463f; font-size: 12px; font-weight: 800; }
.availability-modes { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.availability-modes label { position: relative; display: block; cursor: pointer; }
.availability-modes input { position: absolute; width: 1px; height: 1px; margin: 0; padding: 0; opacity: 0; pointer-events: none; }
.availability-modes span { display: grid; min-height: 48px; place-items: center; padding: 8px; color: #586158; background: #fafbf9; border: 1px solid #d4dad4; border-radius: 8px; font-size: 12px; font-weight: 800; text-align: center; }
.availability-modes input:checked + span { color: #344800; background: #f2f9dd; border-color: #86a91f; box-shadow: inset 0 0 0 1px #86a91f; }
.availability-panel { margin-bottom: 16px; padding: 15px; background: #f4f7ee; border: 1px solid #dce5c4; border-radius: 8px; }
.availability-panel > p { margin: 0; color: #5e6657; font-size: 12px; line-height: 1.55; }
.availability-picker { position: relative; }
.date-picker-trigger { width: 100%; justify-content: space-between; color: var(--ink); background: #fff; border-color: #b9c6a0; border-radius: 8px; }
.date-picker-trigger::after { content: "⌄"; color: #66734b; font-size: 18px; }
.date-picker-popover { position: absolute; z-index: 30; top: calc(100% + 8px); left: 0; width: min(390px, calc(100vw - 72px)); padding: 14px; background: #fff; border: 1px solid #cbd6b4; border-radius: 8px; box-shadow: 0 18px 45px rgba(26,36,20,.18); }
.date-picker-head { display: grid; grid-template-columns: 42px 1fr 42px; align-items: center; gap: 8px; margin-bottom: 12px; }
.date-picker-head strong { text-align: center; font-size: 14px; }
.date-picker-weekdays, .date-picker-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 3px; }
.date-picker-weekdays { margin-bottom: 5px; }
.date-picker-weekdays span { padding: 5px 0; color: var(--muted); font-size: 10px; font-weight: 800; text-align: center; }
.date-picker-day { min-height: 38px; padding: 0; color: var(--ink); background: transparent; border: 0; border-radius: 4px; font-size: 12px; }
.date-picker-day:hover { color: var(--ink); background: #edf5d6; transform: none; }
.date-picker-day.outside { color: #a4ada4; }
.date-picker-day.selected { color: #243400; background: #e0f7a0; border-radius: 0; }
.date-picker-day.range-start, .date-picker-day.range-end { color: #172600; background: var(--accent); border-radius: 50%; }
.date-picker-actions { display: flex; justify-content: flex-end; margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--line); }
.icon-button { width: 42px; min-height: 42px; padding: 0; color: #6d3934; background: #fff; border-color: #dfc5c2; border-radius: 8px; font-size: 23px; font-weight: 400; }
.icon-button:hover { color: #fff; background: #b83e35; border-color: #b83e35; transform: none; }
.availability-time { margin-top: 5px; }
.availability-time small { color: var(--muted); font-weight: 500; }
.choice-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-bottom: 25px; }
.choice-grid label input { position: absolute; width: 1px; height: 1px; margin: 0; padding: 0; opacity: 0; pointer-events: none; }
.choice-grid label span { min-height: 100px; display: grid; place-items: center; align-content: center; gap: 8px; border: 1px solid #d6dbd6; border-radius: 15px; background: #fbfcfa; font-size: 24px; cursor: pointer; }
.choice-grid label b { font-size: 12px; }
.choice-grid input:checked + span { border-color: #86a91f; background: #f2f9dd; box-shadow: inset 0 0 0 1px #86a91f; }
.insurance-choice { margin: 5px 0 0; padding: 0; border: 0; }
.insurance-choice legend { margin-bottom: 10px; color: #3e463f; font-size: 12px; font-weight: 800; }
.payment-choices { margin: 0; }
.payment-choices label span { min-height: 92px; padding: 12px; text-align: center; }
.payment-choices label small { color: var(--muted); font-size: 10px; font-weight: 500; }
.insurance-fields { padding: 18px; background: #f4f7ee; border: 1px solid #dce5c4; border-radius: 15px; }
.insurance-note { margin: 0 0 16px; color: #5e6657; font-size: 12px; line-height: 1.6; }
.insurance-upload { margin-top: 20px; padding: 18px; background: #f4f7ee; border-radius: 15px; }
.insurance-upload h3 { margin: 0; }
.insurance-upload p { color: var(--muted); font-size: 12px; }
.vehicle-registration-upload, .vehicle-profile-pro { display: grid; gap: 14px; margin-top: 20px; padding: 18px; background: #f3f8e4; border: 1px solid #d3e3a5; border-radius: 15px; }
.vehicle-profile-pro { grid-template-columns: 1fr; }
.vehicle-registration-upload.required { background: #fff8e8; border-color: #e7c36f; }
.vehicle-registration-upload h3, .vehicle-profile-pro h3 { margin: 7px 0 5px; font-size: 18px; }
.vehicle-registration-upload p, .vehicle-profile-pro p { margin: 0; color: var(--muted); font-size: 12px; line-height: 1.5; }
.pro-reminder-check {
  position: relative;
  display: grid !important;
  grid-template-columns: auto 1fr;
  gap: 10px;
  align-items: center;
  align-self: end;
  min-height: 52px;
  padding: 11px 14px;
  background: #fff;
  border: 1px solid #dfe9c4;
  border-radius: 12px;
  cursor: pointer;
}
.pro-reminder-check input {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: 0;
  padding: 0;
  opacity: 0;
  pointer-events: none;
}
.pro-reminder-check::before {
  content: "";
  width: 42px;
  height: 24px;
  background: #c5cec2;
  border-radius: 999px;
  box-shadow: inset 0 0 0 1px rgba(18,30,16,.08);
}
.pro-reminder-check::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 18px;
  width: 18px;
  height: 18px;
  background: #fff;
  border-radius: 50%;
  box-shadow: 0 2px 6px rgba(20,30,18,.2);
  transform: translateY(-50%);
  transition: left .18s ease;
}
.pro-reminder-check:has(input:checked)::before { background: #82a718; }
.pro-reminder-check:has(input:checked)::after { left: 36px; }
.pro-reminder-check span { color: #243022; font-size: 12px; line-height: 1.25; }
.document-upload { display: inline-flex; width: auto; cursor: pointer; }
.document-upload input { position: absolute; opacity: 0; width: 1px; }
.document-upload span { padding: 12px 16px; color: #fff; background: var(--dark); border-radius: 999px; }
.account-offer { margin: 8px 0 4px; padding: 20px; border: 1px solid #c7d5a4; border-radius: 16px; background: linear-gradient(135deg, #f8fbea, #f0f7dd); }
.account-offer-head { display: flex; justify-content: space-between; gap: 18px; align-items: start; margin-bottom: 15px; }
.account-offer-head h3 { margin: 7px 0 5px; font-size: 20px; letter-spacing: -.035em; }
.account-offer-head p { max-width: 520px; margin: 0; color: var(--muted); font-size: 12px; line-height: 1.5; }
.account-offer-head a { flex: none; color: #526d0d; font-size: 11px; font-weight: 800; }
.recommended-badge {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 0 10px;
  color: #fff;
  background: #2f668f;
  border-radius: 999px;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: 10px;
  font-weight: 900;
  line-height: 1;
}
.account-benefits { display: flex; flex-wrap: wrap; gap: 7px; margin-bottom: 16px; }
.account-benefits span { padding: 7px 9px; color: #526044; background: rgba(255,255,255,.75); border-radius: 999px; font-size: 10px; font-weight: 700; }
.account-toggle { display: grid; grid-template-columns: auto 1fr; gap: 13px; cursor: pointer; }
.account-toggle input { position: absolute; width: 1px; height: 1px; margin: 0; padding: 0; opacity: 0; }
.account-toggle > span { position: relative; width: 45px; height: 25px; background: #bdc4bd; border-radius: 999px; }
.account-toggle > span::after { content: ""; position: absolute; top: 3px; left: 3px; width: 19px; height: 19px; background: #fff; border-radius: 50%; transition: .2s; }
.account-toggle input:checked + span { background: #82a718; }
.account-toggle input:checked + span::after { left: 23px; }
.account-toggle strong, .account-toggle small { display: block; }
.account-toggle small { margin-top: 4px; color: var(--muted); font-weight: 500; line-height: 1.45; }
.account-password-fields { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 18px; padding-top: 18px; border-top: 1px solid #d8dfc8; }
.account-password-fields p { grid-column: 1 / -1; margin: 0; color: var(--muted); font-size: 11px; }
.account-connected { display: flex; gap: 12px; margin: 20px 0; padding: 16px; background: #f1f8de; border-radius: 14px; }
.account-connected > span { display: grid; place-items: center; width: 32px; height: 32px; color: #fff; background: #789b18; border-radius: 50%; }
.account-connected p { margin: 4px 0 0; color: var(--muted); font-size: 12px; }
.form-divider { position: relative; margin: 7px 0 0; text-align: center; }
.form-divider::before { content: ""; position: absolute; top: 50%; right: 0; left: 0; height: 1px; background: var(--line); }
.form-divider span { position: relative; padding: 0 12px; color: #758075; background: #fff; text-transform: uppercase; letter-spacing: .14em; font-size: 9px; font-weight: 800; }
.upload-zone { min-height: 260px; place-items: center; align-content: center; border: 1px dashed #aeb7ae; border-radius: 18px; background: #f8faf6; cursor: pointer; }
.upload-zone input { position: absolute; opacity: 0; width: 1px; }
.upload-zone small { color: var(--muted); font-weight: 500; }
.upload-icon { display: grid; place-items: center; width: 52px; height: 52px; border-radius: 50%; background: var(--accent); font-size: 25px; }
.photo-preview { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; margin-top: 12px; }
.photo-preview div { height: 80px; border-radius: 10px; background-size: cover; background-position: center; }
.photo-tips { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 22px; color: var(--muted); font-size: 11px; }
.photo-tips strong { width: 100%; color: var(--ink); }
.photo-tips span { padding: 7px 10px; background: #eef1ec; border-radius: 999px; }
.toggle-row { grid-template-columns: auto auto 1fr; align-items: center; gap: 12px; margin-top: 25px; cursor: pointer; }
.toggle-row input { position: absolute; width: 1px; height: 1px; margin: 0; padding: 0; opacity: 0; }
.toggle-row span { position: relative; width: 44px; height: 24px; border-radius: 99px; background: #ccd2cc; }
.toggle-row span::after { content: ""; position: absolute; top: 3px; left: 3px; width: 18px; height: 18px; background: #fff; border-radius: 50%; transition: .2s; }
.toggle-row input:checked + span { background: #83a91b; }
.toggle-row input:checked + span::after { left: 23px; }
.summary-card { overflow: hidden; padding: 5px 22px; border: 1px solid #e4e8e2; border-radius: 18px; background: #f7f8f5; }
.summary-card dl { display: block; margin: 0; }
.summary-row { display: grid; grid-template-columns: minmax(118px, .72fr) minmax(0, 1.28fr); gap: 24px; padding: 16px 0; border-bottom: 1px solid #e1e5df; }
.summary-row:last-child { border-bottom: 0; }
.summary-card dt { color: #747d75; font-size: 12px; font-weight: 700; }
.summary-card dd { min-width: 0; margin: 0; overflow-wrap: anywhere; color: #171a17; font-size: 14px; font-weight: 750; line-height: 1.45; }
.check { font-weight: 500; }
.consent-field { margin-top: 22px; padding: 15px 16px; border: 1px solid #e2e6df; border-radius: 14px; background: #fbfcfa; }
.consent-check { position: relative; display: block; margin: 0; padding-left: 34px; line-height: 1.55; cursor: pointer; }
.consent-check input[type="checkbox"] { position: absolute; width: 1px; height: 1px; margin: 0; padding: 0; opacity: 0; pointer-events: none; }
.consent-check > span::before { content: ""; position: absolute; top: 0; left: 0; width: 20px; height: 20px; border: 1.5px solid #aeb6ae; border-radius: 6px; background: #fff; transition: border-color .18s, background .18s, box-shadow .18s; }
.consent-check > span::after { content: ""; position: absolute; top: 4px; left: 7px; width: 5px; height: 9px; border: solid #142000; border-width: 0 2px 2px 0; opacity: 0; transform: rotate(45deg) scale(.7); transition: opacity .18s, transform .18s; }
.consent-check input:checked + span::before { border-color: #9ccd12; background: var(--accent); }
.consent-check input:checked + span::after { opacity: 1; transform: rotate(45deg) scale(1); }
.consent-check input:focus-visible + span::before { box-shadow: 0 0 0 4px rgba(169,223,16,.2); }
.consent-check .required-mark { display: inline; }
.consent-error { margin: 10px 0 0 34px; color: #9b2c2c; font-size: 12px; font-weight: 800; line-height: 1.45; }
.consent-field.field-invalid { background: #fff5f3; border-color: #d86960; box-shadow: 0 0 0 3px rgba(216, 105, 96, .12); }
.field-invalid input:not([type="checkbox"]), .field-invalid select, .field-invalid textarea { border-color: #c64d43; box-shadow: 0 0 0 4px rgba(198, 77, 67, .1); }
.wizard-actions { display: grid; grid-template-columns: auto minmax(170px, 1fr); justify-content: end; gap: 14px; padding: 20px 48px 24px; border-top: 1px solid var(--line); background: #fbfcfa; }
.wizard-back { visibility: hidden; }
.wizard-submit { display: none; }
.wizard-actions .wizard-back { min-height: 48px; padding: 0 4px; color: #505850; background: transparent; border: 0; border-radius: 0; font-size: 13px; font-weight: 700; }
.wizard-actions .wizard-back:hover { color: var(--ink); background: transparent; transform: translateX(-2px); }
.wizard-actions .wizard-next, .wizard-actions .wizard-submit { min-height: 50px; width: 100%; border-radius: 12px; box-shadow: 0 8px 20px rgba(77, 104, 12, .12); }
.wizard-actions .wizard-submit { align-items: center; justify-content: space-between; padding: 0 8px 0 20px; color: #132000; background: var(--accent); border: 1px solid #b5ea25; font-size: 14px; font-weight: 800; }
.wizard-actions .wizard-submit:hover { background: #d7ff69; border-color: #c4f33e; }
.submit-arrow { display: grid; place-items: center; width: 34px; height: 34px; color: #fff; background: #182018; border-radius: 9px; font-size: 17px; transition: transform .18s; }
.wizard-submit:hover .submit-arrow { transform: translateX(2px); }

/* Dashboard */
.dashboard-nav { height: 76px; display: flex; align-items: center; justify-content: space-between; gap: 25px; padding: 0 max(24px, calc((100vw - 1240px) / 2)); color: #fff; background: var(--dark); }
.dashboard-nav nav { display: flex; align-self: stretch; gap: 28px; }
.dashboard-nav nav a { display: flex; align-items: center; color: #aeb5ae; text-decoration: none; font-size: 13px; font-weight: 700; border-bottom: 2px solid transparent; }
.dashboard-nav nav a.active { color: #fff; border-color: var(--accent); }
.dashboard-nav .ghost { color: #fff; border-color: #555c55; }
.public-preview-switch { position: sticky; top: 0; z-index: 20; display: flex; justify-content: center; gap: 14px; flex-wrap: wrap; padding: 10px 18px; color: #d6ded3; background: #171b17; border-bottom: 1px solid #303830; }
.public-preview-switch > div, .industry-preview-panel > div { display: flex; align-items: center; gap: 5px; flex-wrap: wrap; }
.public-preview-switch span, .industry-preview-panel span { margin-right: 5px; color: #9ea79e; font-size: 10px; font-weight: 850; letter-spacing: .12em; text-transform: uppercase; }
.public-preview-switch a, .industry-preview-panel button { min-height: 30px; padding: 0 11px; color: #c7cec7; background: #2a302a; border: 1px solid #3d463d; border-radius: 999px; font-size: 11px; font-weight: 800; text-decoration: none; }
.public-preview-switch a.active, .industry-preview-panel button.active { color: #172013; background: var(--accent); border-color: var(--accent); }
.package-preview-switch { display: flex; align-items: center; gap: 9px; margin-left: auto; color: #aeb5ae; font-size: 10px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }
.package-preview-switch > div { display: flex; gap: 3px; padding: 3px; background: #333a33; border-radius: 999px; }
.package-preview-switch button { min-height: 28px; padding: 0 10px; color: #c5cbc5; background: transparent; border: 0; border-radius: 999px; font-size: 10px; font-weight: 800; letter-spacing: .02em; }
.package-preview-switch button.active { color: #172013; background: var(--accent); }
.package-preview-upgrade, .package-preview-locked { display: flex; align-items: center; justify-content: space-between; gap: 20px; margin: 0 0 20px; padding: 18px 20px; background: #f3f8e4; border: 1px solid #c9db94; border-radius: 16px; }
.package-preview-summary { margin: -8px 0 20px; padding: 18px 20px; color: #e8eee4; background: #202620; border-radius: 16px; }
.package-preview-summary div { display: grid; gap: 4px; }
.package-preview-summary span { color: var(--accent); font-size: 10px; font-weight: 800; letter-spacing: .13em; text-transform: uppercase; }
.package-preview-summary strong { font: 700 20px "Manrope"; }
.package-preview-summary p { margin: 0; color: #bdc7bb; font-size: 13px; line-height: 1.55; }
.package-preview-upgrade div { display: grid; gap: 3px; }
.package-preview-upgrade span, .package-preview-locked > span { color: #6e8d14; font-size: 9px; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; }
.package-preview-upgrade strong, .package-preview-locked strong { font: 700 17px "Manrope"; }
.package-preview-upgrade p { margin: 0; color: #596254; font-size: 12px; line-height: 1.5; }
.package-preview-upgrade button, .package-preview-locked button { flex: 0 0 auto; min-height: 40px; padding: 0 14px; color: #172013; background: var(--accent); border-color: var(--accent); font-size: 12px; }
.package-preview-locked { display: grid; grid-template-columns: auto 1fr auto; margin-bottom: 26px; }
.package-preview-start .dashboard-stats { grid-template-columns: repeat(2, 1fr); }
.package-preview-start [data-package-page="pro"] .calendar-tool,
.package-preview-start [data-package-page="pro"] .notification-list { opacity: .24; pointer-events: none; filter: grayscale(1); }
.shell, .form-shell { width: min(1180px, calc(100% - 40px)); margin: 0 auto; padding: 45px 0 80px; }
.shell > .top { display: flex; justify-content: space-between; align-items: center; gap: 22px; margin-bottom: 30px; }
.shell h1, .form-shell > h1 { margin: 0; font: 700 clamp(42px, 6vw, 72px)/1 "Manrope"; letter-spacing: -.06em; }
.top .eyebrow { margin: 0 0 6px; color: #78941f; text-transform: uppercase; font-size: 10px; font-weight: 800; letter-spacing: .16em; }
.actions { display: flex; gap: 9px; flex-wrap: wrap; }
.requests { display: grid; gap: 14px; }
.request-pagination { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-top: 20px; padding: 14px 4px; color: var(--muted); font-size: 12px; }
.request-pagination > a + a { margin-left: 6px; }
.dashboard-head { display: flex; justify-content: space-between; align-items: end; gap: 30px; margin-bottom: 30px; }
.dashboard-head p:last-child { color: var(--muted); }
.dashboard-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-bottom: 20px; }
.dashboard-stats article { padding: 20px; background: #fff; border: 1px solid var(--line); border-radius: 16px; }
.dashboard-stats span, .dashboard-stats small { display: block; color: var(--muted); }
.dashboard-stats strong { display: block; margin: 8px 0 2px; font: 700 34px "Manrope"; }
.monthly-stats { grid-template-columns: repeat(5, 1fr); }
.monthly-stats strong { font-size: 28px; }
.monthly-damages { margin-top: 16px; }
.monthly-damages ul { display: grid; gap: 8px; margin: 16px 0 0; padding: 0; list-style: none; }
.monthly-damages li { border-bottom: 1px solid var(--line); }
.monthly-damages li:last-child { border-bottom: 0; }
.monthly-damage-item summary { display: grid; grid-template-columns: 1fr auto auto; align-items: center; gap: 16px; padding: 14px 2px; cursor: pointer; list-style: none; }
.monthly-damage-item summary::-webkit-details-marker { display: none; }
.monthly-damage-item summary > span { font-weight: 800; }
.monthly-damage-item summary > strong { display: grid; place-items: center; min-width: 28px; height: 28px; color: #405317; background: #edf7d2; border-radius: 50%; font-size: 12px; }
.monthly-damage-item summary > small { color: var(--muted); font-size: 11px; font-weight: 700; }
.monthly-damage-item[open] summary { color: #405317; }
.monthly-damage-requests { display: grid; gap: 7px; padding: 0 0 15px; }
.monthly-damage-requests > a { display: grid; grid-template-columns: minmax(0, 1fr) auto auto; align-items: center; gap: 12px; padding: 11px 13px; color: var(--ink); background: #f7f9f5; border: 1px solid #e2e8db; border-radius: 10px; text-decoration: none; }
.monthly-damage-requests > a:hover { border-color: #b5d463; background: #f0f8dd; }
.monthly-damage-requests strong, .monthly-damage-requests small { display: block; }
.monthly-damage-requests small, .monthly-damage-requests time { color: var(--muted); font-size: 11px; }
.monthly-damage-requests em { padding: 4px 7px; color: #526f0c; background: #edf7d2; border-radius: 999px; font-size: 10px; font-style: normal; font-weight: 800; white-space: nowrap; }
.settings-metrics { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin: 0 0 18px; }
.settings-metrics article { padding: 20px; color: #edf1ec; background: #202620; border-radius: 16px; }
.settings-metrics span, .settings-metrics small { display: block; color: #bdc7bb; font-size: 12px; }
.package-sms-info { display: grid; align-content: center; gap: 5px; min-height: 76px; padding: 15px 16px; background: #f3f7ed; border: 1px solid #dbe6ce; border-radius: 12px; }
.package-sms-info span, .package-sms-info small { color: var(--muted); font-size: 12px; }
.package-sms-info strong { font: 800 20px "Manrope"; letter-spacing: -.03em; }
.settings-metrics strong { display: block; margin: 8px 0 3px; color: var(--accent); font: 700 28px "Manrope"; }
.workshop-settings-form { display: grid; gap: 16px; }
.workshop-settings-form > .button { justify-self: start; }
.package-choice-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin: 16px 0; }
.package-choice { display: grid; grid-template-columns: auto 1fr; gap: 12px; align-items: start; padding: 17px; border: 1px solid var(--line); border-radius: 14px; cursor: pointer; }
.package-choice:has(input:checked) { border-color: #9fc932; background: #f5fbe5; box-shadow: inset 0 0 0 1px #d4eaa1; }
.package-choice input { width: 18px; margin-top: 3px; }
.package-choice span { display: grid; gap: 5px; }
.package-choice strong { font: 700 18px "Manrope"; }
.package-choice small { color: var(--muted); line-height: 1.45; }
.settings-usage { margin-top: 4px; }
.design-studio { overflow: hidden; padding: 26px; }
.design-studio-title { gap: 24px; margin-bottom: 22px; }
.design-studio-title h2 { margin: 3px 0 7px; font-size: clamp(25px, 3vw, 38px); letter-spacing: -.045em; }
.design-studio-title p:last-child { max-width: 620px; margin: 0; color: var(--muted); font-size: 13px; line-height: 1.55; }
.design-choice-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.business-type-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-top: 16px; }
.business-type-choice { display: grid; grid-template-columns: auto 1fr; gap: 12px; align-items: start; padding: 16px; border: 1px solid var(--line); border-radius: 14px; cursor: pointer; }
.business-type-choice:has(input:checked), .business-type-choice.selected { border-color: #9fc932; background: #f5fbe5; box-shadow: inset 0 0 0 1px #d4eaa1; }
.business-type-choice input { width: 18px; margin-top: 3px; }
.business-type-choice span { display: grid; gap: 4px; }
.business-type-choice strong { font: 750 16px "Manrope"; }
.business-type-choice small { color: var(--muted); line-height: 1.4; }
.industry-preview-panel { display: grid; gap: 10px; margin: 18px 0 0; padding: 13px; background: #171b17; border-radius: 13px; }
.design-choice { position: relative; display: block; overflow: hidden; padding: 0; background: #fff; border: 1px solid var(--line); border-radius: 18px; cursor: pointer; transition: border-color .2s, box-shadow .2s, transform .2s; }
.design-choice:hover { transform: translateY(-3px); box-shadow: 0 14px 35px rgba(23,32,23,.08); }
.design-choice:has(input:checked) { border-color: #151915; box-shadow: 0 0 0 2px #151915, 0 16px 38px rgba(23,32,23,.12); }
.design-choice input { position: absolute; width: 1px; height: 1px; opacity: 0; pointer-events: none; }
.design-choice-visual { position: relative; display: block; height: 112px; overflow: hidden; background: #181c18; }
.design-choice-visual::before { content: ""; position: absolute; inset: 0; opacity: .65; background: linear-gradient(120deg, transparent 45%, rgba(255,255,255,.16)); }
.design-choice-visual i { position: absolute; top: 16px; left: 16px; width: 48%; height: 8px; background: #c9ff38; border-radius: 999px; }
.design-choice-visual b { position: absolute; top: 38px; left: 16px; width: 67%; height: 34px; border-top: 7px solid #fff; border-bottom: 7px solid #fff; opacity: .95; }
.design-choice-visual em { position: absolute; right: 14px; bottom: 12px; width: 60px; height: 22px; background: #c9ff38; border-radius: 999px; }
.design-choice-copy { display: grid; gap: 7px; padding: 16px; }
.design-choice-copy strong { font: 700 16px "Manrope"; }
.design-choice-copy small { min-height: 48px; color: var(--muted); font-weight: 500; line-height: 1.45; }
.design-palette { display: flex; gap: 5px; margin-top: 2px; }
.design-palette i { width: 17px; height: 17px; border: 1px solid rgba(0,0,0,.08); border-radius: 50%; }
.design-choice-performance .design-palette i:nth-child(1) { background: #141714; }
.design-choice-performance .design-palette i:nth-child(2) { background: #c9ff38; }
.design-choice-performance .design-palette i:nth-child(3) { background: #f5f6f3; }
.design-choice-atelier .design-choice-visual { background: #252b2e; }
.design-choice-atelier .design-choice-visual i, .design-choice-atelier .design-choice-visual em { background: #c9bca9; }
.design-choice-atelier .design-choice-visual b { width: 54%; border-color: #f2eee8; border-width: 5px; }
.design-choice-atelier .design-choice-visual em { border-radius: 3px; }
.design-choice-atelier .design-palette i:nth-child(1) { background: #252b2e; }
.design-choice-atelier .design-palette i:nth-child(2) { background: #c9bca9; }
.design-choice-atelier .design-palette i:nth-child(3) { background: #f2eee8; }
.design-choice-clarity .design-choice-visual { background: #edf2f6; }
.design-choice-clarity .design-choice-visual i, .design-choice-clarity .design-choice-visual em { background: #315f86; }
.design-choice-clarity .design-choice-visual b { border-color: #172b3b; }
.design-choice-clarity .design-choice-visual em { background: #7894aa; border-radius: 8px; }
.design-choice-clarity .design-palette i:nth-child(1) { background: #f6f8fa; }
.design-choice-clarity .design-palette i:nth-child(2) { background: #315f86; }
.design-choice-clarity .design-palette i:nth-child(3) { background: #172b3b; }
.design-preview-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 15px; margin-top: 24px; padding: 10px 12px; color: #cbd2cb; background: #171b17; border-radius: 13px 13px 0 0; }
.design-preview-toolbar > div { display: flex; gap: 4px; }
.design-preview-toolbar button { min-height: 30px; padding: 0 11px; color: #aab1aa; background: transparent; border: 0; border-radius: 7px; font-size: 11px; }
.design-preview-toolbar button.active { color: #172013; background: var(--accent); }
.design-preview-toolbar span { font-size: 10px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }
.design-preview-frame { display: grid; place-items: start center; min-height: 510px; padding: 18px; overflow: hidden; background: #dfe4df; border-radius: 0 0 13px 13px; }
.design-preview-frame iframe { width: 100%; height: 490px; background: #fff; border: 0; border-radius: 8px; box-shadow: 0 12px 36px rgba(18,27,18,.18); transition: width .3s ease; }
.design-preview-frame.mobile iframe { width: 390px; max-width: 100%; }
.dashboard-tools { display: grid; grid-template-columns: 1fr 230px; gap: 10px; margin: 20px 0; }
.search-field { display: grid; grid-template-columns: auto 1fr; align-items: center; gap: 10px; padding: 0 14px; background: #fff; border: 1px solid var(--line); border-radius: 12px; font-size: 20px; }
.search-field input { padding-left: 0; border: 0; background: transparent; box-shadow: none; }
.request, .panel, .appointment-card, .calendar-entry { padding: 22px; background: #fff; border: 1px solid var(--line); border-radius: 18px; }
.dashboard-request { display: grid; grid-template-columns: 190px 1fr; gap: 22px; padding: 12px; }
.request-thumb { width: 100%; height: 100%; min-height: 230px; object-fit: cover; border-radius: 13px; background: #232723; }
.request-thumb.placeholder { display: grid; place-items: center; color: var(--accent); font: 700 32px "Manrope"; }
.request-main { padding: 10px 10px 10px 0; }
.request-actions { align-items: center; }
.customer-reaction-badge { display: inline-flex; box-sizing: border-box; width: fit-content; height: 38px; align-items: center; gap: 8px; padding: 0 15px; color: #7a2d24; background: #fff0ed; border: 1px solid #efc8c1; border-radius: 999px; font-size: 13px; font-weight: 900; letter-spacing: .01em; white-space: nowrap; }
.customer-reaction-badge::before { content: "!"; display: grid; place-items: center; width: 18px; height: 18px; color: #fff; background: #d8594b; border-radius: 50%; font: 800 11px "Manrope"; }
.request-id { margin: 0 0 3px !important; color: #819b2c !important; font-size: 9px; font-weight: 800; letter-spacing: .14em; }
.request-head strong { font: 700 23px "Manrope"; }
.request-meta { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin: 18px 0; }
.request-meta p { margin: 0; padding: 12px; background: #f5f7f3; border-radius: 10px; font-size: 12px; }
.request-meta span { margin: 0 0 6px; text-transform: uppercase; letter-spacing: .12em; font-size: 8px; font-weight: 800; }
.empty-state { padding: 80px 20px; text-align: center; background: #fff; border-radius: 20px; }
.request-head { display: flex; align-items: center; justify-content: space-between; gap: 15px; }
.request span { display: block; margin-top: 5px; color: var(--muted); font-size: 12px; }
.request p { margin: 10px 0; color: #4d554e; }
.status, .status-large { display: inline-flex !important; width: fit-content; padding: 7px 11px; color: #44600d !important; background: #eff9d5; border-radius: 999px; font-weight: 800; }
.request-head .status { align-self: center; margin-top: 0; }
.status-large { margin: 20px 0; padding: 11px 15px; }
.links { display: flex; gap: 10px; }
.detail-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.detail-grid > .panel:only-child { grid-column: 1 / -1; }
.detail-shell > .panel { margin-top: 16px; }
.panel-kicker { margin: 0 0 5px; color: #7e9f1f; text-transform: uppercase; letter-spacing: .14em; font-size: 9px; font-weight: 800; }
.panel-title { display: flex; justify-content: space-between; align-items: center; }
.panel-title span { color: var(--muted); font-size: 12px; }
.workflow-panel { display: grid; grid-template-columns: 176px minmax(0, 1fr) auto; align-items: center; gap: 28px; margin-top: 16px; padding: 22px 24px; color: #fff; background: #1b1f1b; border: 1px solid #1b1f1b; border-radius: 18px; }
.workflow-current { display: grid; gap: 7px; padding-right: 24px; border-right: 1px solid rgba(255,255,255,.18); }
.workflow-current span, .workflow-copy > p { margin: 0; color: #b7c891; font-size: 9px; font-weight: 800; letter-spacing: .14em; }
.workflow-current strong { color: var(--accent); font: 700 17px/1.15 "Manrope"; letter-spacing: -.03em; }
.workflow-copy { display: grid; gap: 5px; }
.workflow-copy h2 { margin: 0; color: #fff; font: 700 23px/1.15 "Manrope"; letter-spacing: -.04em; }
.workflow-copy > span { color: #bbc2ba; font-size: 13px; line-height: 1.55; }
.workflow-action { margin: 0; }
.workflow-action button { min-height: 46px; padding: 0 18px; color: #141914; background: var(--accent); border-color: var(--accent); white-space: nowrap; }
.workflow-action button:hover { color: #141914; background: #ddff72; border-color: #ddff72; }
.design-atelier .workflow-panel { color: #24282a; background: #e6dfd5; border-color: #d3c8bb; border-radius: 5px; }
.design-atelier .workflow-current { border-color: #bfb3a6; }
.design-atelier .workflow-current span, .design-atelier .workflow-copy > p { color: #746b61; }
.design-atelier .workflow-current strong, .design-atelier .workflow-copy h2 { color: #24282a; font-family: "Playfair Display", Georgia, serif; }
.design-atelier .workflow-copy > span { color: #595b59; }
.design-atelier .workflow-action button { color: #f4f1eb; background: #242a2d; border-color: #242a2d; border-radius: 3px; }
.design-atelier .workflow-action button:hover { color: #f4f1eb; background: #3b4448; border-color: #3b4448; }
.design-clarity .workflow-panel { color: #172b3b; background: #eef3f6; border-color: #d2dfe7; }
.design-clarity .workflow-current { border-color: #c7d7e1; }
.design-clarity .workflow-current span, .design-clarity .workflow-copy > p { color: #5d7485; }
.design-clarity .workflow-current strong, .design-clarity .workflow-copy h2 { color: #172b3b; }
.design-clarity .workflow-copy > span { color: #526776; }
.design-clarity .workflow-action button { color: #fff; background: #315f86; border-color: #315f86; }
.design-clarity .workflow-action button:hover { color: #fff; background: #244d70; border-color: #244d70; }
.proposal-panel { margin-top: 16px; }
.proposal-panel > .muted-copy { max-width: 720px; margin: 8px 0 20px; }
.proposal-panel form { display: grid; gap: 14px; }
.proposal-choice-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.proposal-choice { display: flex; align-items: flex-start; gap: 11px; min-height: 76px; padding: 15px; background: #f5f7f3; border: 1px solid var(--line); border-radius: 12px; cursor: pointer; }
.proposal-choice:has(input:checked) { background: #f1f8dd; border-color: #b6d75a; box-shadow: 0 0 0 1px #b6d75a; }
.proposal-choice input { width: 18px; height: 18px; min-height: 0; margin: 1px 0 0; accent-color: #668517; }
.proposal-choice span { display: grid; gap: 4px; }
.proposal-choice strong { font-size: 14px; }
.proposal-choice small { color: var(--muted); font-size: 12px; line-height: 1.4; }
.proposal-fields { display: grid; grid-template-columns: minmax(220px, .45fr); gap: 12px; }
.proposal-appointment-fields { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.proposal-fields[hidden] { display: none; }
.proposal-panel label small { color: var(--muted); font-weight: 500; }
.design-atelier .proposal-choice { background: #f5f1eb; border-color: #d8d0c5; border-radius: 3px; }
.design-atelier .proposal-choice:has(input:checked) { background: #eee6dc; border-color: #ae9e8d; box-shadow: 0 0 0 1px #ae9e8d; }
.design-clarity .proposal-choice { background: #f4f8fa; border-color: #d5e0e7; }
.design-clarity .proposal-choice:has(input:checked) { background: #edf4f8; border-color: #8ca9bc; box-shadow: 0 0 0 1px #8ca9bc; }
.admin-photo-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
.result-photo-upload { display: grid; gap: 12px; margin-top: 16px; }
.gallery-item { position: relative; display: block; overflow: hidden; border-radius: 12px; background: #111; }
.admin-photo-grid img { display: block; width: 100%; height: 180px; object-fit: cover; border-radius: 12px; transition: transform .2s; }
.gallery-item:hover img, .gallery-item:focus-visible img { transform: scale(1.02); }
.gallery-zoom { position: absolute; right: 12px; bottom: 12px; display: grid; place-items: center; width: 42px; height: 42px; color: #111; background: rgba(255,255,255,.96); border: 1px solid rgba(0,0,0,.08); border-radius: 50%; box-shadow: 0 8px 22px rgba(0,0,0,.32); font-size: 19px; opacity: 1; transform: translateY(0); transition: transform .18s, background .18s; }
.gallery-caption { position: absolute; left: 10px; bottom: 12px; max-width: calc(100% - 70px); padding: 7px 10px; color: #fff; background: rgba(10,14,10,.78); border-radius: 999px; font-size: 11px; line-height: 1; opacity: 1; backdrop-filter: blur(8px); }
.gallery-item:hover .gallery-zoom, .gallery-item:focus-visible .gallery-zoom { background: var(--accent); transform: scale(1.05); }
body.photo-lightbox-open { overflow: hidden; }
.photo-lightbox { position: fixed; z-index: 1000; inset: 0; display: none; place-items: center; padding: 40px; background: rgba(8,10,8,.92); }
.photo-lightbox.open { display: grid; }
.photo-lightbox.is-loading .photo-lightbox-stage::after { content: ""; position: absolute; width: 34px; height: 34px; border: 3px solid rgba(255,255,255,.28); border-top-color: var(--accent); border-radius: 50%; animation: photo-spin .7s linear infinite; }
.photo-lightbox-stage { position: relative; display: grid; place-items: center; width: min(1200px, calc(100vw - 160px)); height: min(84vh, 900px); overflow: hidden; touch-action: none; }
.photo-lightbox img { display: block; max-width: 100%; max-height: 100%; border-radius: 12px; box-shadow: 0 20px 80px #000; cursor: zoom-in; user-select: none; transform-origin: center; transition: transform .14s ease; will-change: transform; }
.photo-lightbox-stage.zoomed img { cursor: grab; }
.photo-lightbox-stage.dragging img { cursor: grabbing; transition: none; }
.photo-lightbox button { position: absolute; display: grid; place-items: center; width: 48px; height: 48px; min-height: 48px; padding: 0; color: #fff; background: rgba(30,34,30,.9); border: 1px solid #666; border-radius: 8px; font-size: 26px; }
.photo-lightbox button[hidden] { display: none; }
.photo-lightbox button:hover:not(:disabled), .photo-lightbox button:focus-visible { color: var(--ink); background: var(--accent); border-color: var(--accent); }
.photo-lightbox button:disabled { opacity: .4; cursor: default; }
.photo-lightbox-close { top: 20px; right: 25px; }
.photo-lightbox-previous { top: 50%; left: 25px; transform: translateY(-50%); }
.photo-lightbox-next { top: 50%; right: 25px; transform: translateY(-50%); }
.photo-lightbox-previous:hover, .photo-lightbox-next:hover { color: var(--ink); background: var(--accent); border-color: var(--accent); transform: translateY(-50%); }
.photo-lightbox-count { position: absolute; top: 20px; left: 25px; margin: 0; padding: 7px 11px; color: #fff; background: rgba(20,23,20,.82); border-radius: 6px; font-size: 12px; font-weight: 800; }
@keyframes photo-spin { to { transform: rotate(360deg); } }
.photo-lightbox-tools { position: absolute; bottom: 18px; left: 50%; display: flex; align-items: center; gap: 7px; padding: 7px; background: rgba(20,23,20,.9); border: 1px solid #555; border-radius: 12px; box-shadow: 0 8px 30px rgba(0,0,0,.35); transform: translateX(-50%); }
.photo-lightbox-tools button { position: static; width: 38px; height: 38px; min-height: 38px; border-color: #555; border-radius: 7px; font-size: 21px; }
.photo-lightbox-tools .photo-lightbox-reset { width: auto; padding: 0 12px; font-size: 12px; font-weight: 800; }
.photo-lightbox-zoom-level { min-width: 55px; color: #fff; font-size: 12px; font-weight: 800; text-align: center; }
.insurance-admin-panel { margin-top: 16px; }
.insurance-documents { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 18px; }
.document-link { padding: 10px 13px; color: #243208; background: #eff7da; border-radius: 9px; text-decoration: none; font-size: 12px; font-weight: 700; }
.decline-panel { grid-column: 1 / -1; border-color: #ecc8c5; background: #fffafa; }
.danger-button { border-color: #b83e35; background: #b83e35; }
.muted-copy { color: var(--muted); line-height: 1.6; }
.panel h2, .appointment-card h2 { margin-top: 0; }
.panel form { display: grid; gap: 14px; }
dl { display: grid; grid-template-columns: 135px 1fr; gap: 9px; }
dt { font-weight: 800; } dd { margin: 0; }
.timeline { display: grid; gap: 12px; padding-left: 20px; }
.timeline small { display: block; color: var(--muted); margin-top: 4px; }
.quick-replies { margin: 18px 0; padding: 14px; background: #f4f7ee; border-radius: 12px; }
.quick-replies > span { display: block; margin-bottom: 10px; color: var(--muted); font-size: 10px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.quick-replies > div { display: flex; flex-wrap: wrap; gap: 7px; }
.quick-replies button { min-height: 34px; padding: 0 11px; color: #344020; background: #fff; border: 1px solid #d9e1cc; font-size: 11px; }
.quick-replies button:hover { border-color: var(--accent-dark); background: #edf7d3; }
.appointment-card, .offer-card { border-color: #a9c553; background: #f7fbe9; }
.offer-card { margin-top: 15px; padding: 22px; border: 1px solid #a9c553; border-radius: 18px; }
.offer-card h2 { margin: 4px 0 8px; font: 700 34px "Manrope"; letter-spacing: -.04em; }
.offer-card > p:not(.eyebrow) { margin: 0 0 18px; color: #56604f; line-height: 1.55; }
.offer-status { color: #526f0c !important; background: #eff8d6; }
.offer-admin-panel { margin-top: 16px; }
.appointment-actions { display: flex; gap: 10px; }
.appointment-counter-form { display: grid; gap: 11px; margin-top: 18px; padding-top: 17px; border-top: 1px solid #dbe7ba; }
.appointment-counter-form > p { margin: 0; color: #55634d; font-size: 13px; line-height: 1.5; }
.appointment-counter-form label { display: grid; gap: 6px; color: #405317; font-size: 12px; font-weight: 800; }
.appointment-counter-form input, .appointment-counter-form textarea { background: #fff; border-color: #cbdbaa; }
.appointment-counter-waiting { margin: 16px 0 0; padding: 12px 14px; color: #405317; background: #edf7d2; border-radius: 10px; font-weight: 700; line-height: 1.45; }
.customer-counter-proposal { display: flex; align-items: center; justify-content: space-between; gap: 24px; margin: 16px 0; padding: 22px 24px; background: #f1f9df; border: 1px solid #c5df88; border-radius: 16px; }
.customer-counter-proposal h2, .customer-counter-proposal p { margin: 0; }
.customer-counter-proposal h2 { margin: 4px 0 8px; font-size: 22px; }
.calendar-export { margin-top: 4px; }
.calendar { display: grid; gap: 10px; }
.calendar-tabs { display: flex; width: fit-content; gap: 4px; margin-bottom: 18px; padding: 4px; background: #e3e7e1; border-radius: 999px; }
.calendar-tabs button { min-height: 38px; padding: 0 17px; color: var(--muted); background: transparent; border: 0; }
.calendar-tabs button.active { color: #fff; background: var(--dark); }
.calendar-navigation { display: flex; align-items: center; justify-content: space-between; width: min(430px, 100%); margin: 0 0 16px; }
.calendar-navigation strong { text-align: center; font-family: "Manrope"; }
.calendar-event { display: grid; gap: 4px; padding: 12px; color: inherit; background: #f4f7ee; border-left: 3px solid var(--accent-dark); border-radius: 6px; text-decoration: none; }
.calendar-event:hover { background: #ecf4d7; }
.calendar-event span { color: var(--muted); font-size: 12px; }
.calendar-empty { margin: 0; color: var(--muted); font-size: 13px; }
.calendar-day-view { display: grid; gap: 10px; max-width: 650px; }
.calendar-day-view h2 { margin: 0 0 5px; font-size: 22px; }
.calendar-week-view { display: grid; grid-template-columns: repeat(7, minmax(160px, 1fr)); gap: 10px; overflow-x: auto; padding-bottom: 8px; }
.calendar-week-day { display: grid; align-content: start; gap: 8px; min-height: 180px; padding: 12px; background: #fff; border: 1px solid var(--line); border-radius: 8px; }
.calendar-week-day h3 { margin: 0; font-size: 13px; }
.calendar-month-head, .calendar-month-view { display: grid; grid-template-columns: repeat(7, minmax(100px, 1fr)); min-width: 700px; }
.calendar-month-head { overflow: hidden; border: 1px solid var(--line); border-bottom: 0; border-radius: 8px 8px 0 0; background: #f4f6f2; }
.calendar-month-head span { padding: 10px; color: var(--muted); font-size: 11px; font-weight: 800; text-align: center; }
.calendar-month-view { overflow: hidden; border: 1px solid var(--line); border-radius: 0 0 8px 8px; }
.calendar-month-day { display: grid; align-content: start; gap: 5px; min-height: 116px; padding: 9px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.calendar-month-day:nth-child(7n) { border-right: 0; }
.calendar-month-day strong { font-size: 12px; }
.calendar-month-day a { overflow: hidden; padding: 4px 5px; color: #354600; background: #eef7d2; border-radius: 4px; font-size: 10px; font-weight: 800; text-decoration: none; text-overflow: ellipsis; white-space: nowrap; }
.calendar-month-day.outside { color: #aab2aa; background: #fafbfa; }
.notification-list { display: grid; gap: 16px; }
.notification-item { overflow: hidden; background: #fff; border: 1px solid var(--line); border-radius: 14px; box-shadow: 0 8px 28px rgba(28,36,29,.045); }
.notification-item-head { display: grid; grid-template-columns: auto minmax(0, 1fr) auto; gap: 18px; align-items: center; padding: 18px 20px; background: #f7f8f5; border-bottom: 1px solid var(--line); }
.notification-meta { display: flex; flex-wrap: wrap; gap: 7px; }
.notification-channel, .notification-status { display: inline-flex; width: fit-content; padding: 6px 9px; border-radius: 6px; font-size: 10px; font-weight: 800; }
.notification-channel { color: #3d4e20; background: #edf5d6; }
.notification-status { color: #4e5a4e; background: #edf0ed; }
.notification-status.gesendet { color: #315700; background: #e5f7bd; }
.notification-status.fehlgeschlagen { color: #8d3028; background: #fff0ee; }
.notification-recipient { display: grid; min-width: 0; }
.notification-recipient span, .notification-copy-label { color: var(--muted); font-size: 10px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.notification-recipient strong { overflow: hidden; margin-top: 3px; text-overflow: ellipsis; white-space: nowrap; }
.notification-recipient small { margin-top: 2px; color: var(--muted); }
.notification-copy { padding: 20px; }
.notification-copy h2 { margin: 5px 0 12px; font-size: 20px; }
.notification-message { padding: 14px 16px; color: #384139; background: #f7f8f5; border-left: 3px solid var(--accent); border-radius: 0 9px 9px 0; line-height: 1.6; overflow-wrap: anywhere; }
.notification-sms .notification-message { max-width: 720px; font-size: 14px; }
.notification-item footer { padding: 0 20px 18px; color: var(--muted); font-size: 12px; }
.calendar-entry { display: grid; grid-template-columns: 170px 1fr auto auto; gap: 18px; align-items: center; }
.calendar-entry span { display: block; color: var(--muted); font-size: 12px; margin-top: 4px; }
.calendar-entry time { font-weight: 800; }
.lead { color: var(--muted); font-size: 17px; }
.customer-status-shell { max-width: 900px; }
.customer-status-shell > .panel, .customer-status-shell > .appointment-card { margin-top: 15px; }
.customer-damage-photos .gallery-item .gallery-caption { background: rgba(15,19,16,.82); }
.repair-photo-columns { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 16px; }
.repair-photo-columns > div { display: grid; gap: 9px; }
.repair-photo-columns > div > div { display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px; }
.repair-photo-columns img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; border-radius: 10px; }
.small-upload { min-height: 150px; margin-bottom: 12px; }
.success-page { min-height: 100vh; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 20px; padding: 40px; text-align: center; background: #eef1eb; }
.success-page h1 { margin: 0; font: 700 clamp(45px, 7vw, 80px)/1 "Manrope"; letter-spacing: -.06em; }
.success-page > p:not(.kicker) { max-width: 600px; color: var(--muted); font-size: 18px; line-height: 1.7; }
.success-mark { display: grid; place-items: center; width: 70px; height: 70px; color: #111; background: var(--accent); border-radius: 50%; font: 800 30px "Manrope"; }
.conflict-page .success-mark { color: #fff; background: #ce564c; }

/* Kundenkonto */
.customer-login-page { min-height: 100vh; display: grid; grid-template-columns: minmax(0, 1.15fr) minmax(430px, .85fr); background: #f6f7f4; }
.customer-login-showcase { position: relative; display: grid; align-content: space-between; min-height: 720px; padding: 46px clamp(38px, 6vw, 96px); color: #fff; background: linear-gradient(90deg, rgba(12,16,12,.96) 0%, rgba(13,17,13,.78) 50%, rgba(13,17,13,.28) 100%), url("/static/images/workshop-hero.webp") center/cover; overflow: hidden; }
.customer-login-showcase::after { content: ""; position: absolute; right: -130px; bottom: -180px; width: 520px; height: 520px; border: 1px solid rgba(201,255,56,.35); border-radius: 50%; box-shadow: 0 0 0 65px rgba(201,255,56,.04), 0 0 0 130px rgba(201,255,56,.035); }
.customer-login-showcase .brand { position: relative; z-index: 1; }
.customer-login-showcase .brand small { color: #b7c0b4; }
.customer-login-showcase-copy { position: relative; z-index: 1; max-width: 650px; margin: 90px 0; }
.customer-login-showcase-copy .kicker { color: var(--accent); }
.customer-login-showcase-copy h1 { margin: 14px 0 22px; color: #fff; font: 700 clamp(50px, 6vw, 86px)/.9 "Manrope"; letter-spacing: -.075em; }
.customer-login-showcase-copy h1 em { color: var(--accent); font-style: normal; }
.customer-login-showcase-copy > p:last-child { max-width: 510px; margin: 0; color: #d6dcd4; font-size: 17px; line-height: 1.65; }
.customer-login-benefits { position: relative; z-index: 1; display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.customer-login-benefits > div { display: grid; gap: 5px; min-height: 112px; padding: 15px; background: rgba(30,35,30,.72); border: 1px solid rgba(255,255,255,.16); border-radius: 14px; backdrop-filter: blur(10px); }
.customer-login-benefits span { color: var(--accent); font-size: 11px; font-weight: 800; letter-spacing: .1em; }
.customer-login-benefits strong { font-size: 14px; }
.customer-login-benefits small { color: #c4cdc3; font-size: 11px; line-height: 1.35; }
.customer-login-panel { display: flex; flex-direction: column; justify-content: center; width: min(510px, 100%); min-height: 100vh; margin: 0 auto; padding: 52px clamp(28px, 5vw, 72px); }
.customer-login-back { align-self: flex-start; margin-bottom: auto; color: var(--muted); font-size: 13px; font-weight: 700; text-decoration: none; }
.customer-login-back:hover { color: var(--ink); }
.customer-login-heading { margin: 72px 0 30px; }
.customer-login-heading h2 { margin: 10px 0 15px; font: 700 clamp(48px, 5vw, 72px)/.9 "Manrope"; letter-spacing: -.075em; }
.customer-login-heading > p:last-child { margin: 0; color: var(--muted); line-height: 1.6; }
.customer-login-panel form { display: grid; gap: 16px; }
.customer-login-panel label { display: grid; gap: 8px; color: #3d463e; font-size: 13px; font-weight: 800; }
.customer-login-panel input { min-height: 54px; padding: 0 15px; background: #fff; border-color: #d6ddd5; border-radius: 10px; }
.customer-login-panel input:focus { border-color: var(--accent-dark); box-shadow: 0 0 0 4px rgba(169,223,16,.14); }
.customer-login-submit { display: flex; align-items: center; justify-content: space-between; width: 100%; margin-top: 4px; }
.customer-login-divider { display: flex; align-items: center; gap: 12px; margin: 32px 0 20px; color: var(--muted); font-size: 12px; }
.customer-login-divider::before, .customer-login-divider::after { content: ""; height: 1px; flex: 1; background: var(--line); }
.customer-login-new { display: flex; align-items: center; justify-content: space-between; gap: 18px; }
.customer-login-new strong, .customer-login-new small { display: block; }
.customer-login-new strong { margin-bottom: 5px; font-size: 14px; }
.customer-login-new small { max-width: 255px; color: var(--muted); font-size: 12px; line-height: 1.45; }
.customer-login-new .button { flex: 0 0 auto; }
.customer-account-nav { height: 76px; display: flex; align-items: center; justify-content: space-between; gap: 25px; padding: 0 max(24px, calc((100vw - 1240px) / 2)); color: #fff; background: var(--dark); }
.customer-account-nav nav { display: flex; align-self: stretch; gap: 28px; }
.customer-account-nav nav a { display: flex; align-items: center; color: #aeb5ae; text-decoration: none; font-size: 13px; font-weight: 700; border-bottom: 2px solid transparent; }
.customer-account-nav nav a.active { color: #fff; border-color: var(--accent); }
.customer-account-nav .ghost { color: #fff; border-color: #555c55; }
.customer-portal { padding-top: 34px; padding-bottom: 70px; }
.customer-portal-hero { display: flex; align-items: end; justify-content: space-between; gap: 28px; padding: clamp(28px, 4vw, 48px); color: #fff; background: linear-gradient(120deg, #141914, #26321a); border-radius: 26px; box-shadow: 0 22px 50px rgba(20,31,18,.15); }
.customer-portal-hero .eyebrow { color: var(--accent); }
.customer-portal-hero h1 { margin: 10px 0; color: #fff; font: 700 clamp(40px, 5vw, 66px)/.92 "Manrope"; letter-spacing: -.065em; }
.customer-portal-hero > div > p:last-child { max-width: 540px; margin: 0; color: #d1d9cf; font-size: 16px; line-height: 1.55; }
.customer-portal-hero-actions { display: grid; justify-items: end; gap: 22px; }
.customer-portal-stats { display: flex; gap: 18px; }
.customer-portal-stats span { color: #bdc7bb; font-size: 11px; white-space: nowrap; }
.customer-portal-stats strong { display: block; margin-bottom: 3px; color: #fff; font: 800 23px "Manrope"; }
.customer-portal-grid { display: grid; grid-template-columns: minmax(260px, .65fr) minmax(0, 1.35fr); gap: 20px; margin-top: 22px; }
.customer-portal-panel { padding: 26px; background: #fff; border: 1px solid var(--line); border-radius: 20px; }
.customer-portal-panel .panel-title { margin-bottom: 18px; }
.customer-vehicles { margin: 0; }
.customer-vehicles > div:last-child { display: grid; gap: 10px; }
.customer-vehicles article { display: grid; grid-template-columns: 36px 1fr; gap: 10px; align-items: center; padding: 14px; background: #f7f9f5; border: 1px solid #e2e7df; border-radius: 12px; }
.garage-icon { display: grid; place-items: center; width: 36px; height: 36px; color: #405317 !important; background: #e9f8c1; border-radius: 10px; font: 900 13px/1 "Manrope", sans-serif; letter-spacing: -.04em; }
.customer-vehicles article div { display: grid; gap: 2px; }
.customer-vehicles span, .customer-vehicles small { color: var(--muted); font-size: 12px; }
.customer-vehicles strong { font-size: 14px; }
.customer-vehicle-meta { margin: 4px 0 0 !important; color: #526f0c !important; font-size: 11px !important; line-height: 1.4; }

/* Rechtlich defensiver Brand-Icon-Prototyp: nur Text, Kürzel und UI-Grundformen. */
.brand-preview-nav { display: flex; align-items: center; justify-content: space-between; gap: 20px; height: 78px; padding: 0 max(24px, calc((100vw - 1180px) / 2)); color: #f1f3ef; background: #151816; }
.brand-preview-nav .brand-mark { color: #f1f3ef; background: #2b312b; border-color: #475048; }
.brand-preview-nav .brand small { color: #aeb6ae; }
.brand-preview-nav .ghost { color: #f1f3ef; border-color: #565f56; }
.brand-icon-preview { min-height: calc(100vh - 78px); padding: clamp(42px, 7vw, 86px) max(24px, calc((100vw - 1080px) / 2)); background: #111412; }
.brand-icon-preview-intro { max-width: 670px; margin-bottom: 40px; }
.brand-icon-preview .eyebrow { margin: 0 0 12px; color: #b8c0b8; }
.brand-icon-preview h1 { margin: 0; color: #f7f8f5; font: 800 clamp(40px, 6vw, 72px)/.95 "Manrope", sans-serif; letter-spacing: -.06em; }
.brand-icon-preview-intro > p:last-child { max-width: 640px; margin: 19px 0 0; color: #aeb6ae; line-height: 1.65; }
.brand-icon-preview-count { margin: 0 0 15px; color: #aeb6ae; font-size: 12px; font-weight: 750; letter-spacing: .08em; text-transform: uppercase; }
.brand-icon-preview-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 14px; }
.brand-icon-tile { min-height: 190px; display: grid; align-content: space-between; gap: 22px; padding: 18px; color: #f3f5f1; background: #202420; border: 1px solid #353b35; border-radius: 18px; box-shadow: 0 18px 35px rgba(0,0,0,.16); transition: transform .18s ease, border-color .18s ease; }
.brand-icon-tile:hover { transform: translateY(-3px); border-color: #737d74; }
.brand-icon-tile-mark { display: grid; grid-template-columns: 1fr auto; align-items: end; min-height: 90px; padding: 17px; color: #eef1ed; background: #161a17; border: 1px solid #333a34; border-radius: 12px; }
.brand-icon-tile-mark strong { font: 850 clamp(23px, 2.6vw, 31px)/1 "Manrope", sans-serif; letter-spacing: -.055em; }
.brand-icon-tile-mark svg { width: 30px; height: 20px; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; opacity: .72; }
.brand-icon-tile-copy { display: grid; gap: 5px; }
.brand-icon-tile-copy strong { font: 750 15px "Manrope", sans-serif; }
.brand-icon-tile-copy span { color: #aab3aa; font-size: 11px; font-weight: 750; letter-spacing: .1em; text-transform: uppercase; }
.customer-orders { display: grid; gap: 10px; }
.customer-order-card { display: grid; grid-template-columns: minmax(0, 1fr) auto; grid-template-areas: "summary state" "meta state"; gap: 14px 24px; align-items: center; padding: 20px; background: #fdfefd; border: 1px solid #e1e6df; border-radius: 16px; transition: border-color .18s, transform .18s, box-shadow .18s; }
.customer-order-card:hover { border-color: #bddc71; box-shadow: 0 12px 26px rgba(29,44,24,.08); transform: translateY(-1px); }
.customer-order-summary { grid-area: summary; }
.customer-order-card h3 { margin: 4px 0; font-size: 22px; }
.customer-order-card p { margin: 4px 0; color: var(--muted); }
.customer-order-state { grid-area: state; display: grid; justify-items: end; gap: 12px; }
.customer-order-state .status { margin: 0; }
.customer-order-meta { grid-area: meta; display: flex; gap: 28px; padding-top: 13px; border-top: 1px solid #e7ebe5; }
.customer-order-meta span, .customer-order-meta strong { display: block; font-size: 11px; }
.customer-order-meta strong { color: var(--ink); font-size: 12px; }
.design-atelier .customer-portal-hero { background: linear-gradient(120deg, #282d2e, #465056); border-radius: 4px; }
.design-atelier .customer-portal-panel, .design-atelier .customer-order-card { background: #faf8f4; border-color: #d9d2c8; border-radius: 4px; }
.design-clarity .customer-portal-hero { background: linear-gradient(120deg, #123149, #245a74); }
.design-clarity .customer-portal-panel, .design-clarity .customer-order-card { border-color: #d7e2e9; box-shadow: 0 10px 32px rgba(24,51,71,.06); }

/* Login + Rechtliches */
.login-page { min-height: 100vh; display: grid; grid-template-columns: 1fr 1fr; background: #fff; }
.login-panel { display: flex; flex-direction: column; justify-content: space-between; padding: 55px max(40px, calc((100vw - 1120px) / 2)); }
.login-panel .brand { align-self: flex-start; }
.login-panel .brand small { color: var(--muted); }
.login-panel form { display: grid; gap: 15px; max-width: 430px; }
.login-hint { color: var(--muted); font-size: 12px; }
.form-error { padding: 12px; color: #9b2c2c; background: #fff0f0; border-radius: 10px; }
.login-visual { display: grid; place-items: end start; padding: 60px; color: #fff; background: linear-gradient(0deg, rgba(0,0,0,.75), transparent), url("/static/images/workshop-hero.webp") center/cover; }
.login-visual div { padding: 22px; background: rgba(17,19,17,.78); border: 1px solid #555; border-radius: 18px; backdrop-filter: blur(12px); }
.login-visual span, .login-visual small { display: block; color: #c3c9c3; }
.login-visual strong { display: block; margin: 5px 0; font: 700 25px "Manrope"; }
.legal-page { max-width: 800px; margin: 0 auto; padding: 80px 30px; line-height: 1.7; }
.legal-page h1 { font-size: 65px; letter-spacing: -.06em; }

/* Website-Design 02: Atelier */
.design-atelier {
  --ink: #24282a;
  --muted: #6b6b67;
  --line: #d9d4cc;
  --paper: #f3f1ed;
  --accent: #c9bca9;
  --accent-dark: #7b6d5f;
  --dark: #22282b;
  --radius: 5px;
}
.design-atelier .site-header { height: 96px; color: #24282a; background: rgba(244,241,235,.97); border-bottom: 1px solid #d7d1c7; }
.design-atelier .site-header .brand small { color: #77736d; }
.design-atelier .site-header .brand-mark { color: #24282a; border-color: #aaa197; border-radius: 2px; }
.design-atelier .desktop-nav a { color: #505456; }
.design-atelier .desktop-nav a:hover { color: #6d6358; }
.design-atelier .header-cta { color: #fff; background: #242a2d; border-color: #242a2d; border-radius: 3px; }
.design-atelier .button-icon, .design-atelier .action-link i { border-radius: 2px; }
.design-atelier .action-link { background: #f0ece6; border-color: #d9d2c8; border-radius: 2px; }
.design-atelier .action-link:hover { background: #faf8f4; border-color: #bdb3a7; }
.design-atelier .button-accent .button-icon { color: #f4f1eb; background: #242a2d; }
.design-atelier .button-dark .button-icon { color: #242a2d; background: #f0ece6; }
.design-atelier .process-section .button-dark {
  color: #24282a;
  background: #f0ece6;
  border-color: #f0ece6;
  box-shadow: 0 12px 30px rgba(0,0,0,.16);
}
.design-atelier .process-section .button-dark:hover {
  background: #faf8f4;
  border-color: #faf8f4;
}
.design-atelier .process-section .button-dark .button-icon {
  color: #f4f1eb;
  background: #6f655a;
}
.design-atelier .contact-route-button {
  color: #24282a !important;
  background: #f0ece6;
  border-color: #f0ece6;
}
.design-atelier .contact-route-button:hover { background: #d8d0c5; border-color: #d8d0c5; }
.design-atelier .contact-route-button .button-icon { color: #f0ece6; background: #242a2d; }
.design-atelier .public-hero { min-height: calc(100vh - 96px); background-position: 58% center; }
.design-atelier .hero-shade { background: linear-gradient(90deg, rgba(30,35,38,.97) 0%, rgba(30,35,38,.87) 43%, rgba(30,35,38,.2) 78%), linear-gradient(0deg, rgba(30,35,38,.44), transparent 55%); }
.design-atelier .public-hero h1, .design-atelier .section-heading h2, .design-atelier .process-intro h2, .design-atelier .about-copy h2, .design-atelier .contact-section h2 { font-family: "Playfair Display", Georgia, serif; font-weight: 600; letter-spacing: -.045em; }
.design-atelier .public-hero h1 { max-width: 900px; line-height: .93; }
.design-atelier .hero-proof, .design-atelier .button, .design-atelier button, .design-atelier .trust-strip, .design-atelier .about-photo span { border-radius: 3px; }
.design-atelier .trust-strip { color: #24282a; background: #d8d0c5; }
.design-atelier .section-light { background: #f7f5f1; }
.design-atelier .service-card, .design-atelier .wizard-card, .design-atelier .contact-card { border-radius: 5px; }
.design-atelier .service-number { border-radius: 2px; }
.design-atelier .process-section { color: #f4f1eb; background: #22282b; }
.design-atelier .process-section h2 em { color: #c9bca9; }
.design-atelier .process-list { border-color: rgba(255,255,255,.2); }
.design-atelier .process-list li { border-color: rgba(255,255,255,.2); }
.design-atelier .process-list p { color: #c8c2ba; }
.design-atelier .testimonial-section { background: #e9e5de; }
.design-atelier .stars { color: #746b61; }
.design-atelier .wizard-shell { background: #ece8e1; }
.design-atelier .wizard-card { border: 1px solid #d8d1c7; box-shadow: 18px 18px 0 #ddd6cc; }
.design-atelier .wizard-intro h1, .design-atelier .wizard-step h2 { font-family: "Playfair Display", Georgia, serif; letter-spacing: -.035em; }
.design-atelier input:focus, .design-atelier select:focus, .design-atelier textarea:focus { border-color: #7b6d5f; box-shadow: 0 0 0 4px rgba(123,109,95,.12); }
.design-atelier .wizard-actions .wizard-next, .design-atelier .wizard-actions .wizard-submit { border-radius: 3px; }

/* Website-Design 03: Clarity */
.design-clarity {
  --ink: #172b3b;
  --muted: #5e6d78;
  --line: #d6e0e7;
  --paper: #f3f6f8;
  --accent: #315f86;
  --accent-dark: #244d70;
  --dark: #162d40;
  --radius: 18px;
}
.design-clarity .site-header { color: #172b3b; background: rgba(255,255,255,.96); border-bottom: 1px solid #d9e2e8; backdrop-filter: blur(18px); }
.design-clarity .site-header .brand small { color: #687783; }
.design-clarity .site-header .brand-mark { color: #244d70; background: #edf2f6; border-color: #cbd8e1; }
.design-clarity .desktop-nav a { color: #455c6d; }
.design-clarity .desktop-nav a:hover { color: #244d70; }
.design-clarity .header-cta { color: #fff; background: #244d70; border-color: #244d70; }
.design-clarity .button-accent { color: #fff; background: #315f86; border-color: #315f86; }
.design-clarity .button-accent:hover { background: #244d70; border-color: #244d70; }
.design-clarity .button-icon { color: #244d70; background: #fff; box-shadow: 0 4px 13px rgba(23,43,59,.14); }
.design-clarity .button-accent .button-icon { color: #244d70; background: #fff; }
.design-clarity .button-dark .button-icon { color: #244d70; background: #fff; }
.design-clarity .action-link i { color: #fff; background: #315f86; }
.design-clarity .action-link { background: #edf2f6; border-color: #d3dfe7; }
.design-clarity .action-link:hover { background: #fff; border-color: #aebfcb; }
.design-clarity .contact-route-button { color: #172b3b !important; background: #fff; border-color: #fff; }
.design-clarity .contact-route-button:hover { color: #fff !important; background: #315f86; border-color: #315f86; }
.design-clarity .public-hero { min-height: calc(100vh - 86px); color: #172b3b; background-color: #edf2f6; background-position: 74% center; }
.design-clarity .hero-shade { background: linear-gradient(90deg, rgba(247,249,250,.99) 0%, rgba(247,249,250,.96) 46%, rgba(247,249,250,.2) 79%), linear-gradient(0deg, rgba(231,237,241,.34), transparent); }
.design-clarity .hero-copy > p:not(.kicker) { color: #526776; }
.design-clarity .public-hero h1 em { color: #244d70; }
.design-clarity .hero-proof { color: #334e61; background: rgba(255,255,255,.78); border-color: #c5d2db; }
.design-clarity .text-link { color: #244d70; border-color: #8fa4b3; }
.design-clarity .hero-stats span { color: #61717c; }
.design-clarity .trust-strip { color: #fff; background: #244d70; }
.design-clarity .trust-strip i { background: #dbe5ec; }
.design-clarity .section-light { background: #f6f8f9; }
.design-clarity .service-card { border-color: #d9e2e8; box-shadow: 0 12px 38px rgba(25,55,78,.06); }
.design-clarity .process-section { color: #172b3b; background: linear-gradient(135deg, #e3eaf0, #f0f3f5); }
.design-clarity .process-list, .design-clarity .process-list li { border-color: rgba(23,43,59,.15); }
.design-clarity .process-list p { color: #526776; }
.design-clarity .testimonial-section { background: #e9eef2; }
.design-clarity .stars { color: #315f86; }
.design-clarity .contact-section { background: #162d40; }
.design-clarity .contact-card { background: #203b50; border-color: #36546a; }
.design-clarity .site-footer { background: #102535; border-color: #294459; }
.design-clarity .wizard-shell { background: linear-gradient(135deg, #edf2f5, #f8fafb); }
.design-clarity .wizard-card { border: 1px solid #d9e2e8; box-shadow: 0 30px 90px rgba(31,73,104,.09); }
.design-clarity .wizard-intro { max-width: 820px; margin: 0 auto; padding-top: 0; text-align: center; }
.design-clarity .wizard-intro > p:not(.kicker) { margin-right: auto; margin-left: auto; }
.design-clarity .wizard-help { justify-content: center; }
.design-clarity .wizard-card { width: min(880px, 100%); margin: 0 auto; }
.design-clarity input:focus, .design-clarity select:focus, .design-clarity textarea:focus { border-color: #315f86; box-shadow: 0 0 0 4px rgba(49,95,134,.1); }
.design-clarity .wizard-actions .wizard-submit { color: #fff; background: #315f86; border-color: #315f86; }
.design-clarity .wizard-actions .wizard-submit:hover { background: #244d70; border-color: #244d70; }

@media (min-width: 901px) {
  /* Performance: every service card uses the same image line. This keeps the
     wide featured card and the regular card visually aligned. */
  .design-performance .service-card {
    display: grid;
    grid-template-rows: 312px auto;
    justify-content: initial;
    min-height: 0;
  }
  .design-performance .service-photo {
    position: relative;
    inset: auto;
    grid-row: 1;
    min-height: 312px;
  }
  .design-performance .service-content {
    grid-row: 2;
  }

  /* Atelier: editorial, asymmetrisch und handwerklich */
  .design-atelier .site-header { display: grid; grid-template-columns: 1fr auto 1fr; }
  .design-atelier .site-header .desktop-nav { justify-self: center; }
  .design-atelier .site-header .header-cta { justify-self: end; }
  .design-atelier .public-hero {
    min-height: 760px;
    color: #24282a;
    background: #f3f1ed;
  }
  .design-atelier .public-hero::after {
    content: "";
    position: absolute;
    z-index: 0;
    inset: 0 0 0 48%;
    background: linear-gradient(0deg, rgba(30,35,38,.1), transparent 55%), url("/static/images/workshop-hero.webp") center/cover;
  }
  .design-atelier .hero-shade { display: none; }
  .design-atelier .hero-copy { z-index: 1; width: min(1320px, calc(100% - 72px)); padding: 76px 54% 64px 0; }
  .design-atelier .hero-copy > * { max-width: none; }
  .design-atelier .public-hero h1 { max-width: 620px; font-size: clamp(60px, 6.2vw, 92px); color: #24282a; }
  .design-atelier .public-hero h1 em { color: #7b6d5f; }
  .design-atelier .hero-copy > p:not(.kicker) { max-width: 570px; color: #595b59; }
  .design-atelier .hero-proof { color: #4e514f; background: #e8e3dc; border-color: #cbc2b7; }
  .design-atelier .text-link { color: #24282a; border-color: #8f877d; }
  .design-atelier .hero-stats { gap: 34px; margin-top: 54px; }
  .design-atelier .hero-stats span { color: #676963; }
  .design-atelier .section-heading { grid-template-columns: .8fr 1.2fr; }
  .design-atelier .service-grid { grid-template-columns: 1fr 1fr; gap: 24px; }
  .design-atelier .service-featured { grid-column: 1 / -1; min-height: 430px; }
  .design-atelier .service-featured .service-photo { inset: 0 48% 0 0; }
  .design-atelier .service-featured .service-content { min-height: 430px; margin-left: 52%; display: flex; flex-direction: column; justify-content: center; }
  .design-atelier .service-card:not(.service-featured) { min-height: 500px; }
  .design-atelier .service-card:nth-child(even) { margin-top: 38px; }
  .design-atelier .process-section { display: block; }
  .design-atelier .process-intro { position: static; max-width: 800px; margin-bottom: 64px; }
  .design-atelier .process-list { display: grid; grid-template-columns: repeat(5, 1fr); }
  .design-atelier .process-list li { display: block; padding: 28px 22px; border-right: 1px solid rgba(255,255,255,.18); }
  .design-atelier .process-list li:last-child { border-right: 0; }
  .design-atelier .process-list b { display: block; margin-bottom: 38px; }
  .design-atelier .process-list h3 { font-size: 20px; }
  .design-atelier .contact-section { grid-template-columns: .75fr 1.25fr; }

  /* Clarity: modular, systematisch und großzügig */
  .design-clarity .site-header {
    width: min(1380px, calc(100% - 32px));
    height: 72px;
    margin: 16px auto 0;
    padding: 0 22px;
    border: 1px solid #d9e2e8;
    border-radius: 18px;
    box-shadow: 0 10px 35px rgba(26,54,75,.07);
  }
  .design-clarity .public-hero {
    min-height: 720px;
    background: #f3f6f8;
  }
  .design-clarity .public-hero::after {
    content: "";
    position: absolute;
    z-index: 0;
    top: 36px;
    right: max(28px, calc((100vw - 1360px) / 2));
    bottom: 36px;
    width: min(46%, 660px);
    background: linear-gradient(0deg, rgba(22,45,64,.12), transparent 55%), url("/static/images/workshop-hero.webp") center/cover;
    border-radius: 30px;
    box-shadow: 0 24px 60px rgba(24,51,71,.14);
  }
  .design-clarity .hero-shade { display: none; }
  .design-clarity .hero-copy { z-index: 1; width: min(1320px, calc(100% - 64px)); padding: 76px 52% 64px 0; }
  .design-clarity .hero-copy > * { max-width: none; }
  .design-clarity .public-hero h1 { max-width: 680px; font-size: clamp(62px, 6.5vw, 94px); line-height: .94; }
  .design-clarity .hero-copy > p:not(.kicker) { max-width: 610px; }
  .design-clarity .hero-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-top: 52px; }
  .design-clarity .hero-stats div { display: grid; gap: 3px; padding: 15px; background: #fff; border: 1px solid #d7e1e8; border-radius: 14px; }
  .design-clarity .section-heading { display: block; max-width: 850px; margin-right: auto; margin-left: auto; text-align: center; }
  .design-clarity .section-heading > p { margin: 24px auto 0; }
  .design-clarity .service-grid { grid-template-columns: repeat(3, 1fr); gap: 20px; }
  .design-clarity .service-featured { grid-column: auto; }
  .design-clarity .service-card { min-height: 490px; }
  .design-clarity .service-content { padding: 24px; }
  .design-clarity .process-section { grid-template-columns: .72fr 1.28fr; gap: 60px; }
  .design-clarity .process-intro { position: static; padding: 32px; background: #fff; border: 1px solid #d4dfe7; border-radius: 22px; }
  .design-clarity .process-list { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; border: 0; }
  .design-clarity .process-list li { grid-template-columns: 42px 1fr; gap: 14px; padding: 22px; background: rgba(255,255,255,.78); border: 1px solid #d4dfe7; border-radius: 18px; }
  .design-clarity .contact-section {
    width: min(1320px, calc(100% - 56px));
    margin: 70px auto;
    padding: 76px;
    border-radius: 30px;
  }
  .design-clarity .site-footer { margin-top: 0; }
  .design-clarity .wizard-shell { grid-template-columns: 1fr; }
}

@media (max-width: 900px) {
  .desktop-nav { display: none; }
  .site-header > .header-cta {
    display: inline-flex;
    flex: 0 0 auto;
    min-height: 38px;
    max-width: 104px;
    gap: 6px;
    padding: 3px 4px 3px 10px;
    font-size: 0;
  }
  .site-header > .header-cta span:first-child {
    font-size: 0;
  }
  .site-header > .header-cta span:first-child::after {
    content: "Anfrage";
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0;
  }
  .site-header > .header-cta .button-icon {
    width: 30px;
    height: 30px;
    font-size: 14px;
  }
  .mobile-menu-toggle { display: inline-flex; align-items: center; justify-content: center; gap: 8px; min-height: 42px; padding: 0 14px; color: #fff; background: transparent; border-color: #596059; font-size: 12px; }
  .mobile-menu-toggle > span:first-child { font-size: 18px; line-height: 1; }
  .mobile-menu-toggle[aria-expanded="true"] { color: #162012; background: var(--accent); border-color: var(--accent); }
  .mobile-site-nav { position: absolute; top: 72px; right: 0; left: 0; z-index: 30; display: grid; gap: 2px; padding: 14px 18px 20px; background: #151915; border-top: 1px solid #353b35; box-shadow: 0 20px 32px rgba(0,0,0,.28); }
  .mobile-site-nav[hidden] { display: none; }
  .mobile-site-nav > a:not(.button) { padding: 15px 5px; color: #eef2ec; border-bottom: 1px solid #303630; font-size: 15px; font-weight: 700; text-decoration: none; }
  .mobile-site-nav > .button { width: 100%; margin-top: 12px; }
  .design-atelier .mobile-menu-toggle { color: #24282a; border-color: #aaa197; }
  .design-atelier .mobile-menu-toggle[aria-expanded="true"] { color: #fff; background: #242a2d; border-color: #242a2d; }
  .design-atelier .mobile-site-nav { background: #f4f1eb; border-color: #d7d1c7; box-shadow: 0 20px 32px rgba(44,42,38,.16); }
  .design-atelier .mobile-site-nav > a:not(.button) { color: #24282a; border-color: #d7d1c7; }
  .design-clarity .mobile-menu-toggle { color: #244d70; border-color: #cbd8e1; }
  .design-clarity .mobile-menu-toggle[aria-expanded="true"] { color: #fff; background: #244d70; border-color: #244d70; }
  .design-clarity .mobile-site-nav { background: #fff; border-color: #d9e2e8; box-shadow: 0 20px 32px rgba(28,60,86,.16); }
  .design-clarity .mobile-site-nav > a:not(.button) { color: #244d70; border-color: #d9e2e8; }
  .public-hero { min-height: 850px; background-position: 60% center; }
  .hero-shade { background: linear-gradient(90deg, rgba(11,13,11,.96), rgba(11,13,11,.62)); }
  .section-heading, .process-section, .about-grid, .contact-section, .wizard-shell, .login-page { grid-template-columns: 1fr; }
  .workflow-panel { grid-template-columns: 1fr; gap: 16px; padding: 20px; }
  .workflow-current { padding: 0 0 14px; border-right: 0; border-bottom: 1px solid rgba(255,255,255,.18); }
  .design-atelier .workflow-current, .design-clarity .workflow-current { border-color: #c7d0c5; }
  .workflow-action button { width: 100%; }
  .proposal-choice-grid, .proposal-appointment-fields { grid-template-columns: 1fr; }
  .service-grid { grid-template-columns: 1fr 1fr; }
  .service-featured { grid-column: span 2; }
  .design-choice-grid { grid-template-columns: 1fr; }
  .design-choice { display: grid; grid-template-columns: 180px 1fr; }
  .design-choice-visual { height: 100%; min-height: 130px; }
  .design-choice-copy small { min-height: 0; }
  .process-intro { position: static; }
  .wizard-shell { gap: 30px; padding-top: 25px; }
  .wizard-intro { padding-top: 0; }
  .wizard-help { display: none; }
  .wizard-card { width: min(100%, 760px); margin: 0 auto; }
  .login-visual { display: none; }
  .customer-login-page { grid-template-columns: 1fr; }
  .customer-login-showcase { min-height: 500px; padding: 34px 42px; }
  .customer-login-showcase-copy { margin: 56px 0; }
  .customer-login-panel { min-height: auto; padding: 44px max(28px, 10vw) 58px; }
  .customer-login-back { margin-bottom: 48px; }
  .customer-login-heading { margin: 0 0 30px; }
  .design-atelier .public-hero { color: #fff; background-size: cover; background-position: 62% center; }
  .design-atelier .public-hero::after { display: none; }
  .design-atelier .hero-shade { background: linear-gradient(90deg, rgba(27,32,35,.96), rgba(27,32,35,.55)); }
  .design-atelier .public-hero h1 { color: #f4f1eb; }
  .design-atelier .public-hero h1 em { color: #c9bca9; }
  .design-atelier .hero-copy > p:not(.kicker) { color: #d7d4ce; }
  .design-atelier .text-link { color: #fff; border-color: #8f918e; }
  .design-atelier .hero-stats span { color: #c7c9c5; }
  .design-clarity .public-hero { min-height: 980px; background: #f3f6f8; }
  .design-clarity .public-hero::after {
    content: "";
    position: absolute;
    top: 24px;
    right: 18px;
    left: 18px;
    height: 300px;
    background: url("/static/images/workshop-hero.webp") center/cover;
    border-radius: 24px;
  }
  .design-clarity .hero-shade { display: none; }
  .design-clarity .hero-copy { z-index: 1; padding-top: 365px; }
  .design-clarity .hero-copy > * { max-width: 700px; }
  .design-clarity .wizard-intro { text-align: left; }
  .design-clarity .wizard-help { justify-content: flex-start; }
}

@media (max-width: 650px) {
  .brand-preview-nav { height: 68px; padding: 0 18px; }
  .brand-preview-nav .brand small { display: none; }
  .brand-icon-preview { min-height: calc(100vh - 68px); padding: 40px 18px 56px; }
  .brand-icon-preview-intro { margin-bottom: 28px; }
  .brand-icon-preview-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
  .brand-icon-tile { min-height: 155px; gap: 15px; padding: 12px; border-radius: 14px; }
  .brand-icon-tile-mark { min-height: 68px; padding: 13px; border-radius: 10px; }
  .brand-icon-tile-mark strong { font-size: 22px; }
  .brand-icon-tile-copy strong { font-size: 13px; }
  .brand-icon-tile-copy span { font-size: 9px; }
  .action-toast { top: 12px; right: 16px; }
  .global-back-button {
    top: 82px;
    left: 12px;
    min-height: 38px;
    padding: 0 12px;
    font-size: 12px;
  }
  .site-header { height: 72px; padding: 0 18px; }
  .site-header { gap: 8px; }
  .site-header .brand { flex: 1 1 auto; min-width: 0; }
  .site-header .brand > span:last-child { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .mobile-menu-toggle { flex: 0 0 auto; min-height: 38px; padding: 0 11px; }
  .site-header > .header-cta { max-width: 100px; }
  .site-header > .header-cta.button-with-icon { gap: 6px; padding: 3px 4px 3px 10px; }
  .site-header > .header-cta .button-icon { width: 28px; height: 28px; font-size: 13px; }
  .customer-login-showcase { min-height: 490px; padding: 28px 20px; }
  .customer-login-showcase-copy { margin: 44px 0 34px; }
  .customer-login-showcase-copy h1 { font-size: clamp(42px, 14vw, 58px); }
  .customer-login-benefits { grid-template-columns: 1fr; gap: 7px; }
  .customer-login-benefits > div { grid-template-columns: 34px 1fr; min-height: 0; padding: 11px; }
  .customer-login-benefits span { grid-row: span 2; }
  .customer-login-benefits small { grid-column: 2; }
  .customer-login-panel { padding: 34px 20px 44px; }
  .customer-login-back { margin-bottom: 38px; }
  .customer-login-heading h2 { font-size: clamp(44px, 14vw, 58px); }
  .customer-login-new { align-items: flex-start; flex-direction: column; }
  .customer-login-new .button { width: 100%; }
  .header-cta { min-height: 42px; font-size: 11px; }
  .header-cta.button-with-icon { gap: 9px; padding: 4px 5px 4px 13px; }
  .header-cta .button-icon { width: 32px; height: 32px; }
  .hero-actions .button-with-icon { width: min(100%, 360px); }
  .hero-copy { width: calc(100% - 36px); padding-top: 55px; }
  .hero-copy h1 { font-size: 58px; }
  .hero-proof { font-size: 10px; }
  .hero-actions { align-items: flex-start; flex-direction: column; }
  .hero-stats { gap: 24px; margin-top: 50px; flex-wrap: wrap; }
  .design-clarity .public-hero { min-height: 930px; }
  .design-clarity .public-hero::after { height: 230px; border-radius: 18px; }
  .design-clarity .hero-copy { padding-top: 285px; }
  .design-clarity .hero-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; margin-top: 34px; }
  .design-clarity .hero-stats div { display: grid; gap: 3px; padding: 9px 4px; text-align: center; background: #fff; border: 1px solid #d7e1e8; border-radius: 10px; }
  .design-clarity .hero-stats strong { font-size: 21px; }
  .design-clarity .hero-stats span { font-size: 8px; }
  .trust-strip { justify-content: flex-start; padding-left: 20px; }
  .section { padding: 80px 20px; }
  .section-heading { gap: 20px; margin-bottom: 40px; }
  .service-grid { grid-template-columns: 1fr; }
  .service-featured { grid-column: auto; }
  .about-photo { min-height: 440px; }
  .contact-section { padding: 80px 20px; }
  .site-footer { align-items: flex-start; flex-direction: column; }
  .site-footer nav { flex-wrap: wrap; }
  .form-header .brand small { display: none; }
  .wizard-shell { gap: 18px; padding: 18px 12px 42px; }
  .wizard-intro { padding: 0 6px; }
  .wizard-intro h1 { font-size: clamp(38px, 12vw, 54px); }
  .wizard-intro > p:not(.kicker) { margin-bottom: 4px; font-size: 14px; }
  .wizard-card { border-radius: 20px; box-shadow: 0 18px 55px rgba(24,35,24,.1); }
  .wizard-top { padding: 19px 20px 14px; }
  .wizard-step { min-height: 0; padding: 30px 20px 34px; }
  .wizard-step h2 { font-size: clamp(32px, 10vw, 42px); }
  .wizard-error { margin: 16px 22px 0; }
  .wizard-actions { grid-template-columns: 92px minmax(0, 1fr); gap: 10px; padding: 14px 20px 18px; }
  .wizard-actions .wizard-back { justify-content: flex-start; min-height: 48px; }
  .wizard-actions .wizard-next, .wizard-actions .wizard-submit { min-height: 50px; }
  .summary-card { padding: 4px 16px; }
  .summary-row { grid-template-columns: 106px minmax(0, 1fr); gap: 14px; padding: 14px 0; }
  .summary-card dt { font-size: 11px; }
  .summary-card dd { font-size: 13px; }
  .consent-field { margin-top: 18px; padding: 14px; }
  .consent-error { margin-left: 34px; }
  .field-grid, .choice-grid, .detail-grid { grid-template-columns: 1fr; }
  label.wide { grid-column: auto; }
  .field-grid > .wide { grid-column: auto; }
  .voice-row { align-items: flex-start; flex-direction: column; }
  .choice-grid { grid-template-columns: 1fr 1fr; }
  .payment-choices, .account-password-fields { grid-template-columns: 1fr; }
  .account-offer-head { flex-direction: column; }
  .choice-grid label span { min-height: 84px; }
  .shell > .top, .request-head { align-items: flex-start; flex-direction: column; }
  .dashboard-nav {
    position: sticky;
    top: 0;
    z-index: 70;
    height: auto;
    min-height: 76px;
    flex-wrap: wrap;
    gap: 10px;
    padding: 12px 16px 10px;
    box-shadow: 0 10px 26px rgba(9, 13, 9, .18);
  }
  .dashboard-nav .brand { order: 1; }
  .package-preview-switch { order: 2; }
  .dashboard-nav > .button.ghost { order: 3; }
  .dashboard-nav nav {
    order: 4;
    display: flex;
    width: 100%;
    align-self: auto;
    gap: 7px;
    overflow-x: auto;
    padding: 5px 0 2px;
    scrollbar-width: none;
  }
  .dashboard-nav nav::-webkit-scrollbar { display: none; }
  .dashboard-nav nav a {
    flex: 0 0 auto;
    min-height: 34px;
    padding: 0 12px;
    color: #cbd3cb;
    background: #232923;
    border: 1px solid #323a32;
    border-radius: 999px;
    font-size: 12px;
    white-space: nowrap;
  }
  .dashboard-nav nav a.active {
    color: #162012;
    background: var(--accent);
    border-color: var(--accent);
  }
  .dashboard-nav .brand { min-width: 0; }
  .dashboard-nav .brand > span:last-child { display: none; }
  .package-preview-switch { margin-left: auto; gap: 5px; }
  .package-preview-switch > span { display: none; }
  .package-preview-switch button { min-height: 30px; padding: 0 9px; }
  .dashboard-nav > .button.ghost { min-height: 34px; padding: 0 11px; font-size: 11px; }
  .dashboard-head { align-items: flex-start; flex-direction: column; }
  .dashboard-shell { width: min(100% - 22px, 1180px); padding-top: 22px; }
  .dashboard-head { gap: 16px; margin-bottom: 16px; }
  .dashboard-head h1 { font-size: 42px; line-height: 1; letter-spacing: -.055em; }
  .dashboard-head p:last-child { margin: 8px 0 0; font-size: 15px; line-height: 1.35; }
  .dashboard-head-actions { display: grid; grid-template-columns: 1fr 1fr; width: 100%; gap: 8px; }
  .dashboard-head-actions > .button,
  .dashboard-head-actions > form,
  .dashboard-head-actions > form > button { width: 100%; }
  .demo-sms-toggle { grid-column: 1 / -1; }
  .package-preview-summary { display: none; }
  .dashboard-stats, .dashboard-tools, .dashboard-request, .request-meta { grid-template-columns: 1fr; }
  .dashboard-stats { grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 7px; margin-bottom: 12px; }
  .dashboard-stats article { min-width: 0; padding: 11px 9px; border-radius: 12px; }
  .dashboard-stats span, .dashboard-stats small { font-size: 10px; line-height: 1.2; }
  .dashboard-stats strong { margin: 4px 0 1px; font-size: 24px; }
  .dashboard-tools { gap: 8px; margin: 12px 0; }
  .search-field { min-height: 42px; font-size: 16px; border-radius: 10px; }
  .dashboard-tools select { min-height: 42px; }
  .settings-metrics, .package-choice-grid, .business-type-grid { grid-template-columns: 1fr; }
  .design-studio { padding: 18px; }
  .design-studio-title { align-items: flex-start; flex-direction: column; }
  .design-choice { display: block; }
  .design-choice-visual { height: 105px; min-height: 0; }
  .design-preview-frame { min-height: 440px; padding: 10px; }
  .design-preview-frame iframe { height: 420px; }
  .admin-photo-grid { grid-template-columns: 1fr 1fr; }
  .repair-photo-columns { grid-template-columns: 1fr; }
  .industry-result-grid { grid-template-columns: 1fr; }
  .industry-result-grid article { min-height: 0; }
  .industry-result-grid span { margin-bottom: 30px; }
  .customer-account-nav nav { display: none; }
  .customer-portal { padding: 18px 12px 45px; }
  .customer-portal-hero { align-items: flex-start; flex-direction: column; padding: 26px 22px; border-radius: 18px; }
  .customer-portal-hero-actions { justify-items: stretch; width: 100%; }
  .customer-portal-hero-actions > .button { width: 100%; }
  .customer-portal-stats { justify-content: space-between; width: 100%; }
  .customer-portal-grid { grid-template-columns: 1fr; gap: 14px; margin-top: 14px; }
  .customer-portal-panel { padding: 20px; border-radius: 16px; }
  .customer-order-card { grid-template-areas: "summary" "meta" "state"; grid-template-columns: 1fr; }
  .customer-order-state { justify-items: stretch; }
  .customer-order-state .button { width: 100%; }
  .requests { gap: 10px; }
  .request.dashboard-request {
    grid-template-columns: 82px minmax(0, 1fr);
    gap: 9px;
    align-items: start;
    padding: 9px;
    border-radius: 13px;
  }
  .request-thumb {
    width: 82px;
    height: 82px;
    min-height: 0;
    aspect-ratio: 1;
    border-radius: 9px;
  }
  .request-thumb.placeholder {
    min-height: 0;
    font-size: 18px;
  }
  .request-main {
    min-width: 0;
    padding: 0;
  }
  .request-head {
    align-items: flex-start;
    flex-direction: row;
    gap: 8px;
  }
  .request-head > div {
    min-width: 0;
  }
  .request-id {
    margin-bottom: 1px !important;
    font-size: 8px;
    letter-spacing: .1em;
  }
  .request-head strong {
    display: block;
    overflow: hidden;
    font-size: 18px;
    line-height: 1.12;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .request-head > div > span {
    overflow: hidden;
    margin-top: 3px;
    font-size: 10px;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .request-head .status {
    flex: 0 0 auto;
    max-width: 96px;
    padding: 4px 7px;
    font-size: 9px;
    line-height: 1.15;
    text-align: center;
    white-space: normal;
  }
  .request-meta {
    gap: 4px;
    margin: 9px 0;
  }
  .request-meta p {
    display: grid;
    grid-template-columns: 64px minmax(0, 1fr);
    gap: 8px;
    align-items: baseline;
    min-width: 0;
    padding: 0;
    background: transparent;
    border-radius: 0;
    font-size: 11px;
  }
  .request-meta span {
    margin: 0;
    font-size: 7px;
    letter-spacing: .08em;
  }
  .request-meta strong {
    display: block;
    overflow: hidden;
    min-width: 0;
    font-size: 12px;
    line-height: 1.25;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .request-actions {
    gap: 6px;
  }
  .request-actions .button {
    min-height: 31px;
    padding: 0 9px;
    border-radius: 999px;
    font-size: 11px;
  }
  .customer-reaction-badge {
    width: 100%;
    height: 30px;
    margin-top: 2px;
    padding: 0 10px;
    border-radius: 10px;
    font-size: 11px;
  }
  .customer-reaction-badge::before {
    width: 16px;
    height: 16px;
    font-size: 10px;
  }
  .calendar-entry { grid-template-columns: 1fr; }
  .package-preview-upgrade, .package-preview-locked { align-items: flex-start; flex-direction: column; gap: 12px; }
  .package-preview-locked { display: flex; }
  .calendar-entry { gap: 8px; }
  .notification-item { grid-template-columns: 1fr; gap: 12px; }
  .appointment-actions, .customer-counter-proposal { align-items: stretch; flex-direction: column; }
  .customer-counter-proposal .button { width: 100%; }
  .monthly-damage-item summary { grid-template-columns: 1fr auto; gap: 9px; }
  .monthly-damage-item summary > small { grid-column: 1 / -1; }
  .monthly-damage-requests > a { grid-template-columns: 1fr auto; gap: 8px; }
  .monthly-damage-requests > a time { grid-column: 1; }
  .photo-lightbox { padding: 18px; }
  .photo-lightbox-previous { left: 12px; }
  .photo-lightbox-next { right: 12px; }
  .photo-lightbox-close { top: 12px; right: 12px; }
  .photo-lightbox-stage { width: 100%; height: calc(100dvh - 130px); }
  .photo-lightbox-count { top: 12px; left: 12px; }
  .photo-lightbox-tools { bottom: 12px; }
  .photo-lightbox-tools .photo-lightbox-reset { padding: 0 9px; }
  .calendar-tabs { width: 100%; }
  .calendar-tabs button { flex: 1; padding: 0 8px; font-size: 11px; }
  .calendar-week-view { grid-template-columns: repeat(7, minmax(145px, 1fr)); }
  .calendar-month-head, .calendar-month-view { min-width: 630px; }
  .calendar { overflow-x: auto; }
  .date-picker-popover { left: 50%; width: min(390px, calc(100vw - 48px)); transform: translateX(-50%); }
}

@media (max-width: 370px) {
  .site-header { padding: 0 14px; }
  .form-header .brand { font-size: 15px; }
  .form-header .brand-mark { width: 36px; height: 36px; }
  .request.dashboard-request { grid-template-columns: 76px minmax(0, 1fr); gap: 8px; padding: 8px; }
  .request-thumb { width: 76px; height: 76px; border-radius: 9px; }
  .request-head strong { font-size: 16px; }
  .request-head .status { max-width: 92px; padding: 5px 6px; font-size: 9px; }
  .request-meta p { grid-template-columns: 56px minmax(0, 1fr); gap: 6px; }
  .request-actions .button { min-height: 30px; padding: 0 8px; font-size: 10px; }
  .wizard-shell { padding-right: 8px; padding-left: 8px; }
  .wizard-step { padding-right: 16px; padding-left: 16px; }
  .wizard-actions { grid-template-columns: 1fr; }
  .wizard-actions .wizard-back { order: 2; justify-content: center; min-height: 40px; }
  .wizard-actions .wizard-next, .wizard-actions .wizard-submit { order: 1; }
  .summary-row { grid-template-columns: 1fr; gap: 5px; }
  .consent-check { padding-left: 32px; font-size: 11px; }
}

.demo-landing-header {
  display: flex;
  align-items: center;
  gap: 28px;
  padding: 22px max(24px, calc((100vw - 1240px) / 2));
  color: #f6f2e9;
  background: #101610;
}
.demo-landing-header nav { display: flex; gap: 22px; margin-left: auto; }
.demo-landing-header nav a { color: rgba(246,242,233,.78); text-decoration: none; font-weight: 800; }
.demo-landing {
  color: #101610;
  background: linear-gradient(180deg, #f4f7ef 0%, #ffffff 72%);
}
.demo-hero {
  display: grid;
  grid-template-columns: minmax(0, .92fr) minmax(340px, .62fr);
  gap: 42px;
  align-items: center;
  width: min(1240px, calc(100% - 48px));
  margin: 0 auto;
  padding: 54px 0 36px;
}
.demo-hero h1 {
  max-width: 900px;
  margin: 18px 0 20px;
  font-size: clamp(46px, 6.4vw, 86px);
  line-height: .94;
  letter-spacing: 0;
}
.demo-hero h1 em { color: #79a30f; font-style: normal; }
.demo-hero-copy > p:not(.kicker) {
  max-width: 760px;
  color: #5f6a5d;
  font-size: clamp(19px, 2vw, 25px);
  line-height: 1.45;
}
.demo-hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 30px; }
.demo-proof-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  max-width: 760px;
  margin-top: 28px;
}
.demo-proof-grid span {
  padding: 16px 18px;
  color: #5f6a5d;
  background: #fff;
  border: 1px solid #dde5d8;
  border-radius: 8px;
}
.demo-proof-grid strong { display: block; color: #101610; font-size: 24px; }
.demo-video-card {
  align-self: stretch;
  padding: 16px;
  color: #f6f2e9;
  background: #101610;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 8px;
  box-shadow: 0 26px 60px rgba(16,22,16,.22);
}
.demo-video-frame {
  overflow: hidden;
  aspect-ratio: 9 / 16;
  max-height: min(68vh, 720px);
  margin: 0 auto;
  background: #050805;
  border-radius: 6px;
}
.demo-video-player {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  background: #050805;
}
.demo-video-caption {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: center;
  padding: 14px 2px 0;
}
.demo-video-caption strong { font-size: 20px; }
.demo-video-caption span { color: rgba(246,242,233,.72); line-height: 1.35; text-align: right; }
.demo-phone-card {
  padding: 24px;
  color: #f6f2e9;
  background: linear-gradient(145deg, #101610, #1e261f);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 34px;
  box-shadow: 0 30px 70px rgba(16,22,16,.24);
}
.demo-phone-top { display: flex; align-items: center; gap: 10px; margin-bottom: 28px; }
.demo-phone-top span { width: 11px; height: 11px; background: var(--accent); border-radius: 50%; box-shadow: 0 0 0 7px rgba(201,255,56,.13); }
.demo-phone-card ol { display: grid; gap: 14px; margin: 0; padding: 0; list-style: none; }
.demo-phone-card li {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 14px;
  align-items: center;
  padding: 16px;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 18px;
}
.demo-phone-card li b {
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  color: #101610;
  background: var(--accent);
  border-radius: 14px;
}
.demo-summary,
.demo-pricing,
.demo-contact {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 26px;
  align-items: center;
  width: min(1240px, calc(100% - 48px));
  margin: 0 auto 24px;
  padding: 34px;
  background: #fff;
  border: 1px solid #dde5d8;
  border-radius: 8px;
  box-shadow: 0 22px 55px rgba(25,37,22,.08);
}
.demo-summary h2,
.demo-pricing h2,
.demo-contact h2 { margin: 8px 0 12px; font-size: clamp(32px, 4vw, 54px); line-height: 1; letter-spacing: 0; }
.demo-summary p,
.demo-pricing p,
.demo-contact p { color: #657064; font-size: 18px; line-height: 1.45; }
.demo-steps {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  width: min(1240px, calc(100% - 48px));
  margin: 0 auto 24px;
}
.demo-steps article,
.demo-price-card {
  padding: 24px;
  background: #fff;
  border: 1px solid #dde5d8;
  border-radius: 8px;
}
.demo-steps span,
.demo-price-card span {
  color: #79a30f;
  font-weight: 1000;
  font-size: 13px;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.demo-steps h3 { margin: 18px 0 10px; font-size: 24px; line-height: 1.05; }
.demo-steps p { color: #657064; line-height: 1.45; }
.demo-price-card strong { display: block; margin: 12px 0; font-size: 28px; line-height: 1.1; }
.demo-price-card.featured { color: #f6f2e9; background: #101610; border-color: #101610; }
.demo-price-card.featured p { color: rgba(246,242,233,.74); }
.demo-contact { margin-bottom: 0; border-radius: 8px 8px 0 0; background: #101610; color: #f6f2e9; }
.demo-contact p { color: rgba(246,242,233,.72); }
.demo-contact code { color: #101610; background: var(--accent); border-radius: 8px; padding: 3px 7px; }

@media (max-width: 900px) {
  .demo-landing-header { align-items: flex-start; flex-direction: column; padding: 18px; }
  .demo-landing-header nav { margin-left: 0; flex-wrap: wrap; }
  .demo-landing-header .button { width: 100%; }
  .demo-hero,
  .demo-summary,
  .demo-pricing,
  .demo-contact { grid-template-columns: 1fr; width: min(100% - 28px, 640px); }
  .demo-hero { padding: 44px 0 26px; }
  .demo-video-frame { max-height: 70vh; }
  .demo-video-caption { display: grid; }
  .demo-video-caption span { text-align: left; }
  .demo-phone-card { border-radius: 24px; }
  .demo-proof-grid,
  .demo-steps { grid-template-columns: 1fr; width: min(100% - 28px, 640px); }
  .demo-summary,
  .demo-pricing,
  .demo-contact { padding: 22px; border-radius: 8px; }
}
