*{box-sizing:border-box}
:root{
  --brand-primary:#d71920;
  --brand-primary-soft:rgba(215,25,32,.10);
  --brand-primary-line:rgba(215,25,32,.20);
  --brand-accent:#ffd23f;
  --text:#1d1d1f;
  --text-soft:#3a3a3c;
  --muted:#86868b;
  --muted-2:#a1a1a6;
  --bg:#f5f5f7;
  --surface:rgba(255,255,255,.72);
  --surface-strong:rgba(255,255,255,.88);
  --surface-soft:rgba(255,255,255,.54);
  --line:rgba(0,0,0,.075);
  --line-light:rgba(255,255,255,.72);
  --danger:#d92d20;
  --ok:#1f8f56;
  --info:#0a84ff;
  --warning:#b86e00;
  --radius-xs:12px;
  --radius-sm:16px;
  --radius-md:22px;
  --radius-lg:28px;
  --radius-xl:36px;
  --blur:blur(28px) saturate(180%);
  --blur-heavy:blur(42px) saturate(190%);
  --shadow-card:0 18px 54px rgba(0,0,0,.075);
  --shadow-soft:0 10px 32px rgba(0,0,0,.055);
  --shadow-button:0 10px 22px rgba(215,25,32,.18);
  --ease:cubic-bezier(.2,.8,.2,1);
  --accent-grad:linear-gradient(135deg,#ff4b55 0%,var(--brand-primary) 72%,#a70f18 100%);
}

.hero-search{display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,620px);gap:22px;align-items:end;margin-bottom:24px}
.hero-search form{display:flex;gap:12px;align-items:center}
.cards-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}
.module-tile,.article-card{display:flex;flex-direction:column;gap:10px;min-height:168px}
.module-tile strong,.article-card strong{font-size:20px;letter-spacing:0}
.module-tile small,.article-card small,.article-card p{color:var(--text-soft);line-height:1.55}
.tile-token{width:48px;height:48px;border-radius:16px;display:grid;place-items:center;background:var(--brand-primary-soft);color:var(--brand-primary);font-weight:760}
.section-head{display:flex;justify-content:space-between;align-items:end;gap:16px;margin:30px 0 14px}
.category-list{display:flex;flex-wrap:wrap;gap:10px}
.chip,.badge{display:inline-flex;align-items:center;width:auto;border-radius:999px;background:rgba(255,255,255,.76);border:1px solid var(--line);padding:8px 12px;color:var(--text-soft);font-size:13px;font-weight:680}
.filter-panel{margin-bottom:22px}
.filter-panel form,.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;align-items:end}
.meta-row{display:flex;flex-wrap:wrap;gap:8px;color:var(--muted);font-size:13px}
.article-detail{display:grid;gap:18px}
.detail-head{display:flex;justify-content:space-between;align-items:center;gap:16px}
.lead{font-size:18px;line-height:1.6;color:var(--text-soft);margin:0}
.article-content{line-height:1.72;white-space:normal}
.fact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px;margin:6px 0 0}
.fact-grid div{padding:14px;border-radius:16px;background:rgba(255,255,255,.56);border:1px solid var(--line)}
.fact-grid dt{font-size:12px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:0}
.fact-grid dd{margin:5px 0 0;color:var(--text)}
.steps-list{display:grid;gap:14px}
.step-card{display:grid;grid-template-columns:48px minmax(0,1fr);gap:16px}
.step-number{width:40px;height:40px;border-radius:14px;background:var(--accent-grad);color:#fff;display:grid;place-items:center;font-weight:760}
.step-image{max-width:100%;border-radius:16px;margin-top:12px;border:1px solid var(--line)}
.attachment-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.attachment-card{display:flex;flex-direction:column;gap:6px}
.edit-form{display:grid;gap:16px}
.step-editor{display:grid;gap:12px}
.step-edit-row{display:grid;gap:10px;padding:14px;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.48)}
.danger{background:#d92d20;box-shadow:none}
.compact{margin:0 0 14px}
.modular-editor{display:grid;gap:18px;padding-bottom:86px}
.editor-base-card,.editor-block{display:grid;gap:14px}
.editor-toolbar-card{display:flex;flex-wrap:wrap;gap:10px;position:sticky;top:12px;z-index:4}
.editor-stack{display:grid;gap:14px}
.block-head{display:flex;align-items:center;justify-content:space-between;gap:12px}
.danger-lite{color:var(--danger);background:rgba(217,45,32,.08);box-shadow:none}
.sticky-editor-actions{position:sticky;bottom:14px;z-index:5;display:flex;gap:10px;align-items:center;justify-content:flex-end;padding:12px;border-radius:24px;background:rgba(255,255,255,.82);border:1px solid var(--line-light);box-shadow:var(--shadow-soft);backdrop-filter:var(--blur)}
.ck.ck-editor{width:100%}
.ck.ck-editor__main>.ck-editor__editable{min-height:180px;border-radius:0 0 16px 16px;pointer-events:auto;user-select:text;-webkit-user-select:text;background:#fff;color:var(--text)}
.ck.ck-editor__main>.ck-editor__editable.ck-focused{border-color:var(--brand-primary-line);box-shadow:0 0 0 5px var(--brand-primary-soft)}
.ck.ck-toolbar button,.ck.ck-button{box-shadow:none;transform:none;min-height:auto;border-radius:6px;padding:4px;color:var(--ck-color-button-default-text);background:transparent}
.ck.ck-toolbar button:hover,.ck.ck-button:hover{transform:none;box-shadow:none;background:var(--ck-color-button-default-hover-background)}
.rich-editor{min-height:190px;resize:vertical}
.simple-rich-editor{display:grid;gap:0;border:1px solid rgba(0,0,0,.08);border-radius:18px;background:#fff;overflow:hidden;box-shadow:inset 0 1px 0 rgba(255,255,255,.9)}
.simple-rich-toolbar{display:flex;flex-wrap:wrap;gap:6px;padding:9px;border-bottom:1px solid var(--line);background:rgba(248,248,250,.92)}
.simple-rich-toolbar button{min-height:32px;padding:6px 10px;border-radius:10px;background:rgba(255,255,255,.86);border:1px solid var(--line);box-shadow:none;color:var(--text-soft);font-size:13px;font-weight:760}
.simple-rich-toolbar button:hover{transform:none;box-shadow:none;background:#fff;color:var(--brand-primary)}
.simple-rich-editor.is-uploading .simple-rich-toolbar:after{content:"Bild wird hochgeladen...";align-self:center;color:var(--muted);font-size:13px;font-weight:720}
.simple-rich-surface{min-height:220px;padding:14px 16px;outline:none;line-height:1.7;color:var(--text);background:#fff;user-select:text;-webkit-user-select:text;overflow:auto}
.simple-rich-surface:focus{box-shadow:inset 0 0 0 4px var(--brand-primary-soft)}
.simple-rich-surface h2,.simple-rich-surface h3{margin:12px 0 8px}
.simple-rich-surface p{margin:0 0 10px}
.simple-rich-surface ul,.simple-rich-surface ol{padding-left:22px}
.simple-rich-surface blockquote{margin:10px 0;padding:10px 12px;border-left:4px solid var(--brand-primary);border-radius:12px;background:rgba(215,25,32,.06)}
.simple-rich-surface table{width:100%;border-collapse:collapse;margin:10px 0}
.simple-rich-surface td,.simple-rich-surface th{border:1px solid var(--line);padding:8px}
.simple-rich-surface figure,.rich-content figure{clear:both;margin:14px 0;display:grid;gap:7px;justify-items:start}
.simple-rich-surface img,.rich-content img{display:block;width:min(100%,420px);max-height:300px;object-fit:contain;height:auto;border-radius:16px;border:1px solid var(--line);box-shadow:var(--shadow-soft);background:#fff}
.article-detail .rich-content img,.article-section .rich-content img{width:min(100%,460px);max-height:340px}
.rich-content img.is-zoomable{cursor:zoom-in;transition:filter .18s var(--ease),transform .18s var(--ease)}
.rich-content img.is-zoomable:hover{filter:brightness(.96);transform:translateY(-1px)}
.rich-content img.is-zoomable:focus{outline:3px solid var(--brand-primary-line);outline-offset:3px}
.simple-rich-surface figcaption,.rich-content figcaption{color:var(--muted);font-size:13px;font-weight:650}
.toc{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin:16px 0}
.toc strong{margin-right:6px}
.toc a{padding:7px 11px;border-radius:999px;background:rgba(255,255,255,.62);border:1px solid var(--line);color:var(--text-soft);font-size:13px;font-weight:680}
.article-section-stack{display:grid;gap:14px}
.article-section{display:grid;gap:8px}
.section-warning{border-color:rgba(217,45,32,.22);background:rgba(255,245,244,.9)}
.section-tip{border-color:rgba(31,143,86,.20);background:rgba(244,252,248,.9)}
.section-error_description,.section-cause,.section-solution,.section-checklist{border-color:rgba(10,132,255,.16)}
.rich-content{line-height:1.72}
.rich-content h2,.rich-content h3,.rich-content h4{margin:18px 0 8px;letter-spacing:0}
.rich-content p{margin:0 0 12px}
.rich-content ul,.rich-content ol{padding-left:22px}
.rich-content table{width:100%;border-collapse:collapse;margin:12px 0;border-radius:14px;overflow:hidden}
.rich-content th,.rich-content td{border:1px solid var(--line);padding:10px;text-align:left;background:rgba(255,255,255,.52)}
.rich-content blockquote{margin:12px 0;padding:12px 14px;border-left:4px solid var(--brand-primary);border-radius:12px;background:rgba(255,255,255,.58)}
.inline-alert{display:grid;gap:4px;margin:12px 0 0;padding:12px 14px;border-radius:16px;border:1px solid var(--line)}
.inline-alert.warning{background:rgba(217,45,32,.08);border-color:rgba(217,45,32,.16);color:#8c1d18}
.inline-alert.tip{background:rgba(31,143,86,.08);border-color:rgba(31,143,86,.18);color:#17613d}
.media-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px;margin-top:14px}
.media-gallery img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:16px;border:1px solid var(--line)}
.media-file{display:grid;place-items:center;min-height:92px;padding:12px;border-radius:16px;background:rgba(255,255,255,.72);border:1px solid var(--line);font-weight:700;text-align:center}
.parts-table{width:100%;border-collapse:collapse}
.parts-table th,.parts-table td{padding:12px;border-bottom:1px solid var(--line);vertical-align:top;text-align:left}
.parts-table small{display:block;margin-top:4px;color:var(--muted);line-height:1.4}
.parts-table code{display:inline-flex;padding:5px 8px;border-radius:8px;background:rgba(0,0,0,.055);font:700 13px ui-monospace,SFMono-Regular,Menlo,monospace}
.parts-table a{color:var(--brand-primary);font-weight:720}
.attachment-card span{color:var(--text-soft);font-size:13px;line-height:1.4}
.existing-media-list{display:flex;flex-wrap:wrap;gap:8px}
.existing-media-list span{display:inline-flex;padding:6px 9px;border-radius:999px;background:rgba(0,0,0,.055);font-size:12px;font-weight:700;color:var(--text-soft)}
.wiki-builder{padding-bottom:40px}
.builder-layout{display:grid;grid-template-columns:minmax(0,1fr) 330px;gap:18px;align-items:start}
.builder-main{display:grid;gap:18px;min-width:0}
.builder-sidebar{position:sticky;top:18px;display:grid;gap:14px;max-height:calc(100vh - 36px);overflow:auto}
.builder-hero{display:flex;justify-content:space-between;gap:16px;align-items:center;background:linear-gradient(135deg,rgba(255,255,255,.92),rgba(255,255,255,.68)),linear-gradient(120deg,rgba(215,25,32,.08),rgba(255,210,63,.10))}
.builder-hero h2{font-size:30px;margin:0}
.save-state{display:inline-flex;align-items:center;min-height:34px;padding:7px 11px;border-radius:999px;background:rgba(255,255,255,.72);border:1px solid var(--line);color:var(--muted);font-size:13px;font-weight:720;white-space:nowrap}
.base-card{display:grid;gap:10px}
.builder-card-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:4px}
.title-input{font-size:25px;font-weight:730;letter-spacing:-.02em;padding:15px 16px}
.base-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:12px;align-items:end}
.base-grid.two{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.module-palette{display:grid;gap:12px}
.module-palette-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(138px,1fr));gap:10px}
.module-add-card{min-height:82px;display:grid;grid-template-columns:34px minmax(0,1fr);gap:10px;align-items:center;justify-content:start;text-align:left;border-radius:18px;background:rgba(255,255,255,.66);border:1px solid var(--line);box-shadow:none;color:var(--text);padding:12px}
.module-add-card span,.module-icon{display:grid;place-items:center;width:34px;height:34px;border-radius:12px;background:var(--brand-primary-soft);color:var(--brand-primary);font-weight:800}
.module-add-card strong{font-size:13px;line-height:1.25;white-space:normal}
.module-stack{display:grid;gap:14px}
.module-card{display:grid;gap:0;padding:0;overflow:hidden;border-radius:24px}
.module-card.drag-over{outline:2px solid var(--brand-primary)}
.module-head{display:grid;grid-template-columns:34px 38px minmax(0,1fr) auto;gap:12px;align-items:center;padding:16px 18px;border-bottom:1px solid var(--line)}
.module-head h3{margin:0;overflow-wrap:anywhere}
.module-body{display:grid;gap:12px;padding:18px}
.module-card.is-collapsed .module-body{display:none}
.drag-handle,.mini-handle,.icon-button{display:grid;place-items:center;min-width:0;width:34px;height:34px;min-height:34px;padding:0;border-radius:12px;background:rgba(255,255,255,.68);border:1px solid var(--line);color:var(--text-soft);box-shadow:none;font-weight:800}
.mini-handle{cursor:grab;align-self:start}
.drag-handle{cursor:grab}
.module-actions{display:flex;gap:6px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.module-warning .module-icon,.section-warning .eyebrow{background:rgba(217,45,32,.10);color:var(--danger)}
.module-tip .module-icon,.section-tip .eyebrow{background:rgba(31,143,86,.10);color:var(--ok)}
.module-steps .module-icon{background:rgba(10,132,255,.10);color:var(--info)}
.module-parts .module-icon{background:rgba(29,29,31,.08);color:var(--text)}
.nested-list,.step-builder{display:grid;gap:10px}
.nested-card,.step-editor-card,.part-editor-card{display:grid;grid-template-columns:34px minmax(0,1fr) 34px;gap:10px;padding:12px;border-radius:18px;background:rgba(255,255,255,.56);border:1px solid var(--line)}
.step-editor-card,.part-editor-card{grid-template-columns:1fr}
.nested-fields{display:grid;gap:8px}
.checkbox-row{display:flex;align-items:center;gap:8px;margin:0;color:var(--text-soft)}
.checkbox-row input[type=checkbox]{width:18px;height:18px}
.oil-editor-row{grid-template-columns:34px minmax(0,1fr) 34px}
.step-editor-head{display:flex;align-items:center;gap:8px;justify-content:space-between;margin-bottom:4px}
.step-editor-head strong{margin-right:auto}
.upload-drop{display:grid;place-items:center;min-height:94px;border:1px dashed rgba(0,0,0,.18);border-radius:18px;background:rgba(255,255,255,.48);color:var(--muted);font-weight:760;text-align:center;margin:4px 0 0;padding:16px}
.upload-drop input{margin-top:10px;background:#fff}
.publish-panel,.outline-panel{display:grid;gap:10px;padding:18px;border-radius:24px}
.publish-actions{display:grid;gap:9px;margin-top:6px}
.outline-panel nav{display:grid;gap:7px}
.outline-panel a{display:block;padding:9px 10px;border-radius:13px;color:var(--text-soft);background:rgba(255,255,255,.48);border:1px solid transparent;font-size:13px;font-weight:680;overflow-wrap:anywhere}
.outline-panel a:hover{color:var(--brand-primary);background:#fff;border-color:var(--brand-primary-line)}
.preview-dialog{width:min(920px,calc(100vw - 28px));border:0;border-radius:28px;padding:0;background:transparent}
.preview-dialog::backdrop{background:rgba(20,20,24,.38);backdrop-filter:blur(8px)}
.preview-shell{max-height:calc(100vh - 56px);overflow:auto;background:var(--surface-strong);border:1px solid var(--line-light);border-radius:28px;box-shadow:0 24px 80px rgba(0,0,0,.22)}
.preview-head{position:sticky;top:0;z-index:1;display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:rgba(255,255,255,.84);border-bottom:1px solid var(--line);backdrop-filter:var(--blur)}
.preview-body{display:grid;gap:14px;padding:22px}
.preview-section{padding:16px;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.52)}
.wiki-checklist{display:grid;gap:10px}
.wiki-checkitem{display:grid;grid-template-columns:30px minmax(0,1fr);gap:10px;padding:12px;border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.55)}
.check-dot{width:24px;height:24px;border-radius:999px;background:rgba(31,143,86,.12);border:1px solid rgba(31,143,86,.22);position:relative}
.check-dot:after{content:"";position:absolute;left:7px;top:4px;width:7px;height:12px;border:solid var(--ok);border-width:0 2px 2px 0;transform:rotate(45deg)}
.wiki-checkitem em{display:inline-flex;margin-left:8px;padding:3px 7px;border-radius:999px;background:rgba(215,25,32,.10);color:var(--brand-primary);font-size:11px;font-style:normal;font-weight:760}
.wiki-checkitem p{margin:5px 0 0;color:var(--muted)}
.oil-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:12px}
.oil-card{display:grid;gap:5px;padding:14px;border-radius:16px;background:rgba(255,255,255,.58);border:1px solid var(--line)}
.oil-card span{font-weight:720;color:var(--text-soft)}
.oil-card small,.oil-card p{color:var(--muted);margin:0;line-height:1.45}
.mini-link{min-height:32px;padding:6px 10px;font-size:12px}
.attachment-editor-card{display:grid;gap:14px}
.attachment-editor-list{display:grid;gap:12px}
.attachment-editor-row{display:grid;grid-template-columns:96px minmax(0,1fr) auto;gap:14px;align-items:start;padding:12px;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.56)}
.attachment-preview{display:grid;place-items:center;width:96px;aspect-ratio:1;border-radius:16px;background:rgba(255,255,255,.72);border:1px solid var(--line);overflow:hidden;color:var(--muted);font-weight:800}
.attachment-preview img{width:100%;height:100%;object-fit:cover}
.attachment-image-button{display:block;width:100%;height:100%;min-height:0;padding:0;border:0;border-radius:0;background:transparent;box-shadow:none}
.attachment-image-button:hover{transform:none;box-shadow:none;filter:brightness(.96)}
.attachment-fields{display:grid;gap:8px}
.attachment-fields label{margin:0;color:var(--muted);font-size:12px}
.attachment-meta-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.attachment-meta-row small{color:var(--muted);font-weight:700}
.attachment-row-actions{display:grid;gap:6px}
.danger-check{color:var(--danger)}
.tips-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:18px;align-items:start}
.tips-main{display:grid;gap:14px;min-width:0}
.tip-composer{display:grid;gap:12px;border-radius:26px}
.tip-composer-head{display:grid;grid-template-columns:42px minmax(0,1fr);gap:12px;align-items:start}
.tip-avatar{display:grid;place-items:center;width:42px;height:42px;border-radius:16px;background:var(--accent-grad);color:#fff;font-weight:800;box-shadow:var(--shadow-button)}
.tip-composer textarea{min-height:54px;resize:none;border-radius:20px;font-size:16px;line-height:1.5}
.tip-composer-meta{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.tip-composer-actions{display:flex;gap:10px;align-items:center;justify-content:space-between;flex-wrap:wrap}
.tip-file-button{display:inline-flex;align-items:center;justify-content:center;min-height:40px;margin:0;padding:9px 14px;border-radius:999px;background:rgba(255,255,255,.62);border:1px solid var(--line);color:var(--text-soft);font-weight:760;cursor:pointer}
.tip-file-button input{display:none}
.tips-feed,.tips-inline-list{display:grid;gap:12px}
.tip-card{display:grid;gap:12px;border-radius:24px}
.tip-card.compact{padding:18px}
.tip-card-head{display:grid;grid-template-columns:42px minmax(0,1fr);gap:12px;align-items:center}
.tip-card-head strong,.tip-card-head small{display:block}
.tip-card-head small{color:var(--muted);margin-top:2px}
.tip-content{margin:0;color:var(--text);font-size:16px;line-height:1.62;white-space:normal}
.tip-image{display:block;width:min(100%,460px)}
.tip-image img{display:block;width:100%;max-height:320px;object-fit:cover;border-radius:18px;border:1px solid var(--line);box-shadow:var(--shadow-soft)}
.tip-file{display:inline-flex;justify-self:start;padding:9px 12px;border-radius:999px;background:rgba(255,255,255,.64);border:1px solid var(--line);font-weight:760;color:var(--text-soft)}
.tip-meta-row{display:flex;flex-wrap:wrap;gap:7px}
.tip-meta-row span{display:inline-flex;padding:6px 9px;border-radius:999px;background:rgba(0,0,0,.055);color:var(--text-soft);font-size:12px;font-weight:760}
.tip-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.tip-actions form{display:inline-flex;margin:0}
.tip-actions .is-active{color:var(--brand-primary);border-color:var(--brand-primary-line);background:var(--brand-primary-soft)}
.tips-sidebar{position:sticky;top:18px;display:grid;gap:12px}
.tips-filter{display:grid;gap:10px}
.comments-panel{display:grid;gap:14px;margin-top:18px}
.comment-list{display:grid;gap:12px}
.comment-item{display:grid;grid-template-columns:42px minmax(0,1fr);gap:12px;padding:12px;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.52)}
.comment-item strong,.comment-item small{display:block}
.comment-item small{color:var(--muted);margin-top:2px}
.comment-item p{margin:7px 0 0;line-height:1.55;color:var(--text-soft)}
.comment-form{display:grid;gap:10px}
.comment-preview{display:grid;gap:4px;padding:12px 14px;border-radius:18px;background:rgba(255,255,255,.52);border:1px solid var(--line)}
.comment-preview strong{font-size:13px;color:var(--text)}
.comment-preview p{margin:0;color:var(--text-soft);line-height:1.45}
.comment-preview a{font-size:13px;font-weight:700;color:var(--brand-primary)}
.strength-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}
.mentor-manage-list{display:grid;gap:10px}
.mentor-manage-row{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:12px;align-items:center;padding:12px;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.5)}
.mentor-manage-row strong,.mentor-manage-row small{display:block}
.mentor-manage-row small{color:var(--muted);margin-top:3px}
.onboarding-layer{position:fixed;inset:0;z-index:9000;pointer-events:auto;isolation:isolate}
.onboarding-backdrop{
  position:absolute;
  inset:0;
  background:rgba(20,20,24,.42);
  backdrop-filter:grayscale(.35) blur(5px);
  -webkit-backdrop-filter:grayscale(.35) blur(5px);
  transition:mask-image .25s var(--ease),-webkit-mask-image .25s var(--ease);
  pointer-events:auto;
}
.onboarding-popover{position:fixed;z-index:9100;width:min(360px,calc(100vw - 32px));display:grid;gap:12px;padding:20px;pointer-events:auto;isolation:isolate}
.onboarding-popover.is-sheet{left:16px !important;right:16px !important;top:auto !important;bottom:16px !important;width:auto;max-width:none}
.onboarding-popover h2{margin:0}
.onboarding-popover p{margin:0;color:var(--text-soft);line-height:1.55}
.onboarding-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end;position:relative;z-index:9110}
.onboarding-actions .button,.onboarding-actions button{position:relative;z-index:9110}
.tour-active-target{position:relative;z-index:9010 !important;filter:none !important;backdrop-filter:none !important;-webkit-backdrop-filter:none !important;opacity:1 !important;isolation:isolate}
.tour-passive-target{pointer-events:none !important}
.tour-click-target{pointer-events:auto !important}
.tour-active-target *{filter:none !important}
.image-lightbox-dialog{width:min(980px,calc(100vw - 28px));border:0;border-radius:28px;padding:0;background:transparent}
.image-lightbox-dialog::backdrop{background:rgba(20,20,24,.48);backdrop-filter:blur(8px)}
.image-lightbox-shell{overflow:hidden;background:var(--surface-strong);border:1px solid var(--line-light);border-radius:28px;box-shadow:0 24px 80px rgba(0,0,0,.24)}
.image-lightbox-body{display:grid;place-items:center;padding:18px;max-height:calc(100vh - 120px)}
.image-lightbox-body img{display:block;max-width:100%;max-height:calc(100vh - 160px);width:auto;height:auto;border-radius:18px;box-shadow:var(--shadow-card);background:#fff}
.education-hero{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;margin-bottom:18px;background:linear-gradient(135deg,rgba(255,255,255,.9),rgba(255,255,255,.64)),linear-gradient(120deg,rgba(215,25,32,.08),rgba(255,210,63,.12))}
.education-hero h2{font-size:34px;margin:0 0 8px}
.education-grid{align-items:stretch}
.education-course-card{padding:0;overflow:hidden;min-height:260px}
.education-course-card>img{width:100%;height:130px;object-fit:cover;border-bottom:1px solid var(--line)}
.course-card-body{display:grid;gap:11px;padding:18px;height:100%}
.course-card-body h3{font-size:21px;margin:0}
.course-card-body p{color:var(--text-soft);line-height:1.5;margin:0}
.progress-track{height:10px;border-radius:999px;background:rgba(0,0,0,.07);overflow:hidden;border:1px solid rgba(255,255,255,.72)}
.progress-track span{display:block;height:100%;border-radius:999px;background:var(--accent-grad)}
.progress-track.large{height:14px;margin:12px 0}
.course-progress-line{display:flex;justify-content:space-between;gap:10px;align-items:center;color:var(--muted)}
.course-progress-line strong{color:var(--text)}
.course-layout,.lesson-layout{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:18px;align-items:start}
.lesson-layout{grid-template-columns:320px minmax(0,1fr)}
.course-overview,.lesson-content-card{display:grid;gap:14px}
.lesson-list-card{position:sticky;top:18px;display:grid;gap:12px}
.lesson-list{display:grid;gap:8px}
.lesson-row{display:grid;grid-template-columns:34px minmax(0,1fr);gap:10px;align-items:center;padding:10px;border-radius:16px;background:rgba(255,255,255,.52);border:1px solid var(--line)}
.lesson-row span{display:grid;place-items:center;width:32px;height:32px;border-radius:12px;background:rgba(0,0,0,.06);font-weight:800;color:var(--text-soft)}
.lesson-row strong{display:block;overflow-wrap:anywhere}
.lesson-row small{color:var(--muted);font-weight:650}
.lesson-row.is-current{border-color:var(--brand-primary-line);background:#fff}
.lesson-row.is-done span{background:rgba(31,143,86,.12);color:var(--ok)}
.lesson-main,.quiz-layout{display:grid;gap:14px}
.lesson-wiki-source,.education-article-link{display:flex;align-items:center;justify-content:space-between;gap:12px}
.lesson-actions form{display:inline-flex}
.empty-state-card{display:grid;gap:10px;padding:18px;border-radius:18px;background:rgba(255,255,255,.58);border:1px solid var(--line)}
.quiz-head-card,.quiz-result-card,.quiz-form{display:grid;gap:14px}
.quiz-result-card.passed{border-color:rgba(31,143,86,.24);background:rgba(239,250,244,.88)}
.quiz-result-card.failed{border-color:rgba(217,45,32,.20);background:rgba(255,245,244,.88)}
.quiz-result-card h2{font-size:44px;margin:0}
.quiz-question-card{display:grid;gap:10px;margin:0 0 14px;padding:16px;border:1px solid var(--line);border-radius:20px;background:rgba(255,255,255,.52)}
.quiz-question-card legend{display:flex;gap:10px;align-items:center;font-weight:760;color:var(--text);padding:0 6px}
.quiz-question-card legend span{display:grid;place-items:center;width:30px;height:30px;border-radius:11px;background:var(--brand-primary-soft);color:var(--brand-primary)}
.quiz-answer{display:grid;grid-template-columns:22px minmax(0,1fr);gap:10px;align-items:start;margin:0;padding:12px;border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.72);color:var(--text-soft)}
.quiz-answer input{width:18px;height:18px;margin:2px 0 0}
.progress-list{display:grid;gap:12px;margin-top:14px}
.progress-row-card{display:grid;grid-template-columns:minmax(0,1fr) minmax(180px,320px) auto auto;gap:14px;align-items:center}
.progress-row-card strong,.progress-row-card small{display:block}
.progress-row-card small{color:var(--muted);margin-top:3px}
.education-admin-form{display:grid;gap:16px;padding-bottom:80px}
.education-lesson-editor .module-actions{align-items:center}
.delete-check{margin:0;font-size:12px}
.quiz-builder-card{padding:0;overflow:hidden}
.quiz-answer-edit{grid-template-columns:minmax(0,1fr) auto 34px}
@media (max-width:800px){
  .hero-search{grid-template-columns:1fr}
  .hero-search form{flex-direction:column;align-items:stretch}
  .detail-head,.section-head{align-items:flex-start;flex-direction:column}
  .editor-toolbar-card{position:static}
  .sticky-editor-actions{align-items:stretch;flex-direction:column}
  .step-card{grid-template-columns:1fr}
  .step-number{width:36px;height:36px}
  .builder-layout{grid-template-columns:1fr}
  .builder-sidebar{position:static;max-height:none;order:-1}
  .builder-hero{align-items:flex-start;flex-direction:column}
  .module-head{grid-template-columns:30px 34px minmax(0,1fr);gap:9px}
  .module-actions{grid-column:1/-1;justify-content:flex-start}
  .module-palette-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .nested-card,.oil-editor-row{grid-template-columns:1fr}
  .education-hero,.lesson-wiki-source,.education-article-link{align-items:flex-start;flex-direction:column}
  .course-layout,.lesson-layout{grid-template-columns:1fr}
  .lesson-list-card{position:static}
  .progress-row-card{grid-template-columns:1fr}
  .quiz-answer-edit{grid-template-columns:1fr}
  .attachment-editor-row{grid-template-columns:1fr}
  .attachment-preview{width:100%;max-width:180px}
  .attachment-row-actions{display:flex}
  .tips-layout{grid-template-columns:1fr}
  .tips-sidebar{position:static;order:-1}
  .tip-composer-meta{grid-template-columns:1fr}
  .tip-composer-actions{align-items:stretch;flex-direction:column}
  .tip-composer-actions button,.tip-file-button{width:100%}
}

html,body{min-height:100%;overflow-x:hidden}
body{
  margin:0;
  color:var(--text);
  background:
    radial-gradient(circle at 18% 6%,rgba(255,255,255,.95),transparent 22rem),
    linear-gradient(135deg,#fbfaf8 0%,#f5f5f7 42%,#eceef2 100%);
  font-family:-apple-system,BlinkMacSystemFont,"SF Pro Display","SF Pro Text","Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  font-size:15px;
  letter-spacing:-.01em;
  width:100%;
  overflow-x:hidden;
}
html.tour-lock,
body.tour-lock{overflow:hidden !important;overscroll-behavior:none !important}
body.tour-active{overflow:hidden;touch-action:none}
.tour-lock .app-main,
.tour-lock .content,
.tour-lock main,
.tour-lock aside,
.tour-lock .main,
.tour-lock .sidebar{overflow:hidden !important}
body:before,
body:after{
  content:"";
  position:fixed;
  z-index:-2;
  pointer-events:none;
  border-radius:999px;
  filter:blur(86px);
  opacity:.62;
}
body:before{
  width:520px;
  height:520px;
  left:-190px;
  top:-170px;
  background:rgba(215,25,32,.14);
}
body:after{
  width:560px;
  height:560px;
  right:-230px;
  top:120px;
  background:rgba(255,210,63,.14);
}
a{color:inherit;text-decoration:none}
h1,h2,h3{color:var(--text);letter-spacing:-.03em}
h1{font-size:34px;line-height:1.05;margin:0;font-weight:760}
h2{font-size:21px;line-height:1.16;margin:0 0 10px;font-weight:720}
h3{font-size:16px;margin:0 0 10px;font-weight:700}

.glass-card,
.card,
.login-card,
.public-card{
  background:var(--surface-strong);
  border:1px solid var(--line-light);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-card);
  backdrop-filter:var(--blur);
  -webkit-backdrop-filter:var(--blur);
}
.glass-panel,
.sidebar,
.topbar,
.user-card{
  background:var(--surface);
  border:1px solid var(--line-light);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow-soft);
  backdrop-filter:var(--blur-heavy);
  -webkit-backdrop-filter:var(--blur-heavy);
}
.btn,
.button,
button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:40px;
  border:0;
  border-radius:999px;
  background:var(--accent-grad);
  color:#fff;
  font:inherit;
  font-weight:680;
  padding:10px 18px;
  white-space:nowrap;
  cursor:pointer;
  box-shadow:var(--shadow-button);
  transition:transform .18s var(--ease),box-shadow .18s var(--ease),filter .18s var(--ease),background .18s var(--ease);
}
.btn:hover,
.button:hover,
button:hover{
  transform:translateY(-1px);
  box-shadow:0 14px 30px rgba(215,25,32,.22);
}
.input,
input,
select,
textarea{
  width:100%;
  color:var(--text);
  background:rgba(255,255,255,.72);
  border:1px solid rgba(0,0,0,.08);
  border-radius:var(--radius-sm);
  padding:12px 14px;
  font:inherit;
  outline:none;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.85);
  transition:border-color .18s var(--ease),box-shadow .18s var(--ease),background .18s var(--ease);
}
.input:focus,
input:focus,
select:focus,
textarea:focus{
  border-color:var(--brand-primary-line);
  background:rgba(255,255,255,.94);
  box-shadow:0 0 0 5px var(--brand-primary-soft),inset 0 1px 0 rgba(255,255,255,.9);
}
.table-card{overflow:auto}

