/* =========================================================================
   Narzędzia hydrauliczne h.t8.pl — wspólny arkusz stylów (design system)
   Estetyka: "engineering paper" — ciepły papier techniczny, miedź + woda-teal.
   Jeden arkusz dla wszystkich kalkulatorów. Słownik klas zgodny z oryginałem
   (JS kalkulatorów wstrzykuje te klasy — nie zmieniamy ich nazw, tylko wygląd).
   Fonty: Familjen Grotesk (UI/nagłówki) + DM Mono (odczyty, liczby, etykiety).
   ========================================================================= */

:root{
  /* powierzchnie */
  --paper:#f3efe6;        /* tło — ciepły papier */
  --panel:#fbf9f4;        /* karty */
  --panel-2:#f6f2e9;      /* sekcje wtórne / nagłówki tabel */
  --line:#e2dac9;         /* cienka linia */
  --line-2:#d3c9b4;       /* mocniejsza linia */
  --ink:#211d17;          /* tekst główny */
  --muted:#7a7263;        /* tekst drugorzędny */

  /* marka */
  --copper:#b0562a;       /* MIEDŹ — kolor akcji (rury) */
  --copper-d:#90431f;     /* miedź ciemna (hover) */
  --teal:#0c6b62;         /* WODA — warstwa danych / wyniki */
  --teal-d:#085049;

  /* status */
  --ok:#1f7a4d;
  --warn:#a86a12;
  --bad:#b3402e;
  --gas:#2c5fa8;          /* gaz (porównania) */
  --hp:#0c6b62;           /* pompa ciepła */

  /* aliasy zgodności ze starym słownikiem zmiennych (JS/inline) */
  --bg:var(--paper);
  --card:var(--panel);
  --txt:var(--ink);
  --accent:var(--teal);
  --inp:#fffdf8;

  --radius:12px;
  --shadow:0 1px 2px rgba(45,35,20,.05), 0 6px 18px -10px rgba(45,35,20,.25);
  --mono:'DM Mono', ui-monospace, 'SFMono-Regular', Menlo, Consolas, monospace;
  --ui:'Familjen Grotesk', ui-sans-serif, system-ui, 'Segoe UI', Arial, sans-serif;
}

*{box-sizing:border-box}

html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--ui);
  background:var(--paper);
  /* delikatna siatka milimetrowa — papier techniczny */
  background-image:
    linear-gradient(rgba(176,86,42,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(176,86,42,.035) 1px, transparent 1px);
  background-size:22px 22px;
  background-position:-1px -1px;
  color:var(--ink);
  font-size:15.5px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}

a{color:var(--copper);text-decoration:none}
a:hover{color:var(--copper-d);text-decoration:underline;text-underline-offset:2px}

/* ---- górny pasek nawigacji (spójny na każdej stronie) ---------------- */
.topbar{
  position:sticky;top:0;z-index:20;
  background:rgba(243,239,230,.86);
  backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--line-2);
}
.topbar .bar{
  max-width:1000px;margin:0 auto;padding:9px 16px;
  display:flex;align-items:center;gap:14px;
}
.brand{display:inline-flex;align-items:center;gap:9px;font-weight:700;color:var(--ink);letter-spacing:-.01em}
.brand:hover{text-decoration:none;color:var(--ink)}
.brand .mark{
  width:26px;height:26px;border-radius:7px;flex:none;
  display:grid;place-items:center;
  background:var(--copper);color:#fff;
  font-family:var(--mono);font-weight:500;font-size:13px;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.18);
}
.brand b{font-weight:700}
.brand .sub{font:500 11px/1 var(--mono);color:var(--muted);letter-spacing:.04em;text-transform:uppercase}
.topbar .spacer{flex:1}
.back{
  font:500 12.5px/1 var(--mono);color:var(--muted);
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 10px;border-radius:8px;border:1px solid transparent;
}
.back:hover{color:var(--copper);border-color:var(--line-2);text-decoration:none;background:var(--panel)}
.back svg{width:14px;height:14px}

/* ---- nagłówek strony narzędzia --------------------------------------- */
header.tool-head{
  max-width:1000px;margin:0 auto;padding:30px 16px 8px;
}
.eyebrow{
  font:500 11.5px/1 var(--mono);letter-spacing:.12em;text-transform:uppercase;
  color:var(--copper);display:flex;align-items:center;gap:10px;margin-bottom:12px;
}
.eyebrow .num{
  display:inline-grid;place-items:center;min-width:24px;height:20px;padding:0 6px;
  background:var(--copper);color:#fff;border-radius:5px;font-size:11px;
}
.eyebrow .cat{color:var(--muted)}
header.tool-head h1{
  margin:0;font-weight:700;letter-spacing:-.02em;line-height:1.08;
  font-size:clamp(26px,4.6vw,38px);color:var(--ink);
}
.lead{
  margin:14px 0 0;max-width:62ch;font-size:16.5px;line-height:1.55;color:#43403a;
}
.method{
  margin:16px 0 0;max-width:64ch;padding:11px 14px;
  border-left:3px solid var(--teal);background:var(--panel);border-radius:0 8px 8px 0;
  font-size:13.5px;color:var(--muted);
}
.method b{color:var(--teal-d);font-weight:700}

