@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700&family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,600;0,9..144,700&display=swap');

:root{
  --bg:#faf9f7;--bg2:#ffffff;--sidebar-bg:#f3f1ee;--panel-bg:#ffffff;
  --text:#1a1a1a;--text2:#3d3d3d;--muted:#8a8a8a;
  --accent:#2d7a6f;--accent-light:#e8f4f1;--accent-hover:#245f57;
  --green:#3a9a6c;--green-light:#e6f5ec;--red:#c44b4b;--red-light:#fce8e8;
  --yellow:#c49a1a;--yellow-light:#fdf6e3;
  --border:#e8e5e1;--border2:#d9d5cf;
  --shadow-sm:0 1px 3px rgba(0,0,0,0.04),0 1px 2px rgba(0,0,0,0.02);
  --shadow:0 2px 8px rgba(0,0,0,0.05),0 1px 3px rgba(0,0,0,0.03);
  --shadow-lg:0 4px 16px rgba(0,0,0,0.06),0 2px 6px rgba(0,0,0,0.03);
  --radius:12px;--radius2:16px;--radius3:20px;
  --font:"DM Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --font-display:"Fraunces",Georgia,serif;
}

*,*::before,*::after{box-sizing:border-box;} html,body{height:100%;}
body{margin:0;font-family:var(--font);color:var(--text);background:var(--bg);overflow:hidden;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;}
a{color:inherit;text-decoration:none;} strong{font-weight:600;}

.app{height:100%;display:grid;grid-template-columns:280px 1fr;}

.sidebar{padding:24px 16px;background:var(--sidebar-bg);border-right:1px solid var(--border);display:flex;flex-direction:column;gap:20px;overflow-y:auto;}
.brand{display:flex;gap:12px;align-items:center;padding:16px;border-radius:var(--radius2);background:var(--bg2);border:1px solid var(--border);box-shadow:var(--shadow-sm);}
.brand__mark{position:relative;width:32px;height:32px;}
.brand__mark .dot{position:absolute;inset:8px;background:var(--accent);border-radius:999px;}
.brand__mark .ring{position:absolute;inset:0;border-radius:999px;border:1.5px solid var(--accent);opacity:0.3;}
.brand__title{font-family:var(--font-display);font-size:16px;font-weight:600;color:var(--text);letter-spacing:-0.3px;}
.brand__subtitle{font-size:11px;color:var(--muted);margin-top:1px;letter-spacing:0.2px;text-transform:uppercase;font-weight:500;}

.nav{display:flex;flex-direction:column;gap:2px;}
.nav__item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius);transition:all 150ms;color:var(--text2);font-size:13px;font-weight:500;}
.nav__icon{width:20px;text-align:center;font-size:15px;}
.nav__item:hover{background:rgba(0,0,0,0.04);}
.nav__item.is-active{background:var(--accent-light);color:var(--accent);font-weight:600;}
.nav__item--settings{margin-top:4px;}
.sidebar__footer{margin-top:auto;display:flex;flex-direction:column;gap:8px;}

.chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:var(--bg2);width:fit-content;font-size:12px;}
.chip--admin{border-color:rgba(58,154,108,0.25);background:var(--green-light);}
.chip__dot{width:7px;height:7px;border-radius:999px;background:var(--muted);}
.chip__dot--green{background:var(--green);}
.chip__dot--yellow{background:var(--yellow);}
.chip__text{font-size:11px;color:var(--text2);font-weight:500;}

.user-badge{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius);background:var(--bg2);border:1px solid var(--border);}
.user-badge__avatar{width:32px;height:32px;border-radius:8px;background:var(--accent-light);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;color:var(--accent);}
.user-badge__name{font-weight:600;font-size:13px;}
.user-badge__role{font-size:11px;color:var(--muted);margin-top:1px;}