.login-page{
  min-height:100vh;
  display:grid;
  place-items:center;
  padding:18px;
  position:relative;
  overflow:hidden;
}
.login-body{
  background:
    linear-gradient(135deg,#f7f4ef 0%,#f5f5f7 43%,#e9edf1 100%);
}
.login-body:before{
  inset:0;
  width:auto;
  height:auto;
  left:0;
  top:0;
  border-radius:0;
  filter:none;
  opacity:.42;
  background:
    linear-gradient(115deg,transparent 0 24%,rgba(255,255,255,.78) 25%,transparent 35%),
    repeating-linear-gradient(90deg,rgba(29,29,31,.055) 0 1px,transparent 1px 78px);
  animation:login-shift 18s linear infinite;
}
.login-body:after{
  inset:auto -18% -42% auto;
  width:760px;
  height:760px;
  border-radius:32%;
  filter:blur(18px);
  opacity:.20;
  background:conic-gradient(from 120deg,var(--brand-primary),#ffffff,var(--brand-accent),#7f8ea3,var(--brand-primary));
  animation:login-rotate 28s linear infinite;
}
.login-page:before{
  content:"";
  position:absolute;
  inset:8%;
  border:1px solid rgba(255,255,255,.72);
  border-radius:34px;
  background:
    linear-gradient(120deg,rgba(255,255,255,.34),transparent 28%,rgba(255,255,255,.22) 56%,transparent);
  transform:skewY(-4deg);
  animation:login-panel-drift 12s ease-in-out infinite alternate;
}
@keyframes login-shift{
  from{background-position:0 0,0 0}
  to{background-position:520px 0,156px 0}
}
@keyframes login-rotate{
  to{transform:rotate(360deg)}
}
@keyframes login-panel-drift{
  from{transform:translateY(-10px) skewY(-4deg)}
  to{transform:translateY(10px) skewY(-4deg)}
}
.login-visual{
  position:relative;
  overflow:hidden;
  min-height:calc(100vh - 36px);
  padding:54px;
  border-radius:var(--radius-xl);
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  color:#fff;
  background:
    linear-gradient(145deg,rgba(29,29,31,.78),rgba(215,25,32,.38)),
    rgba(255,255,255,.18);
  border:1px solid rgba(255,255,255,.28);
  box-shadow:0 24px 70px rgba(0,0,0,.14);
  backdrop-filter:var(--blur-heavy);
}
.login-visual:before,
.login-visual:after{
  content:"";
  position:absolute;
  border-radius:999px;
  filter:blur(58px);
}
.login-visual:before{width:420px;height:420px;background:rgba(255,255,255,.22);left:7%;top:7%}
.login-visual:after{width:380px;height:380px;background:rgba(215,25,32,.46);right:-7%;bottom:6%}
.login-visual>*{position:relative;z-index:1}
.login-visual h1{max-width:760px;color:#fff;font-size:clamp(48px,6.8vw,92px);line-height:.92;font-weight:780}
.login-visual p{max-width:560px;color:rgba(255,255,255,.82);font-size:17px;line-height:1.7}
.login-panel{display:grid;place-items:center;width:100%;position:relative;z-index:1}
.login-card{width:min(410px,100%);padding:32px}
.login-brand{
  display:grid;
  justify-items:center;
  gap:12px;
  margin-bottom:24px;
  text-align:center;
}
.login-brand img{
  display:block;
  max-width:180px;
  max-height:78px;
  width:auto;
  height:auto;
  object-fit:contain;
}
.login-brand strong{font-size:22px;color:var(--text)}

.brand-row{display:flex;align-items:center;gap:12px;margin-bottom:28px}
.brand-mark{
  display:grid;
  place-items:center;
  width:42px;
  height:42px;
  border-radius:14px;
  background:var(--accent-grad);
  color:#fff;
  font-weight:760;
  box-shadow:0 12px 28px rgba(215,25,32,.22);
}
.brand-logo{
  display:grid;
  place-items:center;
  width:42px;
  height:42px;
  border-radius:14px;
  background:#fff;
  border:1px solid var(--line);
  overflow:hidden;
  box-shadow:var(--shadow-soft);
}
.brand-logo img{max-width:34px;max-height:34px;object-fit:contain}
.brand{
  display:flex;
  align-items:center;
  gap:12px;
  padding:4px 4px 18px;
  border-bottom:1px solid rgba(0,0,0,.06);
}
.brand.has-logo{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
  align-items:start;
  padding:2px 2px 18px;
}
.brand.has-logo .brand-logo{
  width:100%;
  height:76px;
  padding:4px 0;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
}
.brand.has-logo .brand-logo img{
  display:block;
  width:100%;
  height:100%;
  max-width:184px;
  max-height:54px;
  object-fit:contain;
  object-position:center;
}
.brand strong,.brand-row strong{display:block;color:var(--text);font-weight:720}
.brand small,.brand-row small,.user-card small,.eyebrow{display:block;color:var(--muted)}
.brand small{font-size:12px}

.brand-preview{
  display:flex;
  align-items:center;
  gap:14px;
  padding:16px;
  margin:16px 0;
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  background:rgba(255,255,255,.54);
}
.brand-preview img{max-width:170px;max-height:72px;object-fit:contain}
.asset-list{display:grid;gap:10px;margin:16px 0}
.asset-list div{
  display:grid;
  grid-template-columns:130px minmax(0,1fr);
  gap:12px;
  align-items:center;
}
.asset-list span{font-weight:650;color:var(--text-soft)}
.asset-list code{overflow-wrap:anywhere;color:var(--muted);font-size:12px}

label{display:block;color:var(--text-soft);font-weight:650;font-size:13px;margin:16px 0 7px}
.button.secondary{background:rgba(29,29,31,.88);box-shadow:0 12px 28px rgba(0,0,0,.12)}
.button.ghost{background:rgba(255,255,255,.62);color:var(--text);border:1px solid rgba(0,0,0,.06);box-shadow:var(--shadow-soft)}
.error{background:rgba(255,245,244,.82);border:1px solid rgba(217,45,32,.16);color:var(--danger);padding:12px 14px;border-radius:var(--radius-sm);margin:12px 0;backdrop-filter:var(--blur)}
.flash{background:rgba(239,250,244,.82);border:1px solid rgba(31,143,86,.14);color:var(--ok);padding:12px 14px;border-radius:var(--radius-sm);margin-bottom:16px;box-shadow:var(--shadow-soft);backdrop-filter:var(--blur)}

.app-shell{
  min-height:100vh;
  display:grid;
  grid-template-columns:282px minmax(0,1fr);
  gap:18px;
  padding:18px;
  position:relative;
}
.app-shell:before{
  content:"";
  position:absolute;
  z-index:-1;
  width:420px;
  height:420px;
  right:16%;
  bottom:3%;
  border-radius:999px;
  background:rgba(255,255,255,.72);
  filter:blur(68px);
}
.sidebar{
  min-height:calc(100vh - 36px);
  max-height:calc(100vh - 36px);
  position:sticky;
  top:18px;
  overflow:auto;
  padding:18px;
  display:flex;
  flex-direction:column;
  gap:18px;
}
.sidebar .brand-mark{width:38px;height:38px;border-radius:13px}
.nav{display:grid;gap:6px}
.nav a{
  position:relative;
  display:flex;
  align-items:center;
  gap:11px;
  min-height:42px;
  padding:10px 13px;
  border-radius:14px;
  color:var(--text-soft);
  font-weight:660;
  transition:background .18s var(--ease),color .18s var(--ease),transform .18s var(--ease);
}
.nav-icon{
  width:19px;
  height:19px;
  flex:0 0 19px;
  fill:none;
  stroke:currentColor;
  stroke-width:1.9;
  stroke-linecap:round;
  stroke-linejoin:round;
  opacity:.78;
}
.nav a:hover{
  color:var(--text);
  background:rgba(255,255,255,.66);
  transform:translateX(2px);
}
.nav a:hover .nav-icon{color:var(--brand-primary);opacity:1}
.user-card{
  margin-top:0;
  padding:15px;
  color:var(--text);
  border-radius:var(--radius-md);
}
.user-card strong{display:block;color:var(--text);font-weight:700}
.user-card a{font-weight:690}
.branch-context-form{
  display:grid;
  gap:7px;
  margin-top:12px;
}
.branch-context-form label{
  margin:0;
  color:var(--muted);
  font-size:12px;
  font-weight:720;
}
.branch-context-form select{
  width:100%;
  min-height:38px;
  border-radius:14px;
  padding:8px 10px;
  font-size:13px;
  background:rgba(255,255,255,.72);
}
.user-card .admin-area-link{
  display:flex;
  align-items:center;
  gap:9px;
  justify-content:center;
  color:#fff;
  background:var(--accent-grad);
  border-radius:999px;
  padding:10px 13px;
  margin-top:12px;
  box-shadow:var(--shadow-button);
}
.user-card .admin-area-link .nav-icon{width:17px;height:17px;opacity:.9}
.account-actions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  margin-top:12px;
}
.account-actions a{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:7px;
  min-height:38px;
  padding:8px 10px;
  border-radius:999px;
  color:var(--text-soft);
  background:rgba(255,255,255,.62);
  border:1px solid var(--line);
}
.account-actions a:hover{color:var(--brand-primary);background:#fff}
.account-actions .nav-icon{width:16px;height:16px}

.main{min-width:0;padding:0}
.topbar{
  min-height:96px;
  display:grid;
  grid-template-columns:auto minmax(0,1fr) minmax(250px,360px) auto;
  gap:18px;
  align-items:center;
  margin-bottom:18px;
  padding:20px 22px;
  overflow:hidden;
}
.window-dots{display:flex;gap:7px;align-self:start;padding-top:3px}
.window-dots span{width:12px;height:12px;border-radius:999px;display:block}
.window-dots span:nth-child(1){background:#ff5f57}
.window-dots span:nth-child(2){background:#ffbd2e}
.window-dots span:nth-child(3){background:#28c840}
.topbar-title{min-width:0}
.topbar h1{font-size:32px}
.topbar-user{
  min-width:160px;
  text-align:right;
  color:var(--text);
  font-weight:650;
}
.topbar-user small{display:block;color:var(--muted);font-weight:520;margin-top:3px}
.eyebrow{text-transform:uppercase;font-size:11px;font-weight:720;letter-spacing:.12em;margin:0 0 5px;color:var(--muted)}
.topbar-search{
  display:grid;
  grid-template-columns:minmax(0,1fr) 42px;
  gap:8px;
  align-items:center;
}
.topbar-search input{
  min-height:42px;
  border-radius:999px;
  padding:10px 14px;
  background:rgba(255,255,255,.68);
}
.topbar-search button{
  width:42px;
  height:42px;
  min-height:42px;
  padding:0;
  border-radius:999px;
  font-size:22px;
  line-height:1;
}

.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}
.grid.cards-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.card{padding:22px}
.card h2,.card h3{margin-top:0}
.span-4{grid-column:span 4}.span-5{grid-column:span 5}.span-6{grid-column:span 6}.span-7{grid-column:span 7}.span-8{grid-column:span 8}.span-12{grid-column:span 12}
.metric{font-size:42px;font-weight:760;margin:6px 0 0;color:var(--text);letter-spacing:-.04em}
.muted{color:var(--muted);line-height:1.58}
.actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:16px}

.dashboard-hero{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:22px;
  overflow:hidden;
  position:relative;
  min-height:170px;
  background:
    linear-gradient(135deg,rgba(255,255,255,.86),rgba(255,255,255,.48)),
    linear-gradient(120deg,rgba(215,25,32,.10),rgba(255,210,63,.12));
}
.dashboard-hero:after{
  content:"";
  position:absolute;
  width:360px;
  height:360px;
  right:-120px;
  top:-155px;
  border-radius:42%;
  background:conic-gradient(from 80deg,rgba(215,25,32,.20),rgba(255,255,255,.20),rgba(255,210,63,.22),rgba(120,132,148,.16));
  animation:login-rotate 34s linear infinite;
}
.dashboard-hero>*{position:relative;z-index:1}
.dashboard-kicker{
  display:block;
  color:var(--muted);
  font-size:12px;
  font-weight:760;
  text-transform:uppercase;
  letter-spacing:.10em;
  margin-bottom:8px;
}
.dashboard-hero h2{font-size:38px;margin:0}
.dashboard-hero-meta{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:16px;
}
.dashboard-hero-meta span{
  display:inline-flex;
  align-items:center;
  min-height:32px;
  padding:7px 11px;
  border-radius:999px;
  background:rgba(255,255,255,.68);
  border:1px solid var(--line);
  color:var(--text-soft);
  font-size:13px;
  font-weight:700;
}
.dashboard-hero-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.dashboard-shortcuts{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(150px,1fr));
  gap:12px;
}
.dashboard-shortcuts a{
  display:grid;
  grid-template-columns:42px minmax(0,1fr);
  column-gap:12px;
  row-gap:2px;
  align-items:center;
  min-height:72px;
  padding:12px;
  border-radius:18px;
  background:rgba(255,255,255,.56);
  border:1px solid var(--line);
  transition:transform .18s var(--ease),background .18s var(--ease),box-shadow .18s var(--ease);
}
.dashboard-shortcuts a:hover{
  transform:translateY(-2px);
  background:#fff;
  box-shadow:var(--shadow-soft);
}
.dashboard-shortcuts a>span{
  grid-row:1/3;
  display:grid;
  place-items:center;
  width:42px;
  height:42px;
  border-radius:14px;
  background:var(--accent-grad);
  color:#fff;
  font-weight:780;
  box-shadow:var(--shadow-button);
}
.dashboard-shortcuts strong{min-width:0;color:var(--text);font-size:14px}
.dashboard-shortcuts small{min-width:0;color:var(--muted);font-size:12px;font-weight:650}
.dashboard-status-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
  gap:12px;
}
.dashboard-status-grid a{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:14px;
  min-height:84px;
  padding:16px;
  border-radius:20px;
  background:rgba(255,255,255,.55);
  border:1px solid var(--line);
}
.dashboard-status-grid span{color:var(--muted);font-weight:720}
.dashboard-status-grid strong{font-size:36px;letter-spacing:-.04em}
.dashboard-section-head,
.kiosk-board-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  margin-bottom:14px;
}
.dashboard-section-head .muted,
.kiosk-board-head .muted{margin:0}
.dashboard-list{
  display:grid;
  gap:10px;
}
.dashboard-list a{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto auto;
  gap:12px;
  align-items:center;
  padding:13px;
  border-radius:18px;
  background:rgba(255,255,255,.58);
  border:1px solid var(--line);
}
.dashboard-list strong{min-width:0;color:var(--text);overflow-wrap:anywhere}
.dashboard-list span{color:var(--muted);font-size:13px;font-weight:700;white-space:nowrap}
.dashboard-module-strip{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(210px,1fr));
  gap:12px;
}
.dashboard-module-strip a{
  display:grid;
  gap:5px;
  min-height:86px;
  padding:16px;
  border-radius:20px;
  background:rgba(255,255,255,.54);
  border:1px solid var(--line);
}
.dashboard-module-strip strong{color:var(--text)}
.dashboard-module-strip span{color:var(--muted);font-size:13px;line-height:1.45}
.soundtrack-active-toggle{
  display:flex;
  align-items:end;
}
.soundtrack-active-toggle label{
  display:flex;
  align-items:center;
  gap:8px;
  margin:0 0 10px;
}
.soundtrack-active-toggle input{width:auto}
.soundtrack-section-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin:20px 0 12px;
}
.soundtrack-section-head h3{margin:0}
.soundtrack-steps{
  display:grid;
  gap:9px;
}
.soundtrack-step{
  display:grid;
  grid-template-columns:160px 120px auto;
  gap:8px;
  align-items:center;
}
.soundtrack-step .button{
  min-height:42px;
  padding:10px 12px;
}
.soundtrack-rule-list{
  display:grid;
  gap:12px;
}
.soundtrack-rule-list>section{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(220px,2fr) auto;
  gap:14px;
  align-items:center;
  padding:14px;
  border-radius:20px;
  background:rgba(255,255,255,.56);
  border:1px solid var(--line);
}
.soundtrack-rule-list strong,
.soundtrack-rule-list span,
.soundtrack-rule-list small{display:block}
.soundtrack-rule-list small{color:var(--muted);margin-top:4px}
.soundtrack-rule-steps{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
}

