/* ============================================================
   Cloudbooster CRM — dizájnrendszer
   Tokenek: tinta-navy + papír + boost gradiens (cián→indigó)
   Tipó: Bricolage Grotesque (display) / Instrument Sans (body)
         / JetBrains Mono (domainek, dátumok, összegek)
   ============================================================ */
:root{
  --ink:#101A33; --ink-2:#1B2848; --ink-soft:#3D4A6B;
  --paper:#F6F8FB; --card:#FFFFFF; --line:#E3E8F0;
  --text:#1A2236; --muted:#5B6679;
  --boost-1:#06B6D4; --boost-2:#6366F1;
  --boost-grad:linear-gradient(120deg,#06B6D4,#6366F1);
  --ok:#16A34A; --ok-bg:#EAF7EE;
  --warn:#D97706; --warn-bg:#FDF3E3;
  --danger:#DC2626; --danger-bg:#FCEAEA;
  --info:#2563EB; --info-bg:#EAF0FD;
  --r:14px; --r-sm:9px;
  --shadow:0 1px 2px rgba(16,26,51,.05),0 8px 24px -12px rgba(16,26,51,.18);
  --font-display:"Bricolage Grotesque",system-ui,sans-serif;
  --font-body:"Instrument Sans",system-ui,sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,monospace;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--paper);color:var(--text);font:16px/1.55 var(--font-body)}
h1,h2,h3{font-family:var(--font-display);letter-spacing:-.015em;margin:0}
a{color:var(--boost-2)}
button{font:inherit;cursor:pointer}
input,select,textarea{font:inherit}
:focus-visible{outline:3px solid color-mix(in srgb,var(--boost-1) 55%,white);outline-offset:2px;border-radius:6px}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation:none!important;transition:none!important}}

.mono{font-family:var(--font-mono);font-size:.92em}
.muted{color:var(--muted)}
.hidden{display:none!important}

/* ---------- Gombok ---------- */
.btn{display:inline-flex;align-items:center;gap:.5rem;border:1px solid var(--line);background:var(--card);
  color:var(--text);border-radius:var(--r-sm);padding:.55rem .95rem;font-weight:600;transition:.15s}
