:root{--bg:#f4f6fb;--panel:#fff;--text:#172033;--muted:#667085;--line:#e4e7ec;--brand:#153a6b;--red:#e30613;--green:#067647;--shadow:0 18px 50px rgba(23,32,51,.10);--radius:22px}
*{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:Inter,Segoe UI,Roboto,Arial,sans-serif;color:var(--text);background:radial-gradient(circle at top left,rgba(21,58,107,.15),transparent 35rem),radial-gradient(circle at top right,rgba(227,6,19,.11),transparent 30rem),var(--bg)}a{color:inherit}.hero{display:flex;gap:24px;align-items:center;justify-content:space-between;padding:32px clamp(18px,4vw,60px) 20px}.brandline{display:flex;align-items:center;gap:18px}.company-logo{width:155px;height:auto;object-fit:contain}.eyebrow{margin:0 0 8px;color:var(--red);font-weight:900;letter-spacing:.12em;text-transform:uppercase;font-size:12px}h1{margin:0;font-size:clamp(28px,4.5vw,52px);line-height:1}.subtitle{color:var(--muted);margin:10px 0 0;max-width:760px}.top-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:flex-end}.button,button{border:0;border-radius:12px;background:var(--brand);color:white;padding:11px 14px;font-weight:800;text-decoration:none;cursor:pointer}.button.secondary,button.secondary{background:white;color:var(--brand);border:1px solid var(--line)}.clock-card{background:white;border:1px solid var(--line);border-radius:20px;padding:14px 16px;box-shadow:0 8px 26px rgba(23,32,51,.06);min-width:230px}.clock-time{font-size:30px;font-weight:900}.clock-date{color:var(--muted);font-size:14px}.work-note{font-size:12px;color:var(--green);font-weight:800;margin-top:5px}.search{width:min(520px,calc(100% - 36px));margin:0 clamp(18px,4vw,60px) 18px}.search input{width:100%;border:1px solid var(--line);border-radius:999px;padding:15px 20px;font-size:16px;box-shadow:var(--shadow);outline:none}main{padding:0 clamp(18px,4vw,60px) 90px}.category{margin-top:34px}.category h2{font-size:22px;margin:0 0 16px}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:18px}.tile{aspect-ratio:1/1;display:flex;flex-direction:column;justify-content:space-between;gap:12px;background:rgba(255,255,255,.92);border:1px solid rgba(228,231,236,.95);border-radius:var(--radius);padding:18px;text-decoration:none;box-shadow:0 10px 30px rgba(23,32,51,.07);transition:.18s ease}.tile:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:rgba(227,6,19,.35)}.logo{width:60px;height:60px;border-radius:18px;background:#eef3f8;display:grid;place-items:center;overflow:hidden;font-size:28px}.logo img{width:100%;height:100%;object-fit:contain;padding:10px}.tile h3{margin:0;font-size:18px}.tile p{margin:7px 0 0;color:var(--muted);font-size:14px;line-height:1.35}.badge{align-self:flex-start;font-size:12px;color:var(--brand);background:#eaf2fb;padding:7px 10px;border-radius:999px;font-weight:800}.login-box,.admin-box{width:min(620px,calc(100% - 36px));margin:32px auto;background:white;border:1px solid var(--line);border-radius:24px;padding:26px;box-shadow:var(--shadow)}label{display:block;margin:13px 0 6px;font-weight:800}input,textarea,select{width:100%;border:1px solid var(--line);border-radius:12px;padding:12px;font:inherit;background:white}textarea{min-height:96px}.notice{background:#ecfdf3;color:#067647;padding:12px;border-radius:12px}.error{background:#fff1f3;color:#b42318;padding:12px;border-radius:12px}.table{width:100%;border-collapse:collapse;background:white;border-radius:18px;overflow:hidden;box-shadow:0 6px 22px rgba(23,32,51,.06)}.table th,.table td{padding:12px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}.admin-nav{display:flex;gap:10px;flex-wrap:wrap;margin:20px clamp(18px,4vw,60px)}.admin-nav a{text-decoration:none;background:white;border:1px solid var(--line);padding:10px 12px;border-radius:12px}.task-board{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px}.task-col{background:white;border:1px solid var(--line);border-radius:22px;padding:16px;box-shadow:0 8px 26px rgba(23,32,51,.06)}.task-card{border:1px solid var(--line);border-radius:16px;padding:13px;margin:10px 0;background:#fbfcff}.task-done{opacity:.64}.deadline{font-size:13px;font-weight:900;color:#b42318}.status{display:inline-block;padding:6px 9px;border-radius:999px;background:#fff1f3;color:#b42318;font-weight:900;font-size:12px}.status.done{background:#ecfdf3;color:#067647}.chat-button{position:fixed;right:24px;bottom:24px;width:58px;height:58px;border-radius:50%;background:var(--brand);font-size:24px;box-shadow:var(--shadow)}.chat-panel{position:fixed;right:24px;bottom:94px;width:min(430px,calc(100vw - 36px));height:560px;max-height:calc(100vh - 130px);display:none;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow);overflow:hidden}.chat-panel.open{display:flex}.chat-head{padding:16px 18px;background:var(--brand);color:white;display:flex;justify-content:space-between;align-items:center}.chat-head button{background:transparent;color:white;font-size:28px;padding:0}.chat-body{flex:1;padding:16px;overflow:auto;background:#f8fafc}.bot,.user{padding:11px 13px;border-radius:14px;margin:0 0 10px;line-height:1.35}.bot{background:white;border:1px solid var(--line)}.user{background:#dfeffc;margin-left:40px}.chat-form{display:flex;gap:8px;padding:12px;border-top:1px solid var(--line)}.chat-form input{flex:1}.chat-form button{background:var(--red)}@media(max-width:840px){.hero{flex-direction:column;align-items:flex-start}.brandline{align-items:flex-start}.company-logo{width:120px}.grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.tile{aspect-ratio:auto;min-height:190px}.clock-card{width:100%}}

.task-table-wrap{overflow:auto;background:white;border:1px solid var(--line);border-radius:22px;box-shadow:0 8px 26px rgba(23,32,51,.06)}
.task-table{width:100%;border-collapse:collapse;min-width:1050px}
.task-table th,.task-table td{border-bottom:1px solid var(--line);padding:11px;text-align:left;vertical-align:top}
.task-table th{background:#f8fafc;font-size:13px;text-transform:uppercase;letter-spacing:.04em}
.task-table textarea{min-height:70px;min-width:240px}
.task-table select{min-width:130px}
.priority{display:inline-block;padding:6px 9px;border-radius:999px;font-weight:900;font-size:12px}
.priority.niski{background:#ecfdf3;color:#067647}.priority.sredni{background:#fffaeb;color:#b54708}.priority.duzy{background:#fff1f3;color:#b42318}
.tabs{display:flex;gap:10px;flex-wrap:wrap;margin:0 0 18px}.tabs a{background:white;border:1px solid var(--line);border-radius:999px;padding:10px 14px;text-decoration:none;font-weight:800}.tabs a.active{background:var(--brand);color:white}
.save-state{font-size:12px;color:var(--muted);margin-top:5px}
.chat-hint{position:fixed;right:92px;bottom:35px;background:white;border:1px solid var(--line);border-radius:999px;padding:9px 12px;box-shadow:0 8px 26px rgba(23,32,51,.08);font-weight:800;color:var(--brand)}

.chat-tabs{display:flex;gap:8px;padding:10px;background:#f8fafc;border-bottom:1px solid var(--line)}
.chat-tabs button{flex:1;padding:9px 10px;background:white;color:var(--brand);border:1px solid var(--line)}
.chat-tabs button.active{background:var(--brand);color:white}
.chat-tools{display:flex;gap:6px;flex-wrap:wrap;padding:8px 12px;border-top:1px solid var(--line);background:#fff}
.chat-tools button,.chat-tools label{border:1px solid var(--line);background:#fff;color:var(--brand);border-radius:10px;padding:8px 10px;font-weight:800;cursor:pointer;font-size:12px}
.chat-tools input{display:none}


/* =========================================================
   FINAL HOTFIX: wygląd panelu + admin + czat + linki
   ========================================================= */

/* Nie pozwalamy, żeby tabele lub długie linki rozciągały całą stronę */
html, body {
  max-width: 100%;
  overflow-x: hidden;
}

main {
  max-width: 100%;
}

/* Panel główny kafelków zostaje normalny i elastyczny */
.grid {
  width: 100%;
}

/* Formularze admina */
.admin-box {
  max-width: 760px;
}

/* Zwykłe tabele admina mają mieścić się na ekranie */
.table {
  width: calc(100vw - 72px);
  max-width: 100%;
  table-layout: fixed;
}

.table th,
.table td {
  word-break: break-word;
  overflow-wrap: anywhere;
  white-space: normal;
}

/* Kolumna akcji ma być widoczna */
.table th:last-child,
.table td:last-child {
  width: 220px;
  min-width: 180px;
}

.table td:last-child form {
  margin-top: 6px;
}

/* Linki w tabelach łamią się zamiast rozszerzać ekran */
.table a,
.table td a {
  overflow-wrap: anywhere;
  word-break: break-all;
}

/* Tabela zadań ma prawo przewijać się tylko wewnątrz własnego kontenera */
.task-table-wrap {
  max-width: 100%;
  overflow-x: auto;
}

.task-table {
  min-width: 1050px;
}

/* Czat: szerszy, ale nie niszczy układu strony */
.chat-panel {
  width: min(560px, calc(100vw - 36px));
  height: min(720px, calc(100vh - 120px));
  min-width: 360px;
  min-height: 430px;
  resize: both;
  overflow: hidden;
}

.chat-body {
  overflow-y: auto;
  overflow-x: hidden;
}

.bot,
.user {
  max-width: 100%;
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.bot a {
  color: var(--brand);
  font-weight: 900;
  text-decoration: underline;
  overflow-wrap: anywhere;
  word-break: break-all;
}

.chat-tools {
  overflow-x: auto;
}

.chat-form input {
  min-width: 0;
}

@media (min-width: 1600px) {
  .chat-panel {
    width: 600px;
  }
}

@media (max-width: 900px) {
  .table {
    width: calc(100vw - 36px);
  }

  .table th:last-child,
  .table td:last-child {
    width: 170px;
  }

  .button,
  button {
    padding: 9px 11px;
  }
}

@media (max-width: 780px) {
  .chat-panel {
    right: 12px;
    left: 12px;
    bottom: 84px;
    width: auto;
    max-width: none;
    resize: none;
  }
}

/* =========================================================
   HOME BANNER: zdjęcie siedziby z lekką mgłą na stronie głównej
   ========================================================= */
.home-banner{
  position:relative;
  overflow:hidden;
  margin:0 0 6px;
  padding-bottom:26px;
  background-image:
    linear-gradient(90deg, rgba(244,246,251,.60) 0%, rgba(244,246,251,.60) 34%, rgba(244,246,251,.45) 68%, rgba(255,241,245,.45) 100%),
    linear-gradient(180deg, rgba(255,255,255,.72) 0%, rgba(255,255,255,.28) 46%, rgba(244,246,251,.88) 100%),
    url('/assets/home-banner.jpg');
  background-size:cover;
  background-position:center center;
  background-repeat:no-repeat;
  box-shadow:inset 0 -70px 90px rgba(244,246,251,.88);
}

.home-banner::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(circle at 18% 35%, rgba(255,255,255,.52), transparent 32rem),
    radial-gradient(circle at 76% 22%, rgba(255,255,255,.30), transparent 28rem);
}

.home-banner > *{
  position:relative;
  z-index:1;
}

.home-hero{
  padding-top:42px;
  padding-bottom:22px;
}

.home-search{
  margin-bottom:0;
}

.logo-home-link{
  display:inline-flex;
  align-items:center;
  text-decoration:none;
  border-radius:18px;
}

.logo-home-link:focus-visible{
  outline:3px solid rgba(21,58,107,.35);
  outline-offset:6px;
}

.home-banner .company-logo{
  filter:drop-shadow(0 10px 24px rgba(255,255,255,.55));
}

.home-banner .clock-card,
.home-banner .button.secondary{
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(8px);
}

@media(max-width:840px){
  .home-banner{
    padding-bottom:20px;
    background-position:center top;
  }
  .home-hero{
    padding-top:24px;
  }
}
/* =========================================================
   INSTRUKCJA - zdjęcia w adminie i w podglądzie instrukcji
   ========================================================= */

/* Miniatury zdjęć w panelu admina, żeby nie rozwalały edytora */
body img[src*="/assets/instruction_uploads/"],
body img[src*="/storage/supplier_instruction/"] {
  max-width: 240px !important;
  max-height: 160px !important;
  width: auto !important;
  height: auto !important;
  object-fit: contain !important;
  border-radius: 12px !important;
  border: 1px solid #d8e0ec !important;
  background: #f8fafc !important;
  padding: 6px !important;
  display: inline-block !important;
  margin: 8px 12px 8px 0 !important;
  vertical-align: middle !important;
}

/* Na stronie instrukcji zdjęcia mają być większe, ale nie gigantyczne */
.so-instruction-content img[src*="/assets/instruction_uploads/"],
.so-instruction-content img[src*="/storage/supplier_instruction/"],
.so-instruction-page img[src*="/assets/instruction_uploads/"],
.so-instruction-page img[src*="/storage/supplier_instruction/"] {
  max-width: min(100%, 900px) !important;
  max-height: 620px !important;
  width: auto !important;
  height: auto !important;
  object-fit: contain !important;
  display: block !important;
  margin: 14px auto !important;
  border-radius: 16px !important;
  border: 1px solid #d8e0ec !important;
  background: #f8fafc !important;
  padding: 8px !important;
}

/* Figure w instrukcji */
.so-instruction-content figure,
.so-instruction-page figure {
  max-width: 940px !important;
  margin: 22px auto !important;
  text-align: center !important;
}

/* Podpis pod zdjęciem */
.so-instruction-content figcaption,
.so-instruction-page figcaption {
  margin-top: 8px !important;
  color: #667085 !important;
  font-size: 14px !important;
  font-weight: 700 !important;
}