table{width:100%;border-collapse:separate;border-spacing:0 8px}
th,td{text-align:left;padding:13px 12px;vertical-align:top}
th{font-size:11px;text-transform:uppercase;color:var(--muted);letter-spacing:.08em;font-weight:720}
td{
  background:rgba(255,255,255,.56);
  border-top:1px solid rgba(255,255,255,.72);
  border-bottom:1px solid rgba(0,0,0,.045);
  color:var(--text-soft);
}
td:first-child{border-left:1px solid rgba(255,255,255,.72);border-radius:16px 0 0 16px}
td:last-child{border-right:1px solid rgba(255,255,255,.72);border-radius:0 16px 16px 0}
.badge{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:5px 10px;
  font-size:12px;
  font-weight:680;
  white-space:nowrap;
  background:rgba(255,255,255,.66);
  color:var(--text-soft);
  border:1px solid rgba(0,0,0,.045);
}
.badge.on{background:rgba(31,143,86,.10);color:var(--ok)}
.badge.progress{background:rgba(10,132,255,.10);color:var(--info)}
.badge.wait{background:rgba(255,189,46,.16);color:var(--warning)}
.badge.soon{background:rgba(175,82,222,.12);color:#8e3fc4}
.badge.master{background:rgba(255,210,63,.20);color:#8a6100}
.priority-urgent{background:rgba(217,45,32,.10);color:var(--danger)}
.priority-high{background:rgba(255,149,0,.14);color:#a14e00}
.priority-low{background:rgba(10,132,255,.09);color:#0969c3}
.category-pill{
  display:inline-flex;
  align-items:center;
  min-height:30px;
  border-radius:999px;
  padding:6px 12px;
  font-size:12px;
  font-weight:720;
  white-space:nowrap;
  border:1px solid rgba(0,0,0,.045);
  background:rgba(255,255,255,.70);
}
.category-defect{color:#b42318;background:rgba(255,238,236,.78)}
.category-order{color:#175cd3;background:rgba(235,243,255,.82)}
.category-general{color:#8a6100;background:rgba(255,246,219,.86)}
.row-overdue td{background:rgba(255,240,239,.72)}
.table-title{font-weight:700;color:var(--text)}
.check-list{display:grid;gap:9px;margin-top:12px}
.check-list label{display:flex;gap:10px;margin:0;font-weight:620}
.check-list input{width:auto}
.branch-feature-config{
  padding:16px;
  border-radius:20px;
  background:rgba(255,255,255,.45);
  border:1px solid rgba(18,24,38,.06);
}
.branch-feature-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:10px;
  margin-top:12px;
}
.branch-feature-toggle{display:grid;margin:0}
.branch-feature-toggle input[type="checkbox"]{
  position:absolute;
  opacity:0;
  pointer-events:none;
}
.branch-feature-toggle span{
  display:grid;
  gap:4px;
  min-height:78px;
  padding:12px 14px;
  border-radius:16px;
  background:rgba(255,255,255,.64);
  border:1px solid rgba(18,24,38,.07);
}
.branch-feature-toggle strong{color:var(--text);font-size:14px}
.branch-feature-toggle small{color:var(--muted);font-size:12px;font-weight:650;line-height:1.35}
.branch-feature-toggle input:checked + span{
  border-color:rgba(31,143,86,.22);
  background:rgba(31,143,86,.08);
}
.branch-feature-toggle input:checked + span strong{color:var(--ok)}
.plate-input{text-transform:uppercase;font-size:32px;font-weight:780;letter-spacing:.08em}
.complaint-card h3{text-transform:uppercase;letter-spacing:.06em}
.complaint-form{padding:26px}
.complaint-form-grid{
  display:grid;
  grid-template-columns:minmax(420px,1.18fr) minmax(280px,.82fr);
  gap:18px;
  align-items:start;
}
.complaint-form-grid.public{grid-template-columns:minmax(420px,1.08fr) minmax(260px,.92fr)}
.complaint-plate-area{grid-column:1}
.complaint-form-grid>div:nth-last-child(-n+2){align-self:stretch}
.complaint-form-grid textarea{min-height:148px;resize:vertical}
.complaint-public-card{width:min(1040px,100%);padding:30px}
.license-plate{
  display:grid;
  grid-template-columns:38px minmax(84px,1fr) minmax(96px,1fr) minmax(126px,1.22fr);
  align-items:stretch;
  min-height:104px;
  max-width:680px;
  overflow:hidden;
  border:4px solid #111827;
  border-radius:12px;
  background:#f8fafc;
  box-shadow:inset 0 0 0 3px #fff, 0 12px 24px rgba(17,24,39,.16);
}
.plate-eu{
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  align-items:center;
  padding:9px 0 8px;
  background:#0647a8;
  color:#fff;
  font-size:12px;
  font-weight:800;
}
.plate-eu span{font-size:10px;letter-spacing:0;text-transform:uppercase;opacity:.9}
.plate-eu strong{font-size:17px;line-height:1}
.plate-field{
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:11px 8px;
  border-left:3px solid #111827;
  background:linear-gradient(180deg,#fff 0%,#f8fafc 55%,#eef2f7 100%);
}
.plate-field label{
  margin:0 0 4px;
  text-align:center;
  text-transform:uppercase;
  font-size:11px;
}
.plate-field input{
  border:0;
  background:transparent;
  text-align:center;
  text-transform:uppercase;
  font-size:38px;
  line-height:1;
  font-weight:900;
  padding:0;
  box-shadow:none;
  color:#111827;
}
.plate-field input:focus{outline:0;background:rgba(215,25,32,.07);border-radius:7px}
.inline-field{display:flex;gap:10px;align-items:center}
.inline-field input{max-width:220px}
.service-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:10px}
.service-grid.compact{grid-template-columns:repeat(3,minmax(0,1fr))}
.service-option input{position:absolute;opacity:0;pointer-events:none}
.service-option span{
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  min-height:58px;
  padding:12px 36px 12px 14px;
  border-radius:14px;
  background:rgba(255,255,255,.66);
  border:1px solid rgba(0,0,0,.07);
  font-weight:720;
  text-align:center;
  box-shadow:var(--shadow-soft);
  transition:background .16s var(--ease),border-color .16s var(--ease),color .16s var(--ease),transform .16s var(--ease);
}
.service-option span:after,
.pretty-check span:before{
  content:"";
  position:absolute;
  width:22px;
  height:22px;
  border-radius:999px;
  border:2px solid rgba(29,29,31,.18);
  background:rgba(255,255,255,.75);
}
.service-option span:after{right:10px;top:50%;transform:translateY(-50%)}
.service-option input:checked+span{border-color:var(--brand-primary);background:rgba(215,25,32,.09);color:var(--brand-primary);transform:translateY(-1px)}
.service-option input:checked+span:after,
.pretty-check input:checked+span:before{
  border-color:var(--brand-primary);
  background:var(--brand-primary);
  box-shadow:inset 0 0 0 5px #fff;
}
.terms-box{
  padding:0;
  border-radius:16px;
  background:rgba(255,245,244,.72);
  border:1px solid rgba(217,45,32,.12);
}
.pretty-check{
  display:block;
  margin-top:18px;
  cursor:pointer;
}
.pretty-check input{position:absolute;opacity:0;pointer-events:none}
.pretty-check span{
  position:relative;
  display:block;
  padding:16px 18px 16px 52px;
  color:var(--text-soft);
  font-weight:650;
  line-height:1.45;
}
.pretty-check span:before{left:18px;top:17px}
summary{cursor:pointer;color:var(--text);font-weight:700}
.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(112px,1fr));gap:12px;margin-top:12px}
.photo-grid img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:18px;box-shadow:var(--shadow-soft)}
.qr-card{display:grid;grid-template-columns:150px minmax(0,1fr);gap:18px;padding:18px 0;border-bottom:1px solid rgba(0,0,0,.055)}
.qr-card img{width:150px;height:150px;border-radius:20px;background:rgba(255,255,255,.72);padding:12px;box-shadow:var(--shadow-soft);border:1px solid rgba(255,255,255,.72)}
.todo-alert{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:12px;align-items:center;margin-top:10px;padding:13px 15px;border-radius:18px;background:rgba(255,255,255,.58);border:1px solid rgba(255,255,255,.72)}
.alert-card{background:rgba(255,255,255,.78);border-left:4px solid var(--brand-primary)}
.order-items-field{
  display:grid;
  gap:10px;
  margin-top:16px;
}
.order-items-field[hidden],
.todo-title-field[hidden],
.todo-description-field[hidden],
.todo-location-field[hidden]{display:none}
.order-items-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.order-items-head label{margin:0}
.order-items-head .button{
  min-height:34px;
  padding:8px 12px;
  font-size:13px;
}
.order-items-list{
  display:grid;
  gap:9px;
}
.order-item-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) 120px 40px;
  gap:8px;
  align-items:center;
}
.order-item-row input{min-height:42px}
.order-remove-row{
  width:40px;
  height:40px;
  min-height:40px;
  padding:0;
  border-radius:999px;
  background:rgba(29,29,31,.86);
  box-shadow:none;
}
.todo-toolbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  margin-bottom:14px;
}
.todo-toolbar h2{margin-bottom:2px}
.complaint-link-card{margin-bottom:18px}
.todo-filters{
  display:flex;
  gap:9px;
  flex-wrap:wrap;
  margin:0 0 18px;
}
.filter-chip{
  display:inline-flex;
  align-items:center;
  min-height:36px;
  padding:8px 13px;
  border-radius:999px;
  background:rgba(255,255,255,.68);
  border:1px solid rgba(255,255,255,.72);
  color:var(--text);
  font-weight:650;
  white-space:nowrap;
  box-shadow:var(--shadow-soft);
  backdrop-filter:var(--blur);
}
.filter-chip:hover{background:rgba(255,255,255,.9)}
.filter-chip.is-active{
  background:rgba(215,25,32,.10);
  color:var(--brand-primary);
  border-color:rgba(215,25,32,.18);
}
.muted-chip{color:var(--muted);font-weight:600}
.todo-filters-wrapper{
  display:flex;
  flex-direction:column;
  gap:9px;
  margin:0 0 18px;
}
.toggle-filters{
  display:inline-flex;
  align-items:center;
  gap:6px;
  width:fit-content;
  min-height:36px;
  padding:8px 13px;
  border-radius:999px;
  background:rgba(255,255,255,.68);
  border:1px solid rgba(255,255,255,.72);
  color:var(--text);
  font-weight:650;
  white-space:nowrap;
  box-shadow:var(--shadow-soft);
  backdrop-filter:var(--blur);
  cursor:pointer;
  transition:all .2s var(--ease);
}
.toggle-filters:hover{
  background:rgba(255,255,255,.9);
}
.toggle-filters.is-active{
  background:rgba(215,25,32,.10);
  color:var(--brand-primary);
  border-color:rgba(215,25,32,.18);
}
.toggle-filters .chevron{
  display:inline-block;
  transition:transform .2s var(--ease);
  font-size:11px;
  margin-left:4px;
}
.toggle-filters.is-active .chevron{
  transform:rotate(180deg);
}
.todo-filters{
  display:none;
  gap:9px;
  flex-wrap:wrap;
  margin:0;
}
.todo-filters.is-open{
  display:flex;
}
.todo-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(310px,1fr));
  gap:18px;
}
.todo-card{
  position:relative;
  min-height:360px;
  display:flex;
  flex-direction:column;
  overflow:hidden;
  background:var(--surface-strong);
  border:1px solid var(--line-light);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-card);
  backdrop-filter:var(--blur);
  -webkit-backdrop-filter:var(--blur);
  transition:transform .18s var(--ease),box-shadow .18s var(--ease);
}
.todo-card:hover{transform:translateY(-2px);box-shadow:0 24px 62px rgba(0,0,0,.09)}
.todo-card.is-overdue{border-color:rgba(215,25,32,.22)}
.todo-card.todo-priority-high{
  box-shadow:0 20px 62px rgba(255,149,0,.13);
  border-color:rgba(255,149,0,.20);
}
.todo-card.todo-priority-urgent{
  box-shadow:0 22px 68px rgba(217,45,32,.18);
  border-color:rgba(217,45,32,.30);
}
.todo-priority-ribbon{
  position:absolute;
  top:14px;
  right:14px;
  z-index:3;
  border-radius:999px;
  padding:7px 11px;
  color:#fff;
  background:rgba(217,45,32,.88);
  box-shadow:0 12px 28px rgba(217,45,32,.22);
  backdrop-filter:blur(16px);
  font-size:12px;
  font-weight:780;
}
.todo-priority-high .todo-priority-ribbon{background:rgba(255,149,0,.90);box-shadow:0 12px 28px rgba(255,149,0,.20)}
.todo-photo-preview{
  position:relative;
  display:block;
  width:100%;
  height:156px;
  overflow:hidden;
  background:rgba(255,255,255,.48);
  border:0;
  border-radius:0;
  padding:0;
  cursor:zoom-in;
  box-shadow:none;
}
.todo-photo-preview:hover{transform:none;box-shadow:none;filter:none}
.todo-photo-preview img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.todo-photo-preview:after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(to bottom,transparent 45%,rgba(0,0,0,.22));
}
.todo-photo-preview span{
  position:absolute;
  right:12px;
  bottom:10px;
  z-index:1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:34px;
  height:30px;
  border-radius:999px;
  color:#fff;
  background:rgba(0,0,0,.36);
  backdrop-filter:blur(14px);
  font-weight:700;
}
.todo-pattern{
  position:relative;
  height:156px;
  overflow:hidden;
  background:rgba(255,255,255,.48);
}
.todo-pattern:before{
  content:"";
  position:absolute;
  inset:0;
  opacity:.34;
  background-size:74px 74px;
  transform:rotate(-8deg) scale(1.1);
}
.todo-pattern-defect{
  background:linear-gradient(135deg,rgba(255,238,236,.84),rgba(255,255,255,.56));
}
.todo-pattern-defect:before{
  opacity:.46;
  background-image:url("data:image/svg+xml,%3Csvg width='74' height='74' viewBox='0 0 74 74' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%23d92d20' stroke-width='3.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M37 12 63 58H11L37 12Z'/%3E%3Cpath d='M37 28v14'/%3E%3Cpath d='M37 51h.01'/%3E%3C/g%3E%3C/svg%3E");
}
.todo-pattern-complaint{
  background:linear-gradient(135deg,rgba(235,243,255,.86),rgba(255,255,255,.58));
}
.todo-pattern-complaint:before{
  opacity:.40;
  background-image:url("data:image/svg+xml,%3Csvg width='74' height='74' viewBox='0 0 74 74' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%23d92d20' stroke-width='3.1' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M18 43h38c3 0 5 2.2 5 5v7H13v-7c0-2.8 2.1-5 5-5Z'/%3E%3Cpath d='M23 43l5.4-12.2c.8-1.8 2.6-2.8 4.5-2.8h14.2c1.9 0 3.7 1.1 4.5 2.8L57 43'/%3E%3Cpath d='M30 34h20'/%3E%3Cpath d='M22 55v3M52 55v3'/%3E%3Ccircle cx='24' cy='55' r='4.2'/%3E%3Ccircle cx='50' cy='55' r='4.2'/%3E%3Cpath d='M16 47h7M51 47h7'/%3E%3C/g%3E%3C/svg%3E");
}
.todo-pattern-general{
  background:linear-gradient(135deg,rgba(255,246,219,.86),rgba(255,255,255,.58));
}
.todo-pattern-general:before{
  background-image:url("data:image/svg+xml,%3Csvg width='74' height='74' viewBox='0 0 74 74' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%23c08a00' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='20' y='14' width='34' height='46' rx='5'/%3E%3Cpath d='M28 26h18M28 36h18M28 46h12'/%3E%3Cpath d='M28 14v8M37 14v8M46 14v8'/%3E%3C/g%3E%3C/svg%3E");
}
.todo-pattern-order{
  background:linear-gradient(135deg,rgba(235,243,255,.86),rgba(255,255,255,.58));
}
.todo-pattern-order:before{
  background-image:url("data:image/svg+xml,%3Csvg width='74' height='74' viewBox='0 0 74 74' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%230a84ff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M17 19h7l5 27h25l5-18H30'/%3E%3Ccircle cx='34' cy='56' r='4'/%3E%3Ccircle cx='53' cy='56' r='4'/%3E%3Cpath d='M32 36h20'/%3E%3C/g%3E%3C/svg%3E");
}
.todo-card-body{display:flex;flex-direction:column;gap:12px;flex:1;padding:18px}
.todo-card-head,.todo-card-footer{display:flex;align-items:center;justify-content:space-between;gap:10px}
.todo-head-actions{display:flex;align-items:center;gap:8px}
.quick-menu{position:relative}
.quick-menu-button{
  min-width:34px;
  width:34px;
  height:30px;
  min-height:30px;
  padding:0;
  border-radius:999px;
  color:var(--text-soft);
  background:rgba(255,255,255,.62);
  border:1px solid rgba(0,0,0,.045);
  box-shadow:none;
  font-size:15px;
  letter-spacing:1px;
  line-height:1;
}
.quick-menu-button:hover{transform:none;box-shadow:var(--shadow-soft);background:rgba(255,255,255,.9)}
.quick-menu-popover{
  position:absolute;
  z-index:20;
  top:calc(100% + 8px);
  right:0;
  width:218px;
  padding:7px;
  border-radius:16px;
  background:rgba(255,255,255,.88);
  border:1px solid rgba(255,255,255,.72);
  box-shadow:0 18px 48px rgba(0,0,0,.14);
  backdrop-filter:var(--blur-heavy);
  -webkit-backdrop-filter:var(--blur-heavy);
  opacity:0;
  transform:translateY(-4px) scale(.98);
  pointer-events:none;
  transition:opacity .16s var(--ease),transform .16s var(--ease);
}
.quick-menu.is-open .quick-menu-popover{
  opacity:1;
  transform:translateY(0) scale(1);
  pointer-events:auto;
}
.quick-menu-popover form{display:grid;gap:3px}
.quick-menu-popover button{
  justify-content:flex-start;
  min-height:36px;
  width:100%;
  padding:8px 10px;
  border-radius:11px;
  background:transparent;
  color:var(--text);
  box-shadow:none;
  font-weight:640;
  white-space:nowrap;
}
.quick-menu-popover button:hover{
  transform:none;
  box-shadow:none;
  background:rgba(215,25,32,.08);
  color:var(--brand-primary);
}
.quick-menu-popover .danger-action{color:var(--danger)}
.quick-menu-popover .danger-action:hover{background:rgba(217,45,32,.10);color:var(--danger)}
.todo-card h3{font-size:20px;line-height:1.18;margin:0}
.todo-card h3 a{color:var(--text)}
.todo-card .muted{margin:0}
.todo-meta{
  display:grid;
  gap:7px;
  margin-top:auto;
  color:var(--muted);
  font-size:13px;
}
.todo-meta span{
  display:flex;
  align-items:center;
  gap:8px;
  min-width:0;
}
.todo-meta svg{
  width:16px;
  height:16px;
  flex:0 0 16px;
  color:rgba(215,25,32,.72);
  stroke:currentColor;
  stroke-width:2;
  fill:none;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.todo-last-comment{
  display:block;
  padding:11px 12px;
  border-radius:16px;
  background:rgba(255,255,255,.52);
  border:1px solid rgba(0,0,0,.045);
}
.todo-last-comment strong{
  display:block;
  color:var(--text);
  font-size:12px;
  margin-bottom:3px;
}
.todo-last-comment span{
  display:block;
  color:var(--muted);
  font-size:13px;
  line-height:1.35;
}
.quick-comment-form{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:8px;
}
.quick-comment-form input{
  min-height:38px;
  padding:9px 12px;
  border-radius:999px;
}
.quick-comment-form button{
  min-height:38px;
  padding:9px 14px;
}
.empty-state{grid-column:1/-1;text-align:center;padding:42px}
.photo-overlay{
  position:fixed;
  inset:0;
  z-index:100;
  display:grid;
  place-items:center;
  padding:24px;
  opacity:0;
  pointer-events:none;
  transition:opacity .18s var(--ease);
}
.photo-overlay.is-open{
  opacity:1;
  pointer-events:auto;
}
.has-photo-overlay{overflow:hidden}
.photo-overlay-backdrop{
  position:absolute;
  inset:0;
  border:0;
  border-radius:0;
  padding:0;
  background:rgba(18,18,20,.58);
  backdrop-filter:blur(18px);
  box-shadow:none;
}
.photo-overlay-backdrop:hover{transform:none;box-shadow:none}
.photo-overlay figure{
  position:relative;
  z-index:1;
  width:min(760px,92vw);
  margin:0;
  border-radius:26px;
  overflow:hidden;
  background:rgba(255,255,255,.86);
  border:1px solid rgba(255,255,255,.72);
  box-shadow:0 34px 90px rgba(0,0,0,.30);
}
.photo-overlay figure img{
  width:100%;
  max-height:70vh;
  object-fit:contain;
  display:block;
  background:#111;
}
.photo-overlay figcaption{padding:14px 18px;color:var(--text);font-weight:700}
.photo-overlay-close{
  position:absolute;
  top:12px;
  right:12px;
  z-index:2;
  color:#fff;
  background:rgba(0,0,0,.42);
  border-radius:999px;
  padding:8px 12px;
  min-height:0;
  font-size:13px;
  backdrop-filter:blur(12px);
  box-shadow:none;
}
.photo-overlay-close:hover{transform:none;box-shadow:none}
.todo-chat{
  margin-top:24px;
  padding-top:20px;
  border-top:1px solid rgba(0,0,0,.06);
}
.chat-thread{
  display:grid;
  gap:10px;
  max-height:460px;
  overflow:auto;
  padding:4px 2px 10px;
}
.chat-message{display:flex}
.chat-message.mine{justify-content:flex-end}
.chat-message.theirs{justify-content:flex-start}
.chat-message>div{
  max-width:84%;
  padding:10px 12px;
  border-radius:18px;
  box-shadow:var(--shadow-soft);
}
.chat-message.theirs>div{
  background:rgba(255,255,255,.72);
  border-bottom-left-radius:6px;
}
.chat-message.mine>div{
  background:rgba(215,25,32,.92);
  color:#fff;
  border-bottom-right-radius:6px;
}
.chat-message p{margin:0;line-height:1.42}
.chat-message small{
  display:block;
  margin-top:5px;
  font-size:11px;
  color:var(--muted);
}
.chat-message.mine small{color:rgba(255,255,255,.72)}
.chat-form{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:8px;
  margin-top:10px;
}
.chat-form input{border-radius:999px}
.todo-detail-main{display:grid;gap:20px}
.todo-detail-hero{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:18px;
}
.todo-detail-hero h2{font-size:34px;margin:12px 0 6px;line-height:1.05}
.todo-detail-badges{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.quick-status-row{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  padding:10px;
  border-radius:22px;
  background:rgba(255,255,255,.50);
  border:1px solid rgba(255,255,255,.70);
}
.quick-status-row form{margin:0}
.quick-status-row .button{min-height:34px;padding:8px 12px;font-size:13px}
.todo-detail-summary{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.todo-detail-summary>div{
  padding:14px;
  border-radius:20px;
  background:rgba(255,255,255,.56);
  border:1px solid rgba(0,0,0,.045);
}
.todo-detail-summary span{
  display:block;
  color:var(--muted);
  font-size:12px;
  margin-bottom:5px;
}
.todo-detail-summary strong{display:block;color:var(--text);line-height:1.25}
.todo-description-block{
  padding:18px;
  border-radius:24px;
  background:rgba(255,255,255,.50);
  border:1px solid rgba(0,0,0,.045);
}
.todo-description-block h3{margin:0 0 8px}
.todo-description-block p{margin:0;color:var(--text-soft);line-height:1.55}
.order-position-list{
  display:grid;
  gap:8px;
}
.order-position-list div{
  display:flex;
  justify-content:space-between;
  gap:14px;
  align-items:center;
  padding:11px 12px;
  border-radius:16px;
  background:rgba(255,255,255,.58);
  border:1px solid rgba(0,0,0,.045);
}
.order-position-list span{color:var(--text);font-weight:680}
.order-position-list strong{color:var(--brand-primary);white-space:nowrap}
.photo-grid.manageable{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.photo-grid.manageable figure{margin:0;display:grid;gap:7px}
.photo-grid.manageable img{
  width:100%;
  aspect-ratio:1.25;
  object-fit:cover;
  border-radius:18px;
}
.photo-grid.manageable .button{width:100%;min-height:32px;padding:7px 10px;font-size:12px}
.danger-action{color:var(--danger)}
.compact-upload{
  display:grid;
  gap:10px;
  margin-top:16px;
  padding-top:16px;
  border-top:1px solid rgba(0,0,0,.06);
}
.drop-upload{
  padding:16px;
  border:1px dashed rgba(215,25,32,.24);
  border-radius:22px;
  background:rgba(255,255,255,.44);
  transition:background .18s var(--ease),border-color .18s var(--ease),transform .18s var(--ease);
}
.drop-upload.is-dragging{
  background:rgba(255,238,236,.72);
  border-color:rgba(215,25,32,.45);
  transform:translateY(-1px);
}
.drop-upload .muted{margin:0;font-size:12px}
.todo-timeline{
  margin-top:24px;
  padding-top:20px;
  border-top:1px solid rgba(0,0,0,.06);
}
.todo-timeline article{
  display:grid;
  grid-template-columns:14px minmax(0,1fr);
  gap:10px;
  padding:8px 0;
}
.todo-timeline article>span{
  width:10px;
  height:10px;
  margin-top:5px;
  border-radius:999px;
  background:rgba(215,25,32,.28);
  box-shadow:0 0 0 5px rgba(215,25,32,.07);
}
.todo-timeline strong{display:block;font-size:13px;color:var(--text);line-height:1.35}
.todo-timeline small{display:block;color:var(--muted);font-size:11px;margin-top:3px}
.todo-signal-row{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
}
.todo-signal-row a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:14px 16px;
  border-radius:20px;
  background:rgba(255,255,255,.58);
  border:1px solid rgba(255,255,255,.72);
  color:var(--text);
}
.todo-signal-row span{color:var(--muted);font-weight:650}
.todo-signal-row strong{font-size:24px}
.kiosk-board-card{
  display:grid;
  gap:16px;
}
.kiosk-board-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
}
.kiosk-board-head h2{margin-bottom:2px}
.complaint-board-list{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:12px;
}
.complaint-board-item{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:7px 12px;
  padding:15px;
  border-radius:18px;
  background:rgba(255,255,255,.62);
  border:1px solid rgba(0,0,0,.055);
  box-shadow:var(--shadow-soft);
}
.complaint-board-item strong{
  display:block;
  color:var(--text);
  font-size:26px;
  line-height:1;
  letter-spacing:.03em;
}
.complaint-board-item span{
  align-self:start;
  padding:6px 10px;
  border-radius:999px;
  background:rgba(31,143,86,.10);
  color:var(--ok);
  font-size:12px;
  font-weight:760;
  white-space:nowrap;
}
.complaint-board-item.is-soon span{
  background:rgba(217,45,32,.10);
  color:var(--danger);
}
.complaint-board-item small,
.complaint-board-item p{
  grid-column:1/-1;
  margin:0;
}
.complaint-board-item small{
  color:var(--muted);
  font-weight:650;
}
.complaint-board-item p{
  color:var(--text-soft);
  line-height:1.42;
}
.dashboard-empty{
  color:var(--text);
  background:rgba(255,255,255,.48);
}
.technik-jumpbar{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:16px;
}
.technik-jumpbar a{
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.58);
  border:1px solid rgba(0,0,0,.055);
  color:var(--text-soft);
  font-size:13px;
  font-weight:720;
}
.technik-overview{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}
.technik-overview a{
  display:grid;
  gap:5px;
  padding:16px;
  border-radius:20px;
  background:rgba(255,255,255,.58);
  border:1px solid rgba(255,255,255,.72);
}
.technik-overview span,
.technik-overview small{
  color:var(--muted);
  font-weight:680;
}
.technik-overview strong{
  color:var(--text);
  font-size:34px;
  line-height:1;
}
.technik-section{display:grid;gap:18px}
.technik-section-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
}
.technik-section-head h2{margin-bottom:3px}
.technik-band-tabs{
  display:inline-flex;
  gap:6px;
  flex-wrap:wrap;
  margin-top:12px;
  padding:4px;
  border-radius:999px;
  background:rgba(18,24,38,.055);
  border:1px solid rgba(18,24,38,.06);
}
.technik-band-tabs a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:7px 13px;
  border-radius:999px;
  color:var(--text-soft);
  font-size:13px;
  font-weight:820;
}
.technik-band-tabs a.is-active{
  color:#fff;
  background:var(--accent-grad);
  box-shadow:var(--shadow-button);
}
.technik-form-title{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  padding:14px 16px;
  border-radius:18px;
  background:rgba(215,25,32,.07);
  border:1px solid rgba(215,25,32,.12);
}
.technik-form-title strong{
  display:block;
  color:var(--text);
  font-size:17px;
}
.technik-form-title span{
  color:var(--muted);
  font-weight:650;
}
.technik-signal-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(230px,1fr));
  gap:12px;
}
.technik-signal-board{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(260px,360px);
  gap:16px;
  align-items:start;
}
.technik-signal-main{display:grid;gap:14px}
.technik-signal-legend{
  display:flex;
  flex-wrap:wrap;
  gap:10px 16px;
  padding:12px 14px;
  border-radius:18px;
  background:rgba(255,255,255,.56);
  border:1px solid rgba(0,0,0,.05);
  color:var(--muted);
  font-size:13px;
  font-weight:720;
}
.technik-signal-legend span{display:inline-flex;align-items:center;gap:7px}
.technik-signal-legend .dot{
  width:11px;
  height:11px;
  border-radius:50%;
  display:inline-block;
}
.technik-signal-legend .red{background:#ef4444}
.technik-signal-legend .orange{background:#f59e0b}
.technik-signal-legend .green{background:#22c55e}
.technik-signal-card{
  display:grid;
  gap:8px;
  min-height:224px;
  padding:16px;
  border-radius:20px;
  background:rgba(255,255,255,.62);
  border:1px solid rgba(0,0,0,.055);
  box-shadow:var(--shadow-soft);
}
.technik-signal-card.status-red,
.technik-signal-row.status-red{border-color:rgba(217,45,32,.26);box-shadow:0 16px 34px rgba(217,45,32,.10)}
.technik-signal-card.status-orange,
.technik-signal-row.status-orange{border-color:rgba(255,189,46,.38);box-shadow:0 16px 34px rgba(255,189,46,.10)}
.technik-signal-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.technik-kicker{
  display:block;
  color:var(--muted);
  font-size:11px;
  font-weight:820;
  text-transform:uppercase;
  letter-spacing:.06em;
  margin-bottom:4px;
}
.technik-signal-card strong{display:block;font-size:17px;color:var(--text);line-height:1.2}
.technik-signal-pills{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
}
.technik-signal-card > span,
.technik-signal-card .status-pill,
.technik-signal-row .status-pill,
.reason-badge,
.technik-signal-count{
  justify-self:start;
  padding:5px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:780;
}
.technik-signal-card p,
.technik-signal-row p{margin:0;color:var(--text-soft);font-weight:720}
.technik-signal-card small,
.technik-signal-row small{color:var(--muted);font-weight:640}
.technik-signal-card.ok span,.badge.ok{background:rgba(31,143,86,.10);color:var(--ok)}
.technik-signal-card.warning span,.badge.warning{background:rgba(255,189,46,.16);color:var(--warning)}
.technik-signal-card.danger span,.badge.danger{background:rgba(217,45,32,.10);color:var(--danger)}
.status-pill.green{background:rgba(31,143,86,.11);color:var(--ok)}
.status-pill.orange{background:rgba(255,189,46,.18);color:#9a6700}
.status-pill.red,.reason-badge{background:rgba(217,45,32,.10);color:var(--danger)}
.technik-signal-count{background:rgba(18,24,38,.06);color:var(--text-soft)}
.technik-ampel{
  width:46px;
  flex:0 0 46px;
  padding:9px 8px;
  border-radius:15px;
  background:#101827;
  display:flex;
  flex-direction:column;
  gap:7px;
  box-shadow:0 13px 24px rgba(16,24,39,.28);
}
.technik-ampel .lamp{
  width:100%;
  aspect-ratio:1/1;
  border-radius:50%;
  background:#64748b;
  opacity:.20;
  box-shadow:inset 0 -2px 4px rgba(0,0,0,.34);
}
.technik-ampel.ampel-green .lamp.green{background:#22c55e;opacity:1;box-shadow:0 0 0 4px rgba(34,197,94,.15),0 0 18px rgba(34,197,94,.42)}
.technik-ampel.ampel-orange .lamp.orange{background:#f59e0b;opacity:1;box-shadow:0 0 0 4px rgba(245,158,11,.16),0 0 18px rgba(245,158,11,.42)}
.technik-ampel.ampel-red .lamp.red{background:#ef4444;opacity:1;box-shadow:0 0 0 4px rgba(239,68,68,.16),0 0 18px rgba(239,68,68,.42)}
.technik-reason-form{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:8px;
  margin-top:4px;
}
.technik-reason-form input{
  min-height:40px;
  background:rgba(255,255,255,.92);
}
.technik-signal-group{display:grid;gap:8px}
.technik-signal-group h3{
  margin:0 2px;
  color:var(--text-soft);
  font-size:13px;
  font-weight:830;
  text-transform:uppercase;
  letter-spacing:.06em;
}
.technik-signal-group-card{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
  padding:14px;
  border-radius:22px;
  background:rgba(255,255,255,.42);
  border:1px solid rgba(0,0,0,.045);
}
.technik-signal-row{
  display:grid;
  gap:8px;
  padding:14px;
  border-radius:18px;
  background:rgba(255,255,255,.70);
  border:1px solid rgba(0,0,0,.055);
}
.technik-signal-side{display:grid;gap:12px}
.technik-heartbeat-card,
.technik-recent-card{
  display:grid;
  gap:8px;
  padding:16px;
  border-radius:20px;
  background:rgba(255,255,255,.70);
  border:1px solid rgba(0,0,0,.055);
  box-shadow:var(--shadow-soft);
}
.technik-heartbeat-card.online{border-color:rgba(31,143,86,.24);background:rgba(31,143,86,.10)}
.technik-heartbeat-card.offline{border-color:rgba(217,45,32,.24);background:rgba(217,45,32,.09)}
.technik-heartbeat-card strong,
.technik-recent-card strong{color:var(--text);font-size:17px}
.technik-heartbeat-card span,
.technik-heartbeat-card small{color:var(--muted);font-weight:700}
.technik-recent-card div{
  display:grid;
  gap:2px;
  padding-top:9px;
  border-top:1px solid rgba(0,0,0,.06);
}
.technik-recent-card div:first-of-type{border-top:0;padding-top:0}
.technik-recent-card span{
  justify-self:start;
  padding:3px 8px;
  border-radius:999px;
  font-size:11px;
  font-weight:820;
}
.technik-recent-card .ok{background:rgba(31,143,86,.10);color:var(--ok)}
.technik-recent-card .danger{background:rgba(217,45,32,.10);color:var(--danger)}
.technik-recent-card p{margin:0;color:var(--text);font-weight:760}
.technik-recent-card small{color:var(--muted);font-weight:650}
.technik-form-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
  align-items:start;
  padding:16px;
  border-radius:22px;
  background:rgba(255,255,255,.38);
  border:1px solid rgba(0,0,0,.045);
}
.technik-form-grid label{margin:0}
.technik-form-grid fieldset{margin:0}
.technik-form-grid input,
.technik-form-grid select,
.technik-form-grid textarea,
.technik-inline-form input,
.technik-inline-form select{
  background:rgba(255,255,255,.92);
  min-height:44px;
}
.technik-form-grid .span-full{grid-column:1/-1}
.technik-maintenance-forms{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
}
.technik-maintenance-forms > .technik-maintenance-form:only-child{grid-column:1/-1}
.technik-maintenance-form{
  align-content:start;
  border-color:rgba(18,24,38,.08);
  background:linear-gradient(180deg,rgba(255,255,255,.70),rgba(255,255,255,.43));
}
.technik-choice-field{
  display:grid;
  gap:8px;
  padding:0;
  border:0;
}
.technik-choice-field legend{
  margin:0 0 6px;
  color:var(--text-soft);
  font-size:13px;
  font-weight:760;
}
.technik-choice-group{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
  padding:4px;
  border-radius:16px;
  background:rgba(18,24,38,.055);
  border:1px solid rgba(18,24,38,.06);
}
.technik-choice-group label{display:block}
.technik-choice-group input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}
.technik-choice-group span{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:8px 10px;
  border-radius:12px;
  background:rgba(255,255,255,.54);
  color:var(--text-soft);
  font-size:13px;
  font-weight:830;
  text-align:center;
  border:1px solid transparent;
}
.technik-choice-group input:checked + span{
  color:#fff;
  background:var(--accent-grad);
  border-color:rgba(215,25,32,.16);
  box-shadow:var(--shadow-button);
}
.technik-latest-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(440px,1fr));
  gap:16px;
}
.technik-lane-columns{
  grid-column:1/-1;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
}
.technik-lane-column{
  display:grid;
  gap:12px;
  align-content:start;
  padding:14px;
  border-radius:22px;
  background:rgba(255,255,255,.36);
  border:1px solid rgba(18,24,38,.055);
}
.technik-lane-column > h3{
  margin:0;
  color:var(--text);
  font-size:18px;
  font-weight:850;
}
.technik-lane-card-stack{
  display:grid;
  gap:14px;
}
.technik-latest-card{
  display:grid;
  gap:5px;
  padding:16px;
  border-radius:20px;
  background:rgba(255,255,255,.62);
  border:1px solid rgba(0,0,0,.055);
  box-shadow:var(--shadow-soft);
}
.technik-latest-card span,
.technik-latest-card small{
  color:var(--muted);
  font-weight:680;
}
.technik-latest-card strong{
  color:var(--text);
  font-size:31px;
  line-height:1;
}
.technik-latest-card.detailed{
  gap:16px;
  align-content:start;
  padding:20px;
  background:linear-gradient(180deg,rgba(255,255,255,.76),rgba(255,255,255,.54));
}
.technik-latest-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  padding-bottom:10px;
  border-bottom:1px solid rgba(18,24,38,.07);
}
.technik-latest-head span{
  display:block;
  color:var(--muted);
  font-size:12px;
  font-weight:820;
  text-transform:uppercase;
  letter-spacing:.05em;
}
.technik-latest-head strong{
  display:block;
  margin-top:2px;
  font-size:19px;
  line-height:1.18;
}
.technik-latest-head small{
  flex:0 0 auto;
  padding:5px 9px;
  border-radius:999px;
  background:rgba(18,24,38,.055);
  color:var(--text-soft);
  font-size:12px;
  font-weight:780;
}
.technik-latest-measure-group{
  display:grid;
  gap:10px;
}
.technik-latest-measure-group h3{
  margin:0;
  color:var(--text);
  font-size:14px;
  font-weight:840;
}
.technik-latest-values{
  display:grid;
  gap:10px;
}
.technik-latest-values.cols-2{grid-template-columns:repeat(2,minmax(150px,1fr))}
.technik-latest-values.cols-3{grid-template-columns:repeat(3,minmax(128px,1fr))}
.technik-latest-value{
  display:grid;
  gap:6px;
  min-width:128px;
  padding:12px;
  border-radius:14px;
  background:rgba(18,24,38,.04);
  border:1px solid rgba(18,24,38,.045);
}
.technik-latest-value summary{
  display:grid;
  gap:6px;
  min-width:0;
  cursor:pointer;
  list-style:none;
}
.technik-latest-value summary::-webkit-details-marker{display:none}
.technik-latest-value summary span{
  color:var(--muted);
  font-size:11px;
  font-weight:850;
  text-transform:uppercase;
  letter-spacing:.04em;
}
.technik-latest-value summary strong{
  color:var(--text);
  font-size:18px;
  line-height:1.18;
  white-space:normal;
  overflow-wrap:anywhere;
}
.technik-latest-value summary small{
  justify-self:start;
  max-width:100%;
  padding:3px 7px;
  border-radius:999px;
  background:rgba(18,24,38,.055);
  color:var(--muted);
  font-size:11px;
  line-height:1.2;
  font-weight:820;
  white-space:normal;
}
.technik-latest-value.up{
  border-color:rgba(31,143,86,.22);
  background:rgba(31,143,86,.075);
}
.technik-latest-value.up summary small{background:rgba(31,143,86,.13);color:var(--ok)}
.technik-latest-value.down{
  border-color:rgba(217,45,32,.22);
  background:rgba(217,45,32,.07);
}
.technik-latest-value.down summary small{background:rgba(217,45,32,.12);color:var(--danger)}
.technik-latest-value.same summary small{color:var(--text-soft)}
.technik-latest-value[open]{
  box-shadow:0 10px 22px rgba(18,24,38,.08);
}
.technik-value-history{
  display:grid;
  gap:5px;
  margin-top:8px;
  padding-top:8px;
  border-top:1px solid rgba(18,24,38,.08);
}
.technik-value-history p{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  gap:8px;
  align-items:center;
  margin:0;
  color:var(--muted);
}
.technik-value-history p span{
  font-size:12px;
  font-weight:730;
}
.technik-value-history p strong{
  justify-self:end;
  color:var(--text);
  font-size:13px;
  font-weight:840;
  white-space:normal;
  overflow-wrap:anywhere;
}
.technik-delete-form{flex:0 0 auto}
.button.danger,
button.danger{
  color:var(--danger);
  border-color:rgba(217,45,32,.22);
  background:rgba(217,45,32,.07);
}
.technik-card-history{
  display:grid;
  gap:10px;
  margin-top:4px;
  padding-top:12px;
  border-top:1px solid rgba(18,24,38,.08);
}
.technik-card-history > h3{
  margin:0;
  color:var(--text);
  font-size:14px;
  font-weight:850;
}
.technik-history-entry{
  display:grid;
  gap:8px;
  padding:12px;
  border-radius:14px;
  background:rgba(255,255,255,.62);
  border:1px solid rgba(18,24,38,.055);
}
.technik-history-entry > div{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.technik-history-entry > div strong{
  font-size:15px;
  color:var(--text);
}
.technik-history-entry > div span{
  color:var(--muted);
  font-size:12px;
  font-weight:780;
}
.technik-history-entry section{
  display:grid;
  gap:3px;
}
.technik-history-entry h4{
  margin:0;
  color:var(--text-soft);
  font-size:12px;
  font-weight:840;
}
.technik-history-entry p{
  margin:0;
  color:var(--muted);
  font-size:12px;
  font-weight:690;
  line-height:1.35;
}
.technik-fieldset{
  display:grid;
  gap:10px;
  padding:14px;
  border-radius:20px;
  background:rgba(255,255,255,.50);
  border:1px solid rgba(0,0,0,.05);
}
.technik-fieldset h3{margin:0;font-size:15px}
.technik-wash-field,
.technik-interior-field{grid-column:1/-1}
.technik-measure-groups{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
}
.technik-measure-group{
  display:grid;
  gap:12px;
  margin:0;
  padding:14px;
  border-radius:18px;
  background:rgba(255,255,255,.66);
  border:1px solid rgba(18,24,38,.07);
  box-shadow:0 10px 24px rgba(18,24,38,.045);
}
.technik-measure-group legend{
  padding:0 6px;
  color:var(--text);
  font-size:14px;
  font-weight:840;
}
.technik-measure-row{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
}
.technik-measure-row.two{grid-template-columns:repeat(2,minmax(0,1fr))}
.technik-measure-row label{
  display:grid;
  gap:6px;
  padding:10px;
  border-radius:14px;
  background:rgba(18,24,38,.035);
  color:var(--text-soft);
  font-size:12px;
  font-weight:820;
}
.technik-measure-row input{
  font-size:18px;
  font-weight:820;
  text-align:center;
}
.technik-inline-form{
  display:grid;
  grid-template-columns:minmax(160px,240px) minmax(160px,220px) minmax(220px,1fr) auto;
  gap:10px;
  align-items:end;
  padding:14px;
  border-radius:20px;
  background:rgba(255,255,255,.38);
  border:1px solid rgba(0,0,0,.045);
}
.technik-sludge-open{
  display:grid;
  gap:12px;
}
.technik-sludge-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:14px;
  align-items:start;
}
.technik-sludge-card-wrap{
  display:grid;
  gap:8px;
  align-content:start;
  align-items:start;
}
.technik-sludge-card{
  display:grid;
  gap:12px;
  align-content:start;
  padding:16px;
  border-radius:20px;
  background:linear-gradient(180deg,rgba(255,255,255,.76),rgba(255,255,255,.54));
  border:1px solid rgba(18,24,38,.06);
  box-shadow:var(--shadow-soft);
}
.technik-sludge-card summary{
  display:grid;
  gap:12px;
  cursor:pointer;
  list-style:none;
}
.technik-sludge-card summary::-webkit-details-marker{display:none}
.technik-sludge-card-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
}
.technik-sludge-card-head span{
  display:block;
  color:var(--muted);
  font-size:11px;
  font-weight:850;
  text-transform:uppercase;
  letter-spacing:.05em;
}
.technik-sludge-card-head strong{
  display:block;
  margin-top:2px;
  color:var(--text);
  font-size:21px;
  line-height:1.1;
}
.technik-sludge-card-head small{
  flex:0 0 auto;
  max-width:118px;
  text-align:right;
  color:var(--muted);
  font-size:12px;
  font-weight:760;
  line-height:1.25;
}
.technik-sludge-current{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:12px;
}
.technik-sludge-current strong{
  color:var(--text);
  font-size:34px;
  line-height:1;
}
.technik-sludge-current span{
  color:var(--text-soft);
  font-size:14px;
  font-weight:820;
  text-align:right;
}
.technik-sludge-increase{
  justify-self:start;
  min-height:24px;
  padding:4px 8px;
  border-radius:999px;
  background:rgba(217,45,32,.10);
  color:var(--danger);
  font-size:12px;
  font-weight:850;
}
.technik-sludge-increase.is-empty{
  background:rgba(18,24,38,.055);
  color:var(--muted);
}
.technik-sludge-bar{
  height:12px;
  border-radius:999px;
  overflow:hidden;
  background:rgba(18,24,38,.08);
}
.technik-sludge-bar i{
  display:block;
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg,#9096a3,#2f3542);
}
.technik-sludge-card summary p{
  margin:0;
  color:var(--muted);
  font-size:13px;
  font-weight:690;
  line-height:1.4;
}
.technik-sludge-history{
  display:grid;
  gap:9px;
  margin-top:12px;
  padding-top:12px;
  border-top:1px solid rgba(18,24,38,.08);
}
.technik-sludge-history h3{
  margin:0;
  color:var(--text);
  font-size:14px;
  font-weight:850;
}
.technik-sludge-delete-latest{
  display:flex;
  justify-content:flex-start;
}
.technik-sludge-delete-latest button{
  min-height:34px;
  padding:7px 10px;
  font-size:12px;
}
.technik-sludge-history article{
  display:grid;
  gap:5px;
  padding:10px;
  border-radius:14px;
  background:rgba(255,255,255,.62);
  border:1px solid rgba(18,24,38,.055);
}
.technik-sludge-history article div{
  display:flex;
  justify-content:space-between;
  gap:8px;
}
.technik-sludge-history article strong{
  color:var(--text);
  font-size:13px;
}
.technik-sludge-history article span,
.technik-sludge-history article p{
  margin:0;
  color:var(--muted);
  font-size:12px;
  font-weight:720;
}
.technik-sludge-quick-form{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:8px;
  align-self:start;
  padding:10px;
  border-radius:16px;
  background:rgba(255,255,255,.52);
  border:1px solid rgba(18,24,38,.055);
}
.technik-sludge-quick-form input{
  min-height:40px;
  background:rgba(255,255,255,.92);
}
.technik-sludge-quick-form button{
  min-height:40px;
  padding-inline:12px;
}
.sludge-card{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto auto;
  gap:12px;
  align-items:center;
  padding:14px;
  border-radius:18px;
  background:rgba(255,255,255,.62);
  border:1px solid rgba(0,0,0,.055);
}
.sludge-card strong{font-size:18px}
.sludge-card span{font-weight:760}
.sludge-card.ok span{color:var(--ok)}
.sludge-card.warning span{color:var(--warning)}
.sludge-card.danger span{color:var(--danger)}
.public-page{min-height:100vh;display:grid;place-items:center;width:100%;max-width:100%;padding:18px;background:transparent;overflow-x:hidden}
.public-card{width:min(560px,100%);max-width:100%;min-width:0;padding:30px}
.public-card.complaint-public-card{width:min(1040px,100%);padding:30px}
.public-card h1{font-size:32px;margin:0 0 8px}
.global-search-page{
  display:grid;
  grid-template-columns:minmax(0,380px) minmax(0,1fr);
  gap:18px;
  align-items:end;
  margin-bottom:18px;
}
.global-search-large{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:10px;
}
.global-search-large input{min-height:52px;font-size:17px}
.search-group{margin-bottom:22px}
.search-group h3{
  display:flex;
  align-items:center;
  gap:8px;
  margin:0 0 10px;
}
.search-group h3 span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:28px;
  height:28px;
  padding:0 8px;
  border-radius:999px;
  background:rgba(255,255,255,.70);
  color:var(--muted);
  font-size:12px;
}
.search-result-list{display:grid;gap:10px}
.search-result-card{
  display:grid;
  grid-template-columns:auto minmax(0,1fr) auto;
  gap:7px 12px;
  align-items:center;
  padding:15px 16px;
  border-radius:20px;
  background:rgba(255,255,255,.66);
  border:1px solid rgba(255,255,255,.76);
  box-shadow:var(--shadow-soft);
}
.search-result-card strong{min-width:0;overflow-wrap:anywhere}
.search-result-card small{color:var(--muted);font-weight:620;text-align:right}
.search-result-card p{
  grid-column:2/-1;
  margin:0;
  color:var(--text-soft);
  line-height:1.45;
}

