/* ===========================================================
   Tradičné družstvo — Dochádzkový systém
   Design foundation
   =========================================================== */

:root{
  --ink:#1C1B19;
  --ink-soft:#6A675F;
  --ink-faint:#9C988E;
  --paper:#FFFFFF;
  --cream:#FAF8F3;
  --cream-2:#F3EFE7;
  --orange:#E0700F;
  --orange-dark:#BF5C07;
  --orange-tint:#FBEEDF;
  --sage:#7E9082;
  --sage-dark:#5C6E60;
  --sage-bg:#E9EDE9;
  --sage-tint:#EEF2EE;
  --gold:#CF982A;
  --gold-tint:#F8EFD6;
  --line:#E7E3DA;
  --line-soft:#F0ECE3;
  --ok:#5C8A5E;
  --ok-tint:#E6EFE3;
  --late:#C9692E;
  --late-tint:#FAE9DC;
  --absent:#B0ABA0;
  --shadow-sm:0 1px 2px rgba(28,27,25,.05), 0 1px 3px rgba(28,27,25,.04);
  --shadow-md:0 2px 8px rgba(28,27,25,.06), 0 8px 24px rgba(28,27,25,.06);
  --shadow-lg:0 12px 40px rgba(28,27,25,.12);
  --radius:14px;
  --radius-sm:9px;
  --radius-lg:22px;
  --sans:"Archivo", system-ui, sans-serif;
  --serif:"Spectral", Georgia, serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-size:15px;
  line-height:1.5;
}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select{font-family:inherit;font-size:inherit;color:inherit}
::selection{background:var(--orange-tint)}

/* ---- Typography helpers ---- */
.serif{font-family:var(--serif)}
.eyebrow{
  font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-faint);
}
h1,h2,h3{font-family:var(--serif);font-weight:700;line-height:1.08;letter-spacing:-.01em}
.tnum{font-variant-numeric:tabular-nums}

/* ===========================================================
   App shell
   =========================================================== */
.app{display:flex;min-height:100vh;background:var(--cream)}

/* ---- Sidebar ---- */
.sidebar{
  width:264px;flex:none;background:var(--paper);
  border-right:1px solid var(--line);
  display:flex;flex-direction:column;
  position:sticky;top:0;height:100vh;
}
.sb-brand{padding:26px 24px 18px;display:flex;align-items:center;gap:13px}
.sb-brand .logo{width:50px;height:50px;flex:none}
.sb-brand-txt{display:flex;flex-direction:column;line-height:1.15}
.sb-brand-txt b{font-family:var(--serif);font-size:18px;font-weight:700;letter-spacing:-.01em}
.sb-brand-txt span{font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-faint);font-weight:600}

.sb-nav{padding:8px 14px;display:flex;flex-direction:column;gap:2px;flex:1}
.sb-section{font-size:10.5px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-faint);padding:18px 10px 7px}
.nav-item{
  display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;
  font-size:14.5px;font-weight:500;color:var(--ink-soft);text-align:left;width:100%;
  transition:background .14s,color .14s;
}
.nav-item svg{width:19px;height:19px;flex:none;stroke-width:1.7}
.nav-item:hover{background:var(--cream-2);color:var(--ink)}
.nav-item.active{background:var(--sage-tint);color:var(--sage-dark);font-weight:600}
.nav-item .badge-count{margin-left:auto;font-size:12px;font-weight:700;background:var(--sage);color:#fff;border-radius:20px;min-width:20px;height:20px;display:flex;align-items:center;justify-content:center;padding:0 6px}

.sb-foot{padding:14px;border-top:1px solid var(--line)}

/* role switcher */
.role-switch{display:flex;background:var(--cream-2);border-radius:11px;padding:4px;gap:4px}
.role-switch button{
  flex:1;padding:8px 6px;border-radius:8px;font-size:12.5px;font-weight:600;color:var(--ink-soft);
  display:flex;align-items:center;justify-content:center;gap:6px;transition:.14s;
}
.role-switch button svg{width:15px;height:15px;stroke-width:1.8}
.role-switch button.on{background:var(--paper);color:var(--ink);box-shadow:var(--shadow-sm)}

.who{display:flex;align-items:center;gap:11px;padding:10px 8px 4px}
.who .avatar{width:38px;height:38px;font-size:14px}
.who-txt{line-height:1.25;min-width:0}
.who-txt b{font-size:14px;font-weight:600;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.who-txt span{font-size:12px;color:var(--ink-faint)}

/* ---- Main ---- */
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{
  height:74px;flex:none;display:flex;align-items:center;gap:18px;
  padding:0 34px;border-bottom:1px solid var(--line);background:rgba(250,248,243,.86);
  backdrop-filter:blur(8px);position:sticky;top:0;z-index:20;
}
.topbar h1{font-size:25px;white-space:nowrap}
.topbar-title{flex:none;min-width:0}
.topbar .sub{font-size:13.5px;color:var(--ink-soft);margin-top:1px}
.topbar-spacer{flex:1}
.hamburger{display:none;align-items:center;justify-content:center;width:42px;height:42px;border-radius:10px;color:var(--ink);flex:none;margin-left:-6px;transition:background .13s}
.hamburger:hover{background:var(--cream-2)}
.hamburger svg{stroke-width:2}
.nav-backdrop{display:none}
.content{padding:30px 34px 60px;max-width:1180px;width:100%}

/* ===========================================================
   Components
   =========================================================== */
.avatar{
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-weight:700;color:#fff;flex:none;font-family:var(--sans);letter-spacing:.01em;
  width:44px;height:44px;font-size:16px;
}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:10px 18px;border-radius:10px;font-size:14px;font-weight:600;
  background:var(--ink);color:#fff;transition:.15s;white-space:nowrap;
}
.btn svg{width:17px;height:17px;stroke-width:2}
.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn.orange{background:var(--orange)}
.btn.orange:hover{background:var(--orange-dark)}
.btn.ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn.ghost:hover{background:var(--paper);border-color:var(--ink-faint);box-shadow:var(--shadow-sm)}
.btn.sage{background:var(--sage)}
.btn.sage:hover{background:var(--sage-dark)}
.btn.sm{padding:7px 13px;font-size:13px;border-radius:8px}

.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}