.main{display:grid;grid-template-rows:auto 1fr auto;min-width:0;background:var(--bg);min-height:0;}
.topbar{padding:20px 28px 16px;display:flex;align-items:center;justify-content:space-between;gap:16px;border-bottom:1px solid var(--border);background:var(--bg2);flex-shrink:0;}
.topbar__left{display:flex;align-items:center;gap:14px;min-width:0;}
.topbar__right{display:flex;align-items:center;gap:10px;}
.iconbtn{width:38px;height:38px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg2);color:var(--text2);cursor:pointer;transition:150ms;font-size:16px;}
.iconbtn:hover{background:var(--bg);border-color:var(--border2);}
.crumbs{min-width:0;}
.crumbs__title{font-family:var(--font-display);font-weight:600;font-size:18px;letter-spacing:-0.3px;color:var(--text);}
.crumbs__meta{font-size:12px;color:var(--muted);margin-top:2px;}
.content{padding:28px;overflow-y:auto;min-height:0;}
.footer{padding:12px 28px;border-top:1px solid var(--border);color:var(--muted);display:flex;justify-content:space-between;font-size:11px;background:var(--bg2);flex-shrink:0;}
.muted{color:var(--muted);}

.btn{padding:8px 14px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg2);color:var(--text);cursor:pointer;transition:150ms;font-weight:500;font-size:13px;white-space:nowrap;font-family:inherit;}
.btn:hover{background:var(--bg);border-color:var(--border2);}
.btn:active{transform:translateY(1px);}
.btn:disabled{opacity:0.45;cursor:not-allowed;}
.btn--ghost{border-color:transparent;background:transparent;color:var(--text2);}
.btn--ghost:hover{background:rgba(0,0,0,0.04);}
.btn--save{background:var(--accent);color:white;border-color:var(--accent);font-weight:600;}
.btn--save:hover{background:var(--accent-hover);border-color:var(--accent-hover);}
.btn--danger{color:var(--red);border-color:transparent;background:transparent;}
.btn--danger:hover{background:var(--red-light);}
.btn--logout{width:100%;text-align:center;font-size:12px;padding:8px;color:var(--muted);border:1px solid var(--border);background:transparent;}
.btn--logout:hover{color:var(--red);border-color:rgba(196,75,75,0.2);background:var(--red-light);}
.filelabel{display:inline-flex;align-items:center;gap:6px;cursor:pointer;}

.grid{display:grid;gap:16px;}
.grid--cards{grid-template-columns:repeat(12,1fr);gap:14px;}
.card{grid-column:span 6;border-radius:var(--radius2);border:1px solid var(--border);background:var(--panel-bg);box-shadow:var(--shadow-sm);overflow:hidden;transition:all 200ms;}
.card:hover{box-shadow:var(--shadow);border-color:var(--border2);transform:translateY(-1px);}
.card__inner{padding:20px;}
.card__title{font-weight:600;font-size:14px;display:flex;align-items:center;justify-content:space-between;gap:10px;}
.card__subtitle{font-size:12px;color:var(--muted);margin-top:6px;line-height:1.45;}
.card__meta{margin-top:14px;display:flex;flex-wrap:wrap;gap:6px;}
.card--wide{grid-column:span 12;}

.panel{border-radius:var(--radius2);border:1px solid var(--border);background:var(--panel-bg);box-shadow:var(--shadow-sm);overflow:hidden;}
.panel__header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px;}
.panel__title{font-weight:600;font-size:14px;}
.panel__body{padding:20px;}

.pill{padding:4px 10px;border-radius:999px;font-size:11px;border:1px solid var(--border);background:var(--bg);color:var(--text2);font-weight:500;}
.pill--status{font-weight:600;}
.pill--active{border-color:rgba(58,154,108,0.25);background:var(--green-light);color:var(--green);}
.pill--warning{border-color:rgba(196,154,26,0.25);background:var(--yellow-light);color:var(--yellow);}
.pill--paused,.pill--default{border-color:var(--border);background:var(--bg);color:var(--muted);}
.pill--done{border-color:rgba(45,122,111,0.2);background:var(--accent-light);color:var(--accent);}

.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center;}
.label{font-size:11px;color:var(--muted);margin-bottom:6px;font-weight:600;text-transform:uppercase;letter-spacing:0.3px;}
.input{flex:1 1 180px;min-width:140px;padding:10px 14px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg2);color:var(--text);outline:none;font-family:inherit;font-size:13px;transition:border-color 150ms,box-shadow 150ms;}
.input::placeholder{color:var(--muted);}
.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(45,122,111,0.1);}
select.input{cursor:pointer;} select.input option{background:var(--bg2);color:var(--text);}
.textarea{width:100%;min-height:100px;padding:12px 14px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg2);color:var(--text);outline:none;resize:vertical;font-family:inherit;font-size:13px;line-height:1.6;}
.textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(45,122,111,0.1);}
.readblock{font-size:13px;line-height:1.6;white-space:pre-wrap;padding:14px 16px;border-radius:var(--radius);background:var(--bg);border:1px solid var(--border);color:var(--text2);min-height:60px;}

