/* ====== INYENC KREDENC - design system ====== */
:root{
  --bg-1:#f7f4ef;
  --bg-2:#ffffff;
  --ink-1:#1a1f36;
  --ink-2:#4a5072;
  --ink-3:#7a809a;
  --line:#e7e5df;
  --brand:#ff6b6b;
  --brand-2:#ffa15c;
  --accent:#4dd0c1;
  --accent-2:#7c5cff;
  --good:#19c37d;
  --bad:#e53e3e;
  --warn:#f6ad55;
  --radius:16px;
  --radius-sm:10px;
  --shadow:0 12px 40px rgba(20,30,60,.08), 0 2px 6px rgba(20,30,60,.04);
  --shadow-sm:0 4px 14px rgba(20,30,60,.08);
  --t:200ms cubic-bezier(.2,.7,.2,1);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  min-height:100vh;
  font-family:system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  font-size:16px;
  color:var(--ink-1);
  background:
    radial-gradient(1200px 600px at 90% -10%, rgba(124,92,255,.10), transparent 60%),
    radial-gradient(900px 600px at -10% 110%, rgba(77,208,193,.12), transparent 60%),
    linear-gradient(180deg,#fbf8f3 0%, #f5f2ec 100%);
  background-attachment:fixed;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--accent-2);text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:920px;margin:0 auto;padding:32px 22px 80px}
.container-wide{max-width:1100px;margin:0 auto;padding:32px 22px 80px}
header.brand{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:28px;
}
.brand-logo{
  display:inline-flex;align-items:center;gap:12px;
  font-weight:700;letter-spacing:.2px;
}
.brand-logo .dot{
  width:32px;height:32px;border-radius:10px;
  background:linear-gradient(135deg,var(--brand),var(--brand-2));
  box-shadow:0 8px 22px rgba(255,107,107,.35);
}
.brand-logo .name{font-size:18px;color:var(--ink-1)}
.brand-logo .name small{display:block;color:var(--ink-3);font-weight:400;font-size:12px;letter-spacing:.3px;text-transform:uppercase}

.card{
  background:var(--bg-2);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:28px;
}
.card + .card{margin-top:18px}
.card h1,.card h2,.card h3{margin:0 0 14px}
h1{font-size:28px;letter-spacing:-.01em}
h2{font-size:22px;letter-spacing:-.005em}
h3{font-size:18px}

.subtitle{color:var(--ink-2);margin-top:-8px;margin-bottom:18px}

.field{display:block;margin:14px 0}
.field label{display:block;font-weight:600;color:var(--ink-2);margin-bottom:6px;font-size:14px}
.hint{display:block;color:var(--ink-3);font-size:13px;margin-top:6px}
.input,.textarea,select{
  width:100%;padding:12px 14px;
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  background:#fff;
  color:var(--ink-1);
  font:inherit;
  transition:border-color var(--t), box-shadow var(--t);
}
.input:focus,.textarea:focus,select:focus{
  outline:0;border-color:var(--accent-2);
  box-shadow:0 0 0 4px rgba(124,92,255,.15);
}
.textarea{min-height:96px;resize:vertical}