.badge{
  display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:30px;
  font-size:12px;font-weight:600;line-height:1;white-space:nowrap;
}
.badge .dot{width:7px;height:7px;border-radius:50%;background:currentColor}
.badge.ok{background:var(--ok-tint);color:var(--ok)}
.badge.late{background:var(--late-tint);color:var(--late)}
.badge.work{background:var(--sage-tint);color:var(--sage-dark)}
.badge.off{background:var(--cream-2);color:var(--ink-faint)}
.badge.gold{background:var(--gold-tint);color:#A8761A}

/* position pill */
.pos{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;color:var(--ink-soft)}
.pos .pdot{width:9px;height:9px;border-radius:3px;flex:none}

/* stat tiles */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:26px}
.stat{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow-sm)}
.stat .k{font-size:12px;font-weight:600;color:var(--ink-faint);letter-spacing:.04em;text-transform:uppercase;display:flex;align-items:center;gap:7px}
.stat .k svg{width:15px;height:15px;stroke-width:1.9}
.stat .v{font-family:var(--serif);font-size:34px;font-weight:700;margin-top:8px;line-height:1}
.stat .v small{font-size:16px;color:var(--ink-faint);font-weight:600}
.stat .meta{font-size:12.5px;color:var(--ink-soft);margin-top:4px}

/* table */
.table{width:100%;border-collapse:collapse}
.table th{
  text-align:left;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--ink-faint);padding:0 16px 11px;border-bottom:1px solid var(--line);
}
.table td{padding:13px 16px;border-bottom:1px solid var(--line-soft);font-size:14px;vertical-align:middle}
.table tr:last-child td{border-bottom:none}
.table tbody tr{transition:background .12s}
.table tbody tr.clickable{cursor:pointer}
.table tbody tr.clickable:hover{background:var(--cream)}
.cell-name{display:flex;align-items:center;gap:12px}
.cell-name .avatar{width:38px;height:38px;font-size:14px}
.cell-name b{font-weight:600}

.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:15px}
.section-head h2{font-size:20px}
.section-head .eyebrow{margin-bottom:4px}

/* segmented control */
.seg{display:inline-flex;background:var(--cream-2);border:1px solid var(--line);border-radius:10px;padding:3px;gap:2px}
.seg button{padding:7px 14px;border-radius:7px;font-size:13px;font-weight:600;color:var(--ink-soft);transition:.13s}
.seg button.on{background:var(--paper);color:var(--ink);box-shadow:var(--shadow-sm)}

/* clock display */
.tnum{font-variant-numeric:tabular-nums}