/* ---- kontener treści (= stary .wrap) --------------------------------- */
.wrap{max-width:1000px;margin:0 auto;padding:16px}

/* ---- karty (= stary .card) ------------------------------------------- */
.card{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px;margin:16px 0;box-shadow:var(--shadow);
}
.card h2{
  margin:0 0 14px;font-size:13px;font-weight:600;color:var(--copper);
  font-family:var(--mono);letter-spacing:.04em;text-transform:uppercase;
  display:flex;align-items:center;gap:8px;
}
.card h2::before{content:"";width:14px;height:2px;background:var(--copper);border-radius:2px;flex:none}
.card > h2:first-child{margin-top:0}

/* etykiety i pola */
label{display:block;font:500 11.5px/1.3 var(--mono);color:var(--muted);margin-bottom:5px;letter-spacing:.01em}
input,select,textarea{
  width:100%;padding:10px 12px;background:var(--inp);
  border:1px solid var(--line-2);border-radius:9px;color:var(--ink);
  font-size:15px;font-family:var(--ui);transition:border-color .15s, box-shadow .15s;
}
input[type=number]{font-family:var(--mono)}
input:focus,select:focus,textarea:focus{
  outline:none;border-color:var(--copper);
  box-shadow:0 0 0 3px rgba(176,86,42,.14);
}
input[type=checkbox]{width:auto;accent-color:var(--copper)}
select{appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%237a7263' stroke-width='2.4' stroke-linecap='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 11px center;padding-right:30px}

/* siatki (zachowane proporcje z oryginału) */
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}
.grid3{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px}
.rooms-head,.room{display:grid;grid-template-columns:1.6fr .9fr 40px;gap:8px;align-items:end}
.rooms-head{font:500 10.5px/1.2 var(--mono);color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}
.room{margin-bottom:8px}
.comp{display:grid;grid-template-columns:28px 1.4fr .8fr;gap:8px;align-items:center;margin-bottom:8px}
.comp input[type=checkbox]{width:20px;height:20px}
.line{display:grid;grid-template-columns:1.5fr .8fr .8fr;gap:8px;align-items:end;margin-bottom:8px}
.ck{display:flex;align-items:center;gap:8px;margin-top:8px}
.ck input{width:20px;height:20px}

/* ---- przyciski ------------------------------------------------------- */
button{
  cursor:pointer;border:0;border-radius:9px;font-family:var(--ui);
  font-size:14.5px;font-weight:600;padding:11px 16px;transition:transform .06s, filter .15s, background .15s;
}
button:active{transform:translateY(1px)}
.btn-calc{
  background:var(--copper);color:#fff;width:100%;font-size:16px;padding:14px;
  letter-spacing:.02em;box-shadow:0 2px 0 var(--copper-d);
}
.btn-calc:hover{background:var(--copper-d)}
.btn-add{background:var(--teal);color:#fff;width:100%}
.btn-add:hover{background:var(--teal-d)}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line-2);font-weight:600;padding:10px 14px}
.btn-ghost:hover{background:var(--panel-2);border-color:var(--muted)}
.btn-del{background:transparent;color:var(--bad);border:1px solid var(--line-2);padding:9px 0;font-size:18px;line-height:1}
.btn-del:hover{background:rgba(179,64,46,.08);border-color:var(--bad)}
.row2{display:flex;gap:12px;flex-wrap:wrap;margin-top:12px}
.row2>button{flex:1;min-width:130px}

/* ---- wynik / odczyt instrumentu (= .big) ----------------------------- */
.big{
  font-family:var(--mono);font-size:34px;font-weight:500;color:var(--teal-d);
  letter-spacing:-.01em;line-height:1.1;
}
.bad{color:var(--bad)}

/* skrzynki informacyjne */
.box{background:var(--panel-2);border:1px solid var(--line);border-radius:10px;padding:14px;margin-top:12px}
.warn{
  background:rgba(168,106,18,.08);border:1px solid rgba(168,106,18,.35);
  border-left:3px solid var(--warn);border-radius:8px;padding:12px 14px;margin-top:12px;font-size:13.5px;color:#6b5212;
}
.diag{
  background:rgba(12,107,98,.07);border:1px solid rgba(12,107,98,.28);
  border-left:3px solid var(--teal);border-radius:8px;padding:12px 14px;margin-top:12px;font-size:13.5px;color:var(--teal-d);
}
.eko{
  background:rgba(31,122,77,.08);border:1px solid rgba(31,122,77,.3);
  border-left:3px solid var(--ok);border-radius:8px;padding:13px 14px;margin-top:12px;color:#185c3a;
}

