/* ============================================================
   Relata portal — application UI
   Shares the marketing design language (Fraunces + Inter, pine/brass).
   ============================================================ */
:root {
  --bg:        #F4F2EC;
  --surface:   #FBFAF6;
  --card:      #ffffff;
  --ink:       #16221C;
  --pine:      #163A2B;
  --pine-700:  #1E4C39;
  --pine-600:  #2A6347;
  --brass:     #B07E3A;
  --brass-soft:#E9D9BE;
  --muted:     #5E6A60;
  --line:      rgba(22,34,28,.12);
  --line-soft: rgba(22,34,28,.07);
  --ok-bg:#EAF1EA; --ok-fg:#1E4C39;
  --warn-bg:#F8EBD2; --warn-fg:#855213;
  --bad-bg:#F7E4E0; --bad-fg:#9A3B28;
  --blue-bg:#E7EEF6; --blue-fg:#1B4C7E;
  --gray-bg:#ECEAE3; --gray-fg:#5E6A60;
  --radius:14px; --radius-sm:9px;
  --shadow:0 1px 2px rgba(22,34,28,.05),0 14px 34px -20px rgba(22,34,28,.22);
  --font-body:"Inter",system-ui,-apple-system,"Segoe UI",sans-serif;
  --font-head:"Fraunces",Georgia,serif;
  --sidebar:248px;
}
* { box-sizing:border-box; }
body { margin:0; font-family:var(--font-body); background:var(--bg); color:var(--ink); -webkit-font-smoothing:antialiased; line-height:1.55; }
h1,h2,h3,h4 { font-family:var(--font-head); font-weight:500; margin:0; letter-spacing:-.01em; }
a { color:inherit; text-decoration:none; }
button { font-family:inherit; cursor:pointer; }
input,select,textarea { font-family:inherit; }
.hidden { display:none !important; }
.sr-only { position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0; }