/* scrollbar */
::-webkit-scrollbar{width:11px;height:11px}
::-webkit-scrollbar-thumb{background:#d8d3c8;border-radius:20px;border:3px solid var(--cream)}
::-webkit-scrollbar-thumb:hover{background:#c4bdae}

/* empty / faint */
.muted{color:var(--ink-soft)}
.faint{color:var(--ink-faint)}

/* divider */
.hr{height:1px;background:var(--line);border:none;margin:22px 0}

/* icon button */
.icon-btn{width:34px;height:34px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;color:var(--ink-soft);border:1px solid var(--line);transition:.13s}
.icon-btn:hover{background:var(--orange-tint);color:var(--orange);border-color:var(--orange)}

/* employee-view banner */
.me-hero{display:flex;align-items:center;gap:20px;padding:24px 26px;background:linear-gradient(100deg,#fff,var(--sage-tint));margin-bottom:24px}
.me-hero .now{margin-left:auto;text-align:right}
.me-hero .now .t{font-family:var(--serif);font-size:38px;font-weight:700;line-height:1}
.me-hero .now .d{font-size:13px;color:var(--ink-soft)}
.me-status{display:inline-flex;align-items:center;gap:9px;padding:14px 20px;border-radius:12px;font-weight:600;font-size:15px}
.me-status.in{background:var(--sage-tint);color:var(--sage-dark)}
.me-status.out{background:var(--cream-2);color:var(--ink-soft)}
.me-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:22px;margin-bottom:24px;align-items:start}

/* ===========================================================
   Responzívnosť
   =========================================================== */
@media (max-width:1180px){
  .content{max-width:none}
}
@media (max-width:1024px){
  .topbar{padding:0 26px}
  .content{padding:28px 26px 56px}
  .stats{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:900px){
  /* sidebar → vysúvací drawer */
  .app{display:block}
  .hamburger{display:inline-flex}
  .sidebar{
    position:fixed;left:0;top:0;height:100vh;width:280px;max-width:84vw;z-index:60;
    transform:translateX(-100%);transition:transform .26s cubic-bezier(.4,0,.2,1);
    box-shadow:none;
  }
  .sidebar.open{transform:none;box-shadow:var(--shadow-lg)}
  .nav-backdrop{display:block;position:fixed;inset:0;background:rgba(28,27,25,.42);z-index:55;backdrop-filter:blur(2px)}
  body:has(.nav-backdrop){overflow:hidden}
  .main{min-height:100vh}
  .topbar{height:64px;padding:0 18px;gap:12px}
  .topbar-title{flex:1 1 auto;min-width:0}
  .topbar-title h1{overflow:hidden;text-overflow:ellipsis}
  .topbar h1{font-size:21px}
  .topbar .sub{font-size:12.5px}
  .content{padding:22px 18px 54px}
  .stats.stats-5{grid-template-columns:repeat(3,1fr)}
  .me-grid{grid-template-columns:1fr}
  .content .card{overflow-x:auto}
  /* PDF */
  .print-overlay{padding:16px 10px 40px}
  .print-doc{padding:32px 26px}
  .pd-info{grid-template-columns:repeat(2,1fr)}
  .pd-grid2{grid-template-columns:1fr;gap:18px}
}
@media (max-width:680px){
  .topbar{padding:0 14px;gap:8px}
  .topbar h1{font-size:18px}
  .content{padding:18px 14px 48px}
  .stats,.stats.stats-5{grid-template-columns:repeat(2,1fr);gap:12px}
  .stat{padding:15px 16px}
  .stat .v{font-size:28px}
  .section-head{flex-direction:column;align-items:stretch;gap:12px}
  .section-head > div:first-child{min-width:0}
  .seg{overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch}
  .seg button{white-space:nowrap}
  .section-head > div{flex-wrap:wrap}
  .search{width:100%}
  /* emp hero stack */
  .emp-hero{flex-wrap:wrap;gap:16px;padding:20px}
  .emp-hero-main{flex-basis:100%;order:3}
  .emp-hero .btn{margin-left:auto}
  /* me hero */
  .me-hero{flex-wrap:wrap;padding:20px}
  .me-hero .now{margin-left:auto}
  /* tables tighter */
  .table td{padding:11px 12px;font-size:13.5px}
  .table th{padding:0 12px 10px}
  .cell-name{gap:9px}
  /* PDF */
  .print-doc{padding:24px 18px}
  .pd-head{flex-direction:column;gap:10px}
  .pd-meta{text-align:left}
  .print-bar{flex-wrap:wrap;gap:8px}
  .print-bar .pb-title{font-size:13.5px;flex-basis:100%;order:-1}
}
@media (max-width:460px){
  .stats,.stats.stats-5{grid-template-columns:1fr}
  .topbar .btn-label{display:none}
  .topbar .btn{padding:9px 11px}
  .me-hero .now{margin-left:0;flex-basis:100%;text-align:left}
  .me-hero .now .t{font-size:32px}
  .pd-info{grid-template-columns:1fr}
  .emp-hero .btn{width:100%;margin-left:0}
}