@media (max-width:900px){
  body:before{width:330px;height:330px;left:-170px;top:-100px}
  body:after{width:360px;height:360px;right:-190px;top:220px}
  .login-page{padding:12px}
  .login-visual{display:none}
  .app-shell{grid-template-columns:1fr;padding:12px;gap:12px}
  .sidebar{position:static;max-height:none;min-height:auto;border-radius:24px;padding:14px}
  .brand{padding-bottom:12px}
  .nav{grid-template-columns:repeat(auto-fit,minmax(118px,1fr));gap:8px}
  .nav a{justify-content:center;padding:10px}
  .nav a .nav-icon{width:18px;height:18px}
  .user-card{border-radius:20px}
  .topbar{grid-template-columns:1fr;gap:10px;min-height:auto;border-radius:24px;padding:18px}
  .window-dots{order:-1}
  .topbar-user{text-align:left;min-width:0}
  .topbar-search{grid-template-columns:minmax(0,1fr) 42px}
  .topbar h1{font-size:28px}
  .grid{grid-template-columns:1fr;gap:14px}
  .span-4,.span-5,.span-6,.span-7,.span-8,.span-12{grid-column:1}
  .dashboard-hero{display:grid;min-height:auto}
  .dashboard-hero h2{font-size:30px}
  .dashboard-hero-actions{justify-content:flex-start}
  .dashboard-list a{grid-template-columns:1fr;gap:8px}
  .dashboard-list span{white-space:normal}
  .card,.login-card,.public-card{border-radius:22px;padding:18px}
  .metric{font-size:36px}
  .qr-card,.todo-alert,.todo-toolbar{grid-template-columns:1fr}
  .global-search-page,.global-search-large,.search-result-card{grid-template-columns:1fr}
  .search-result-card small{text-align:left}
  .search-result-card p{grid-column:1}
  .todo-toolbar{display:grid}
  .todo-grid{grid-template-columns:1fr}
  .order-items-head{align-items:stretch;display:grid}
  .order-item-row{grid-template-columns:minmax(0,1fr) 88px 40px}
  .todo-photo-preview,.todo-pattern{height:180px}
  .todo-detail-hero{display:grid}
  .todo-detail-hero h2{font-size:28px}
  .todo-detail-badges{justify-content:flex-start}
  .todo-detail-summary,.photo-grid.manageable,.todo-signal-row{grid-template-columns:1fr}
  .soundtrack-step,.soundtrack-rule-list>section{grid-template-columns:1fr}
  .asset-list div{grid-template-columns:1fr}
  .kiosk-board-head{align-items:flex-start;flex-direction:column}
  .complaint-board-list{grid-template-columns:1fr}
  .technik-overview{grid-template-columns:1fr}
  .technik-signal-board{grid-template-columns:1fr}
  .technik-signal-group-card{grid-template-columns:1fr}
  .technik-latest-grid{grid-template-columns:1fr}
  .technik-lane-columns{grid-template-columns:1fr}
  .technik-latest-values.cols-2,
  .technik-latest-values.cols-3{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}
  .technik-form-title{align-items:flex-start;flex-direction:column}
  .technik-section-head{align-items:flex-start;flex-direction:column}
  .technik-maintenance-forms{grid-template-columns:1fr}
  .technik-form-grid,.technik-measure-row,.technik-measure-row.two,.technik-inline-form,.sludge-card{grid-template-columns:1fr}
  .complaint-form-grid,.complaint-form-grid.public{grid-template-columns:1fr}
  .complaint-plate-area{grid-column:auto}
  .complaint-public-card,
  .complaint-form-grid,
  .complaint-form-grid.public,
  .complaint-form-grid > div{min-width:0;max-width:100%}
  .license-plate{grid-template-columns:30px minmax(0,1fr) minmax(0,1fr) minmax(0,1.15fr);min-height:82px;max-width:100%;border-width:3px}
  .plate-field{padding:8px 4px}
  .plate-field input{font-size:25px}
  .service-grid{grid-template-columns:1fr}
  .service-option span{
    flex-direction:column;
    justify-content:center;
    gap:8px;
    min-height:76px;
    padding:12px 14px;
    text-align:center;
    line-height:1.25;
  }
  .service-option span:after{position:static;transform:none}
  .inline-field{align-items:stretch;flex-direction:column}
  .inline-field input{max-width:none}
  table{font-size:14px}
  th,td{padding:11px 9px}
}

