*{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%);
}

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;
}
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)}
}
.filter-row{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
  align-items:end;
}
.filter-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.free-request-group{
  margin-top:22px;
}
.print-title{
  margin-bottom:14px;
}
@media (max-width:900px){
  .filter-row{grid-template-columns:1fr}
}
@media print{
  body{background:#fff;color:#000;font-size:12px}
  body:before,body:after,.sidebar,.topbar,.print-hidden{display:none!important}
  .app-shell{display:block}
  .main{margin:0;padding:0}
  .card,.free-request-print{
    background:#fff!important;
    border:0!important;
    box-shadow:none!important;
    border-radius:0!important;
    padding:0!important;
  }
  .free-request-group{break-inside:avoid;margin-top:18px}
  table{width:100%;border-collapse:collapse}
  th,td{border:1px solid #bbb;padding:6px;text-align:left;vertical-align:top}
  h1,h2,h3{color:#000}
  a[href]:after{content:""}
}
.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,
.nav summary{
  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 summary{
  cursor:pointer;
  list-style:none;
}
.nav summary::-webkit-details-marker{display:none}
.nav-group{min-width:0}
.nav-group-content{
  display:grid;
  gap:4px;
  margin:5px 0 0 29px;
  padding:4px 0 4px 10px;
  border-left:1px solid rgba(17,24,39,.1);
}
.nav-group-content a{
  min-height:36px;
  padding:8px 11px;
  border-radius:12px;
  font-size:13px;
}
.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,
.nav summary:hover,
.nav-group[open] > summary{
  color:var(--text);
  background:rgba(255,255,255,.66);
  transform:translateX(2px);
}
.nav a:hover .nav-icon,
.nav summary:hover .nav-icon,
.nav-group[open] > summary .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}
.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}
.badge.schedule-status-work{background:rgba(31,143,86,.12);color:var(--ok)}
.badge.schedule-status-free{background:rgba(142,142,147,.12);color:var(--muted)}
.badge.schedule-status-vacation{background:rgba(10,132,255,.12);color:var(--info)}
.badge.schedule-status-unknown{background:rgba(255,149,0,.16);color:#a45b00}
details summary{cursor:pointer;font-weight:700;color:var(--text)}
td pre{white-space:pre-wrap;margin:8px 0 0;font:12px/1.45 ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;color:var(--text-soft)}
.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,.nav summary{justify-content:center;padding:10px}
  .nav a .nav-icon,.nav summary .nav-icon{width:18px;height:18px}
  .nav-group-content{margin:6px 0 0;padding:0;border-left:0}
  .nav-group-content a{font-size:12px;min-height:34px}
  .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}
}

.qr-page-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-bottom:18px;
}
.qr-page-head .actions{margin-top:0}
.qr-controls{
  display:grid;
  gap:16px;
  margin-bottom:18px;
}
.qr-filter-grid{
  display:grid;
  grid-template-columns:minmax(180px,240px) minmax(160px,220px) minmax(260px,1fr);
  gap:12px;
  align-items:end;
}
.qr-filter-grid label,
.qr-toggle{
  display:grid;
  gap:6px;
  color:var(--muted);
  font-size:12px;
  font-weight:760;
}
.qr-search-field input{min-width:0}
.qr-control-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
}
.qr-layout-control{
  display:flex;
  align-items:center;
  gap:4px;
  margin:0;
  padding:5px;
  border:1px solid rgba(0,0,0,.08);
  border-radius:999px;
  background:rgba(255,255,255,.68);
}
.qr-layout-control legend{
  width:1px;
  height:1px;
  overflow:hidden;
  position:absolute;
  white-space:nowrap;
  clip:rect(0 0 0 0);
}
.qr-layout-control input,
.qr-toggle input,
.qr-asset-option input{
  width:auto;
  min-width:0;
  box-shadow:none;
}
.qr-layout-control label{
  position:relative;
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:7px 12px;
  border-radius:999px;
  color:var(--text-soft);
  font-size:13px;
  font-weight:720;
  cursor:pointer;
  white-space:nowrap;
}
.qr-layout-control label:has(input:checked){
  background:#fff;
  color:var(--brand-primary);
  box-shadow:0 7px 18px rgba(0,0,0,.08);
}
.qr-layout-control label input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}
.qr-toggle{
  display:flex;
  align-items:center;
  grid-auto-flow:column;
  color:var(--text-soft);
  font-size:13px;
}
.qr-selection-actions{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
}
.qr-builder{
  display:grid;
  grid-template-columns:minmax(290px,380px) minmax(0,1fr);
  gap:18px;
  align-items:start;
}
.qr-picker{
  padding:16px;
  position:sticky;
  top:18px;
}
.qr-picker-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:12px;
}
.qr-picker-head span{
  color:var(--muted);
  font-size:12px;
  font-weight:780;
}
.qr-asset-list{
  display:grid;
  gap:8px;
  max-height:calc(100vh - 320px);
  overflow:auto;
  padding-right:2px;
}
.qr-asset-option{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:8px;
  align-items:center;
  min-height:64px;
  padding:10px;
  border:1px solid rgba(0,0,0,.07);
  border-radius:8px;
  background:rgba(255,255,255,.68);
}
.qr-asset-option label{
  display:flex;
  align-items:flex-start;
  gap:10px;
  min-width:0;
  cursor:pointer;
}
.qr-asset-option strong,
.qr-asset-option small{
  display:block;
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
}
.qr-asset-option strong{
  color:var(--text);
  font-size:14px;
  line-height:1.2;
  white-space:nowrap;
}
.qr-asset-option small{
  margin-top:3px;
  color:var(--muted);
  font-size:12px;
  line-height:1.3;
}
.qr-png-link{
  min-height:34px;
  padding:7px 10px;
  font-size:12px;
  box-shadow:none;
}
.qr-print-stage{
  padding:18px;
  background:#f1f2f4;
  overflow:auto;
}
.qr-sheet{
  display:grid;
  gap:12px;
  margin:0 auto;
  color:#111827;
}
.qr-sheet.layout-small{
  grid-template-columns:repeat(auto-fill,minmax(190px,1fr));
}
.qr-sheet.layout-medium{
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
}
.qr-sheet.layout-a4{
  grid-template-columns:repeat(auto-fill,minmax(230px,1fr));
  max-width:920px;
}
.qr-sheet.layout-large{
  grid-template-columns:minmax(0,560px);
  justify-content:center;
}
.qr-label{
  position:relative;
  overflow:hidden;
  background:#fff;
  border:1px solid #d9dde5;
  border-radius:8px;
  padding:12px 12px 10px 16px;
  box-shadow:0 12px 28px rgba(0,0,0,.08);
  break-inside:avoid;
  page-break-inside:avoid;
}
.qr-label-accent{
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:5px;
  background:var(--brand-primary);
}
.qr-label-main{
  display:grid;
  grid-template-columns:96px minmax(0,1fr);
  gap:12px;
  align-items:center;
}
.qr-image-wrap{
  background:#fff;
  border:1px solid #eef0f4;
  border-radius:6px;
  padding:5px;
}
.qr-image-wrap img{
  display:block;
  width:100%;
  aspect-ratio:1/1;
  object-fit:contain;
}
.qr-label-copy{
  min-width:0;
  display:grid;
  gap:4px;
}
.qr-brand{
  display:flex;
  align-items:center;
  gap:6px;
  color:var(--brand-primary);
  font-size:10px;
  line-height:1;
  font-weight:860;
  text-transform:uppercase;
}
.qr-brand-mark{
  display:inline-flex;
  width:18px;
  height:18px;
  align-items:center;
  justify-content:center;
  border-radius:5px;
  background:var(--brand-primary);
  color:#fff;
  font-size:12px;
  font-weight:900;
}
.qr-asset-name{
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  color:#111827;
  font-size:18px;
  line-height:1.12;
  font-weight:840;
  letter-spacing:0;
}
.qr-area,
.qr-model,
.qr-serial{
  display:block;
  min-width:0;
  overflow:hidden;
  color:#4b5563;
  font-size:12px;
  line-height:1.25;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.qr-url{
  margin-top:9px;
  color:#6b7280;
  font-size:9px;
  line-height:1.25;
  word-break:break-all;
  letter-spacing:0;
}
.layout-small .qr-label{
  min-height:118px;
  padding:8px 8px 7px 12px;
}
.layout-small .qr-label-main{
  grid-template-columns:72px minmax(0,1fr);
  gap:8px;
}
.layout-small .qr-brand{
  font-size:8px;
}
.layout-small .qr-brand-mark{
  width:15px;
  height:15px;
  border-radius:4px;
  font-size:10px;
}
.layout-small .qr-asset-name{
  font-size:12px;
  line-height:1.1;
}
.layout-small .qr-area,
.layout-small .qr-model,
.layout-small .qr-serial{
  font-size:9px;
}
.layout-small .qr-url{
  margin-top:5px;
  font-size:7px;
}
.layout-medium .qr-label{
  min-height:158px;
}
.layout-medium .qr-label-main{
  grid-template-columns:112px minmax(0,1fr);
}
.layout-a4 .qr-label{
  min-height:150px;
}
.layout-large .qr-label{
  padding:28px;
}
.layout-large .qr-label-main{
  grid-template-columns:220px minmax(0,1fr);
  gap:24px;
}
.layout-large .qr-brand{
  font-size:13px;
}
.layout-large .qr-brand-mark{
  width:28px;
  height:28px;
  border-radius:7px;
  font-size:18px;
}
.layout-large .qr-asset-name{
  font-size:30px;
}
.layout-large .qr-area,
.layout-large .qr-model,
.layout-large .qr-serial{
  font-size:16px;
}
.layout-large .qr-url{
  margin-top:22px;
  font-size:11px;
}
.qr-empty,
.qr-empty-print{
  border:1px dashed rgba(0,0,0,.16);
  border-radius:8px;
  padding:20px;
  color:var(--muted);
  text-align:center;
  background:rgba(255,255,255,.62);
}

@media (max-width:980px){
  .qr-filter-grid{grid-template-columns:1fr 1fr}
  .qr-search-field{grid-column:1/-1}
  .qr-builder{grid-template-columns:1fr}
  .qr-picker{position:relative;top:auto}
  .qr-asset-list{max-height:none}
}
@media (max-width:720px){
  .qr-page-head{align-items:flex-start;flex-direction:column}
  .qr-filter-grid{grid-template-columns:1fr}
  .qr-layout-control{align-items:stretch;border-radius:8px;flex-wrap:wrap}
  .qr-layout-control label{flex:1 1 140px;justify-content:center;border-radius:6px}
  .qr-control-row{align-items:stretch;flex-direction:column}
  .qr-selection-actions{display:grid;grid-template-columns:1fr}
  .qr-asset-option{grid-template-columns:1fr}
  .qr-png-link{justify-self:start}
  .qr-sheet.layout-large,
  .qr-sheet.layout-a4,
  .qr-sheet.layout-medium,
  .qr-sheet.layout-small{grid-template-columns:1fr}
  .layout-large .qr-label-main{grid-template-columns:1fr}
}

@media print{
  @page{size:A4 portrait;margin:8mm}
  html,body{
    width:auto!important;
    min-height:0!important;
    overflow:visible!important;
    background:#fff!important;
  }
  body:before,
  body:after,
  .sidebar,
  .topbar,
  .flash,
  .no-print{
    display:none!important;
  }
  .app-shell,
  .main{
    display:block!important;
    width:auto!important;
    min-height:0!important;
    margin:0!important;
    padding:0!important;
    background:#fff!important;
    overflow:visible!important;
  }
  .qr-builder{
    display:block!important;
    margin:0!important;
  }
  .qr-print-stage{
    display:block!important;
    padding:0!important;
    margin:0!important;
    border:0!important;
    border-radius:0!important;
    box-shadow:none!important;
    background:#fff!important;
    overflow:visible!important;
  }
  .qr-sheet{
    width:100%!important;
    max-width:none!important;
    margin:0!important;
    color:#111827!important;
  }
  .qr-label{
    box-shadow:none!important;
    border-color:#cfd4dc!important;
    border-radius:2mm!important;
  }
  .qr-image-wrap{
    border-color:#eef0f4!important;
  }
  .qr-sheet.layout-small{
    grid-template-columns:repeat(3,62mm)!important;
    gap:4mm!important;
  }
  .layout-small .qr-label{
    width:62mm!important;
    min-height:32mm!important;
    padding:3mm 2mm 2mm 4mm!important;
  }
  .layout-small .qr-label-main{
    grid-template-columns:19mm minmax(0,1fr)!important;
    gap:2.5mm!important;
  }
  .layout-small .qr-url{font-size:5.5pt!important}
  .qr-sheet.layout-medium{
    grid-template-columns:repeat(2,92mm)!important;
    gap:5mm!important;
  }
  .layout-medium .qr-label{
    width:92mm!important;
    min-height:50mm!important;
    padding:4mm 4mm 3mm 5mm!important;
  }
  .layout-medium .qr-label-main{
    grid-template-columns:31mm minmax(0,1fr)!important;
    gap:4mm!important;
  }
  .qr-sheet.layout-a4{
    grid-template-columns:repeat(3,62mm)!important;
    gap:4mm!important;
  }
  .layout-a4 .qr-label{
    width:62mm!important;
    min-height:44mm!important;
    padding:3.5mm 3mm 2.5mm 4.5mm!important;
  }
  .layout-a4 .qr-label-main{
    grid-template-columns:24mm minmax(0,1fr)!important;
    gap:3mm!important;
  }
  .layout-a4 .qr-asset-name{font-size:11pt!important}
  .layout-a4 .qr-area,
  .layout-a4 .qr-model,
  .layout-a4 .qr-serial{font-size:7pt!important}
  .layout-a4 .qr-url{font-size:5.5pt!important}
  .qr-sheet.layout-large{
    display:block!important;
  }
  .layout-large .qr-label{
    width:132mm!important;
    min-height:176mm!important;
    margin:0 auto!important;
    padding:9mm!important;
    break-after:page;
    page-break-after:always;
  }
  .layout-large .qr-label-main{
    grid-template-columns:1fr!important;
    gap:7mm!important;
    text-align:center;
  }
  .layout-large .qr-image-wrap{
    width:86mm!important;
    margin:0 auto!important;
  }
  .layout-large .qr-label-copy{
    justify-items:center;
  }
  .layout-large .qr-asset-name{font-size:24pt!important}
  .layout-large .qr-area,
  .layout-large .qr-model,
  .layout-large .qr-serial{font-size:12pt!important}
  .layout-large .qr-url{font-size:7pt!important;text-align:center}
}
