
:root{--bg:#f5f7fb;--card:#ffffff;--muted:#52607a;--text:#0f172a;--line:#e2e8f0;--accent:#2563eb;}
*{box-sizing:border-box;}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--text);}
a{color:var(--accent);text-decoration:none;}
a:hover{text-decoration:underline;}
.container{max-width:1200px;margin:0 auto;padding:16px;}
.card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px;margin:12px 0;box-shadow:0 10px 28px rgba(2,6,23,.08);}
.grid{display:grid;grid-template-columns:1fr;gap:12px;}
@media(min-width:900px){.grid-2{grid-template-columns:1fr 1fr;}.layout{display:grid;grid-template-columns:260px 1fr;min-height:100vh;}}
.layout.guest{min-height:100vh;}
@media(min-width:900px){.layout.guest{display:block;}}
.sidebar{background:var(--card);border-right:1px solid var(--line);padding:14px;position:sticky;top:0;height:100vh;display:none;}
@media(min-width:900px){.sidebar{display:block;}}
.brand{font-weight:700;margin-bottom:14px;display:flex;flex-direction:column;gap:8px;}
.brand-logo img{max-width:180px;max-height:56px;object-fit:contain;display:block;}
.brand-title{font-weight:800;font-size:18px;}
.nav a{display:block;padding:10px 10px;border-radius:10px;color:var(--text);opacity:.95}
.nav a.active{background:#f1f5ff;border:1px solid var(--line);}
.nav a:hover{background:#eef2ff;}
.topbar{display:flex;gap:10px;align-items:center;justify-content:space-between;margin-bottom:12px;}

.topbar-logo{display:flex;align-items:center;margin-right:8px;}
.topbar-logo img{max-width:250px;max-height:56px;object-fit:contain;display:block;}
.brand-logo img{max-width:160px;max-height:56px;object-fit:contain;display:block;}

.badge{display:inline-block;padding:4px 10px;border-radius:999px;background:#f8fafc;border:1px solid var(--line);color:var(--muted);font-size:12px;}
.btn{display:inline-block;padding:10px 14px;border-radius:12px;background:#ffffff;border:1px solid var(--line);color:var(--text);cursor:pointer;}
.btn:hover{filter:brightness(1.1);text-decoration:none;}
.btn.primary{background:linear-gradient(135deg,#2a7bff,#6bb1ff);border:none;color:white;font-weight:700;}
.btn.danger{background:#fff1f2;border:1px solid #fecdd3;color:#9f1239;font-weight:700;}
.btn.small{padding:7px 10px;border-radius:10px;font-size:13px;}
input,select,textarea{width:100%;padding:10px 12px;border-radius:12px;border:1px solid var(--line);background:#ffffff;color:var(--text);}
label{display:block;margin:10px 0 6px;color:var(--muted);font-size:13px;}
table{width:100%;border-collapse:collapse;}
th,td{padding:10px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top;}
th{color:var(--muted);font-weight:600;}
.flash{padding:10px 12px;border-radius:12px;border:1px solid var(--line);background:#eef2ff;margin:10px 0;color:var(--text);}
.flash.ok{border-color:#86efac;background:#ecfdf5;color:#065f46;}
.flash.err{border-color:#fecaca;background:#fff1f2;color:#991b1b;}
.hstack{display:flex;gap:10px;align-items:center;flex-wrap:wrap;}
.right{margin-left:auto;}
hr{border:none;border-top:1px solid var(--line);margin:14px 0;}
.small{font-size:13px;color:var(--muted);}


/* Sprint 1.4 meetmodus */
.low-value{background:#fff3b0 !important;color:#111;}
.measure-grid{width:100%;border-collapse:collapse;}
.measure-grid th,.measure-grid td{padding:8px;border-bottom:1px solid var(--line);}
.measure-input{width:90px;font-size:22px;padding:10px;text-align:center;border-radius:10px;border:1px solid var(--line);background:#ffffff;color:var(--text);} 
.measure-input:focus{outline:2px solid var(--accent);} 
.measure-row-label{white-space:nowrap;}
@media (max-width:700px){.measure-input{width:74px;font-size:20px;padding:10px;}}

.grid-3{grid-template-columns:repeat(3,1fr);} 
.grid-4{grid-template-columns:repeat(4,1fr);} 
@media (max-width:900px){.grid-3,.grid-4{grid-template-columns:1fr 1fr;}} 
@media (max-width:520px){.grid-3,.grid-4{grid-template-columns:1fr;}}


.logo-preview{border:1px solid #e5e7eb;border-radius:12px;padding:14px;background:#fff;}
.logo-preview img{max-width:100%;height:auto;display:block;}
.pill{display:inline-block;padding:6px 10px;border-radius:999px;background:#f3f4f6;}

.logo-link{display:inline-block;text-decoration:none;}
.logo-link:hover{opacity:.9;}
.login-logo{display:flex;justify-content:center;align-items:center;}
.login-logo img{max-width:250px;max-height:90px;object-fit:contain;display:block;}

.login-wrap{max-width:440px;margin:70px auto;}
.login-card{padding:22px;}
.login-title{font-size:22px;font-weight:800;margin:6px 0 2px;}
.login-sub{margin:0 0 14px;color:var(--muted);font-size:13px;}


/* Visit reports */
.photos{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
}
.photo{
  width:180px;
  border:1px solid #e6eaf0;
  border-radius:12px;
  padding:8px;
  background:#fff;
}
.photo img{
  width:100%;
  height:120px;
  object-fit:cover;
  border-radius:8px;
  display:block;
}
.badge{
  display:inline-block;
  font-size:12px;
  padding:2px 8px;
  border-radius:999px;
  border:1px solid #dbe3ee;
  background:#f6f8fc;
}
.badge.ok{
  border-color:#bfe6c8;
  background:#eaf8ef;
  color:#145a2b;
}
.badge.err{
  border-color:#f1b9b9;
  background:#fdecec;
  color:#7a1a1a;
}


.dashboard-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:16px;margin-bottom:16px;}
.dashboard-hero{grid-column:1 / span 1;}
.stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;}
.stat-card{border:1px solid var(--line);border-radius:16px;padding:14px;background:#fff;}
.stat-label{font-size:12px;color:var(--muted);margin-bottom:6px;}
.stat-value{font-size:24px;font-weight:800;color:var(--text);}
.mini-chart{width:100%;height:auto;display:block;border:1px solid var(--line);border-radius:14px;background:#fff;}
.customer-title{display:flex;align-items:center;gap:14px;}
.customer-title-logo{width:64px;height:64px;border-radius:14px;background:#fff;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;padding:8px;}
.customer-title-logo img{max-width:100%;max-height:100%;object-fit:contain;}
.logo-preview-customer{min-height:120px;display:flex;align-items:center;justify-content:center;}
.logo-preview-customer img{max-width:250px;max-height:110px;object-fit:contain;}
.control-entry-toolbar{display:flex;align-items:center;gap:10px;margin-top:12px;padding:10px 12px;border:1px solid var(--line);border-radius:14px;background:#f8fbff;}
.measure-mode-shell{overflow-x:auto;}
.measure-live-grid .card{box-shadow:none;border:1px solid var(--line);background:#fff;}
@media (max-width:1200px){.dashboard-grid{grid-template-columns:1fr 1fr;}.dashboard-hero{grid-column:1 / span 2;}}
@media (max-width:820px){.dashboard-grid,.grid.grid-2,.control-entry-grid{grid-template-columns:1fr !important;}.stat-grid{grid-template-columns:1fr 1fr;}.topbar-logo img{max-width:160px;}.control-entry-toolbar{position:sticky;top:8px;z-index:5;}}
@media (max-width:560px){.stat-grid{grid-template-columns:1fr;}.measure-grid th,.measure-grid td{padding:6px;}.measure-input{width:100%;min-width:84px;font-size:26px;padding:14px 10px;}.btn{width:auto;}.hstack{gap:8px;}.container{padding:12px;}}


.compact-summary-card{padding:10px 16px;margin-bottom:10px;}
.compact-summary{display:flex;gap:12px 20px;align-items:center;flex-wrap:wrap;font-size:14px;}
.compact-stat{display:inline-flex;align-items:center;gap:8px;padding-right:16px;border-right:1px solid var(--line);}
.compact-stat:last-child{border-right:none;padding-right:0;}
.compact-stat-label{color:var(--muted);}
@media (max-width:640px){
  .compact-summary{display:grid;grid-template-columns:1fr 1fr;gap:8px 12px;}
  .compact-stat{border-right:none;padding-right:0;}
}


.muted{color:var(--muted);}
.status-pill{display:inline-block;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:700;border:1px solid var(--line);background:#f8fafc;color:var(--text);}
.status-pill.is-green{background:#ecfdf5;border-color:#86efac;color:#166534;}
.status-pill.is-yellow{background:#fffbeb;border-color:#fcd34d;color:#92400e;}
.status-pill.is-red{background:#fff1f2;border-color:#fda4af;color:#9f1239;}
.status-pill.is-empty{background:#f8fafc;border-color:#cbd5e1;color:#64748b;}