.checkbox{
  display:flex;align-items:flex-start;gap:10px;
  padding:14px;border:1px dashed var(--line);border-radius:var(--radius-sm);
  background:#fafaf7;
}
.checkbox input{margin-top:3px;width:18px;height:18px;accent-color:var(--accent-2)}
.checkbox label{font-weight:500;color:var(--ink-2)}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 20px;border:0;border-radius:999px;
  background:linear-gradient(135deg,var(--accent-2),var(--brand));
  color:#fff;font-weight:600;cursor:pointer;
  box-shadow:0 10px 24px rgba(124,92,255,.25);
  transition:transform var(--t), box-shadow var(--t), filter var(--t);
}
.btn:hover{transform:translateY(-1px);box-shadow:0 14px 30px rgba(124,92,255,.32)}
.btn:active{transform:translateY(0)}
.btn.secondary{
  background:#fff;color:var(--ink-1);
  border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
}
.btn.secondary:hover{filter:brightness(.99)}
.btn.danger{background:linear-gradient(135deg,#ff7a7a,#e53e3e);box-shadow:0 10px 24px rgba(229,62,62,.25)}
.btn.ghost{background:transparent;color:var(--ink-2);box-shadow:none}
.btn.ghost:hover{background:rgba(0,0,0,.04)}
.btn.small{padding:8px 14px;font-size:14px}

.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.row.between{justify-content:space-between}

.alert{
  padding:12px 14px;border-radius:var(--radius-sm);
  border:1px solid;font-size:14px;margin-bottom:14px;
}
.alert.error{background:#fff5f5;border-color:#feb2b2;color:#9b2c2c}
.alert.info{background:#eef9ff;border-color:#9adcff;color:#0b6aa2}
.alert.ok{background:#effaf3;border-color:#9ae6b4;color:#1f7a4d}

.menu-desc{
  white-space:pre-wrap;
  padding:18px;border-radius:var(--radius-sm);
  background:linear-gradient(135deg,rgba(77,208,193,.10),rgba(124,92,255,.08));
  border:1px solid var(--line);
  color:var(--ink-1);font-size:16px;
}
.menu-day{
  display:inline-flex;align-items:center;gap:8px;
  font-weight:600;color:var(--ink-2);margin-bottom:10px;
}
.menu-day .pill{
  background:#fff;border:1px solid var(--line);
  padding:4px 10px;border-radius:999px;font-size:13px;
}

.thanks{
  text-align:center;padding:48px 20px;
}
.thanks .emoji{font-size:48px}
.thanks h2{font-size:30px;margin:10px 0}
.thanks p{color:var(--ink-2)}

/* Tables */
.table{
  width:100%;border-collapse:separate;border-spacing:0;
  background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
}
.table th,.table td{
  text-align:left;padding:12px 14px;border-bottom:1px solid var(--line);
  font-size:14px;
}
.table thead th{
  background:#fafaf7;color:var(--ink-2);font-weight:700;font-size:13px;
  text-transform:uppercase;letter-spacing:.04em;
}
.table tbody tr:last-child td{border-bottom:0}
.table tbody tr.clickable{cursor:pointer}
.table tbody tr.clickable:hover{background:#fbf9f4}

.tag{
  display:inline-block;padding:3px 9px;border-radius:999px;
  font-size:12px;font-weight:600;
}
.tag.past{background:#f1f1ee;color:#7a809a}
.tag.future{background:rgba(77,208,193,.18);color:#0e7a6e}
.tag.today{background:rgba(255,161,92,.22);color:#a35112}

/* Nav (admin) */
.nav{
  display:flex;gap:6px;margin-bottom:18px;flex-wrap:wrap;
  background:#fff;border:1px solid var(--line);border-radius:999px;
  padding:6px;box-shadow:var(--shadow-sm);
  width:fit-content;
}
.nav a{
  padding:9px 16px;border-radius:999px;color:var(--ink-2);font-weight:600;font-size:14px;
}
.nav a:hover{background:#faf8f3;text-decoration:none}
.nav a.active{background:linear-gradient(135deg,var(--accent-2),var(--brand));color:#fff;box-shadow:0 6px 16px rgba(124,92,255,.25)}

/* Modal */
.modal-backdrop{
  position:fixed;inset:0;background:rgba(20,30,60,.45);
  display:flex;align-items:center;justify-content:center;z-index:50;
  animation:fade .2s ease;
}
.modal{
  background:#fff;border-radius:var(--radius);
  max-width:560px;width:calc(100% - 32px);
  padding:24px;box-shadow:0 30px 80px rgba(20,30,60,.25);
  animation:pop .25s cubic-bezier(.2,.7,.2,1);
}
.modal h3{margin-top:0}
.modal dl{margin:0;display:grid;grid-template-columns:140px 1fr;gap:8px 14px}
.modal dt{color:var(--ink-3);font-size:13px}
.modal dd{margin:0;color:var(--ink-1)}
.modal .row{justify-content:flex-end;margin-top:16px}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes pop{from{transform:scale(.96);opacity:0}to{transform:scale(1);opacity:1}}

.footer-note{margin-top:24px;color:var(--ink-3);font-size:13px;text-align:center}

/* Login compact */
.login-wrap{max-width:460px;margin:60px auto 0}
.login-wrap .card{padding:30px}
.login-wrap h1{margin-bottom:6px}
.login-wrap .subtitle{margin-bottom:18px}

@media (max-width:560px){
  .container,.container-wide{padding:18px 14px 60px}
  .table th,.table td{padding:10px 10px;font-size:13px}
  .modal dl{grid-template-columns:1fr}
}