/* ---------- buttons ---------- */
.btn { display:inline-flex; align-items:center; gap:.45rem; justify-content:center; height:40px; padding:0 1.1rem; border-radius:999px; border:1.5px solid transparent; font-size:.92rem; font-weight:500; transition:.15s; }
.btn:active { transform:translateY(1px); }
.btn-solid { background:var(--pine); color:#fff; }
.btn-solid:hover { background:var(--pine-700); }
.btn-line { background:transparent; border-color:var(--line); color:var(--ink); }
.btn-line:hover { border-color:var(--pine); }
.btn-sm { height:32px; padding:0 .75rem; font-size:.82rem; }
.btn-danger { background:transparent; border-color:var(--bad-fg); color:var(--bad-fg); }
.btn-danger:hover { background:var(--bad-bg); }
.btn:disabled { opacity:.5; cursor:not-allowed; }

/* ---------- auth screen ---------- */
.auth { min-height:100vh; display:grid; place-items:center; padding:1.5rem; }
.auth-card { background:var(--card); border:1px solid var(--line); border-radius:18px; box-shadow:var(--shadow); width:100%; max-width:440px; padding:2.4rem; }
.auth-brand { display:flex; align-items:center; gap:.5rem; color:var(--pine); margin-bottom:1.5rem; }
.auth-brand b { font-family:var(--font-head); font-size:1.5rem; color:var(--ink); font-weight:500; }
.auth-card h1 { font-size:1.5rem; margin-bottom:.4rem; }
.auth-card p.sub { color:var(--muted); font-size:.92rem; margin:0 0 1.5rem; }
.auth-toggle { margin-top:1.2rem; text-align:center; font-size:.88rem; color:var(--muted); }
.auth-toggle a { color:var(--pine); font-weight:500; cursor:pointer; }
.demo-hint { margin-top:1.2rem; padding:.7rem .9rem; background:var(--ok-bg); border-radius:var(--radius-sm); font-size:.82rem; color:var(--pine-700); }

/* ---------- form fields ---------- */
.field { margin-bottom:1rem; }
.field label { display:block; font-size:.82rem; font-weight:500; margin-bottom:.35rem; color:var(--ink); }
.field input, .field select, .field textarea {
  width:100%; height:42px; padding:0 .8rem; border:1.5px solid var(--line); border-radius:var(--radius-sm);
  background:var(--surface); color:var(--ink); font-size:.95rem; transition:border-color .15s;
}
.field textarea { height:auto; padding:.6rem .8rem; min-height:70px; resize:vertical; }
.field input:focus, .field select:focus, .field textarea:focus { outline:none; border-color:var(--pine); }
.field-row { display:grid; grid-template-columns:1fr 1fr; gap:.8rem; }

/* ---------- app shell ---------- */
.shell { display:grid; grid-template-columns:var(--sidebar) 1fr; min-height:100vh; }
.sidebar { background:var(--pine); color:#D7E2DA; padding:1.4rem 1rem; display:flex; flex-direction:column; position:sticky; top:0; height:100vh; }
.sidebar .brand { display:flex; align-items:center; gap:.5rem; padding:.2rem .5rem 1.4rem; }
.sidebar .brand b { font-family:var(--font-head); font-size:1.4rem; color:#fff; font-weight:500; }
.sidebar nav { display:flex; flex-direction:column; gap:.15rem; }
.navlink { display:flex; align-items:center; gap:.7rem; padding:.62rem .75rem; border-radius:var(--radius-sm); color:#C2D1C7; font-size:.92rem; font-weight:500; }
.navlink:hover { background:rgba(255,255,255,.07); color:#fff; }
.navlink.active { background:rgba(255,255,255,.13); color:#fff; }
.navlink .ic { width:18px; text-align:center; opacity:.9; }
.sidebar .spacer { flex:1; }
.userbox { border-top:1px solid rgba(255,255,255,.12); padding-top:1rem; margin-top:1rem; font-size:.85rem; }
.userbox .name { color:#fff; font-weight:500; }
.userbox .role { color:#9DB1A4; font-size:.78rem; text-transform:capitalize; }
.userbox button { margin-top:.6rem; width:100%; background:transparent; border:1px solid rgba(255,255,255,.2); color:#D7E2DA; height:34px; border-radius:var(--radius-sm); font-size:.84rem; }
.userbox button:hover { background:rgba(255,255,255,.08); }

.main { padding:0; min-width:0; }
.topbar { display:flex; align-items:center; justify-content:space-between; padding:1.4rem 2rem; border-bottom:1px solid var(--line-soft); background:var(--surface); position:sticky; top:0; z-index:5; }
.topbar h1 { font-size:1.55rem; }
.topbar .sub { color:var(--muted); font-size:.88rem; margin-top:.15rem; }
.content { padding:1.8rem 2rem 3rem; }

/* ---------- cards / grids ---------- */
.grid { display:grid; gap:1rem; }
.cols-4 { grid-template-columns:repeat(4,1fr); }
.cols-3 { grid-template-columns:repeat(3,1fr); }
.cols-2 { grid-template-columns:repeat(2,1fr); }
.card { background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:1.3rem; }
.card h3 { font-size:1.1rem; margin-bottom:.2rem; }
.card .card-sub { color:var(--muted); font-size:.85rem; margin-bottom:1rem; }
.metric { background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:1.2rem 1.3rem; }
.metric .label { font-size:.8rem; color:var(--muted); display:flex; align-items:center; gap:.4rem; }
.metric .value { font-family:var(--font-head); font-size:2rem; margin-top:.3rem; }
.metric .value small { font-size:.95rem; color:var(--muted); font-family:var(--font-body); }
.metric.accent { border-top:3px solid var(--brass); }

.section-title { display:flex; align-items:center; justify-content:space-between; margin:2rem 0 1rem; }
.section-title h2 { font-size:1.25rem; }

/* ---------- tables ---------- */
.table-wrap { background:var(--card); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
table.data { width:100%; border-collapse:collapse; font-size:.9rem; }
table.data th { text-align:left; font-family:var(--font-body); font-size:.74rem; font-weight:600; letter-spacing:.05em; text-transform:uppercase; color:var(--muted); padding:.8rem 1rem; background:var(--surface); border-bottom:1px solid var(--line-soft); }
table.data td { padding:.8rem 1rem; border-bottom:1px solid var(--line-soft); vertical-align:middle; }
table.data tr:last-child td { border-bottom:0; }
table.data tr:hover td { background:var(--surface); }
.t-strong { font-weight:500; }
.t-sub { color:var(--muted); font-size:.8rem; }
.right { text-align:right; }
.nowrap { white-space:nowrap; }

/* ---------- badges ---------- */
.badge { display:inline-flex; align-items:center; gap:.3rem; font-size:.74rem; font-weight:600; padding:.22rem .6rem; border-radius:999px; white-space:nowrap; }
.b-ok { background:var(--ok-bg); color:var(--ok-fg); }
.b-warn { background:var(--warn-bg); color:var(--warn-fg); }
.b-bad { background:var(--bad-bg); color:var(--bad-fg); }
.b-blue { background:var(--blue-bg); color:var(--blue-fg); }
.b-gray { background:var(--gray-bg); color:var(--gray-fg); }
.b-brass { background:var(--brass-soft); color:#7a5520; }

/* ---------- product cards ---------- */
.prod { background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:1.1rem; display:flex; flex-direction:column; }
.prod .thumb { height:130px; border-radius:var(--radius-sm); background:var(--gray-bg); position:relative; overflow:hidden; margin-bottom:.8rem; }
.prod h4 { font-size:1.02rem; margin-bottom:.2rem; }
.prod .supplier { color:var(--muted); font-size:.8rem; }
.prod .price { font-family:var(--font-head); font-size:1.3rem; margin:.6rem 0; }
.prod .meta { display:flex; gap:.4rem; flex-wrap:wrap; margin-bottom:.8rem; }
.prod .btn { margin-top:auto; }

/* progress bar */
.bar { height:8px; background:var(--gray-bg); border-radius:999px; overflow:hidden; margin-top:.5rem; }
.bar > i { display:block; height:100%; background:var(--pine-600); }
.bar > i.over { background:var(--bad-fg); }

/* ---------- modal ---------- */
.modal-bg { position:fixed; inset:0; background:rgba(22,34,28,.45); display:grid; place-items:center; padding:1.5rem; z-index:50; }
.modal { background:var(--card); border-radius:18px; width:100%; max-width:560px; max-height:90vh; overflow:auto; box-shadow:var(--shadow); }
.modal-head { display:flex; justify-content:space-between; align-items:center; padding:1.3rem 1.5rem; border-bottom:1px solid var(--line-soft); position:sticky; top:0; background:var(--card); }
.modal-head h3 { font-size:1.25rem; }
.modal-head .x { background:none; border:0; font-size:1.4rem; color:var(--muted); line-height:1; }
.modal-body { padding:1.4rem 1.5rem; }
.modal-foot { padding:1rem 1.5rem; border-top:1px solid var(--line-soft); display:flex; gap:.6rem; justify-content:flex-end; position:sticky; bottom:0; background:var(--card); }

/* compliance preview panel */
.preview-panel { border-radius:var(--radius-sm); padding:.9rem 1rem; margin-top:.4rem; font-size:.88rem; border:1px solid var(--line-soft); }
.preview-panel.ok { background:var(--ok-bg); color:var(--ok-fg); }
.preview-panel.warning { background:var(--warn-bg); color:var(--warn-fg); }
.preview-panel.blocked { background:var(--bad-bg); color:var(--bad-fg); }
.preview-panel .pp-head { font-weight:600; display:flex; justify-content:space-between; }
.preview-panel .pp-row { display:flex; justify-content:space-between; margin-top:.3rem; opacity:.9; }

/* timeline */
.timeline { list-style:none; padding:0; margin:0; }
.timeline li { display:flex; gap:.7rem; padding:.5rem 0; font-size:.86rem; }
.timeline .dot { width:9px; height:9px; border-radius:50%; background:var(--pine-600); margin-top:.4rem; flex:none; }
.timeline .when { color:var(--muted); font-size:.78rem; }

/* toast */
#toast { position:fixed; bottom:1.4rem; right:1.4rem; display:flex; flex-direction:column; gap:.5rem; z-index:100; }
.toast { background:var(--ink); color:#fff; padding:.7rem 1rem; border-radius:var(--radius-sm); font-size:.88rem; box-shadow:var(--shadow); max-width:340px; }
.toast.err { background:var(--bad-fg); }
.toast.ok { background:var(--pine-700); }

.empty { text-align:center; padding:3rem 1rem; color:var(--muted); }
.empty .big { font-size:2.2rem; margin-bottom:.5rem; }

.inline-actions { display:flex; gap:.4rem; flex-wrap:wrap; }
.muted { color:var(--muted); }
.flex { display:flex; align-items:center; gap:.6rem; }
.between { justify-content:space-between; }
.wrap-tags { display:flex; gap:.4rem; flex-wrap:wrap; }

@media (max-width:900px){
  .shell { grid-template-columns:1fr; }
  .sidebar { position:fixed; left:0; top:0; bottom:0; width:240px; transform:translateX(-100%); transition:.25s; z-index:40; }
  .sidebar.open { transform:none; }
  .cols-4,.cols-3,.cols-2 { grid-template-columns:1fr; }
  .field-row { grid-template-columns:1fr; }
  .topbar .menu-btn { display:inline-flex !important; }
}
.menu-btn { display:none; }

/* ---------- drill-down metric/cards ---------- */
.metric-link { cursor:pointer; transition:border-color .15s, transform .15s; text-decoration:none; color:inherit; }
.metric-link:hover { border-color:var(--pine-600); transform:translateY(-2px); }
.metric-link .go, .card .go { color:var(--brass); font-weight:600; opacity:0; transition:opacity .15s; float:right; }
.metric-link:hover .go, a.card:hover .go { opacity:1; }
.metric-link .label { justify-content:space-between; }

/* ---------- filter chips ---------- */
.chips { display:flex; gap:.5rem; flex-wrap:wrap; margin-bottom:1rem; }
.chips-occasion { margin-top:-.3rem; }
.chip { padding:.4rem .85rem; border-radius:999px; border:1.5px solid var(--line); font-size:.85rem; font-weight:500; color:var(--muted); cursor:pointer; background:var(--surface); }
.chip:hover { border-color:var(--pine); color:var(--ink); }
.chip.active { background:var(--pine); border-color:var(--pine); color:#fff; }

/* ---------- calendar ---------- */
.cal-bar { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:.8rem; margin-bottom:1rem; }
.cal-bar h2 { font-size:1.4rem; }
.cal-legend { display:flex; gap:1rem; flex-wrap:wrap; font-size:.8rem; color:var(--muted); }
.cal-legend span { display:flex; align-items:center; gap:.4rem; }
.cal-legend .lg { width:11px; height:11px; border-radius:3px; display:inline-block; }
.lg.holiday { background:var(--bad-fg); } .lg.fun { background:var(--brass); } .lg.nameday { background:var(--blue-fg); } .lg.gift { background:var(--pine-600); border-radius:50%; }
.cal-grid { display:grid; grid-template-columns:repeat(7,1fr); gap:6px; }
.cal-head { margin-bottom:6px; }
.cal-wd { text-align:center; font-size:.74rem; font-weight:600; letter-spacing:.05em; text-transform:uppercase; color:var(--muted); padding:.3rem 0; }
.cal-cell { background:var(--card); border:1px solid var(--line); border-radius:10px; min-height:104px; padding:.45rem .5rem; cursor:pointer; transition:border-color .12s, box-shadow .12s; overflow:hidden; }
.cal-cell:hover { border-color:var(--pine-600); box-shadow:var(--shadow); }
.cal-empty { background:transparent; border:0; cursor:default; min-height:0; }
.cal-cell.is-today { border-color:var(--brass); box-shadow:0 0 0 1px var(--brass); }
.cal-num { font-weight:600; font-size:.9rem; display:flex; align-items:center; gap:.3rem; }
.cal-dot { background:var(--pine-600); color:#fff; font-size:.66rem; min-width:16px; height:16px; border-radius:999px; display:inline-flex; align-items:center; justify-content:center; padding:0 4px; margin-left:auto; }
.cal-name { font-size:.72rem; color:var(--blue-fg); margin-top:.1rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.cal-tags { display:flex; flex-direction:column; gap:2px; margin-top:.25rem; }
.cal-tag { font-size:.68rem; padding:1px 5px; border-radius:5px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.cal-tag.holiday { background:var(--bad-bg); color:var(--bad-fg); }
.cal-tag.fun { background:var(--brass-soft); color:#7a5520; }
.cal-gift { font-size:.7rem; color:var(--pine-700); margin-top:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.day-line { margin:.4rem 0; display:flex; align-items:center; gap:.5rem; }
.up-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:1rem; }
.up-card { background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:1rem 1.1rem; border-left:3px solid var(--blue-fg); }
.up-when { font-size:.78rem; color:var(--brass); font-weight:600; margin-bottom:.3rem; }
.up-card .btn { margin-top:.7rem; }

/* calendar view switcher + title */
.seg-group { display:inline-flex; border:1px solid var(--line); border-radius:999px; overflow:hidden; }
.seg { border:0; background:transparent; padding:.4rem .85rem; font-size:.85rem; font-weight:500; color:var(--muted); }
.seg:hover { background:var(--surface); color:var(--ink); }
.seg.active { background:var(--pine); color:#fff; }
.cal-title { background:transparent; border:0; font-family:var(--font-head); font-size:1.4rem; font-weight:500; color:var(--ink); padding:0 .4rem; border-radius:8px; }
.cal-title:hover { background:var(--surface); }
.cal-legend { margin-bottom:1rem; }

/* year view */
.cal-year { display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; }
.cal-mini { background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:1.1rem 1.2rem; cursor:pointer; transition:border-color .12s, transform .12s; }
.cal-mini:hover { border-color:var(--pine-600); transform:translateY(-2px); }
.cal-mini-name { font-family:var(--font-head); font-size:1.2rem; margin-bottom:.6rem; }
.cal-mini-stats { display:flex; gap:.4rem; flex-wrap:wrap; }

/* week view — taller cells */
.cal-week .cal-cell { min-height:150px; }

/* day view */
.cal-day { background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:1.4rem 1.5rem; }
.cal-day-tags { display:flex; gap:.5rem; flex-wrap:wrap; }

@media (max-width:900px){ .cal-year { grid-template-columns:repeat(2,1fr); } .seg { padding:.4rem .6rem; } }

/* ---------- webshop ---------- */
.shop-bar { display:flex; align-items:center; justify-content:space-between; gap:1rem; flex-wrap:wrap; }
.shop-search { height:40px; padding:0 .9rem; border:1.5px solid var(--line); border-radius:999px; background:var(--surface); font-size:.92rem; min-width:200px; }
.shop-search:focus { outline:none; border-color:var(--pine); }
.callout-note { background:var(--ok-bg); color:var(--ok-fg); border-radius:var(--radius-sm); padding:.7rem 1rem; margin:-.3rem 0 1rem; font-size:.85rem; }
.prod { position:relative; }
.heart { position:absolute; top:.7rem; right:.7rem; z-index:2; background:rgba(255,255,255,.9); border:1px solid var(--line); width:32px; height:32px; border-radius:50%; font-size:1rem; color:var(--muted); line-height:1; }
.heart:hover { border-color:var(--bad-fg); color:var(--bad-fg); }
.heart.on { color:var(--bad-fg); border-color:var(--bad-fg); }
.stars { color:var(--brass); font-size:.8rem; letter-spacing:1px; }
.prod-detail { display:flex; gap:1.2rem; align-items:center; }
.prod-detail-thumb { width:120px; height:120px; flex:none; border-radius:12px; background:var(--gray-bg); position:relative; overflow:hidden; }
/* emoji fallback sits behind; the photo (if it loads) covers it */
.thumb::before, .prod-detail-thumb::before { content:attr(data-emoji); position:absolute; inset:0; display:grid; place-items:center; font-size:2.2rem; }
.thumb img, .prod-detail-thumb img { position:relative; z-index:1; width:100%; height:100%; object-fit:cover; display:block; }

/* ---------- role select ---------- */
.cellclick { cursor:pointer; }
.cellclick:hover .badge { outline:2px solid var(--line); outline-offset:1px; }
.explain-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:.8rem; }
.explain-grid > div { background:var(--surface); border-radius:var(--radius-sm); padding:.7rem .8rem; }
.explain-grid p { margin:.4rem 0 0; font-size:.8rem; }
@media (max-width:700px){ .explain-grid { grid-template-columns:1fr; } }
.role-select { height:32px; padding:0 .5rem; border:1.5px solid var(--line); border-radius:8px; background:var(--surface); font-size:.84rem; }
.role-select:focus { outline:none; border-color:var(--pine); }

@media (max-width:900px){
  .cal-cell { min-height:78px; }
  .cal-name, .cal-tag, .cal-gift { font-size:.62rem; }
}