.wiki-hero{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(280px,440px);
  gap:18px;
  align-items:center;
  margin-bottom:18px;
}
.wiki-hero h2{max-width:720px;font-size:30px;margin-bottom:0}
.wiki-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.wiki-stats a{
  display:grid;
  gap:4px;
  padding:14px;
  border-radius:18px;
  background:rgba(255,255,255,.62);
  border:1px solid rgba(255,255,255,.76);
  box-shadow:var(--shadow-soft);
}
.wiki-stats span{color:var(--muted);font-size:12px;font-weight:690}
.wiki-stats strong{font-size:30px;line-height:1;color:var(--text)}
.wiki-upload-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin-bottom:24px}
.wiki-smart-search{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto auto;
  gap:10px;
  margin-top:18px;
  max-width:860px;
}
.wiki-smart-search input{
  min-height:48px;
  font-size:16px;
}
.wiki-upload-details{
  margin:0 0 24px;
}
.wiki-upload-details summary{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  min-height:54px;
  padding:14px 18px;
  border-radius:22px;
  background:rgba(255,255,255,.62);
  border:1px solid rgba(255,255,255,.76);
  box-shadow:var(--shadow-soft);
  backdrop-filter:var(--blur);
  -webkit-backdrop-filter:var(--blur);
}
.wiki-upload-details summary span{font-weight:720;color:var(--text)}
.wiki-upload-details summary small{color:var(--muted);font-weight:620}
.wiki-upload-details[open] summary{margin-bottom:14px}
.wiki-upload-card{display:grid;gap:16px}
.wiki-icon{
  display:grid;
  place-items:center;
  width:42px;
  height:42px;
  margin-bottom:12px;
  border-radius:15px;
  color:#fff;
  background:var(--accent-grad);
  font-weight:760;
  box-shadow:var(--shadow-button);
}
.wiki-upload-form{display:grid;gap:4px}
.wiki-denied{
  color:var(--muted);
  background:rgba(255,255,255,.58);
  border:1px solid rgba(0,0,0,.055);
  border-radius:16px;
  padding:14px;
}
.wiki-section-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin:8px 0 14px;
}
.wiki-section-head h2{margin-bottom:2px}
.wiki-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px;margin-bottom:24px}
.wiki-file-card,
.wiki-supplier-card{
  min-height:255px;
  display:flex;
  flex-direction:column;
  gap:13px;
  padding:20px;
  background:var(--surface-strong);
  border:1px solid var(--line-light);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-card);
  backdrop-filter:var(--blur);
  -webkit-backdrop-filter:var(--blur);
  overflow:hidden;
}
.wiki-file-card h3,.wiki-supplier-card h3{margin:0;overflow-wrap:anywhere}
.wiki-file-head{display:flex;justify-content:space-between;align-items:center;gap:8px}
.wiki-file-type{
  display:grid;
  place-items:center;
  width:56px;
  height:42px;
  border-radius:14px;
  background:rgba(215,25,32,.10);
  color:var(--brand-primary);
  font-size:12px;
  font-weight:760;
}
.wiki-meta{display:flex;gap:8px;flex-wrap:wrap;color:var(--muted);font-size:12px;margin-top:auto}
.wiki-file-card .actions,.wiki-supplier-card .actions{margin-top:auto}
.wiki-file-card .actions form,.wiki-supplier-card .actions form{display:inline-flex;margin:0}
.danger-button{
  background:rgba(217,45,32,.10);
  color:var(--danger);
  border:1px solid rgba(217,45,32,.16);
  box-shadow:none;
}
.wiki-search{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;margin-bottom:18px}
.supplier-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}
.wiki-supplier-head{display:flex;gap:13px;align-items:flex-start}
.wiki-supplier-head>span{
  display:grid;
  place-items:center;
  width:50px;
  height:50px;
  flex:0 0 auto;
  border-radius:16px;
  background:rgba(29,29,31,.88);
  color:#fff;
  font-weight:760;
}
.wiki-supplier-head small{
  display:inline-flex;
  margin-top:5px;
  padding:5px 9px;
  border-radius:999px;
  background:rgba(255,210,63,.22);
  color:#7a5600;
  font-weight:690;
}
.wiki-lines{display:grid;gap:8px}
.wiki-lines div{display:grid;grid-template-columns:86px minmax(0,1fr);gap:10px;color:var(--text-soft);font-size:14px}
.wiki-lines strong{color:var(--muted);font-size:12px}
.wiki-lines span,.wiki-lines a{min-width:0;overflow-wrap:anywhere}
.wiki-note{
  padding:12px;
  border-radius:16px;
  background:rgba(255,255,255,.58);
  border:1px solid rgba(0,0,0,.045);
  color:var(--text-soft);
  line-height:1.55;
}
.wiki-empty{
  padding:32px;
  border-radius:var(--radius-lg);
  border:1px dashed rgba(0,0,0,.14);
  color:var(--muted);
  background:rgba(255,255,255,.46);
}
.wiki-live-results.is-hidden{display:none}
.wiki-live-card{
  animation:wikiFadeIn .16s var(--ease);
}
@keyframes wikiFadeIn{
  from{opacity:.45;transform:translateY(3px)}
  to{opacity:1;transform:none}
}
.wiki-form-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:4px 14px}
.wiki-form-grid .span-full{grid-column:1/-1}
.damage-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(330px,1fr));
  gap:24px;
  align-items:start;
}
.damage-card{
  overflow:hidden;
  background:var(--surface-strong);
  border:1px solid rgba(255,255,255,.82);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-card);
  backdrop-filter:var(--blur);
  -webkit-backdrop-filter:var(--blur);
  transition:transform .18s var(--ease),box-shadow .18s var(--ease),border-color .18s var(--ease);
}
.damage-card:hover{
  transform:translateY(-2px);
  box-shadow:0 24px 62px rgba(0,0,0,.09);
  border-color:rgba(215,25,32,.16);
}
.damage-preview{
  position:relative;
  display:grid;
  place-items:center;
  height:190px;
  overflow:hidden;
  color:#fff;
  background:linear-gradient(135deg,rgba(29,29,31,.92),rgba(215,25,32,.62));
  font-size:34px;
  font-weight:760;
}
.damage-preview img{width:100%;height:100%;object-fit:cover}
.damage-preview span{
  position:absolute;
  right:12px;
  bottom:12px;
  padding:6px 10px;
  border-radius:999px;
  background:rgba(0,0,0,.58);
  color:#fff;
  font-size:13px;
}
.damage-body{display:grid;gap:15px;padding:20px}
.damage-body h3{margin:0}
.damage-body .actions{margin-top:2px}
.damage-archive-form{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:10px;
  margin-top:4px;
  padding-top:14px;
  border-top:1px solid rgba(0,0,0,.06);
}
.damage-archive-form input{min-height:40px}
.damage-detail-hero{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  margin-bottom:18px;
}
.damage-detail-hero h2{font-size:42px;margin-bottom:4px}
.damage-detail-grid{margin-bottom:22px}
.damage-detail-grid>.card{height:100%}
.damage-facts{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:12px 0 18px}
.damage-facts div{
  display:grid;
  gap:4px;
  padding:12px;
  border-radius:16px;
  background:rgba(255,255,255,.56);
  border:1px solid rgba(255,255,255,.76);
}
.damage-facts strong{color:var(--muted);font-size:12px}
.damage-facts span{overflow-wrap:anywhere}
.damage-media-card{
  display:flex;
  flex-direction:column;
  gap:16px;
}
.damage-section-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  margin-bottom:18px;
}
.damage-section-head h2{margin-bottom:3px}
.damage-section-head .muted{margin:0}
.damage-form-panel{
  display:grid;
  gap:14px;
  padding:14px;
  border-radius:22px;
  background:rgba(255,255,255,.46);
  border:1px solid rgba(0,0,0,.045);
}
.damage-form-image{width:100%;max-height:520px;object-fit:contain;border-radius:16px;background:rgba(255,255,255,.72)}
.damage-media-empty{
  display:grid;
  place-items:center;
  min-height:220px;
  padding:24px;
  border-radius:18px;
  border:1px dashed rgba(0,0,0,.14);
  color:var(--muted);
  background:rgba(255,255,255,.44);
}
.damage-upload-panel{
  margin-top:auto;
  padding:16px;
  border-radius:20px;
  border:1px solid rgba(0,0,0,.055);
  background:rgba(255,255,255,.52);
}
.damage-media-section{margin-top:22px}
.damage-inline-upload{
  display:grid;
  grid-template-columns:minmax(220px,1fr) auto;
  gap:10px;
  align-items:center;
  min-width:min(100%,460px);
}
.damage-inline-upload input{min-height:42px}
.damage-photo-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(210px,1fr));
  gap:18px;
  padding-top:4px;
}
.damage-photo-grid figure{
  display:grid;
  gap:10px;
  margin:0;
  padding:10px;
  border-radius:20px;
  background:rgba(255,255,255,.50);
  border:1px solid rgba(0,0,0,.045);
}
.damage-photo-grid img{width:100%;aspect-ratio:1.25;object-fit:cover;border-radius:18px;box-shadow:var(--shadow-soft)}
.damage-photo-grid button{width:100%}
.damage-note-form{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;margin:12px 0}