/* werdykt / rekomendacja (= .rec .risk .winner) */
.rec,.risk,.winner{
  padding:14px;border-radius:10px;text-align:center;font-weight:700;font-size:18px;margin:10px 0;
  background:var(--panel-2);color:var(--teal-d);border:1px solid var(--line-2);
}
.r-low{background:rgba(31,122,77,.12);color:var(--ok);border-color:rgba(31,122,77,.3)}
.r-mid{background:rgba(168,106,18,.12);color:var(--warn);border-color:rgba(168,106,18,.3)}
.r-high{background:rgba(179,64,46,.12);color:var(--bad);border-color:rgba(179,64,46,.3)}
.r-crit{background:var(--bad);color:#fff;border-color:var(--bad)}
.w-gas{background:rgba(44,95,168,.12);color:var(--gas);border-color:rgba(44,95,168,.3)}
.w-hp{background:rgba(12,107,98,.12);color:var(--hp);border-color:rgba(12,107,98,.3)}
.h-gas{color:var(--gas)}
.h-hp{color:var(--hp)}

/* ---- tabele ---------------------------------------------------------- */
table{width:100%;border-collapse:collapse;font-size:13.5px;margin-top:10px}
th,td{border:1px solid var(--line);padding:8px 10px;text-align:left}
th{
  background:var(--panel-2);color:var(--muted);font-weight:600;
  font:600 11px/1.3 var(--mono);text-transform:uppercase;letter-spacing:.03em;
}
td.r,th.r{text-align:right;font-variant-numeric:tabular-nums}
td{font-variant-numeric:tabular-nums}
.sum{font-weight:700;background:var(--panel-2)}
.grp{font-weight:700;background:#efe7d6;color:var(--copper)}
.hl{background:rgba(12,107,98,.12)}
.cat input{padding:5px 7px;font-size:13px;text-align:right;font-family:var(--mono)}

/* ---- znaczniki / tagi ------------------------------------------------ */
.tag{display:inline-block;padding:2px 9px;border-radius:20px;font:600 11px/1.5 var(--mono);letter-spacing:.02em}
.t-ok{background:rgba(31,122,77,.14);color:var(--ok)}
.t-warn{background:rgba(168,106,18,.16);color:var(--warn)}
.t-bad{background:rgba(179,64,46,.14);color:var(--bad)}

/* ---- chipy (lista kodów / skróty) ------------------------------------ */
.list{display:flex;flex-wrap:wrap;gap:7px;margin-top:10px}
.chip{
  background:var(--panel);border:1px solid var(--line-2);border-radius:8px;
  padding:6px 11px;cursor:pointer;font:600 13px/1 var(--mono);color:var(--copper);transition:.12s;
}
.chip:hover{background:var(--copper);color:#fff;border-color:var(--copper)}

/* ---- kody błędów ----------------------------------------------------- */
.code{font-family:var(--mono);font-size:24px;font-weight:500;color:var(--copper);letter-spacing:.01em}
.name{font-size:17px;font-weight:700;margin:4px 0 10px;color:var(--ink)}
h3{font:600 11px/1.3 var(--mono);color:var(--muted);margin:14px 0 5px;text-transform:uppercase;letter-spacing:.05em}
ul{margin:6px 0;padding-left:20px}
li{margin-bottom:6px}
.fix li{color:var(--ok)}

/* ---- typografia pomocnicza ------------------------------------------- */
.muted{color:var(--muted);font-size:12.5px;margin-top:8px}
.note{font-size:12.5px;color:var(--muted);margin-top:10px;line-height:1.5}
details{margin-top:10px}
summary{cursor:pointer;color:var(--copper);font:600 13px/1.4 var(--mono)}
summary:hover{color:var(--copper-d)}

/* ---- stopka (spójna) ------------------------------------------------- */
footer.tool-foot{
  max-width:1000px;margin:24px auto 0;padding:22px 16px 40px;
  border-top:1px solid var(--line-2);
  display:flex;flex-wrap:wrap;gap:12px 20px;align-items:center;
  font:500 12.5px/1.5 var(--mono);color:var(--muted);
}
footer.tool-foot a{color:var(--muted)}
footer.tool-foot a:hover{color:var(--copper)}
footer.tool-foot .fbrand{color:var(--ink);font-weight:700}
footer.tool-foot .fspace{flex:1}
footer.tool-foot .all-tools{
  display:inline-flex;align-items:center;gap:7px;color:var(--copper);
  padding:7px 12px;border:1px solid var(--line-2);border-radius:8px;
}
footer.tool-foot .all-tools:hover{background:var(--panel);border-color:var(--copper);text-decoration:none}

/* ---- druk ------------------------------------------------------------ */
@media print{
  body{background:#fff;color:#000;background-image:none;font-size:12px}
  .topbar,.no-print,footer.tool-foot,.method{display:none}
  header.tool-head{padding:0 0 8px}
  header.tool-head h1{font-size:20px}
  .card{border:1px solid #999;background:#fff;box-shadow:none;break-inside:avoid}
  .card h2{color:#000}
  th{background:#eee;color:#000}
  .grp{background:#ddd;color:#000}
  .big{color:#000}
  .t-ok{color:#0a0}.t-warn{color:#a60}.t-bad{color:#c00}.fix li{color:#060}
  .hl{background:#e6f2f0}
  a{color:#000;text-decoration:none}
}

/* ---- responsywność --------------------------------------------------- */
@media (max-width:560px){
  body{font-size:15px}
  .card{padding:14px}
  header.tool-head{padding-top:22px}
  .brand .sub{display:none}
}
