/* Base look taken from the uploaded RMS reference stylesheet */
:root{--bg:#f5f7fb;--panel:#fff;--panel2:#f8fafc;--text:#0f172a;--muted:#64748b;--line:#dbe4f0;--accent:#2563eb;--ok:#16a34a;--warn:#d97706;--bad:#dc2626;--shadow:0 10px 30px rgba(15,23,42,.08);--sans:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;--mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:var(--sans)}body{padding-bottom:100px}header{position:sticky;top:0;z-index:20;background:rgba(245,247,251,.94);backdrop-filter:blur(10px);border-bottom:1px solid rgba(219,228,240,.85)}.headerInner,.app{max-width:760px;margin:0 auto;padding:12px}.headerInner{display:flex;flex-direction:column;gap:10px}.brand{display:flex;align-items:center;gap:10px}.logoLink{width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;border-radius:14px;border:1px solid var(--line);background:#fff;text-decoration:none;overflow:hidden}.logoImg{width:100%;height:100%;object-fit:contain;padding:6px}h1{font-size:18px;line-height:1.15;margin:0}.sub{font-size:12px;color:var(--muted);margin-top:2px}.toolbar{display:grid;grid-template-columns:1fr 1fr;gap:8px}button,select,input,textarea,a{font:inherit}button,select,.toolbarBtn{border:1px solid var(--line);background:#fff;color:var(--text);padding:11px 12px;border-radius:14px;font-weight:700;text-decoration:none}input,textarea{width:100%;padding:12px 13px;border-radius:14px;border:1px solid var(--line);background:#fff;color:var(--text);outline:none}input[readonly]{background:var(--panel2)}.stack{display:grid;gap:14px;margin-top:12px}.heroCard,.stepCard{background:var(--panel);border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow)}.heroCard{padding:16px;display:grid;gap:12px;background:linear-gradient(180deg,#fff 0%,#f8fbff 100%)}.stepCard{overflow:hidden}.heroTop{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}.heroTitle{font-size:13px;color:var(--muted);font-weight:700}.heroName{font-size:24px;line-height:1.1;font-weight:850;letter-spacing:-.02em}.heroStatus{display:inline-flex;align-items:center;justify-content:center;padding:8px 10px;border-radius:999px;border:1px solid var(--line);background:#fff;font-size:12px;font-weight:800}.stepHd{padding:14px 14px 10px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:10px}.stepNo{width:28px;height:28px;border-radius:999px;background:#e8f0ff;color:var(--accent);display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:800}.stepTitle{font-size:15px;font-weight:800}.stepSub{font-size:12px;color:var(--muted);margin-top:2px}.stepBd{padding:14px;display:grid;gap:12px}.grid2,.grid3,.summaryGrid{display:grid;gap:10px}.grid2{grid-template-columns:1fr 1fr}.grid3{grid-template-columns:1fr 1fr 1fr}@media (max-width:640px){.grid2,.grid3,.summaryGrid,.toolbar{grid-template-columns:1fr}}.field{display:grid;gap:6px}label{font-size:12px;color:var(--muted);font-weight:600}.mini{font-size:12px;color:var(--muted);line-height:1.45}.pills{display:flex;gap:8px;flex-wrap:wrap}.pill{display:inline-flex;gap:6px;align-items:center;padding:7px 10px;border-radius:999px;border:1px solid var(--line);background:var(--panel2);font-size:12px;font-weight:700}.statusOK{color:var(--ok)}.statusWARN{color:var(--warn)}.statusBAD{color:var(--bad)}.kpi{display:grid;grid-template-columns:1fr 1fr;gap:10px}.kpiBox{border:1px solid var(--line);border-radius:18px;background:var(--panel2);padding:12px}.kpiT{font-size:12px;color:var(--muted)}.kpiV{font-size:20px;font-weight:800;line-height:1.1;margin-top:4px}.kpiU{font-size:12px;color:var(--muted);margin-top:2px}.infoBox,.warnBox,.dangerBox{padding:12px 13px;border-radius:18px;border:1px solid var(--line);font-size:13px;line-height:1.45;font-weight:700}.infoBox{background:#f0fdf4;border-color:#bbf7d0;color:#166534}.warnBox{background:#fff7ed;border-color:#fed7aa;color:#9a3412}.dangerBox{background:#fef2f2;border-color:#fecaca;color:#991b1b}.diagGrid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.diagCard{border:1px solid var(--line);border-radius:16px;background:var(--panel2);padding:10px 12px}.diagLabel{font-size:11px;color:var(--muted)}.diagValue{font-size:16px;font-weight:800;margin-top:3px}.diagFull{grid-column:1/-1}@media (max-width:640px){.diagGrid{grid-template-columns:1fr}}.ctaBar{position:sticky;bottom:10px;z-index:15;padding-top:6px}.ctaCard{background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border:1px solid var(--line);border-radius:20px;box-shadow:0 12px 30px rgba(15,23,42,.12);padding:12px;display:grid;gap:8px}.ctaPrimary{width:100%;padding:14px 16px;border-radius:16px;background:var(--accent);border:1px solid var(--accent);color:#fff;font-weight:800;cursor:pointer}.ctaMeta{font-size:12px;color:var(--muted);text-align:center}details.expert{border:1px solid var(--line);border-radius:18px;background:var(--panel2);overflow:hidden}details.expert>summary{list-style:none;cursor:pointer;padding:14px;display:flex;justify-content:space-between;align-items:center;font-weight:800}details.expert>summary::-webkit-details-marker{display:none}.expertBody{padding:0 14px 14px;display:grid;gap:12px}.tableWrap{overflow:auto;border:1px solid var(--line);border-radius:16px;background:#fff}.mobTable{width:100%;border-collapse:separate;border-spacing:0;min-width:560px}.mobTable th,.mobTable td{padding:9px 10px;border-bottom:1px solid var(--line);border-right:1px solid var(--line);font-size:12px;vertical-align:middle}.mobTable th:last-child,.mobTable td:last-child{border-right:0}.mobTable tr:last-child td{border-bottom:0}.mobTable th{text-align:left;color:var(--muted);font-weight:800;background:var(--panel2)}.mobTable input{padding:8px 9px;border-radius:10px;font-size:12px;min-width:72px}.btnRow{display:flex;gap:8px;flex-wrap:wrap}.heroActions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}.heroMain{display:grid;grid-template-columns:minmax(0,1fr) 180px;gap:12px;align-items:start;margin-top:10px}.heroPreview{border:1px solid var(--line);border-radius:18px;overflow:hidden;background:var(--panel2);min-width:0}.heroPreview img{display:block;width:100%;height:180px;object-fit:contain}.heroSideStats{display:flex;flex-direction:column;gap:10px;width:180px}@media (max-width:640px){.heroMain{grid-template-columns:1fr}.heroSideStats{width:auto;display:grid;grid-template-columns:1fr 1fr}.heroPreview img{height:160px}}.appTabs{display:flex;gap:8px;margin:12px 0 16px;flex-wrap:wrap}.appTab{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line);background:var(--panel);color:var(--text);border-radius:999px;padding:10px 14px;font-weight:700;cursor:pointer;text-decoration:none}.appTab.isActive{background:var(--accent);color:#fff;border-color:var(--accent)}.tabPane{display:none}.tabPane.isActive{display:block}.helpCard{background:var(--panel);border:1px solid var(--line);border-radius:20px;overflow:hidden}.helpHd{padding:16px 16px 8px;border-bottom:1px solid var(--line)}.helpHd h2{margin:0;font-size:20px}.helpHd p{margin:6px 0 0;color:var(--muted);font-size:14px}.helpBd{padding:16px}.helpSection{margin-bottom:22px}.helpSection h3{margin:0 0 10px;font-size:16px}.helpSection ul{margin:8px 0 0 18px;padding:0}.helpSection li{margin:6px 0}.helpField{margin:0 0 12px;padding:10px 12px;border:1px solid var(--line);border-radius:14px;background:var(--panel2)}.helpField h4{margin:0 0 6px;font-size:14px}.helpField p{margin:0;color:var(--muted);font-size:13px;line-height:1.5}.field input,.field select,.field textarea{width:100%;box-sizing:border-box;padding:10px 12px;border:1px solid var(--line,#d1d5db);border-radius:12px;font:inherit;background:#fff;color:inherit}.field textarea{resize:vertical;min-height:88px}.field label.isRequired::after{content:" *";color:#dc2626;font-weight:800}.field input.isInvalid,.field select.isInvalid,.field textarea.isInvalid{border-color:#dc2626 !important;box-shadow:0 0 0 3px rgba(220,38,38,.10)}.submitFeedback{margin-top:12px;padding:12px 14px;border-radius:14px;border:1px solid #c7f0d2;background:#f0fdf4;color:#166534;font-size:14px;line-height:1.45}.submitFeedback.isWarn{border-color:#fde68a;background:#fffbeb;color:#92400e}.submitFeedback.isError{border-color:#fecaca;background:#fef2f2;color:#991b1b}.appModal{position:fixed;inset:0;z-index:9999;background:rgba(15,23,42,.42);display:flex;align-items:center;justify-content:center;padding:20px}.appModalCard{width:min(520px,100%);background:#fff;border:1px solid var(--line,#e5e7eb);border-radius:20px;box-shadow:0 24px 60px rgba(15,23,42,.24);padding:18px}.appModalTitle{font-size:20px;font-weight:800;color:#0f172a;margin-bottom:10px}.appModalBody{font-size:14px;line-height:1.5;color:#334155}.appModalBody ul{margin:8px 0 0 18px;padding:0}.appModalActions{margin-top:16px;display:flex;justify-content:flex-end}.appModalBtn{min-height:42px;padding:10px 16px;border-radius:12px;border:1px solid #dbe3ee;background:linear-gradient(180deg,#ffffff 0%,#f8fafc 100%);color:#0f172a;font-weight:800;cursor:pointer}.appModalBtn:hover{background:linear-gradient(180deg,#ffffff 0%,#f1f5f9 100%)}.appModalCard.isSuccess{border-color:#bbf7d0}.appModalCard.isWarn{border-color:#fde68a}.appModalCard.isError{border-color:#fecaca}.appModal[hidden]{display:none !important}.submitFeedback[hidden]{display:none !important}

/* Portal-specific additions */
body.portalBody{padding-bottom:36px}
a{color:inherit}
.toolbar.toolbarUser{grid-template-columns:1fr auto}
.toolbarUser .userBadge{display:inline-flex;align-items:center;min-height:44px;padding:0 12px;border-radius:14px;border:1px solid var(--line);background:#fff;font-size:13px;font-weight:700}
.toolbarUser .toolbarBtn{display:inline-flex;align-items:center;justify-content:center;min-height:44px}
.loginShell{gap:16px}
.loginGrid,.gridAdmin{display:grid;gap:14px;grid-template-columns:1fr 1fr}
@media (max-width:640px){.loginGrid,.gridAdmin{grid-template-columns:1fr}}
.formWide,.formStack{display:grid;gap:12px}
.fieldFull{grid-column:1/-1}
.alert{padding:12px 14px;border-radius:14px;border:1px solid var(--line);font-size:14px;line-height:1.45;font-weight:700}
.alertError{background:#fef2f2;border-color:#fecaca;color:#991b1b}
.alertSuccess{background:#f0fdf4;border-color:#bbf7d0;color:#166534}
.recommendCard{padding:12px 14px;border-radius:18px;border:1px solid var(--line);background:var(--panel2)}
.recommendCard h3{margin:0 0 6px;font-size:16px}
.recommendCard p{margin:0;color:var(--muted);font-size:14px;line-height:1.5}
.mutedCard{background:linear-gradient(180deg,#fff 0%,#f8fafc 100%)}
.checkGrid{display:flex;flex-wrap:wrap;gap:8px}
.checkItem{display:inline-flex;align-items:center;gap:8px;padding:9px 11px;border-radius:14px;border:1px solid var(--line);background:var(--panel2);font-size:13px;font-weight:700;color:var(--text)}
.checkItem input{width:auto;min-width:auto;margin:0}
.inlineForm{display:grid;gap:10px}
.adminTable td{vertical-align:top}
.emptyState{padding:12px 14px;border-radius:18px;border:1px dashed var(--line);background:var(--panel2);font-size:14px;color:var(--muted)}
.startGrid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media (max-width:640px){.startGrid{grid-template-columns:1fr}}
.startCard{display:grid;gap:6px;padding:12px 14px;border:1px solid var(--line);border-radius:18px;background:#fff;text-decoration:none}
.startCardTitle{font-size:15px;font-weight:800}
.startCardText{font-size:13px;color:var(--muted);line-height:1.45}


.appTabsWrap{margin-top:0}
.pillBad{background:#fef2f2;border-color:#fecaca;color:#991b1b}
.pillWarn{background:#fffbeb;border-color:#fde68a;color:#92400e}
.moduleCards{display:grid;grid-template-columns:1fr;gap:10px}
.moduleCards.twoCols{grid-template-columns:1fr 1fr}
.moduleCards.threeCols{grid-template-columns:1fr 1fr 1fr}
@media (max-width:820px){.moduleCards.twoCols,.moduleCards.threeCols{grid-template-columns:1fr}}
.moduleCard{padding:12px 14px;border:1px solid var(--line);border-radius:18px;background:#fff;box-shadow:0 6px 16px rgba(15,23,42,.04)}
.moduleCard.compactCard p{margin-bottom:0}
.moduleCard p{margin:6px 0 0;color:var(--muted);font-size:14px;line-height:1.5}
.moduleCardHead{display:flex;justify-content:space-between;gap:8px;align-items:center}
.checkGridColumn{display:grid;grid-template-columns:1fr;align-items:start}
.timelineList{display:grid;gap:10px}
.timelineItem{display:grid;grid-template-columns:72px 1fr;gap:12px;align-items:start;padding:12px 14px;border:1px solid var(--line);border-radius:16px;background:var(--panel2)}
.timelineItem strong{font-size:13px}
.timelineItem span{font-size:14px;color:var(--text);line-height:1.45}
.timelineItemLink{text-decoration:none;color:inherit;transition:border-color .15s ease,transform .15s ease,box-shadow .15s ease;cursor:pointer}
.timelineItemLink:hover{border-color:var(--brand);box-shadow:0 8px 20px rgba(15,23,42,.08);transform:translateY(-1px)}
.timelineItemLink:focus-visible{outline:2px solid var(--brand);outline-offset:2px}
.stateOk{border-color:#bbf7d0;background:#f0fdf4}
.stateWarn{border-color:#fde68a;background:#fffbeb}

.actionRow{display:flex;gap:8px;flex-wrap:wrap}.smallActionRow{padding-top:4px}.actionBtn{display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:10px 14px;border-radius:14px;border:1px solid var(--line);background:#fff;color:var(--text);font-weight:800;text-decoration:none;box-shadow:0 6px 18px rgba(15,23,42,.05)}.actionBtnPrimary{background:var(--accent);border-color:var(--accent);color:#fff}.codePill{font-family:var(--mono)}

/* Sales direct workspace */
.salesWorkspace{display:grid;grid-template-columns:minmax(280px,360px) minmax(0,1fr);gap:14px;align-items:start}.salesColumnList,.salesColumnDetail{height:100%}@media (max-width:980px){.salesWorkspace{grid-template-columns:1fr}}
.salesListCards{display:grid;gap:10px}.salesListCard{display:grid;gap:6px;padding:12px 14px;border:1px solid var(--line);border-radius:18px;background:#fff;text-decoration:none;box-shadow:0 6px 16px rgba(15,23,42,.04)}.salesListCard.isSelected{border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,.10)}.salesListCard p{margin:0;color:var(--muted);font-size:14px;line-height:1.5}
.salesSearchBar{display:grid;gap:10px}.searchRow{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:8px;align-items:end}@media (max-width:640px){.searchRow{grid-template-columns:1fr}}
.inlineActionForm{display:inline-flex}.inlineActionForm button{cursor:pointer}.salesEditGrid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.salesEditGrid .fieldFull{grid-column:1/-1}@media (max-width:760px){.salesEditGrid{grid-template-columns:1fr}}
.stepCardInset{display:grid;gap:12px;padding:12px 14px;border:1px solid var(--line);border-radius:18px;background:linear-gradient(180deg,#fff 0%,#f8fafc 100%)}
.actionRow .appTab{margin:0}.actionRow form{margin:0}


/* Quality document additions */
.qualityDocCard strong{font-size:14px}.qualitySearchBar .searchRow{grid-template-columns:minmax(0,1fr) auto auto}.qualityDocCard .pill{white-space:nowrap}.qualityDocCard p{margin-bottom:0}.qualityDocMeta{display:grid;gap:4px}
@media (max-width:640px){.qualitySearchBar .searchRow{grid-template-columns:1fr}}

/* Systems focus */
.systemsWorkspace{display:grid;grid-template-columns:minmax(280px,340px) minmax(0,1fr);gap:14px;align-items:start}
.systemsWorkspaceFull{grid-template-columns:1fr}
@media (max-width:980px){.systemsWorkspace{grid-template-columns:1fr}}
.systemDetailGrid{display:grid;grid-template-columns:1.2fr .8fr;gap:12px}
@media (max-width:760px){.systemDetailGrid{grid-template-columns:1fr}}
.qrCard{align-content:start}.qrPreview{display:flex;justify-content:center;align-items:center;padding:14px;border:1px solid var(--line);border-radius:18px;background:#fff}.qrPreview img{display:block;max-width:220px;width:100%;height:auto}
.linkBox{padding:10px 12px;border:1px solid var(--line);border-radius:14px;background:#fff;word-break:break-all;font-size:13px}
.qrLinkCard{margin-top:12px}.qrLinkGrid{display:grid;grid-template-columns:minmax(0,1fr) 220px;gap:14px;align-items:start}.qrLinkGridCompact{margin-top:12px}.qrLinkMain{display:grid;gap:8px}.qrPreviewInline{min-height:0;padding:12px}.qrPreviewInline img{max-width:190px}.publicQrPanel{margin-top:12px}.publicQrPanel .qrPreviewInline img{max-width:220px}@media (max-width:760px){.qrLinkGrid{grid-template-columns:1fr}.qrPreviewInline{justify-content:flex-start}.qrPreviewInline img{max-width:180px}}@media print{body.portalBody{background:#fff;padding-bottom:0}header,.noPrint,.toolbar,.appTabs,.salesSearchBar{display:none!important}.app{max-width:none!important;margin:0!important;padding:0!important}.heroCard,.stepCard,.stepCardInset{box-shadow:none!important;border-color:#cbd5e1!important;break-inside:avoid}.actionRow{display:none!important}.publicQrPanel .actionRow{display:none!important}.qrPreview,.linkBox{border-color:#cbd5e1!important}.kpi{grid-template-columns:repeat(2,1fr)!important}.tableWrap{overflow:visible!important}.mobTable{font-size:11px}}
.detailLead{font-size:18px;font-weight:800;line-height:1.2}.systemPublicTitle{font-size:16px}

/* Calendar */
.calendarMonthGrid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:8px}.calendarWeekday{padding:8px 10px;border-radius:12px;background:var(--panel2);font-size:12px;font-weight:800;color:var(--muted);text-align:center}.calendarDay{min-height:120px;padding:10px;border:1px solid var(--line);border-radius:16px;background:#fff;display:grid;gap:8px}.calendarDay.isMuted{background:var(--panel2);opacity:.8}.calendarDay.isToday{border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,.10)}.calendarDayHead{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--muted)}.calendarDayEvents{display:grid;gap:6px;align-content:start}.calendarEventDot{display:block;padding:6px 8px;border-radius:10px;background:#eef4ff;font-size:12px;line-height:1.35;text-decoration:none}.calendarWeekList{display:grid;gap:10px}@media (max-width:760px){.calendarMonthGrid{grid-template-columns:1fr}.calendarWeekday{display:none}}

.editorToolbar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}.editorToolbar button{border:1px solid var(--line,#d1d5db);background:#fff;border-radius:10px;padding:8px 10px;font-weight:700;cursor:pointer}.richEditor{min-height:220px;border:1px solid var(--line,#d1d5db);border-radius:14px;padding:12px;background:#fff;line-height:1.5}.richEditor:focus{outline:none;border-color:#94a3b8}.richTextContent{line-height:1.6}.richTextContent p,.richTextContent ul,.richTextContent ol,.richTextContent h3{margin:0 0 12px}.richTextContent ul,.richTextContent ol{padding-left:20px}.richTextContent h3{font-size:18px}

.printDocumentBody{display:grid;gap:12px}
.documentPrintActions button.actionBtn{appearance:none;-webkit-appearance:none;font:inherit;cursor:pointer}

.qualityToolDetailGrid{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(220px,.85fr);gap:14px;align-items:start}
@media (max-width:820px){.qualityToolDetailGrid{grid-template-columns:1fr}}
.qualityQrPanel{display:grid;gap:10px;align-content:start}
.qualityQrBox{display:flex;justify-content:center;align-items:center;padding:14px;border:1px solid var(--line);border-radius:18px;background:#fff;min-height:220px}
.qualityQrBox img{display:block;max-width:190px;width:100%;height:auto}
.userBadgeDetailed{
    display:flex;
    flex-direction:column;
    align-items:flex-start;
    justify-content:center;
    text-align:left;
}

.userBadgeDetailed .userBadgeLabel,
.userBadgeDetailed strong,
.userBadgeDetailed .userBadgeMeta{
    display:block;
    width:100%;
    text-align:left;
}
.headerInner{
    display:flex;
    flex-direction:column;
    gap:12px;
}

.headerTop{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:20px;
}

.headerTopRight{
    display:flex;
    align-items:flex-start;
    justify-content:flex-end;
    margin-left:auto;
}

.logoutBtn{
    margin-top:4px;
}

.globalSearchBarCompact{
    max-width:520px;
    width:100%;
    margin-left:auto;
}

.globalSearchBarCompact .searchRow{
    justify-content:flex-end;
}

.globalSearchBarCompact input[type="search"]{
    max-width:500px;
    width:100%;
}
.dangerBtn{border-color:#f3b4af!important;color:#b42318!important;background:#fff5f4!important;}
.dangerBtn:hover{background:#fee4e2!important;}

.serviceQrPreview{
    display:flex;
    align-items:center;
    gap:18px;
    padding:14px;
    border:1px solid rgba(37, 99, 235, .18);
    border-radius:16px;
    background:#f8fbff;
}
.serviceQrPreview img{
    width:150px;
    height:150px;
    object-fit:contain;
    border-radius:10px;
    background:#fff;
    border:1px solid #d8e2f0;
    padding:6px;
}
@media (max-width: 720px){.serviceQrPreview{align-items:flex-start;flex-direction:column;}}

.servicePositionsBox{border:1px solid var(--line);border-radius:18px;background:var(--panel2);padding:12px}.servicePositionActions{margin-bottom:4px}.servicePositionsWrap{background:#fff}.servicePositionsTable{min-width:1080px}.servicePositionsTable td{vertical-align:top}.servicePositionsTable input,.servicePositionsTable select,.servicePositionsTable textarea{font-size:12px;padding:8px 9px;border-radius:10px}.servicePositionsTable textarea{min-height:54px;margin-top:6px}.servicePartSelect{margin-bottom:6px}.position-title{margin-top:6px}.servicePositionMove .toolbarBtn{padding:7px 9px;border-radius:10px}.servicePositionsEmpty{margin-top:8px}.service-position-type-label{white-space:nowrap}

/* Wide layout for service/quality create and edit screens */
.app.appWide{max-width:1180px;width:100%;}
.app.appWide .stack,.app.appWide .systemsWorkspace,.app.appWide .systemsWorkspaceFull,.app.appWide .systemsColumnDetail{width:100%;max-width:none;min-width:0;}
.app.appWide .systemsWorkspace{grid-template-columns:minmax(280px,320px) minmax(0,1fr);}
.app.appWide .systemsWorkspaceFull{grid-template-columns:1fr;}
@media (min-width:1400px){.app.appWide{max-width:1320px;}}
@media (max-width:980px){.app.appWide .systemsWorkspace{grid-template-columns:1fr;}}

/* Systems parts/accessory editor */
.systemsPartCatalogTable{min-width:1080px}
.systemsPartCatalogTable td{vertical-align:top}
.mobTable tr.isSelectedRow td{background:#f8fbff}
.tableActionRow{gap:6px;align-items:center;justify-content:flex-start}


/* Final: Portal icons and quick access */
.appTab{display:inline-flex;align-items:center;gap:8px}
.appTabIcon,.startCardIcon,.quickCardIcon{display:inline-flex;align-items:center;justify-content:center;width:1.65rem;height:1.65rem;border-radius:999px;background:#eef4ff;font-size:.95rem;line-height:1;flex:0 0 auto}
.startCardTitle,.moduleCard strong{display:flex;align-items:center;gap:8px}

/* Final: Teile/Zubehör cards */
.systemsPartCatalogCards{display:grid;gap:12px}
.systemsPartCatalogCard{border:1px solid var(--line,#d0d5dd);border-radius:18px;background:#fff;padding:14px;box-shadow:0 8px 22px rgba(15,23,42,.05)}
.systemsPartCatalogCard.isSelectedRow{outline:2px solid rgba(37,99,235,.35);border-color:#93c5fd}
.systemsPartCardMeta{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-top:10px;font-size:13px;color:var(--muted,#667085)}
.systemsPartCardMeta span{min-width:0;overflow:hidden;text-overflow:ellipsis}
.systemsPartCardSystems{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-top:12px}
.systemsPartCardFooter{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin-top:12px;border-top:1px solid var(--line,#d0d5dd);padding-top:10px}
.systemsPartUsage{display:flex;gap:6px;flex-wrap:wrap}
@media(max-width:900px){.systemsPartCardMeta{grid-template-columns:1fr 1fr}.systemsPartCardFooter{align-items:flex-start;flex-direction:column}}
@media(max-width:560px){.systemsPartCardMeta{grid-template-columns:1fr}.systemsPartCatalogCard .moduleCardHead{align-items:flex-start;flex-direction:column}}

/* Final: service auto parts */
.serviceAutoPartsBox{display:grid;gap:6px;margin:8px 0 10px;padding:10px;border:1px dashed var(--line,#d0d5dd);border-radius:14px;background:#f8fafc}
.serviceAutoPartsToggle{display:flex;gap:8px;align-items:center}.serviceAutoPartsToggle input{width:auto}

/* Final: API token management */
.apiTokenCreatedGrid{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:16px;align-items:start}
.apiTokenTextarea{width:100%;min-height:74px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:12px;line-height:1.45;resize:vertical}
.apiConfigTextarea{min-height:150px}
.apiTokenQrBox{display:grid;gap:10px;justify-items:center;border:1px solid var(--line,#d0d5dd);border-radius:18px;background:#fff;padding:14px}
.apiTokenQrBox img{display:block;width:260px;max-width:100%;height:auto}
@media(max-width:820px){.apiTokenCreatedGrid{grid-template-columns:1fr}.apiTokenQrBox{justify-items:start}}

.gridForm{display:grid;grid-template-columns:1fr 1fr;gap:12px}.gridForm .fieldFull{grid-column:1/-1}@media (max-width:760px){.gridForm{grid-template-columns:1fr}}
.qualityEditWithQr{display:grid;grid-template-columns:minmax(0,1fr);gap:16px;align-items:start}.qualityEditWithQr.hasQr{grid-template-columns:minmax(0,1fr) minmax(240px,320px)}.qualityEditWithQr .salesEditGrid{min-width:0}.qualityEditQrPanel{position:sticky;top:18px}@media (max-width:980px){.qualityEditWithQr.hasQr{grid-template-columns:1fr}.qualityEditQrPanel{position:static}}

/* Branding / Firmendaten */
.grid4{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
.brandingSettingsForm{gap:16px}.brandingPreviewGrid{display:grid;grid-template-columns:minmax(0,260px) minmax(0,1fr);gap:12px;align-items:stretch}.brandPreviewCard{border:1px solid var(--line);background:var(--panel2);border-radius:18px;padding:14px;display:grid;gap:8px;align-content:start}.brandPreviewLogo{max-width:220px;max-height:90px;object-fit:contain;background:#fff;border:1px solid var(--line);border-radius:14px;padding:10px}.brandLogoPlaceholder{border:1px dashed var(--line);border-radius:14px;background:#fff;color:var(--muted);padding:24px 12px;text-align:center;font-size:13px}.logoLink{background:#fff}.logoImg{max-width:100%;max-height:100%}@media (max-width:840px){.grid4,.brandingPreviewGrid{grid-template-columns:1fr}}

/* Servicepersonal / Field Operations */
.fieldJobCards{grid-template-columns:1fr;}
.fieldJobCard{min-height:0;}
.fieldJobGrid{display:grid;grid-template-columns:minmax(0,1fr) 160px;gap:16px;align-items:start;}
.fieldJobQr{display:grid;gap:8px;justify-items:center;align-content:start;border:1px solid var(--line,#d0d5dd);border-radius:16px;background:#fff;padding:10px;}
.fieldJobQr img{display:block;width:140px;height:140px;object-fit:contain;}
@media(max-width:780px){.fieldJobGrid{grid-template-columns:1fr}.fieldJobQr{justify-items:start;max-width:180px}}

/* Serviceeinsatz über mehrere Tage im Kalender */
.calendarEventDot.isMultiDay{background:var(--accent);color:#fff;font-weight:800;box-shadow:0 6px 14px rgba(37,99,235,.18);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.calendarEventDot.isMultiDay span{font-weight:900;opacity:.95}
.calendarEventDot.isRangeStart{border-top-right-radius:4px;border-bottom-right-radius:4px;margin-right:-10px;padding-right:18px}
.calendarEventDot.isRangeMiddle{border-radius:4px;margin-left:-10px;margin-right:-10px;padding-left:18px;padding-right:18px}
.calendarEventDot.isRangeEnd{border-top-left-radius:4px;border-bottom-left-radius:4px;margin-left:-10px;padding-left:18px}
.timelineItem.isMultiDay{border-left:4px solid var(--accent);background:#eef4ff}
@media (max-width:760px){.calendarEventDot.isRangeStart,.calendarEventDot.isRangeMiddle,.calendarEventDot.isRangeEnd{margin-left:0;margin-right:0;border-radius:10px}}

.languageSwitch{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.languageSwitch .toolbarBtn{padding:8px 10px;min-height:38px}.languageSwitch .toolbarBtn.isActive{background:var(--accent);border-color:var(--accent);color:#fff}.headerTopRight{gap:8px;flex-wrap:wrap;align-items:center}.logoutBtn{margin-top:0}

/* Clean language switch */
.languageSwitch{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.languageSwitch .toolbarBtn{border-radius:999px;padding:8px 12px;font-weight:700}
.languageSwitch .toolbarBtn.isActive{background:var(--accent);border-color:var(--accent);color:#fff}