.kiosk-lock-body{
  min-height:100vh;
  overflow-x:hidden;
  background:
    linear-gradient(135deg,rgba(29,29,31,.78),rgba(215,25,32,.34)),
    radial-gradient(circle at 20% 14%,rgba(255,255,255,.34),transparent 26rem),
    #1d1d1f;
}
.kiosk-lock{
  min-height:100vh;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(360px,440px);
  gap:28px;
  align-items:center;
  padding:42px;
}
.kiosk-lock-dashboard{
  display:grid;
  gap:22px;
  min-width:0;
}
.kiosk-clock{
  color:#fff;
  text-shadow:0 18px 54px rgba(0,0,0,.24);
}
.kiosk-clock-row{
  display:flex;
  align-items:center;
  gap:24px;
  flex-wrap:wrap;
}
.kiosk-clock-row>div:first-child{
  font-size:112px;
  line-height:.9;
  font-weight:760;
  letter-spacing:0;
}
.kiosk-clock>span{
  display:block;
  margin-top:18px;
  font-size:25px;
  color:rgba(255,255,255,.78);
}
.kiosk-signal-alerts{
  display:grid;
  gap:5px;
  min-width:180px;
  max-width:280px;
  padding:12px 14px;
  border-radius:18px;
  background:rgba(217,45,32,.95);
  box-shadow:0 18px 50px rgba(217,45,32,.24);
  color:#fff;
  text-shadow:none;
}
.kiosk-signal-alerts strong{
  font-size:13px;
  line-height:1.1;
  text-transform:uppercase;
  letter-spacing:.04em;
}
.kiosk-signal-alerts span,
.kiosk-signal-alerts small{
  color:#fff;
  font-size:14px;
  font-weight:760;
  line-height:1.15;
}
.kiosk-status-strip{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:10px;
}
.kiosk-status-strip div,
.kiosk-overdue-panel{
  border:1px solid rgba(255,255,255,.20);
  background:rgba(255,255,255,.12);
  box-shadow:0 20px 70px rgba(0,0,0,.16);
  backdrop-filter:blur(18px);
}
.kiosk-status-strip div{
  min-height:92px;
  padding:15px;
  border-radius:18px;
  color:#fff;
}
.kiosk-status-strip span{
  display:block;
  color:rgba(255,255,255,.72);
  font-size:13px;
  font-weight:680;
}
.kiosk-status-strip strong{
  display:block;
  margin-top:8px;
  font-size:34px;
  line-height:1;
}
.kiosk-overdue-panel{
  display:grid;
  gap:14px;
  max-width:920px;
  padding:18px;
  border-radius:24px;
  color:#fff;
}
.kiosk-board-columns{
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(300px,.95fr);
  gap:14px;
  align-items:stretch;
}
.kiosk-board-columns .kiosk-overdue-panel{
  height:100%;
  min-height:260px;
  max-width:none;
}
.kiosk-panel-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
}
.kiosk-panel-head strong{
  display:block;
  font-size:22px;
  line-height:1.15;
}
.kiosk-panel-head span,
.kiosk-empty-state span{
  display:block;
  margin-top:3px;
  color:rgba(255,255,255,.72);
}
.kiosk-review-badge{
  flex:0 0 auto;
  margin:0;
  padding:8px 11px;
  border-radius:999px;
  background:rgba(255,210,63,.92);
  color:#1d1d1f!important;
  font-size:13px;
  font-weight:780;
}
.kiosk-overdue-list{
  display:grid;
  gap:10px;
}
.kiosk-overdue-list article{
  display:grid;
  gap:8px;
  padding:13px 14px;
  border-radius:18px;
  background:rgba(255,255,255,.88);
  color:var(--text);
}
.kiosk-overdue-list article>div{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.kiosk-overdue-list strong{
  display:block;
  font-size:18px;
  line-height:1.22;
}
.kiosk-overdue-list p{
  margin:0;
  color:var(--muted);
  font-size:13px;
  font-weight:620;
}
.kiosk-empty-state{
  padding:22px;
  border-radius:18px;
  background:rgba(255,255,255,.14);
}
.kiosk-empty-state strong{
  display:block;
  font-size:20px;
}
.kiosk-complaint-list{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(180px,1fr));
  gap:10px;
}
.kiosk-complaint-search{
  min-height:38px;
  padding:8px 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.24);
  background:rgba(255,255,255,.90);
  color:var(--text);
  font-size:14px;
  font-weight:720;
}
.kiosk-complaint-hint{
  padding:12px 14px;
  border-radius:16px;
  background:rgba(255,255,255,.14);
  color:rgba(255,255,255,.78);
  font-size:13px;
  font-weight:720;
}
.kiosk-complaint-records{display:none}
.kiosk-complaint-summary{
  display:grid;
  gap:5px;
  padding:16px;
  border-radius:18px;
  background:rgba(255,255,255,.14);
}
.kiosk-complaint-summary strong{
  display:block;
  color:#fff;
  font-size:21px;
  line-height:1.2;
}
.kiosk-complaint-summary span{
  color:rgba(255,255,255,.72);
  font-weight:680;
}
.kiosk-complaint-open{
  justify-self:start;
}
.kiosk-complaint-list a{
  display:grid;
  gap:4px;
  padding:10px 11px;
  border-radius:15px;
  background:rgba(255,255,255,.88);
  color:var(--text);
}
.kiosk-complaint-list strong{
  display:block;
  font-size:19px;
  line-height:1;
  letter-spacing:.03em;
}
.kiosk-complaint-list em{
  color:var(--text-soft);
  font-size:11px;
  font-style:normal;
  font-weight:780;
  line-height:1.18;
}
.kiosk-complaint-list span{
  justify-self:start;
  padding:4px 8px;
  border-radius:999px;
  background:rgba(31,143,86,.10);
  color:var(--ok);
  font-size:11px;
  font-weight:780;
}
.kiosk-complaint-list a.is-soon span{
  background:rgba(217,45,32,.10);
  color:var(--danger);
}
.kiosk-complaint-list small{
  color:var(--muted);
  font-weight:650;
}
.kiosk-complaint-modal{
  position:fixed;
  inset:0;
  z-index:50;
  display:grid;
  place-items:center;
  padding:24px;
  background:rgba(12,18,28,.58);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.kiosk-complaint-modal[hidden]{display:none}
.kiosk-complaint-dialog{
  width:min(720px,100%);
  max-height:min(760px,88vh);
  overflow:auto;
  display:grid;
  gap:16px;
  padding:20px;
  border-radius:24px;
  background:rgba(255,255,255,.96);
  color:var(--text);
  box-shadow:0 28px 90px rgba(0,0,0,.28);
}
.kiosk-complaint-dialog .kiosk-panel-head span{
  color:var(--muted);
}
.kiosk-complaint-results{
  display:grid;
  gap:12px;
}
.kiosk-complaint-picker{
  display:grid;
  gap:10px;
}
.kiosk-complaint-list-item{
  width:100%;
  display:grid;
  grid-template-columns:minmax(110px,.55fr) minmax(0,1fr) auto;
  gap:12px;
  align-items:center;
  min-height:58px;
  padding:12px 14px;
  border-radius:16px;
  background:rgba(245,247,251,.95);
  color:var(--text);
  border:1px solid rgba(18,24,38,.08);
  box-shadow:none;
  text-align:left;
  white-space:normal;
}
.kiosk-complaint-list-item:hover{
  box-shadow:0 10px 24px rgba(0,0,0,.08);
}
.kiosk-complaint-list-item strong{
  font-size:18px;
  line-height:1.1;
}
.kiosk-complaint-list-item span,
.kiosk-complaint-list-item small{
  color:var(--text-soft);
  font-size:13px;
  font-weight:720;
  line-height:1.25;
}
.kiosk-complaint-list-item small{
  justify-self:end;
  color:var(--muted);
}
.kiosk-complaint-result{
  display:grid;
  gap:12px;
  padding:16px;
  border-radius:18px;
  background:rgba(245,247,251,.95);
  border:1px solid rgba(18,24,38,.08);
}
.kiosk-complaint-result span{
  display:block;
  color:var(--muted);
  font-size:12px;
  font-weight:780;
}
.kiosk-complaint-result strong{
  display:block;
  margin-top:2px;
  font-size:19px;
  line-height:1.2;
}
.kiosk-complaint-result p,
.kiosk-complaint-result small{
  display:block;
  margin:4px 0 0;
  color:var(--text-soft);
  font-size:14px;
  font-weight:640;
  line-height:1.35;
}
.kiosk-complaint-result form{
  display:flex;
  justify-content:flex-end;
}
.kiosk-complaint-back{
  justify-self:start;
}
.kiosk-signal-list{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(180px,1fr));
  gap:10px;
}
.kiosk-signal-list article{
  display:grid;
  gap:7px;
  padding:13px;
  border-radius:18px;
  background:rgba(255,255,255,.88);
  color:var(--text);
}
.kiosk-signal-list strong{
  display:block;
  line-height:1.2;
}
.kiosk-signal-list span{
  justify-self:start;
  padding:5px 9px;
  border-radius:999px;
  font-size:12px;
  font-weight:780;
}
.kiosk-signal-list .ok span{background:rgba(31,143,86,.10);color:var(--ok)}
.kiosk-signal-list .warning span{background:rgba(255,189,46,.16);color:var(--warning)}
.kiosk-signal-list .danger span{background:rgba(217,45,32,.10);color:var(--danger)}
.kiosk-pin-card{
  background:rgba(255,255,255,.86);
}
.kiosk-pin-card h2{margin-bottom:8px}
.kiosk-side-stack{
  align-self:center;
  display:grid;
  gap:14px;
  width:min(410px,100%);
}
.kiosk-weather-card{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:16px 18px;
  border-radius:24px;
  background:rgba(255,255,255,.86);
  border:1px solid rgba(255,255,255,.62);
  box-shadow:0 20px 70px rgba(0,0,0,.16);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
}
.kiosk-side-stack>.login-card,
.kiosk-weather-card{
  width:100%;
}
.kiosk-weather-card span{
  display:block;
  color:var(--muted);
  font-size:12px;
  font-weight:720;
}
.kiosk-weather-card strong{
  display:block;
  color:var(--text);
  font-size:20px;
  line-height:1.15;
}
.kiosk-weather-card b{
  color:var(--brand-primary);
  font-size:34px;
  line-height:1;
}
.kiosk-info-card{
  align-self:stretch;
}
.kiosk-shortcuts{
  display:grid;
  grid-template-columns:1fr;
  gap:9px;
  margin-top:18px;
}
.kiosk-shortcuts a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  min-height:46px;
  padding:12px 14px;
  border-radius:16px;
  background:rgba(255,255,255,.66);
  border:1px solid rgba(0,0,0,.055);
  color:var(--text);
  font-weight:720;
}
.kiosk-shortcuts a:after{
  content:"›";
  color:var(--brand-primary);
  font-size:24px;
  line-height:1;
}

