/* style.css — "industrial dashboard" dla A&K MODLAN
   Kierunek: utylitarny, czytelny w terenie. Granat + bursztyn + status-kolory.
   Font: IBM Plex Sans (techniczny, czytelny) + IBM Plex Mono na liczby. */
@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@400;500;600;700&family=IBM+Plex+Mono:wght@500;600&display=swap');

:root{
  --granat:#0f2747; --granat-2:#16365f; --tlo:#eef1f5; --karta:#ffffff;
  --bursztyn:#e8911a; --tekst:#15233b; --maly:#6b7a90; --linia:#dde3ec;
  --zielony:#1f9d57; --zolty:#e8a91a; --czerwony:#d8453b; --szary:#9aa7b8;
}
*{box-sizing:border-box; margin:0; padding:0;}
body{
  font-family:'IBM Plex Sans',system-ui,sans-serif;
  background:var(--tlo); color:var(--tekst);
  max-width:680px; margin:0 auto; padding:0 0 40px;
  -webkit-font-smoothing:antialiased;
}
.mono{font-family:'IBM Plex Mono',monospace;}

/* Górny pasek — granatowy, sticky */
.topbar{
  background:var(--granat); color:#fff; padding:14px 18px;
  display:flex; justify-content:space-between; align-items:center;
  position:sticky; top:0; z-index:10;
}
.topbar .marka{font-weight:700; letter-spacing:.5px; font-size:15px;}
.topbar .marka small{display:block; font-weight:400; font-size:11px; color:#9db4d4; letter-spacing:1px;}
.topbar a{color:#9db4d4; text-decoration:none; font-size:13px;}
.topbar a:hover{color:#fff;}

.wrap{padding:18px;}
h1{font-size:20px; font-weight:700; margin-bottom:4px;}
h2{font-size:14px; font-weight:600; text-transform:uppercase; letter-spacing:.8px; color:var(--maly); margin-bottom:10px;}
.maly{color:var(--maly); font-size:13px;}

/* Karty */
.karta{
  background:var(--karta); border-radius:12px; padding:16px;
  margin-bottom:12px; border:1px solid var(--linia);
  box-shadow:0 1px 2px rgba(15,39,71,.04);
}

/* Logowanie */
.login-box{margin-top:40px;}
.login-box h1{text-align:center; color:var(--granat); margin-bottom:6px;}
.login-sub{text-align:center; color:var(--maly); margin-bottom:24px; font-size:13px;}

/* Pola formularza — duże pod palec */
label{display:block; font-size:13px; font-weight:500; color:var(--maly); margin:12px 0 5px;}
input[type=text],input[type=number],input[type=password],input[type=date],select{
  width:100%; padding:13px 14px; font-size:16px; font-family:inherit;
  border:1.5px solid var(--linia); border-radius:9px; background:#fbfcfe; color:var(--tekst);
}
input:focus,select:focus{outline:none; border-color:var(--granat-2); background:#fff;}
button{
  width:100%; padding:15px; font-size:16px; font-weight:600; font-family:inherit;
  background:var(--granat); color:#fff; border:none; border-radius:10px;
  cursor:pointer; margin-top:16px; transition:background .15s;
}
button:hover{background:var(--granat-2);} button:active{transform:translateY(1px);}

/* Wiersz kategorii w formularzu wpisu */
.kat-wiersz{
  display:flex; align-items:center; gap:12px; padding:10px 0;
  border-bottom:1px solid var(--linia);
}
.kat-wiersz:last-child{border-bottom:none;}
.kat-wiersz label{flex:1; margin:0; color:var(--tekst); font-weight:500; font-size:15px;}
.kat-wiersz .jedn{color:var(--maly); font-weight:400; font-size:12px;}
.kat-wiersz input{width:88px; text-align:center; font-family:'IBM Plex Mono',monospace;}

/* Lista szkół — kafelki klikalne */
.szkola-link{text-decoration:none; color:inherit; display:block;}
.szkola-row{display:flex; justify-content:space-between; align-items:center; margin-bottom:10px;}
.szkola-row .nazwa{font-weight:600; font-size:15px;}
.szkola-row .rspo{font-family:'IBM Plex Mono',monospace; color:var(--maly); font-size:12px;}
.proc-duzy{font-family:'IBM Plex Mono',monospace; font-size:22px; font-weight:600;}

/* Pasek postępu */
.bar-tlo{background:var(--linia); border-radius:20px; height:10px; overflow:hidden;}
.bar-fill{height:100%; border-radius:20px; transition:width .4s ease;}
.bar-zielony{background:var(--zielony);} .bar-zolty{background:var(--zolty);}
.bar-czerwony{background:var(--czerwony);} .bar-szary{background:var(--szary);}
.bar-granat{background:var(--granat-2);}

/* Kropka semafora */
.kropka{display:inline-block; width:12px; height:12px; border-radius:50%; margin-right:7px; vertical-align:middle;}
.k-zielony{background:var(--zielony);} .k-zolty{background:var(--zolty);}
.k-czerwony{background:var(--czerwony);} .k-szary{background:var(--szary);}

/* Kategoria w drill-down */
.kat-postep{margin:12px 0;}
.kat-postep .gora{display:flex; justify-content:space-between; font-size:14px; margin-bottom:5px;}
.kat-postep .liczby{font-family:'IBM Plex Mono',monospace; color:var(--maly);}

/* Etapy — klikalne */
.etap{display:flex; align-items:center; gap:10px; padding:11px 0; border-bottom:1px solid var(--linia); font-size:14px;}
.etap:last-child{border-bottom:none;}
.etap-check{width:22px; height:22px; border-radius:6px; border:2px solid var(--linia); flex-shrink:0; display:flex; align-items:center; justify-content:center; cursor:pointer; background:#fff; font-size:14px;}
.etap-check.on{background:var(--zielony); border-color:var(--zielony); color:#fff;}
.etap.zrobiony{color:var(--maly);}
.etap-form{display:inline;}

/* Alerty */
.flash{background:#fff4dd; border:1px solid var(--bursztyn); color:#8a5a06; padding:12px 14px; border-radius:9px; margin-bottom:14px; font-size:14px;}
.blokada{background:#fdeae8; border:1px solid var(--czerwony); color:#9c2820; padding:12px 14px; border-radius:9px; margin:12px 0; font-size:14px; font-weight:500;}

/* Nagłówek szkoły z semaforem */
.szkola-head{background:var(--granat); color:#fff; margin:-18px -18px 16px; padding:20px 18px;}
.szkola-head h1{color:#fff; display:flex; align-items:center; gap:10px;}
.szkola-head .daty{color:#9db4d4; font-size:12px; margin-top:6px; font-family:'IBM Plex Mono',monospace;}
.szkola-head .proc-duzy{color:#fff;}

.opis-box{font-size:14px; line-height:1.55;}
.link-pw{display:inline-block; margin-top:8px; color:var(--granat-2); font-weight:600; text-decoration:none; font-size:14px;}

/* Stopka — na każdym ekranie */
.stopka{
  text-align:center; color:var(--maly); font-size:11px; letter-spacing:.8px;
  padding:20px 18px 8px; margin-top:8px; text-transform:uppercase;
  border-top:1px solid var(--linia);
}

/* Kalendarz miesięczny */
.kal-nav{display:flex; justify-content:space-between; align-items:center; margin-bottom:14px;}
.kal-nav a{background:var(--karta); border:1px solid var(--linia); border-radius:8px; padding:8px 14px; text-decoration:none; color:var(--granat); font-weight:600;}
.kal-nav .mc{font-weight:700; font-size:17px;}
.kal-grid{display:grid; grid-template-columns:repeat(7,1fr); gap:3px;}
.kal-naglowek{text-align:center; font-size:11px; font-weight:600; color:var(--maly); padding:4px 0; text-transform:uppercase;}
.kal-dzien{background:var(--karta); border:1px solid var(--linia); border-radius:6px; min-height:60px; padding:3px; font-size:11px;}
.kal-dzien.pusty{background:transparent; border:none;}
.kal-dzien.weekend{background:#f3f5f8;}
.kal-dzien.dzis{border:2px solid var(--bursztyn);}
.kal-numer{font-family:'IBM Plex Mono',monospace; color:var(--maly); font-size:10px; display:block; margin-bottom:2px;}
.kal-pasek{font-size:9px; color:#fff; border-radius:3px; padding:1px 3px; margin-bottom:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; line-height:1.4;}
.kal-pasek.zielony{background:var(--zielony);} .kal-pasek.zolty{background:var(--zolty);}
.kal-pasek.czerwony{background:var(--czerwony);} .kal-pasek.szary{background:var(--szary);}
.kal-legenda{margin-top:16px;}
.kal-legenda .poz{display:flex; align-items:center; gap:8px; padding:6px 0; font-size:13px;}
.nawigacja{display:flex; gap:8px; margin-bottom:16px;}
.nawigacja a{flex:1; text-align:center; background:var(--karta); border:1px solid var(--linia); border-radius:8px; padding:10px; text-decoration:none; color:var(--granat); font-weight:600; font-size:14px;}
.nawigacja a.aktywna{background:var(--granat); color:#fff;}