.table{width:100%;border-collapse:separate;border-spacing:0;border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;}
.table th,.table td{padding:10px 14px;text-align:left;font-size:13px;border-bottom:1px solid var(--border);vertical-align:top;}
.table th{font-size:11px;color:var(--muted);font-weight:600;background:var(--bg);text-transform:uppercase;letter-spacing:0.3px;position:sticky;top:0;z-index:1;}
.table tr:hover td{background:rgba(0,0,0,0.015);}
.table tr:last-child td{border-bottom:none;}
.table th[data-sort]{cursor:pointer;user-select:none;transition:color 150ms;}
.table th[data-sort]:hover{color:var(--accent);}
.th--sorted{color:var(--accent);}

.kv{display:grid;grid-template-columns:120px 1fr;gap:6px 14px;font-size:13px;}
.kv__k{color:var(--muted);font-weight:500;}
.kv__v{color:var(--text);}
.split{display:grid;grid-template-columns:1fr 1fr;gap:20px;}

.dash-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;}
.dash-tile{border-radius:var(--radius2);border:1px solid var(--border);background:var(--panel-bg);box-shadow:var(--shadow-sm);padding:20px;transition:all 200ms;text-align:center;}
.dash-tile:hover{box-shadow:var(--shadow);transform:translateY(-2px);}
.dash-tile__icon{font-size:24px;margin-bottom:8px;}
.dash-tile__value{font-family:var(--font-display);font-size:30px;font-weight:700;color:var(--accent);line-height:1;}
.dash-tile__label{font-size:12px;font-weight:600;margin-top:6px;color:var(--text);}
.dash-tile__sub{font-size:11px;color:var(--muted);margin-top:2px;}

.bar-chart{display:flex;flex-direction:column;gap:10px;}
.bar-row{display:flex;align-items:center;gap:12px;}
.bar-label{font-size:12px;min-width:100px;color:var(--text2);font-weight:500;}
.bar-track{flex:1;height:20px;background:var(--bg);border-radius:10px;overflow:hidden;border:1px solid var(--border);}
.bar-fill{height:100%;background:linear-gradient(90deg,var(--accent-light),rgba(45,122,111,0.25));border-radius:10px;min-width:4px;transition:width 400ms;}
.bar-val{font-size:12px;font-weight:600;color:var(--accent);min-width:24px;text-align:right;}

.actie-form{padding:14px;border-radius:var(--radius);background:var(--bg);border:1px solid var(--border);}
.actie-item{padding:12px 0;border-bottom:1px solid var(--border);}
.actie-item:last-child{border-bottom:none;}
.actie-item__header{display:flex;gap:12px;align-items:flex-start;}
.actie-item__title{font-size:13px;font-weight:600;color:var(--text);}
.actie-item__desc{font-size:12px;color:var(--muted);margin-top:3px;line-height:1.45;}

.toast{position:fixed;right:20px;bottom:20px;padding:12px 18px;border-radius:var(--radius);background:var(--text);color:white;box-shadow:var(--shadow-lg);transform:translateY(12px);opacity:0;pointer-events:none;transition:200ms;font-size:13px;font-weight:500;z-index:100;}
.toast.is-show{transform:translateY(0);opacity:1;}

/* Modal */
.modal-overlay{
  position:fixed;inset:0;z-index:50;
  background:rgba(0,0,0,0.35);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);
  display:flex;align-items:flex-start;justify-content:center;
  padding:40px 20px;overflow-y:auto;
  animation:modalFadeIn 150ms ease;
}
.modal{
  width:100%;max-width:1000px;
  border-radius:var(--radius2);border:1px solid var(--border);
  background:var(--panel-bg);box-shadow:var(--shadow-lg);
  overflow:hidden;
  animation:modalSlideUp 200ms ease;
}
.modal .panel__header{position:sticky;top:0;background:var(--panel-bg);z-index:1;border-bottom:1px solid var(--border);}