.btn:hover{border-color:#C7D0DE;background:#FBFCFE}
.btn-primary{background:var(--boost-grad);color:#fff;border:none}
.btn-primary:hover{filter:brightness(1.07)}
.btn-danger{background:var(--danger-bg);color:var(--danger);border-color:#F3C8C8}
.btn-ghost{border-color:transparent;background:transparent;color:var(--muted)}
.btn-ghost:hover{background:#EEF1F7;color:var(--text)}
.btn-sm{padding:.32rem .65rem;font-size:.86rem}
.btn:disabled{opacity:.55;cursor:wait}

/* ---------- Kártyák, fejlécek ---------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow)}
.card-pad{padding:1.1rem 1.2rem}
.page-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1.1rem}
.page-head h1{font-size:1.45rem}
.eyebrow{font-size:.74rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--muted)}

/* ---------- Státusz jelvények ---------- */
.badge{display:inline-flex;align-items:center;gap:.35rem;font-size:.78rem;font-weight:700;
  padding:.18rem .6rem;border-radius:99px;white-space:nowrap}
.badge::before{content:"";width:.5rem;height:.5rem;border-radius:50%;background:currentColor}
.b-ok{background:var(--ok-bg);color:var(--ok)}
.b-warn{background:var(--warn-bg);color:var(--warn)}
.b-danger{background:var(--danger-bg);color:var(--danger)}
.b-info{background:var(--info-bg);color:var(--info)}
.b-mutedx{background:#EEF1F7;color:var(--muted)}

/* ---------- Lejárati gyűrű (szignatúra) ---------- */
.ring{position:relative;width:58px;height:58px;flex:none}
.ring svg{width:100%;height:100%;transform:rotate(-90deg)}
.ring circle{fill:none;stroke-width:5;stroke-linecap:round}
.ring .track{stroke:#E9EDF4}
.ring .bar{transition:stroke-dashoffset .6s ease}
.ring .days{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;line-height:1}
.ring .days b{font-family:var(--font-mono);font-size:.95rem}
.ring .days span{font-size:.58rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}

/* ---------- Űrlapok ---------- */
.field{margin-bottom:.9rem}
.field label{display:block;font-size:.84rem;font-weight:600;margin-bottom:.3rem;color:var(--ink-soft)}
.field input,.field select,.field textarea{width:100%;border:1px solid var(--line);border-radius:var(--r-sm);
  padding:.6rem .75rem;background:#fff;color:var(--text)}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--boost-1)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 1rem}
@media(max-width:560px){.form-grid{grid-template-columns:1fr}}

/* ---------- Táblázat → mobilon kártya ---------- */
.tbl{width:100%;border-collapse:collapse;font-size:.93rem}
.tbl th{font-size:.74rem;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);
  text-align:left;padding:.6rem .8rem;border-bottom:1px solid var(--line)}
.tbl td{padding:.7rem .8rem;border-bottom:1px solid var(--line);vertical-align:middle}
.tbl tbody tr:hover{background:#FAFBFE}
@media(max-width:760px){
  .tbl thead{display:none}
  .tbl, .tbl tbody, .tbl tr, .tbl td{display:block;width:100%}
  .tbl tr{border:1px solid var(--line);border-radius:var(--r-sm);margin-bottom:.7rem;background:#fff;padding:.4rem 0}
  .tbl td{border:none;padding:.32rem .9rem}
  .tbl td[data-l]::before{content:attr(data-l);display:block;font-size:.7rem;text-transform:uppercase;
    letter-spacing:.06em;color:var(--muted);font-weight:700}
}

/* ---------- Modal ---------- */
.modal-bg{position:fixed;inset:0;background:rgba(16,26,51,.45);display:flex;align-items:flex-end;
  justify-content:center;z-index:60;padding:0;backdrop-filter:blur(2px)}
.modal{background:#fff;border-radius:18px 18px 0 0;width:100%;max-width:640px;max-height:92dvh;
  overflow:auto;padding:1.3rem 1.3rem 1.6rem;animation:slideUp .22s ease}
@media(min-width:640px){.modal-bg{align-items:center;padding:1.5rem}.modal{border-radius:18px}}
@keyframes slideUp{from{transform:translateY(24px);opacity:.6}to{transform:none;opacity:1}}
.modal h2{font-size:1.18rem;margin-bottom:.9rem}
.modal-actions{display:flex;gap:.6rem;justify-content:flex-end;margin-top:1rem;flex-wrap:wrap}

/* ---------- Toast ---------- */
#toast{position:fixed;left:50%;bottom:max(1.2rem,env(safe-area-inset-bottom));transform:translateX(-50%) translateY(20px);
  background:var(--ink);color:#fff;padding:.7rem 1.2rem;border-radius:99px;font-weight:600;font-size:.92rem;
  opacity:0;pointer-events:none;transition:.25s;z-index:99;max-width:92vw;text-align:center}
#toast.show{opacity:1;transform:translateX(-50%)}
#toast.err{background:var(--danger)}

/* ---------- Üres állapot ---------- */
.empty{text-align:center;padding:2.4rem 1rem;color:var(--muted)}
.empty b{display:block;font-family:var(--font-display);font-size:1.05rem;color:var(--text);margin-bottom:.25rem}

/* ---------- KPI ---------- */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.8rem;margin-bottom:1.1rem}
.kpi{padding:.95rem 1.05rem}
.kpi .v{font-family:var(--font-mono);font-size:1.5rem;font-weight:700;line-height:1.15}
.kpi .l{font-size:.8rem;color:var(--muted);font-weight:600}
.kpi.alert .v{color:var(--danger)}
.kpi.warn .v{color:var(--warn)}

/* ---------- Radar (12 havi lejárati oszlopok) ---------- */
.radar{display:flex;align-items:flex-end;gap:6px;height:120px;padding-top:.4rem}
.radar .col{flex:1;display:flex;flex-direction:column;align-items:center;gap:.3rem;min-width:0}
.radar .bar{width:100%;max-width:34px;border-radius:6px 6px 2px 2px;background:var(--boost-grad);min-height:4px;position:relative}
.radar .bar .cnt{position:absolute;top:-1.25rem;left:50%;transform:translateX(-50%);font-family:var(--font-mono);font-size:.72rem;font-weight:700}
.radar .m{font-size:.66rem;color:var(--muted);font-family:var(--font-mono);white-space:nowrap}

/* ---------- Skeleton ---------- */
.skel{background:linear-gradient(90deg,#EDF0F6 25%,#F6F8FC 50%,#EDF0F6 75%);background-size:200% 100%;
  animation:sk 1.1s infinite;border-radius:8px;height:1em}
@keyframes sk{to{background-position:-200% 0}}
