/* EMPOLI · Corners reporting — stylesheet */
:root{
  --bg:#f4f5f7;
  --panel:#ffffff;
  --ink:#1c2230;
  --ink-soft:#5b657a;
  --line:#e3e6ec;
  --line-strong:#cdd2dc;
  --brand:#0f2f4a;
  --brand-2:#16456b;
  --accent:#e8732a;
  --accent-soft:#fff1e7;
  --ok:#1f9d6b;
  --ok-soft:#e7f6ef;
  --warn:#c4452f;
  --warn-soft:#fbe9e6;
  --focus:#2f7fd0;
  --radius:10px;
  --shadow:0 1px 2px rgba(20,30,50,.06),0 6px 18px rgba(20,30,50,.06);
  --mono:"SFMono-Regular",ui-monospace,"Cascadia Mono","Segoe UI Mono",Menlo,Consolas,monospace;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans",sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:
    radial-gradient(1200px 500px at 100% -10%,rgba(22,69,107,.06),transparent 60%),
    var(--bg);
  font-size:14.5px;line-height:1.45;-webkit-font-smoothing:antialiased;
}
a{color:var(--brand-2);text-decoration:none}
a:hover{text-decoration:underline}
h1{font-size:22px;margin:0;letter-spacing:-.01em}
h2{font-size:15px;margin:0;letter-spacing:.02em;text-transform:uppercase;color:var(--ink-soft)}
h3{font-size:16px;margin:0}
.muted{color:var(--ink-soft)}
.r{text-align:right}
code{font-family:var(--mono);background:#eef0f4;padding:1px 5px;border-radius:5px;font-size:.9em}

/* ── Topbar ── */
.topbar{
  display:flex;align-items:center;gap:22px;
  background:linear-gradient(180deg,var(--brand),var(--brand-2));
  color:#fff;padding:0 22px;height:58px;
  box-shadow:0 1px 0 rgba(255,255,255,.06) inset,0 2px 10px rgba(8,20,40,.18);
  position:sticky;top:0;z-index:50;
}
.brand{display:flex;align-items:center;gap:11px}
.brand-mark{
  width:34px;height:34px;border-radius:9px;display:grid;place-items:center;
  background:var(--accent);color:#fff;font-weight:800;font-size:18px;
  box-shadow:0 2px 8px rgba(232,115,42,.4);
}
.brand-txt strong{display:block;font-size:15px;letter-spacing:.06em}
.brand-txt small{display:block;font-size:11px;opacity:.7;letter-spacing:.04em}
.mainnav{display:flex;gap:4px;margin-left:6px}
.mainnav a{
  color:rgba(255,255,255,.78);padding:8px 13px;border-radius:8px;font-weight:500;font-size:13.5px;
}
.mainnav a:hover{background:rgba(255,255,255,.1);color:#fff;text-decoration:none}
.mainnav a.is-active{background:rgba(255,255,255,.16);color:#fff}
.userbox{margin-left:auto;display:flex;align-items:center;gap:12px}
.uname{font-size:13px;opacity:.85}

/* ── Layout ── */
.wrap{max-width:1480px;margin:24px auto 60px;padding:0 22px}
.day-head{margin:6px 0 18px;display:flex;align-items:baseline;gap:14px;flex-wrap:wrap}
.day-head p{margin:0}
.foot{max-width:1480px;margin:0 auto;padding:18px 22px;display:flex;justify-content:space-between;color:var(--ink-soft);font-size:12px}

/* ── Buttons ── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:7px;
  border:1px solid transparent;border-radius:8px;padding:9px 16px;font-size:14px;font-weight:600;
  cursor:pointer;font-family:inherit;transition:.12s;white-space:nowrap;
}
.btn:hover{text-decoration:none}
.btn-sm{padding:6px 11px;font-size:12.5px;border-radius:7px}
.btn-block{width:100%}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 1px 2px rgba(232,115,42,.3)}
.btn-primary:hover{background:#d4641f}
.btn-ghost{background:#fff;color:var(--ink);border-color:var(--line-strong)}
.btn-ghost:hover{background:#f7f8fa;border-color:var(--ink-soft)}
.topbar .btn-ghost{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.2)}
.topbar .btn-ghost:hover{background:rgba(255,255,255,.22)}
.btn-warn{background:var(--warn-soft);color:var(--warn);border-color:#f1c9c2}
.btn-warn:hover{background:#f7ddd8}
.btn-ok{background:var(--ok-soft);color:var(--ok);border-color:#bfe6d3}
.link{font-weight:600;font-size:13px}

/* ── Flash ── */
.flash{padding:11px 15px;border-radius:9px;margin-bottom:14px;font-size:14px;border:1px solid}
.flash-success{background:var(--ok-soft);border-color:#bfe6d3;color:#13694a}
.flash-error{background:var(--warn-soft);border-color:#f1c9c2;color:#9a2f1e}
.flash-warn{background:var(--accent-soft);border-color:#f6d3ba;color:#9a531f}

/* ── Toolbar / filters ── */
.toolbar{
  display:flex;gap:14px;align-items:flex-end;flex-wrap:wrap;
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:14px 16px;box-shadow:var(--shadow);margin-bottom:18px;
}
.field{display:flex;flex-direction:column;gap:5px}
.field.grow{flex:1 1 40px}
.field label{font-size:11.5px;font-weight:600;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.04em}
.field.date-nav>div{display:flex;gap:6px}
select,input[type=text],input[type=password],input[type=date],input[type=number]{
  font-family:inherit;font-size:14px;color:var(--ink);background:#fff;
  border:1px solid var(--line-strong);border-radius:8px;padding:8px 11px;outline:none;transition:.12s;
}
select{min-width:170px;cursor:pointer}
input:focus,select:focus{border-color:var(--focus);box-shadow:0 0 0 3px rgba(47,127,208,.15)}

/* ── Progress ── */
.progress{position:relative;background:#e9ecf1;border-radius:8px;height:30px;min-width:150px;overflow:hidden;display:flex;align-items:center}
.progress.big{height:36px}
.progress-bar{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,var(--ok),#27b07c);transition:width .3s}
.progress span{position:relative;z-index:1;font-size:12.5px;font-weight:700;padding:0 12px;color:var(--ink);mix-blend-mode:luminosity}

/* ── Cards (dashboard) ── */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-bottom:22px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
.card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.card-stats{display:flex;gap:24px;margin-top:14px}
.card-stats label{display:block;font-size:11px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.04em}
.card-stats strong{font-size:18px;font-variant-numeric:tabular-nums}

/* ── Panels ── */
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:22px;overflow:hidden}
.panel-head{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid var(--line)}
.panel .empty{padding:24px 18px}

/* ── Summary strip ── */
.summary-strip{display:flex;gap:0;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:18px;overflow:hidden}
.summary-strip>div{flex:1;padding:14px 18px;border-right:1px solid var(--line)}
.summary-strip>div:last-child{border-right:0}
.summary-strip label{display:block;font-size:11px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.04em;margin-bottom:3px}
.summary-strip strong{font-size:18px;font-variant-numeric:tabular-nums}

/* ── Entry grid ── */
.floor{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:16px;overflow:hidden}
.floor-head{display:flex;justify-content:space-between;align-items:center;padding:11px 16px;background:linear-gradient(180deg,#fbfcfe,#f3f5f9);border-bottom:1px solid var(--line)}
.floor-head h2{color:var(--brand-2)}
.floor-sum{font-size:13px;font-weight:700;color:var(--ink-soft);font-variant-numeric:tabular-nums}
table.grid{width:100%;border-collapse:collapse}
table.grid th{
  font-size:11.5px;text-transform:uppercase;letter-spacing:.03em;color:var(--ink-soft);
  text-align:right;padding:9px 12px;border-bottom:1px solid var(--line);background:#fafbfc;font-weight:700;
}
table.grid th.c-name{text-align:left}
table.grid td{padding:5px 8px;border-bottom:1px solid var(--line)}
table.grid tr:last-child td{border-bottom:0}
td.c-name{font-weight:600;font-size:13.5px;max-width:230px}
table.grid input.num{width:100%;text-align:right;font-variant-numeric:tabular-nums;border-color:var(--line)}
table.grid input.num:hover{border-color:var(--line-strong)}
table.grid .c-note input{width:100%;border-color:var(--line)}
table.grid .c-note{min-width:160px}
tr.has-data td.c-name{box-shadow:inset 3px 0 0 var(--ok)}
tr.has-data input.num{background:#fbfffd}

/* ── List tables ── */
table.grid.list th{text-align:left}
table.grid.list th.r{text-align:right}
table.grid.list td{padding:10px 14px;font-size:13.5px}
table.grid.list .r{text-align:right;font-variant-numeric:tabular-nums}
table.grid.list tbody tr:hover{background:#f8fafc}
table.grid.list tr.floor-row td{background:#eef2f7;font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.03em;color:var(--ink-soft);padding:7px 14px}
table.grid.list tr.floor-row:hover td{background:#eef2f7}
table.grid.list tr.subtotal td{font-weight:700;border-top:1px solid var(--line-strong);background:#fcfdfe}
table.grid.list tr.subtotal:hover td{background:#fcfdfe}
.delta-pos{color:#15803d}
.delta-neg{color:#b91c1c}
tr.row-off{opacity:.5}
.tag{display:inline-block;background:var(--accent-soft);color:var(--accent);font-size:10.5px;font-weight:700;padding:1px 7px;border-radius:20px;vertical-align:middle;margin-left:6px}

/* ── Save bar ── */
.savebar{
  position:sticky;bottom:0;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;
  background:rgba(255,255,255,.92);backdrop-filter:blur(8px);
  border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 -2px 14px rgba(20,30,50,.08);
  padding:13px 18px;margin-top:6px;
}
.savebar-totals{font-size:13.5px;color:var(--ink-soft)}
.savebar-totals strong{color:var(--ink);font-variant-numeric:tabular-nums}

/* ── Manage ── */
.manage-list{padding:8px 14px}
.manage-row{display:flex;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid var(--line);flex-wrap:wrap}
.manage-row:last-child{border-bottom:0}
.inline-form{display:flex;align-items:center;gap:7px;margin:0}
.inline-form.add{padding:12px 18px}
.inline-form input.inactive,input.inactive{opacity:.5;text-decoration:line-through}
.inline-form input.strong{font-weight:700}
.floor-manage{padding:12px 18px;border-bottom:1px solid var(--line)}
.floor-title{border-bottom:0;padding-bottom:4px}
.corner-chips{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.chip{display:flex;margin:0}
.chip input{font-size:12.5px;padding:5px 9px;border-radius:7px 0 0 7px;border-right:0;width:130px}
.chip.inactive input{opacity:.45;text-decoration:line-through}
.chip-x{margin:0}
.chip-x button{border:1px solid var(--line-strong);border-left:0;border-radius:0 7px 7px 0;background:#f7f8fa;cursor:pointer;padding:0 9px;height:31px;color:var(--ink-soft);font-size:15px;line-height:1}
.chip-x button:hover{background:var(--warn-soft);color:var(--warn)}
.corner-chips .add input{width:120px}

/* ── Auth ── */
.auth-body{display:grid;place-items:center;min-height:100vh;
  background:radial-gradient(900px 500px at 50% -20%,rgba(22,69,107,.18),transparent 60%),linear-gradient(180deg,#0f2f4a,#0b2236)}
.auth-card{background:#fff;border-radius:16px;padding:32px;width:380px;max-width:92vw;box-shadow:0 20px 60px rgba(0,0,0,.35)}
.auth-brand{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.auth-brand strong{display:block;font-size:18px;letter-spacing:.06em}
.auth-brand small{color:var(--ink-soft);font-size:12px}
.auth-card h1{font-size:18px;margin-bottom:16px}
.form{display:flex;flex-direction:column;gap:14px}
.form label{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:600;color:var(--ink-soft)}
.form input{font-size:15px}
.install-log{font-size:13px;color:var(--ink-soft);margin:6px 0 14px;padding-left:18px}
.install-log li{margin:3px 0}

@media (max-width:720px){
  .mainnav{display:none}
  .topbar{gap:12px}
  td.c-note,th.c-note{display:none}
  .card-stats{gap:16px}
}