@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500&family=IBM+Plex+Sans:wght@400;500;600&display=swap');
*{box-sizing:border-box;margin:0;padding:0;}
#ph-root{display:flex;height:100vh;font-family:'IBM Plex Sans',system-ui,sans-serif;font-size:17px;background:#faf9f7;border:0.5px solid #e2e0d8;border-radius:0;overflow:hidden;}
#ph-sidebar{width:260px;flex-shrink:0;background:#f0ede6;display:flex;flex-direction:column;border-right:0.5px solid #e2e0d8;overflow-y:auto;}
#ph-main{flex:1;overflow-y:auto;background:#faf9f7;display:flex;flex-direction:column;min-width:0;}
.sb-logo{padding:22px 18px 16px;display:flex;align-items:center;gap:11px;border-bottom:0.5px solid #e2e0d8;flex-shrink:0;}
.sb-mark{width:34px;height:34px;background:#16a34a;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;flex-shrink:0;}
.sb-nav{flex:1;padding:6px 10px;display:flex;flex-direction:column;gap:2px;overflow-y:auto;}
.ni{display:flex;align-items:center;gap:11px;padding:11px 14px;border-radius:9px;cursor:pointer;user-select:none;transition:background .1s;}
.ni:hover{background:#e8e5dd;}
.ni.active{background:#e3dfd7;}
.ni svg{flex-shrink:0;}
.ni span{font-size:15px;}
.sb-foot{padding:14px 18px;border-top:0.5px solid #e2e0d8;display:flex;align-items:center;gap:10px;flex-shrink:0;}
.sb-foot-info{flex:1;min-width:0;}
.sb-foot-info div{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.ua{width:32px;height:32px;border-radius:50%;background:#16a34a;color:#fff;font-size:14px;font-weight:600;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.hdiv{margin:20px 32px 0;height:0.5px;background:#e8e5de;flex-shrink:0;}
/* SMED */
.smed-zone{background:#fff;border:0.5px solid #e2e0d8;border-radius:10px;display:flex;flex-direction:column;overflow:hidden;}
.smed-zone-head{padding:12px 14px 11px;border-bottom:0.5px solid #e2e0d8;flex-shrink:0;}
.smed-zone-row{display:flex;align-items:center;gap:6px;margin-bottom:5px;}
.smed-zone-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;}
.smed-zone-title{font-size:16px;font-weight:600;color:#1a1a1a;flex:1;}
.smed-zone-cnt{font-family:'IBM Plex Mono',monospace;font-size:14px;padding:1px 6px;border-radius:10px;background:#f0ede6;color:#5c5a56;white-space:nowrap;}
.smed-zone-cnt.amber{background:#fef3c7;color:#92400e;}
.smed-zone-cnt.green{background:#dcfce7;color:#166534;}
.smed-zone-desc{font-size:14px;color:#5c5a56;line-height:1.4;margin-bottom:4px;}
.smed-zone-time{font-family:'IBM Plex Mono',monospace;font-size:14px;font-weight:500;}
.smed-zone-time.gray{color:#9c9a92;}
.smed-zone-time.amber{color:#d4910a;}
.smed-zone-time.green{color:#16a34a;}
.zb{flex:1;padding:8px;display:flex;flex-direction:column;gap:5px;min-height:200px;transition:background .12s;}
.zb.dov{background:#f0fdf4;outline:2px dashed #86efac;outline-offset:-4px;border-radius:6px;}
.zb.dov-amber{background:#fffbeb;outline:2px dashed #fcd34d;outline-offset:-4px;border-radius:6px;}
.act-c{background:#faf9f7;border:0.5px solid #e2e0d8;border-radius:8px;padding:11px 13px;cursor:grab;user-select:none;position:relative;transition:border-color .1s;}
.act-c:hover{border-color:#c8c5be;}
.act-c.dragging{opacity:.3;}
.act-c.ac-intern{border-left:3px solid #d4910a;background:#fffdf7;}
.act-c.ac-extern{border-left:3px solid #16a34a;background:#f7fef9;}
.act-c.ac-unclassified{border-left:3px solid #c8c5be;}
.zone-empty-msg{display:flex;align-items:center;justify-content:center;flex:1;font-size:15px;color:#c8c5be;text-align:center;padding:12px;pointer-events:none;}
.add-zone-btn{display:flex;align-items:center;justify-content:center;gap:4px;padding:6px;border:0.5px dashed #c8c5be;border-radius:6px;color:#5c5a56;font-size:14px;cursor:pointer;background:none;font-family:inherit;width:100%;transition:background .1s;}
.add-zone-btn:hover{background:#f0ede6;}
.modal-ov{position:absolute;inset:0;background:rgba(26,26,26,.3);display:flex;align-items:center;justify-content:center;z-index:200;}
.modal-box{background:#fff;border-radius:12px;border:0.5px solid #e2e0d8;padding:22px;width:400px;}
::-webkit-scrollbar{width:4px;height:4px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:#e2e0d8;border-radius:2px;}
/* LOGIN — molnets motsvarighet till PIN-skärmen (Google Sign-In via Supabase) */
#ph-login{position:fixed;inset:0;background:#faf9f7;display:flex;align-items:center;justify-content:center;z-index:9999;font-family:'IBM Plex Sans',system-ui,sans-serif;}
#ph-login.hidden{display:none;}
.login-box{text-align:center;display:flex;flex-direction:column;align-items:center;gap:16px;}
.login-mark{width:56px;height:56px;background:#16a34a;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:#fff;}
.login-title{font-size:22px;font-weight:500;color:#1a1a1a;}
.login-sub{font-size:14px;color:#a09e97;margin-top:-8px;}
.login-btn{font-size:15px;font-family:inherit;background:#1a1a1a;color:#fff;border:none;border-radius:7px;padding:11px 22px;cursor:pointer;min-width:220px;}
.login-btn:hover{background:#333330;}
.login-status{font-size:14px;color:#a09e97;height:20px;}
.login-status.error{color:#e05252;}
/* Flöden */
.fl-node{transition:stroke-width .1s;}
.fl-conn{transition:stroke .1s,stroke-width .1s;}

/* ── Custom Properties ── */
:root {
  --c-dark: #1a1a1a;
  --c-muted: #5c5a56;
  --c-faint: #a09e97;
  --c-border: #e2e0d8;
  --c-bg: #f5f4f2;
  --c-white: #ffffff;
  --c-green: #16a34a;
  --c-green-light: #f0fdf4;
  --c-green-border: #bbf7d0;
  --c-blue: #3b82f6;
  --c-blue-light: #eff6ff;
  --c-blue-border: #bfdbfe;
  --c-amber: #d4910a;
  --c-amber-light: #fffbeb;
  --c-amber-border: #fde68a;
  --c-red: #e05252;
  --c-red-light: #fef2f2;
  --c-red-border: #f5c4c4;
  --font-sans: 'IBM Plex Sans', sans-serif;
  --font-mono: 'IBM Plex Mono', monospace;
  --radius-sm: 5px;
  --radius-md: 7px;
  --radius-lg: 10px;
}

/* ── Buttons ── */
.btn {
  font-size: 14px;
  font-family: inherit;
  border-radius: var(--radius-sm);
  padding: 3px 10px;
  cursor: pointer;
  white-space: nowrap;
  line-height: 1.5;
}
.btn-primary { background: var(--c-dark); color: white; border: none; }
.btn-green { background: var(--c-green); color: white; border: none; }
.btn-outline { background: none; color: var(--c-muted); border: 0.5px solid var(--c-border); }
.btn-outline-green { background: none; color: var(--c-green); border: 0.5px solid var(--c-green); }
.btn-danger { background: none; color: var(--c-red); border: 0.5px solid var(--c-red-border); }
.btn-danger-fill { background: var(--c-red); color: white; border: none; border-radius: var(--radius-sm); padding: 4px 10px; font-size: 14px; font-family: inherit; cursor: pointer; }

/* ── Cards ── */
.card {
  background: var(--c-white);
  border: 0.5px solid var(--c-border);
  border-radius: var(--radius-lg);
  padding: 13px 15px;
}

/* ── Pills/badges ── */
.pill {
  font-size: 14px;
  padding: 2px 9px;
  border-radius: 12px;
  white-space: nowrap;
}

/* ── Page header ── */
.page-title { font-size: 25px; font-weight: 500; color: var(--c-dark); }
.page-subtitle { color: var(--c-faint); font-size: 15px; margin-top: 3px; }

/* ── Section header row ── */
.hdr-row {
  padding: 24px 32px 0;
  flex-shrink: 0;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}

/* ── Modal ── */
.modal-title { font-size: 18px; font-weight: 500; color: var(--c-dark); }
.modal-close {
  font-size: 22px;
  cursor: pointer;
  color: var(--c-faint);
  line-height: 1;
  padding: 2px 6px;
  border-radius: 4px;
}
.modal-close:hover { background: var(--c-bg); }

/* ── Form inputs ── */
.form-input {
  width: 100%;
  padding: 7px 10px;
  font-size: 15px;
  font-family: inherit;
  border: 0.5px solid var(--c-border);
  border-radius: var(--radius-sm);
  outline: none;
  color: var(--c-dark);
}
.form-input:focus { border-color: var(--c-green); }
.form-label {
  font-size: 14px;
  font-weight: 500;
  color: var(--c-muted);
  margin-bottom: 4px;
}

/* ── Utility ── */
.flex-col { display: flex; flex-direction: column; flex: 1; }
.text-mono { font-family: var(--font-mono); }
.text-faint { color: var(--c-faint); }
.text-muted { color: var(--c-muted); }