@media (max-width:980px){
  .wiki-hero,.wiki-upload-grid,.kiosk-lock{grid-template-columns:1fr}
  .kiosk-clock-row>div:first-child{font-size:76px}
  .kiosk-status-strip{grid-template-columns:repeat(3,minmax(0,1fr))}
  .kiosk-board-columns{grid-template-columns:1fr}
}
@media (max-width:720px){
  .wiki-stats,.wiki-search,.wiki-smart-search,.wiki-form-grid{grid-template-columns:1fr}
  .wiki-section-head{align-items:flex-start;flex-direction:column}
  .supplier-grid,.wiki-grid,.damage-grid,.damage-facts,.damage-note-form,.damage-archive-form,.damage-inline-upload{grid-template-columns:1fr}
  .damage-section-head{align-items:flex-start;flex-direction:column}
  .damage-detail-hero{align-items:flex-start;flex-direction:column}
  .wiki-lines div{grid-template-columns:1fr;gap:2px}
  .kiosk-lock{padding:18px}
  .kiosk-clock-row>div:first-child{font-size:54px}
  .kiosk-clock>span{font-size:17px}
  .kiosk-status-strip{grid-template-columns:repeat(2,minmax(0,1fr))}
  .kiosk-status-strip div{min-height:78px;padding:12px}
  .kiosk-status-strip strong{font-size:28px}
  .kiosk-panel-head{align-items:flex-start;flex-direction:column}
  .kiosk-overdue-panel{padding:14px;border-radius:20px}
  .kiosk-complaint-list-item{grid-template-columns:1fr}
  .kiosk-complaint-list-item small{justify-self:start}
}