@keyframes modalFadeIn{from{opacity:0;}to{opacity:1;}}
@keyframes modalSlideUp{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}

.login-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:var(--bg);}
.login-card{width:100%;max-width:380px;margin:20px;border-radius:var(--radius3);border:1px solid var(--border);background:var(--panel-bg);box-shadow:var(--shadow-lg);overflow:hidden;}
.login-brand{display:flex;gap:14px;align-items:center;padding:32px 32px 0;}
.login-form{padding:28px 32px 32px;}
.login-input{width:100%;flex:unset;padding:12px 14px;font-size:14px;background:var(--bg);border-color:var(--border);}
.login-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(45,122,111,0.1);}
.btn--login{width:100%;padding:12px;font-size:14px;font-weight:600;background:var(--accent);color:white;border-color:var(--accent);letter-spacing:0.2px;}
.btn--login:hover{background:var(--accent-hover);border-color:var(--accent-hover);}
.login-footer{padding:14px 32px;text-align:center;border-top:1px solid var(--border);background:var(--bg);}

/* Toolbar */
.toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:16px;flex-wrap:wrap;}

/* Tag list (settings page) */
.tag-list{display:flex;flex-direction:column;gap:6px;}
.tag-item{display:flex;align-items:center;gap:8px;}
.tag-input{flex:1;}
.pill--thema{border-color:rgba(45,122,111,0.2);background:var(--accent-light);color:var(--accent);font-weight:500;}
.pill--rabo{border-color:rgba(255,102,0,0.25);background:#fff5eb;color:#e06000;font-weight:600;}

/* Progress bar */
.progress-track{height:12px;background:var(--bg);border-radius:6px;overflow:hidden;border:1px solid var(--border);flex:1;}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-light),var(--accent));border-radius:6px;transition:width 300ms ease;min-width:2px;}

/* Filter selects */
.filter-select{flex:0 0 140px;min-width:120px;font-size:12px;padding:8px 10px;}

/* Range input */
input[type="range"]{-webkit-appearance:none;appearance:none;height:6px;background:var(--bg);border:1px solid var(--border);border-radius:3px;outline:none;}
input[type="range"]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid var(--bg2);box-shadow:var(--shadow-sm);}
input[type="range"]::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid var(--bg2);box-shadow:var(--shadow-sm);}

/* Inline delete button */
.btn--icon-del{
  width:26px;height:26px;border-radius:8px;border:1px solid transparent;
  background:transparent;color:var(--muted);cursor:pointer;font-size:16px;
  display:inline-flex;align-items:center;justify-content:center;
  transition:all 150ms;line-height:1;font-family:inherit;flex-shrink:0;
}
.btn--icon-del:hover{background:var(--red-light);color:var(--red);border-color:rgba(196,75,75,0.15);}

/* Traject rows */
.trj-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:var(--radius);border:1px solid var(--border);margin-bottom:8px;cursor:pointer;transition:all 150ms;background:var(--bg2);}
.trj-row:hover{border-color:var(--border2);box-shadow:var(--shadow-sm);}
.trj-row--active{border-color:var(--accent);background:var(--accent-light);}
.trj-row__main{min-width:0;}
.trj-row__title{font-size:13px;font-weight:600;color:var(--text);}
.trj-row__sub{font-size:12px;color:var(--muted);margin-top:2px;}

/* Subpanels (lightweight nested sections) */
.subpanel{padding:14px 0;border-bottom:1px solid var(--border);}
.subpanel:last-child{border-bottom:none;}
.subpanel__header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px;font-size:13px;}

/* Responsive */
@media(max-width:980px){
  body{overflow:auto;} .app{grid-template-columns:1fr;grid-template-rows:auto 1fr;}
  .sidebar{position:sticky;top:0;z-index:10;border-right:none;border-bottom:1px solid var(--border);}
  .sidebar.collapsed .nav,.sidebar.collapsed .sidebar__footer{display:none;}
  .main{min-height:60vh;} .split{grid-template-columns:1fr;} .card{grid-column:span 12;} .content{padding:20px;}
}
