*{box-sizing:border-box;margin:0;padding:0}:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;--bg: #0f0f0f;--bg-card: #191919;--bg-nav-active: #242424;--bg-icon-btn: #202020;--bg-input: #1a1a1a;--card-blue: #e3f5ff;--card-gray: #e5ecf6;--card-dark: #0f0f0f;--text: #ffffff;--text-muted: #aeaeae;--text-dark: #1c1c1c;--purple: #95a4fc;--blue-light: #b1e3ff;--mint: #baedbd;--orange: #fcb684;--red: #f87171;--blue: #60a5fa;--yellow: #f4bf24;--sidebar-w: 260px;--radius: 16px;--radius-sm: 8px;--radius-pill: 100px}html,body,#root{height:100%;background:var(--bg);color:var(--text)}body{background:var(--bg)}button,input,textarea,select{font:inherit}a{color:inherit;text-decoration:none}.app-shell{min-height:100vh;display:grid;grid-template-columns:var(--sidebar-w) 1fr}.sidebar{width:var(--sidebar-w);background:var(--bg);border-right:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;padding:28px 16px;gap:0;position:sticky;top:0;height:100vh;overflow-y:auto}.brand{display:flex;align-items:center;gap:10px;padding:4px 12px 28px}.brand-logo{width:32px;height:32px}.brand-name{font-size:22px;font-weight:700;letter-spacing:.04em;color:var(--text)}.nav-section{flex:1;display:flex;flex-direction:column;gap:4px}.nav-label{font-size:11px;font-weight:500;color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;padding:16px 12px 8px}.nav-item{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:var(--radius-sm);cursor:pointer;border:none;background:transparent;color:var(--text-muted);font-size:15px;font-weight:400;width:100%;text-align:left;transition:background .15s,color .15s;text-decoration:none}.nav-item:hover{background:#ffffff0d;color:var(--text)}.nav-item.active{background:var(--bg-nav-active);color:var(--text);font-weight:600}.nav-item svg{flex-shrink:0;opacity:.7}.nav-item.active svg{opacity:1}.nav-bottom{display:flex;flex-direction:column;gap:4px;padding-top:16px;border-top:1px solid rgba(255,255,255,.06)}.main-content{min-width:0;display:flex;flex-direction:column;background:var(--bg)}.mobile-topbar{display:none;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-card);border-bottom:1px solid rgba(255,255,255,.06);position:sticky;top:0;z-index:10}.mobile-topbar-brand{font-size:15px;font-weight:700;color:var(--yellow);letter-spacing:.04em;width:56px}.mobile-topbar-title{flex:1;text-align:center;font-size:16px;font-weight:600;color:var(--text)}.mobile-bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:80;background:var(--bg-card);border-top:1px solid rgba(255,255,255,.07);padding-bottom:env(safe-area-inset-bottom)}.mobile-bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:10px 4px;color:var(--text-muted);font-size:11px;font-weight:500;background:none;border:none;cursor:pointer;text-decoration:none;transition:color .15s}.mobile-bottom-nav-item.active{color:#fff}.mobile-bottom-nav-item svg{flex-shrink:0}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 28px 0}.topbar-left{display:flex;align-items:center;gap:14px;min-width:0}.topbar-avatar{width:44px;height:44px;border-radius:50%;background:var(--bg-nav-active);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;color:var(--text);flex-shrink:0;overflow:hidden}.topbar-avatar img{width:100%;height:100%;object-fit:cover}.topbar-welcome{font-size:13px;color:var(--text-muted);line-height:1.2}.topbar-name{font-size:18px;font-weight:600;color:var(--text);line-height:1.2}.topbar-center{flex:1;max-width:340px}.topbar-search{display:flex;align-items:center;gap:8px;background:var(--bg-input);border:1px solid rgba(255,255,255,.07);border-radius:var(--radius-pill);padding:9px 16px;color:var(--text-muted)}.topbar-search input{background:none;border:none;outline:none;color:var(--text);font-size:14px;width:100%}.topbar-search input::placeholder{color:var(--text-muted)}.topbar-right{display:flex;align-items:center;gap:8px}.topbar-icon-btn{width:40px;height:40px;border-radius:var(--radius-sm);background:var(--bg-icon-btn);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-muted);position:relative;transition:background .15s,color .15s}.topbar-icon-btn:hover{background:var(--bg-nav-active);color:var(--text)}.topbar-icon-btn .notif-dot{position:absolute;top:8px;right:8px;width:7px;height:7px;border-radius:50%;background:#ff2d55;border:1.5px solid var(--bg)}.page-content{padding:24px 28px 40px;display:flex;flex-direction:column;gap:20px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.page-header h1{font-size:22px;font-weight:700;color:var(--text);line-height:1.2}.page-header p{font-size:13px;color:var(--text-muted);margin-top:2px}.dash-layout{display:grid;grid-template-columns:1fr 300px;gap:20px;align-items:start}.dash-main,.dash-side{display:flex;flex-direction:column;gap:20px}.card{background:var(--bg-card);border-radius:var(--radius);padding:20px;border:1px solid rgba(255,255,255,.05)}.card.blue{background:var(--card-blue);color:var(--text-dark);border:none}.card.gray{background:var(--card-gray);color:var(--text-dark);border:none}.card.dark{background:var(--card-dark);border:1px solid rgba(255,255,255,.07)}.kpi-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.kpi-card{border-radius:var(--radius);padding:20px;display:flex;flex-direction:column;gap:6px;border:1px solid rgba(255,255,255,.05)}.kpi-card.blue{background:var(--card-blue);color:var(--text-dark);border:none}.kpi-card.gray{background:var(--card-gray);color:var(--text-dark);border:none}.kpi-card.dark{background:var(--bg-card);color:var(--text)}.kpi-label{font-size:13px;font-weight:400;opacity:.65}.kpi-value{font-size:28px;font-weight:700;line-height:1.1}.kpi-sub{font-size:12px;opacity:.55;margin-top:2px}.kpi-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;background:#0000001a;border-radius:20px;padding:2px 8px;margin-top:4px;width:fit-content}.kpi-card.blue .kpi-badge,.kpi-card.gray .kpi-badge{background:#00000014;color:var(--text-dark)}.kpi-card.dark .kpi-badge{background:#ffffff1a;color:var(--text)}.chart-card{background:var(--bg-card);border-radius:var(--radius);padding:20px;border:1px solid rgba(255,255,255,.05)}.chart-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:12px}.chart-title{font-size:15px;font-weight:600;color:var(--text)}.chart-subtitle{font-size:12px;color:var(--text-muted);margin-top:2px}.chart-legend{display:flex;gap:12px;flex-wrap:wrap}.chart-legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted)}.chart-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.bar-chart-wrap{display:flex;align-items:flex-end;gap:8px;height:140px;padding-bottom:4px}.bar-group{display:flex;align-items:flex-end;gap:3px;flex:1}.bar{flex:1;border-radius:4px 4px 0 0;min-width:8px;transition:opacity .15s}.bar:hover{opacity:.8}.bar-labels{display:flex;gap:8px;margin-top:8px}.bar-label{flex:1;text-align:center;font-size:11px;color:var(--text-muted)}.donut-wrap{display:flex;align-items:center;gap:20px}.donut-svg{flex-shrink:0}.donut-legend{display:flex;flex-direction:column;gap:10px;flex:1}.donut-legend-item{display:flex;align-items:center;gap:8px}.donut-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.donut-legend-label{font-size:13px;color:var(--text-muted);flex:1}.donut-legend-value{font-size:13px;font-weight:600;color:var(--text)}.side-panel-section{display:flex;flex-direction:column;gap:10px}.side-panel-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:4px}.side-panel-item{display:flex;align-items:flex-start;gap:10px}.side-panel-icon{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.side-panel-icon.blue{background:var(--card-blue)}.side-panel-icon.gray{background:var(--card-gray)}.notif-icon-created{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:#baedbd2e;color:var(--mint)}.notif-icon-updated{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:#95a4fc2e;color:var(--purple)}.notif-icon-deleted{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:#f871712e;color:var(--red)}.notif-time{white-space:nowrap}.side-panel-text{flex:1;min-width:0}.side-panel-label{font-size:13px;color:var(--text);font-weight:500;line-height:1.3}.side-panel-sub{font-size:12px;color:var(--text-muted);margin-top:2px}.side-panel-meta{font-size:11px;color:var(--text-muted);white-space:nowrap}.inkro-table{width:100%;border-collapse:collapse;font-size:14px}.inkro-table th{text-align:left;font-size:12px;font-weight:500;color:var(--text-muted);padding:0 0 10px;border-bottom:1px solid rgba(255,255,255,.06)}.inkro-table td{padding:11px 0;border-bottom:1px solid rgba(255,255,255,.04);color:var(--text);vertical-align:middle}.inkro-table tr:last-child td{border-bottom:none}.inkro-table .muted{color:var(--text-muted)}.table-name{font-weight:500}.table-avatar{width:28px;height:28px;border-radius:50%;background:var(--bg-nav-active);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--text);flex-shrink:0;overflow:hidden}.table-avatar img{width:100%;height:100%;object-fit:cover}.table-cell-with-avatar{display:flex;align-items:center;gap:8px}.table-badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:20px;font-size:12px;font-weight:500}.table-badge.termin{background:#f8717126;color:var(--red)}.table-badge.besprechung{background:#60a5fa26;color:var(--blue)}.section-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.section-header h2{font-size:15px;font-weight:600;color:var(--text)}.section-header p{font-size:12px;color:var(--text-muted);margin-top:2px}.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:var(--radius-sm);font-size:14px;font-weight:500;cursor:pointer;border:none;transition:opacity .15s,background .15s}.btn:hover{opacity:.88}.btn-primary{background:#fff;color:#0f0f0f}.btn-secondary{background:var(--bg-icon-btn);color:var(--text)}.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid rgba(255,255,255,.1)}.btn-ghost:hover{color:var(--text);border-color:#fff3}.btn-danger{background:#f8717126;color:var(--red)}.btn-sm{padding:6px 12px;font-size:12px}.ghost-btn{background:var(--bg-icon-btn);color:var(--text-muted);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-sm);padding:6px 12px;font-size:12px;cursor:pointer;transition:background .15s,color .15s}.ghost-btn:hover{background:var(--bg-nav-active);color:var(--text)}.ghost-btn.is-disabled{opacity:.35;pointer-events:none}.ghost-icon{background:var(--bg-icon-btn);color:var(--text-muted);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-sm);width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;font-size:16px;cursor:pointer;transition:background .15s,color .15s}.ghost-icon:hover{background:var(--bg-nav-active);color:var(--text)}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:13px;font-weight:500;color:var(--text-muted)}.form-input,.form-select,.form-textarea{background:var(--bg-input);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-sm);color:var(--text);padding:10px 14px;font-size:14px;width:100%;outline:none;transition:border-color .15s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#fff3}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.form-select option{background:var(--bg-card);color:var(--text)}.form-textarea{resize:vertical;min-height:80px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-actions{display:flex;justify-content:flex-end;gap:10px;padding-top:8px}.toggle-group{display:flex;gap:4px;background:var(--bg-input);border-radius:var(--radius-sm);padding:4px}.toggle-option{flex:1;padding:7px 12px;border-radius:6px;border:none;background:transparent;color:var(--text-muted);font-size:13px;font-weight:500;cursor:pointer;transition:background .15s,color .15s}.toggle-option.active{background:var(--bg-nav-active);color:var(--text)}.checkbox-group{display:flex;align-items:center;gap:8px;cursor:pointer}.checkbox-group input[type=checkbox]{width:16px;height:16px;accent-color:var(--purple);cursor:pointer}.modal{background:var(--bg-card);border-radius:var(--radius);border:1px solid rgba(255,255,255,.06);width:100%;max-width:560px;max-height:calc(100vh - 40px);overflow-y:auto;display:flex;flex-direction:column}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 0}.modal-header h2{font-size:17px;font-weight:600;color:var(--text)}.modal-close{background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:20px;line-height:1;padding:4px;border-radius:4px;transition:color .15s}.modal-close:hover{color:var(--text)}.modal-body{padding:20px 24px;display:flex;flex-direction:column;gap:14px;flex:1}.modal-footer{padding:0 24px 20px;display:flex;justify-content:flex-end;gap:10px}.modal-lg{max-width:740px}.modal-xl{max-width:900px}.toast-container{position:fixed;bottom:24px;right:24px;z-index:200;display:flex;flex-direction:column;gap:10px;pointer-events:none}.toast{background:var(--bg-nav-active);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-sm);padding:12px 16px;display:flex;align-items:flex-start;gap:10px;min-width:280px;max-width:380px;pointer-events:all;animation:toast-in .2s ease-out}@keyframes toast-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.toast-success{border-left:3px solid var(--mint)}.toast-error{border-left:3px solid var(--red)}.toast-info{border-left:3px solid var(--blue)}.toast-title{font-size:13px;font-weight:600;color:var(--text)}.toast-desc{font-size:12px;color:var(--text-muted);margin-top:2px}.confirm-icon{width:48px;height:48px;border-radius:50%;background:#f871711f;display:flex;align-items:center;justify-content:center;color:var(--red);margin:0 auto 8px}.image-preview-strip{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px}.tiny-preview{width:44px;height:44px;border-radius:var(--radius-sm);object-fit:cover;border:1px solid rgba(255,255,255,.08)}.tiny-preview-more{width:44px;height:44px;border-radius:var(--radius-sm);background:var(--bg-nav-active);display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--text-muted);border:1px solid rgba(255,255,255,.08)}.clickable-preview{cursor:pointer}.clickable-preview:hover{opacity:.85}.lightbox-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000eb;z-index:300;display:flex;align-items:center;justify-content:center}.lightbox-img{max-width:90vw;max-height:85vh;border-radius:var(--radius);object-fit:contain}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff1a;border:none;color:#fff;font-size:24px;width:48px;height:48px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center}.lightbox-nav.prev{left:20px}.lightbox-nav.next{right:20px}.lightbox-close{position:absolute;top:20px;right:20px;background:#ffffff1a;border:none;color:#fff;font-size:24px;width:44px;height:44px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center}.kind-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:500;white-space:nowrap}.kind-badge.appointment{background:#f8717126;color:var(--red)}.kind-badge.meeting{background:#60a5fa26;color:var(--blue)}.appointments-stack{display:flex;flex-direction:column;gap:20px}.filter-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.list-item{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.04)}.list-item:last-child{border-bottom:none}.list-item-main{flex:1;min-width:0}.list-item-name{font-size:14px;font-weight:500;color:var(--text)}.list-item-sub{font-size:12px;color:var(--text-muted);margin-top:2px}.list-item-meta{display:flex;align-items:center;gap:8px;flex-shrink:0}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.calendar-day-header{text-align:center;font-size:11px;font-weight:500;color:var(--text-muted);padding:8px 0}.calendar-day{background:var(--bg-card);border-radius:var(--radius-sm);padding:8px;min-height:80px;cursor:pointer;transition:background .15s;border:1px solid transparent}.calendar-day:hover{background:var(--bg-nav-active)}.calendar-day.today{border-color:var(--yellow)}.calendar-day.selected{background:var(--bg-nav-active);border-color:#ffffff1f}.calendar-day.other-month{opacity:.35}.calendar-day-number{font-size:13px;font-weight:500;color:var(--text);margin-bottom:4px}.calendar-day.today .calendar-day-number{color:var(--yellow);font-weight:700}.dot-row{display:flex;gap:3px;flex-wrap:wrap}.dot-termin{width:6px;height:6px;border-radius:50%;background:var(--red);flex-shrink:0}.dot-besprechung{width:6px;height:6px;border-radius:50%;background:var(--blue);flex-shrink:0}.calendar-header{display:flex;align-items:center;gap:10px;margin-bottom:16px}.calendar-month-title{font-size:17px;font-weight:600;color:var(--text);flex:1}.week-view{display:flex;flex-direction:column;gap:2px}.week-day-row{display:flex;gap:8px;align-items:flex-start}.week-day-label{width:80px;flex-shrink:0;font-size:12px;color:var(--text-muted);padding-top:12px}.week-day-events{flex:1;display:flex;flex-direction:column;gap:4px;min-height:48px}.week-pill{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:var(--radius-sm);background:var(--bg-card);font-size:13px;cursor:pointer;border-right:3px solid transparent;transition:background .15s}.week-pill:hover{background:var(--bg-nav-active)}.week-pill.termin{border-right-color:var(--red)}.week-pill.besprechung{border-right-color:var(--blue)}.timeline-card{background:var(--bg-card);border-radius:var(--radius-sm);padding:12px 14px;display:flex;align-items:flex-start;gap:10px;border-left:3px solid transparent;cursor:pointer;transition:background .15s}.timeline-card:hover{background:var(--bg-nav-active)}.timeline-card.termin{border-left-color:var(--red)}.timeline-card.besprechung{border-left-color:var(--blue)}.timeline-kind-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-top:4px}.customer-avatar{width:36px;height:36px;border-radius:50%;background:var(--bg-nav-active);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:var(--text);flex-shrink:0}.statistik-stack{display:flex;flex-direction:column;gap:20px}.artist-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}.artist-card{background:var(--bg-card);border-radius:var(--radius);padding:18px;border:1px solid rgba(255,255,255,.05);display:flex;flex-direction:column;gap:10px}.artist-avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:#000;flex-shrink:0}.artist-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:500}.artist-badge.fest{background:#baedbd33;color:var(--mint)}.artist-badge.stuhlmiete{background:#95a4fc33;color:var(--purple)}.settings-section{display:flex;flex-direction:column;gap:14px}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.04)}.settings-row:last-child{border-bottom:none}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:20px}.auth-card{background:var(--bg-card);border-radius:var(--radius);border:1px solid rgba(255,255,255,.07);padding:36px;width:100%;max-width:420px;display:flex;flex-direction:column;gap:20px}.auth-logo{text-align:center}.auth-logo-text{font-size:28px;font-weight:700;letter-spacing:.04em;color:var(--text)}.auth-title{font-size:20px;font-weight:700;text-align:center}.auth-sub{font-size:14px;color:var(--text-muted);text-align:center;margin-top:-12px}.auth-divider{display:flex;align-items:center;gap:12px;color:var(--text-muted);font-size:12px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#ffffff14}.muted{color:var(--text-muted)}.capitalize{text-transform:capitalize}.empty-state{text-align:center;padding:32px 16px;color:var(--text-muted);font-size:14px}.empty-state.compact{padding:16px}.money{font-weight:600;font-size:16px;color:var(--text)}.money.neutral-money{color:var(--text-muted)}.stack{display:flex;flex-direction:column;gap:0}.stack.gap-sm{gap:6px}.stack.gap-md{gap:12px}.no-top-margin{margin-top:0!important}.grid{display:grid;gap:14px}.grid.two{grid-template-columns:1fr 1fr}.grid.three{grid-template-columns:repeat(3,1fr)}.grid.two-equal{grid-template-columns:1fr 1fr;gap:10px}.dashboard-top{grid-template-columns:1fr 1fr}.monthly-header{align-items:flex-start}.month-nav{display:flex;align-items:center;gap:6px;flex-shrink:0}.sub-card{background:#ffffff08;border-radius:var(--radius-sm);padding:12px 14px;border:1px solid rgba(255,255,255,.04);margin-top:10px}.sub-card.small{padding:10px 12px}.sub-card.green{border-left:3px solid var(--mint)}.stat-value{font-size:24px;font-weight:700;margin-top:4px}.stat-value.small{font-size:18px}.dashboard-next-item{align-items:flex-start}.dashboard-next-main{flex:1;min-width:0}.dashboard-next-name{font-size:14px;font-weight:500;color:var(--text)}.dashboard-next-time{font-size:12px;color:var(--text-muted);margin-top:2px}.dashboard-next-deposit{font-size:11px;color:var(--mint);margin-top:3px}.image-upload-area{border:2px dashed rgba(255,255,255,.1);border-radius:var(--radius-sm);padding:20px;text-align:center;cursor:pointer;color:var(--text-muted);font-size:13px;transition:border-color .15s}.image-upload-area:hover{border-color:#fff3}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#fff3}@media (max-width: 900px){.app-shell{grid-template-columns:1fr}.sidebar{display:none}.sidebar.mobile-open{display:flex;position:fixed;left:0;top:0;bottom:0;z-index:100;width:var(--sidebar-w);box-shadow:4px 0 32px #0009}.topbar{display:none}.mobile-topbar,.mobile-bottom-nav{display:flex}.page-content{padding-bottom:calc(72px + env(safe-area-inset-bottom))}.dash-layout{grid-template-columns:1fr}.kpi-grid{grid-template-columns:1fr 1fr}.grid.two{grid-template-columns:1fr}}@media (max-width: 600px){.kpi-grid{grid-template-columns:1fr}.topbar-center{display:none}.page-content{padding:16px 16px 32px}.appointment-card{flex-direction:column;gap:8px}.appointment-secondary{min-width:unset;width:100%;border-top:1px solid rgba(255,255,255,.06);padding-top:8px}.appointment-actions{width:100%;justify-content:flex-end}.appointment-summary-grid{grid-template-columns:1fr 1fr 1fr!important}.page-header{flex-direction:column;align-items:flex-start}.month-nav{flex-wrap:wrap}.hide-mobile{display:none}.analytics-grid{grid-template-columns:1fr 1fr!important}.calendar-toolbar{flex-direction:column;align-items:flex-start;gap:8px}.week-view-grid{grid-template-columns:repeat(7,minmax(100px,1fr));overflow-x:auto}.modal-overlay{padding:8px;align-items:flex-end}.modal-card{max-height:92vh;border-radius:16px 16px 0 0}.modal-form{padding:16px 16px 20px}.modal-header{padding:16px 16px 0}.grid.two-equal{grid-template-columns:1fr}}.input{background:var(--bg-input);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-sm);color:var(--text);padding:10px 14px;font-size:14px;width:100%;outline:none;transition:border-color .15s}.input:focus{border-color:#fff3}.input::placeholder{color:var(--text-muted)}.primary-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;border:none;background:#fff;color:#0f0f0f;transition:background .15s,opacity .15s}.primary-btn:hover{background:#e8e8e8}.primary-btn:disabled{opacity:.4;cursor:not-allowed}.primary-btn.full-width{width:100%;justify-content:center}.danger-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;border:1px solid rgba(248,113,113,.2);background:#f871711a;color:var(--red);transition:background .15s}.danger-btn:hover{background:#f871712e}.link-btn{background:none;border:none;color:var(--purple);font-size:13px;cursor:pointer;padding:0;display:inline-flex;align-items:center;gap:4px;transition:opacity .15s}.link-btn:hover{opacity:.8}.ghost-icon.danger{color:var(--red)}.ghost-icon.danger:hover{background:#f871711a;color:var(--red)}.calendar-switch-group{display:flex;gap:3px;background:#ffffff0d;border-radius:var(--radius-sm);padding:3px;flex-wrap:wrap}.calendar-switch-group .ghost-btn{border:none;background:transparent;font-size:13px;padding:6px 14px;border-radius:6px;color:var(--text-muted);font-weight:500}.calendar-switch-group .ghost-btn:hover{background:#ffffff0d;color:var(--text)}.calendar-switch-group .ghost-btn.active-filter{background:#fff;color:#0f0f0f;font-weight:600}.active-filter{background:#fff!important;color:#0f0f0f!important}.field-label{font-size:13px;font-weight:500;color:var(--text-muted);display:block;margin-bottom:4px}.field-error{font-size:13px;color:var(--red);background:#f8717114;border-radius:var(--radius-sm);padding:8px 12px}.field-hint{font-size:12px;color:var(--yellow);margin-top:6px}.field-success{font-size:13px;color:var(--mint);background:#baedbd14;border-radius:var(--radius-sm);padding:8px 12px}.field-group{display:flex;flex-direction:column;gap:4px}.login-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:20px}.login-card{background:var(--bg-card);border-radius:var(--radius);border:1px solid rgba(255,255,255,.07);padding:36px 32px;width:100%;max-width:420px;display:flex;flex-direction:column;gap:20px}.login-brand{display:flex;align-items:center;gap:10px}.brand-badge{width:38px;height:38px;border-radius:var(--radius-sm);background:var(--yellow);display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:800;color:#000;flex-shrink:0;overflow:hidden}.brand-badge img{width:100%;height:100%;object-fit:cover}.brand-text{display:flex;flex-direction:column;gap:1px}.brand-title{font-size:17px;font-weight:700;color:var(--text)}.brand-subtitle{font-size:11px;color:var(--text-muted)}.login-headline h1{font-size:20px;font-weight:700;margin-bottom:4px}.login-headline p{font-size:13px;color:var(--text-muted)}.login-form{display:flex;flex-direction:column;gap:10px}.login-submit{width:100%;justify-content:center}.login-footer{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-muted)}.signup-type-select{display:flex;flex-direction:column;gap:10px}.signup-type-card{display:flex;align-items:flex-start;gap:14px;padding:16px;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.08);background:var(--bg-input);cursor:pointer;text-align:left;color:var(--text);transition:border-color .15s,background .15s}.signup-type-card:hover{border-color:#ffffff2e;background:var(--bg-nav-active)}.signup-type-title{font-size:15px;font-weight:600;margin-bottom:3px}.signup-type-desc{font-size:12px;color:var(--text-muted)}.signup-type-badge{display:inline-flex;align-items:center;gap:6px;background:var(--bg-nav-active);border-radius:20px;padding:4px 12px;font-size:12px;color:var(--text-muted)}.card-header{margin-bottom:14px}.card-title{font-size:15px;font-weight:600;color:var(--text)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:center;justify-content:center;padding:20px}.modal-card{background:var(--bg-card);border-radius:var(--radius);border:1px solid rgba(255,255,255,.06);width:100%;max-width:520px;max-height:calc(100vh - 40px);overflow-y:auto}.modal-form{padding:20px 24px 24px;display:flex;flex-direction:column;gap:12px}.modal-title{font-size:17px;font-weight:600;color:var(--text)}.modal-actions{display:flex;justify-content:flex-end;gap:10px;padding-top:8px}.color-picker-row{display:flex;gap:8px;flex-wrap:wrap}.color-swatch{width:28px;height:28px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:border-color .15s,transform .1s}.color-swatch:hover{transform:scale(1.1)}.color-swatch.selected{border-color:#fff}.calendar-access-list{display:flex;flex-direction:column;gap:8px}.calendar-access-row{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:var(--text)}.calendar-access-row input[type=checkbox]{accent-color:var(--purple);width:15px;height:15px;cursor:pointer}.calendar-access-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.member-list{display:flex;flex-direction:column;gap:0}.member-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.04)}.member-row:last-child{border-bottom:none}.member-avatar{width:38px;height:38px;border-radius:50%;background:var(--bg-nav-active);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--text);flex-shrink:0;overflow:hidden}.member-avatar img{width:100%;height:100%;object-fit:cover}.member-info{flex:1;min-width:0}.member-name{font-size:14px;font-weight:500;color:var(--text)}.member-email{font-size:12px;color:var(--text-muted)}.member-instagram{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text-muted);margin-top:2px}.member-actions{display:flex;gap:6px}.member-role-badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:20px;font-size:11px;font-weight:600;background:#ffffff0f;color:var(--text-muted);white-space:nowrap}.member-role-badge.owner{background:#f4bf2426;color:var(--yellow)}.member-role-badge.artist{background:#95a4fc26;color:var(--purple)}.member-role-badge.fest{background:#baedbd26;color:var(--mint)}.member-role-badge.stuhlmiete{background:#95a4fc26;color:var(--purple)}.global-search-wrap{position:relative;width:100%}.global-search-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--bg-card);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);z-index:200;overflow:hidden;box-shadow:0 8px 24px #0006;max-height:360px;overflow-y:auto}.search-section-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:8px 14px 4px}.search-result-item{display:block;width:100%;text-align:left;padding:8px 14px;background:none;border:none;cursor:pointer;transition:background .1s}.search-result-item:hover{background:#ffffff0d}.search-result-name{font-size:13px;font-weight:500;color:var(--text)}.search-result-meta{font-size:12px;color:var(--text-muted);margin-top:1px}.search-empty{padding:12px 14px;font-size:13px;color:var(--text-muted)}.open-invoice-row{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.open-invoice-main{flex:1;min-width:0}.open-invoice-name{font-size:15px;font-weight:600;color:var(--text);margin-bottom:2px}.settings-backup-card{margin-top:20px}.settings-backup-actions{display:flex;gap:10px;flex-wrap:wrap}.opening-hours-grid{display:flex;flex-direction:column;gap:8px}.opening-hours-row{display:grid;grid-template-columns:110px 130px 1fr;align-items:center;gap:12px;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.04)}.opening-hours-row:last-child{border-bottom:none}.opening-hours-day{font-size:14px;font-weight:500;color:var(--text)}.opening-hours-toggle{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-muted);cursor:pointer;-webkit-user-select:none;user-select:none}.opening-hours-toggle input[type=checkbox]{width:15px;height:15px;accent-color:var(--purple);cursor:pointer}.opening-hours-times{display:flex;align-items:center;gap:8px}.opening-hours-times .input{width:90px;padding:6px 10px;font-size:13px}.opening-hours-closed{font-size:14px}.bericht-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.bericht-card{display:flex;gap:20px;align-items:flex-start}.bericht-card-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.bericht-card-body{flex:1;min-width:0}.bericht-selectors{display:flex;gap:8px;margin-bottom:14px}.bericht-selectors .input{flex:1;min-width:0}.bericht-checkbox-label{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-muted);margin-bottom:16px;cursor:pointer;-webkit-user-select:none;user-select:none}.bericht-checkbox-label input[type=checkbox]{width:15px;height:15px;accent-color:var(--purple);cursor:pointer}@media (max-width: 768px){.bericht-grid{grid-template-columns:1fr}}.settings-layout{display:grid;grid-template-columns:280px 1fr;gap:20px;align-items:start}.settings-profile-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;padding:24px}.settings-avatar{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;color:#000;flex-shrink:0;overflow:hidden;position:relative}.settings-avatar--editable{cursor:pointer}.settings-avatar img{width:100%;height:100%;object-fit:cover}.settings-avatar-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000073;border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;color:#fff}.settings-avatar--editable:hover .settings-avatar-overlay{opacity:1}.settings-avatar-saving{font-size:12px;color:#fff}.settings-profile-name{font-size:17px;font-weight:600;color:var(--text);margin-top:4px}.settings-name-btn{background:none;border:none;cursor:pointer;display:flex;align-items:center;gap:6px;transition:opacity .15s}.settings-name-btn:hover{opacity:.8}.settings-name-edit-hint,.settings-profile-email{font-size:13px;color:var(--text-muted)}.settings-form{display:flex;flex-direction:column;gap:14px}.settings-form-fields{display:flex;flex-direction:column;gap:12px}.settings-pw-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.settings-form-actions{display:flex;justify-content:flex-end}.settings-name-form{display:flex;flex-direction:column;gap:8px;width:100%}.settings-name-actions{display:flex;gap:8px;justify-content:center}.dashboard-stack{display:flex;flex-direction:column;gap:20px}.appointment-summary-grid{grid-template-columns:repeat(3,1fr)!important}.appointments-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.section-label{font-size:13px;font-weight:500;color:var(--text-muted)}.appointments-group-stack{gap:16px}.appointments-date-group{display:flex;flex-direction:column;gap:8px}.appointments-date-header{display:flex;align-items:center;justify-content:space-between;padding:8px 0 4px}.appointments-date-header h3{font-size:14px;font-weight:600;color:var(--text)}.compact-stack{gap:8px}.appointment-row-card{padding:14px 16px}.card-kind-appointment{border-left:3px solid rgba(248,113,113,.4)}.card-kind-meeting{border-left:3px solid rgba(96,165,250,.4)}.appointment-past-card{opacity:.6}.appointment-card{display:flex;align-items:flex-start;gap:14px}.appointment-primary{flex:1;min-width:0}.appointment-secondary{min-width:140px;font-size:13px;color:var(--text-muted)}.appointment-actions{display:flex;gap:6px;align-items:flex-start}.entry-kind-row{display:flex;align-items:center;gap:6px;margin-bottom:6px}.appointment-name{font-size:15px;font-weight:600;color:var(--text)}.top-name{margin-bottom:2px}.appointment-time{font-size:13px;color:var(--text-muted)}.appointment-note{font-size:12px;margin-top:4px}.appointment-image-count{font-size:12px;color:var(--text-muted)}.appointment-finance-line{font-size:12px;margin-top:4px}.past-pill{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:11px;background:#ffffff0f;color:var(--text-muted)}.today-pill{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:11px;background:#f4bf2426;color:var(--yellow)}.appointments-past-section{margin-top:8px}.appointments-past-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;background:var(--bg-card);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-sm);padding:12px 16px;font-size:14px;font-weight:500;color:var(--text-muted);cursor:pointer;transition:background .15s,color .15s}.appointments-past-toggle:hover{background:var(--bg-nav-active);color:var(--text)}.past-groups-wrap{margin-top:10px}.actions{display:flex;align-items:center;gap:8px}.row-wrap{flex-wrap:wrap}.customer-row{align-items:flex-start;padding:14px 0}.customer-name-block{flex:1;min-width:180px}.customer-name{font-size:15px;font-weight:600;color:var(--text);margin-bottom:2px}.customer-stats{font-size:12px;min-width:160px}.customer-notes{font-size:12px;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:240px}.sm-btn{padding:5px 10px!important;font-size:12px!important}.calendar-layout{grid-template-columns:1fr 300px;gap:16px}.customer-filter-banner{display:flex;align-items:center;justify-content:space-between;gap:8px;background:#95a4fc1a;border:1px solid rgba(149,164,252,.25);border-radius:var(--radius-sm);padding:8px 14px;font-size:13px;color:var(--text-muted);margin-bottom:12px}.customer-filter-banner strong{color:var(--text)}.calendar-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.calendar-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px}.calendar-nav-group{display:flex;align-items:center;gap:10px}.calendar-nav-group h2{font-size:16px;font-weight:700;color:var(--text);min-width:160px}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;font-size:11px;font-weight:600;color:var(--text-muted);letter-spacing:.05em;text-transform:uppercase;padding:0 0 8px;gap:2px}.day{border-radius:var(--radius-sm);min-height:88px;padding:8px;border:1px solid rgba(255,255,255,.04);background:#ffffff05;font-size:12px;transition:background .15s,border-color .15s;display:flex;flex-direction:column;justify-content:space-between}.day.empty{background:transparent;border-color:transparent;pointer-events:none}.day.interactive{cursor:pointer}.day.interactive:hover{background:#ffffff0d;border-color:#ffffff14}.day.selected{background:var(--bg-nav-active);border-color:#ffffff24}.day-number{font-size:13px;font-weight:500;color:var(--text);width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:50%;align-self:flex-start}.day-number-today{background:#fff;color:#0f0f0f!important;font-weight:700}.day-is-today,.week-day-today{border-color:#ffffff2e!important}.week-day-number-today{color:#fff;font-weight:800}.day-dots{display:flex;gap:4px;flex-wrap:wrap;align-items:center}.day-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.dot-termin{background:#f87171}.dot-besprechung{background:#60a5fa}.day-dot-more{width:6px;height:6px;border-radius:50%;background:#ffffff40;flex-shrink:0}.day-events-list{display:flex;flex-direction:column;gap:3px}.day-events-list{display:flex;flex-direction:column;gap:2px;margin-top:2px}.day-event-chip{display:flex;align-items:center;gap:4px;padding:3px 6px;border-radius:4px;font-size:10px;overflow:hidden;white-space:nowrap;line-height:1.4;border-left:3px solid transparent}.day-event-chip.chip-termin{background:#f871711f;border-left-color:#f87171}.day-event-chip.chip-besprechung{background:#60a5fa1f;border-left-color:#60a5fa}.day-event-time{flex-shrink:0;color:var(--text-muted);font-variant-numeric:tabular-nums}.day-event-artist{overflow:hidden;text-overflow:ellipsis;font-weight:500;color:var(--text)}.day-event-more{font-size:10px;color:var(--text-muted);padding:2px 0 0 2px}.week-tl{display:flex;flex-direction:column;overflow:hidden}.week-tl-header{display:grid;grid-template-columns:52px repeat(7,1fr);border-bottom:1px solid rgba(255,255,255,.07);flex-shrink:0}.week-tl-day-head{padding:8px 4px 10px;text-align:center;border-left:1px solid rgba(255,255,255,.05);background:none;cursor:pointer;transition:background .12s}.week-tl-day-head:hover{background:#ffffff08}.week-tl-day-head.today{background:#f4bf240d}.week-tl-day-name{font-size:10px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:4px}.week-tl-day-num{font-size:15px;font-weight:600;color:var(--text);width:28px;height:28px;display:flex;align-items:center;justify-content:center;margin:0 auto;border-radius:50%}.week-tl-day-num.today{background:var(--yellow);color:#000}.week-tl-body{display:flex;overflow-y:auto;max-height:580px}.week-tl-time-col{width:52px;flex-shrink:0}.week-tl-time-label{height:60px;display:flex;align-items:flex-start;justify-content:flex-end;padding:3px 8px 0 0;font-size:10px;color:var(--text-muted);font-variant-numeric:tabular-nums;box-sizing:border-box}.week-tl-days{flex:1;display:grid;grid-template-columns:repeat(7,minmax(80px,1fr));min-width:0;overflow-x:auto}.week-tl-day-col{position:relative;border-left:1px solid rgba(255,255,255,.05)}.week-tl-slot{height:60px;border-top:1px solid rgba(255,255,255,.04);cursor:pointer;box-sizing:border-box}.week-tl-slot:hover{background:#ffffff06}.week-tl-closed{position:absolute;left:0;right:0;background:repeating-linear-gradient(45deg,rgba(255,255,255,.015),rgba(255,255,255,.015) 3px,transparent 3px,transparent 9px);pointer-events:none;z-index:1}.week-tl-appt{position:absolute;border-left:3px solid;border-radius:4px;padding:3px 5px;overflow:hidden;cursor:pointer;z-index:2;box-sizing:border-box;transition:filter .1s}.week-tl-appt:hover{filter:brightness(1.15)}.week-tl-appt-name{font-size:11px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.week-tl-appt-time{font-size:10px;color:#fff9;white-space:nowrap;font-variant-numeric:tabular-nums}.week-view-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.week-day-card{background:#ffffff05;border:1px solid rgba(255,255,255,.05);border-radius:var(--radius-sm);padding:10px 8px;cursor:pointer;text-align:left;min-height:130px;transition:background .15s,border-color .15s;display:flex;flex-direction:column;gap:6px}.week-day-card:hover{background:#ffffff0d;border-color:#ffffff1a}.week-day-card.selected{background:var(--bg-nav-active);border-color:#ffffff24}.week-day-name{font-size:11px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px}.week-day-number{font-size:16px;font-weight:700;color:var(--text)}.week-day-events{display:flex;flex-direction:column;gap:3px}.week-pill{display:flex;align-items:center;gap:5px;padding:4px 7px;border-radius:5px;font-size:11px;border-left:3px solid transparent;overflow:hidden;white-space:nowrap}.week-pill.termin{background:#f871711a;border-left-color:#f87171}.week-pill.besprechung{background:#60a5fa1a;border-left-color:#60a5fa}.week-pill-time{flex-shrink:0;color:var(--text-muted);font-size:10px;font-variant-numeric:tabular-nums}.week-pill-name{flex:1;overflow:hidden;text-overflow:ellipsis;color:var(--text);font-weight:500}.week-pill-artist{color:var(--text-muted);font-size:10px;margin-left:auto;flex-shrink:0}.small-muted{font-size:11px;color:var(--text-muted)}.timeline-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.06)}.timeline-date-label{font-size:15px;font-weight:700;color:var(--text);flex:1}.timeline-slots{position:relative;display:flex;flex-direction:column;gap:0}.timeline-slot{display:flex;gap:16px;height:60px;border-top:1px solid rgba(255,255,255,.04);flex-shrink:0}.timeline-time{width:48px;flex-shrink:0;font-size:11px;font-weight:500;color:var(--text-muted);padding-top:6px;letter-spacing:.02em}.timeline-slot-bg{flex:1;cursor:pointer}.timeline-slot-bg:hover{background:#ffffff04}.timeline-closed-overlay{position:absolute;background:repeating-linear-gradient(-45deg,rgba(255,255,255,.025) 0px,rgba(255,255,255,.025) 2px,transparent 2px,transparent 8px);border-radius:4px;pointer-events:none;z-index:1}.timeline-appts-layer{position:absolute;top:0;left:64px;right:0;pointer-events:none}.timeline-appt-card{position:absolute;left:0;right:8px;padding:8px 12px;border-radius:var(--radius-sm);cursor:pointer;pointer-events:auto;transition:filter .15s;border-left:3px solid transparent;overflow:hidden;box-sizing:border-box}.timeline-appt-card:hover{filter:brightness(1.15)}.timeline-appt-card.timeline-termin{background:#f871711a;border-left-color:#f87171}.timeline-appt-card.timeline-besprechung{background:#60a5fa1a;border-left-color:#60a5fa}.timeline-appt-name{font-size:14px;font-weight:600;color:var(--text)}.timeline-appt-meta{font-size:11px;color:var(--text-muted);display:flex;align-items:center;gap:5px;margin-top:4px}.timeline-kind-dot{display:inline-block;width:6px;height:6px;border-radius:50%;flex-shrink:0}.detail-panel{position:sticky;top:80px;align-self:start}.day-detail-item{padding:14px 0;align-items:flex-start;border-right:none!important;position:relative}.day-detail-item:before{content:none}.day-detail-main{flex:1;min-width:0}.detail-customer-name{font-size:15px;font-weight:700;color:var(--text);margin:6px 0 4px}.time-range-detail{font-size:13px;color:var(--text-muted)}.single-line-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.single-line-previews{flex-wrap:nowrap;overflow-x:auto}.artist-indicator{font-size:12px;font-weight:600;margin-top:3px}.payment-summary{margin-top:8px;padding:10px 12px;background:#ffffff08;border-radius:var(--radius-sm);display:flex;flex-direction:column;gap:3px}.payment-line{font-size:12px}.strong{font-weight:700;color:var(--text)!important}.day-detail-actions-row{display:flex;gap:6px;margin-top:10px}.sm-btn{padding:5px 12px!important;font-size:12px!important}.center-card{text-align:center;padding:24px}.full-width{width:100%;justify-content:center}.month-overview-banner{text-align:center;padding:16px;background:var(--bg-nav-active)}.month-overview-title{font-size:12px;color:var(--text-muted);margin-bottom:4px}.month-overview-value{font-size:20px;font-weight:700;color:var(--text)}.analytics-grid{grid-template-columns:repeat(4,1fr)}.stats-kpi-grid{grid-template-columns:1fr 1fr}.stat-subtitle{font-size:11px;color:var(--text-muted);margin-top:4px}.large-kpi-value{font-size:28px!important}.top-customer-row{padding:10px 0}.weekly-bars{display:flex;flex-direction:column;gap:10px;margin-top:4px}.weekly-bar-row{display:flex;align-items:center;gap:12px}.weekly-bar-label{font-size:12px;color:var(--text-muted);width:130px;flex-shrink:0}.weekly-bar-track{flex:1;height:10px;background:#ffffff0f;border-radius:99px;overflow:hidden}.weekly-bar-fill{height:100%;background:#fff;border-radius:99px;transition:width .3s}.weekly-bar-count{font-size:12px;color:var(--text-muted);width:70px;text-align:right;flex-shrink:0}.top-customer-rank{width:28px;font-size:13px;font-weight:700;color:var(--text-muted);flex-shrink:0}.top-customer-info{flex:1;min-width:0}.top-customer-name{font-size:14px;font-weight:500;color:var(--text)}.top-customer-value{font-size:14px;font-weight:700;color:var(--text)}.revenue-chart-scroll{overflow-x:auto}.revenue-chart{display:flex;align-items:flex-end;gap:6px;height:260px;padding-bottom:28px;min-width:600px}.revenue-bar-column{display:flex;flex-direction:column;align-items:center;justify-content:flex-end;flex:1;gap:4px;height:100%}.revenue-bar-value{font-size:9px;color:var(--text-muted);text-align:center;white-space:nowrap;overflow:hidden;max-width:100%;text-overflow:ellipsis}.revenue-bar{width:100%;border-radius:3px 3px 0 0;background:#ffffff0f;min-width:8px}.revenue-bar.has-value{background:#fff}.revenue-bar-label{font-size:10px;color:var(--text-muted);text-align:center}.yearly-chart-wrap{overflow-x:auto}.yearly-chart-svg{width:100%;display:block}.empty-hint{font-size:13px;color:var(--text-muted);padding:8px 0}.toast-viewport{position:fixed;bottom:24px;right:24px;z-index:200;display:flex;flex-direction:column;gap:10px;pointer-events:none}.toast-description{font-size:12px;color:var(--text-muted);margin-top:2px}.toast-close{background:none;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;padding:0 0 0 8px;line-height:1;margin-left:auto;pointer-events:all}.toast-close:hover{color:var(--text)}.app-ui-modal{max-width:420px}.app-ui-modal .modal-header{padding:20px 24px 16px}.app-ui-modal .modal-header p{font-size:13px;color:var(--text-muted);margin-top:4px}.app-ui-modal-actions{display:flex;justify-content:flex-end;gap:10px;padding:0 24px 20px}.app-ui-modal-body{padding:12px 24px 4px}.price-modal-input-row{display:flex;align-items:center;gap:10px}.price-modal-currency{font-size:18px;font-weight:600;color:var(--text-muted)}.price-modal-input{flex:1;font-size:28px;font-weight:700;background:var(--bg-input);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-sm);color:var(--text);padding:10px 14px;outline:none;text-align:right}.appointment-modal-section{display:flex;flex-direction:column;gap:12px}.appointment-modal-section+.appointment-modal-section{padding-top:12px;border-top:1px solid rgba(255,255,255,.05)}.modal-images-grid{display:flex;gap:8px;flex-wrap:wrap}.modal-image-thumb{width:60px;height:60px;border-radius:var(--radius-sm);object-fit:cover;border:1px solid rgba(255,255,255,.08);cursor:pointer;transition:opacity .15s}.modal-image-thumb:hover{opacity:.8}.modal-add-image-btn{width:60px;height:60px;border-radius:var(--radius-sm);border:2px dashed rgba(255,255,255,.1);background:none;color:var(--text-muted);font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .15s}.modal-add-image-btn:hover{border-color:#fff3;color:var(--text)}.quick-time-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.quick-time-label{font-size:12px;color:var(--text-muted);white-space:nowrap}.quick-time-buttons{display:flex;gap:6px;flex-wrap:wrap}.quick-time-btn{padding:4px 10px;border-radius:20px;border:1px solid rgba(255,255,255,.08);background:var(--bg-input);color:var(--text-muted);font-size:12px;cursor:pointer;transition:background .15s,color .15s}.quick-time-btn:hover{background:var(--bg-nav-active);color:var(--text)}.customer-search-stack{display:flex;flex-direction:column;gap:4px}.customer-dropdown{position:relative}.customer-dropdown-menu{position:absolute;top:100%;left:0;right:0;z-index:50;background:var(--bg-card);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);margin-top:2px;max-height:200px;overflow-y:auto;box-shadow:0 8px 24px #0006}.customer-dropdown-empty{padding:10px 14px;font-size:13px;color:var(--text-muted)}.customer-dropdown-item{display:flex;flex-direction:column;align-items:flex-start;padding:10px 14px;width:100%;background:none;border:none;color:var(--text);cursor:pointer;text-align:left;transition:background .1s;border-bottom:1px solid rgba(255,255,255,.04)}.customer-dropdown-item:last-child{border-bottom:none}.customer-dropdown-item:hover,.customer-dropdown-item.active{background:var(--bg-nav-active)}.customer-dropdown-name{font-size:14px;font-weight:500}.customer-dropdown-meta{font-size:12px;color:var(--text-muted)}.customer-create-hint{font-size:11px;color:var(--text-muted)}.textarea{resize:vertical;min-height:80px}.section-header.simple{margin-bottom:10px}.section-header.simple h3{font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.image-upload-block{display:flex;flex-direction:column;gap:8px}.image-upload-label{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:var(--radius-sm);border:1px dashed rgba(255,255,255,.12);background:none;color:var(--text-muted);font-size:13px;cursor:pointer;transition:border-color .15s}.image-upload-label:hover{border-color:#ffffff38;color:var(--text)}.image-upload-input{display:none}.image-upload-hint{font-size:11px;color:var(--text-muted)}.image-grid{display:flex;gap:8px;flex-wrap:wrap}.image-card{position:relative}.image-preview{width:64px;height:64px;border-radius:var(--radius-sm);object-fit:cover;border:1px solid rgba(255,255,255,.08)}.image-remove-btn{position:absolute;bottom:-4px;left:50%;transform:translate(-50%);background:#000000b3;border:none;color:var(--red);font-size:10px;cursor:pointer;border-radius:0 0 var(--radius-sm) var(--radius-sm);padding:2px 6px;white-space:nowrap}.image-empty-state{font-size:12px;color:var(--text-muted)}.checkbox-row{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:var(--text)}.checkbox-row input[type=checkbox]{accent-color:var(--purple);width:15px;height:15px;cursor:pointer}.conflict-box{background:#f8717112;border:1px solid rgba(248,113,113,.2);border-radius:var(--radius-sm);padding:12px 14px;display:flex;flex-direction:column;gap:6px}.conflict-title{font-size:13px;font-weight:600;color:var(--red)}.conflict-text{font-size:12px;color:var(--text-muted)}.conflict-list{display:flex;flex-direction:column;gap:4px}.conflict-item{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text)}.conflict-item span{color:var(--text-muted)}.customer-modal-form{display:flex;flex-direction:column;gap:12px}.customer-detail-header{display:flex;align-items:center;gap:14px;margin-bottom:14px}.customer-detail-avatar{width:48px;height:48px;border-radius:50%;background:var(--bg-nav-active);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:var(--text);flex-shrink:0}.customer-detail-stats{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:14px}.customer-detail-stat{background:var(--bg-input);border-radius:var(--radius-sm);padding:8px 14px;font-size:12px;color:var(--text-muted)}.customer-detail-stat strong{color:var(--text);font-size:14px;display:block;font-weight:600}@media (max-width: 900px){.analytics-grid{grid-template-columns:1fr 1fr}.settings-layout,.calendar-layout{grid-template-columns:1fr}}
