/* ===== Material Design 3 (Material You) tokens ===== */
:root{
  /* Primary / accent */
  --md-primary:#4f46c4;
  --md-on-primary:#ffffff;
  --md-primary-container:#e3dfff;
  --md-on-primary-container:#160067;
  --md-secondary:#5d5c72;
  --md-secondary-container:#e3e0f9;
  --md-on-secondary-container:#1a1a2c;
  --md-tertiary:#7a5266;
  /* Surfaces */
  --md-background:#fbf8fd;
  --md-surface:#fbf8fd;
  --md-surface-dim:#dbd9dd;
  --md-surface-container-low:#f5f2f7;
  --md-surface-container:#efedf1;
  --md-surface-container-high:#e9e7ec;
  --md-surface-container-highest:#e3e1e6;
  --md-on-surface:#1c1b1f;
  --md-on-surface-variant:#48464c;
  --md-outline:#79767d;
  --md-outline-variant:#cac5cd;
  /* States */
  --md-success:#2e7d52;--md-success-c:#b6f2cf;
  --md-warning:#8a6d00;--md-warning-c:#ffe08c;
  --md-error:#ba1a1a;--md-error-c:#ffdad6;
  --md-info:#1d6fb8;--md-info-c:#d3e4ff;
  /* Shape */
  --r-xs:8px;--r-sm:12px;--r-md:16px;--r-lg:24px;--r-full:999px;
  /* Elevation */
  --e1:0 1px 2px rgba(0,0,0,.10),0 1px 3px rgba(0,0,0,.06);
  --e2:0 1px 2px rgba(0,0,0,.10),0 2px 6px rgba(0,0,0,.10);
  --e3:0 4px 8px rgba(0,0,0,.12),0 1px 3px rgba(0,0,0,.10);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Roboto','Roboto Flex',-apple-system,Segoe UI,'Noto Color Emoji','Apple Color Emoji','Segoe UI Emoji',sans-serif;background:var(--md-background);color:var(--md-on-surface);font-size:14px;line-height:1.5}
a{color:var(--md-primary);text-decoration:none}a:hover{text-decoration:underline}

/* ===== App layout ===== */
.app{display:flex;min-height:100vh}
.sidebar{width:248px;background:var(--md-surface-container-low);display:flex;flex-direction:column;padding:16px 12px;gap:4px}
.sidebar .logo{font-size:20px;font-weight:500;color:var(--md-on-surface);padding:12px 16px 16px;letter-spacing:.2px}
.sidebar nav{display:flex;flex-direction:column;gap:4px}
.sidebar nav a{display:flex;align-items:center;gap:12px;color:var(--md-on-surface-variant);padding:12px 16px;border-radius:var(--r-full);font-weight:500;font-size:14px;transition:background .15s}
.sidebar nav a:hover{background:var(--md-surface-container-high);color:var(--md-on-surface);text-decoration:none}
.sidebar nav a.active{background:var(--md-secondary-container);color:var(--md-on-secondary-container)}
.sidebar .spacer{flex:1}
.userbox{padding:14px 16px;font-size:13px;border-radius:var(--r-md);background:var(--md-surface-container);color:var(--md-on-surface-variant)}
.userbox a{color:var(--md-primary)}
.content{flex:1;padding:28px 36px;max-width:1280px}
h1{font-size:28px;font-weight:400;margin-bottom:18px;letter-spacing:0}
h3{margin-bottom:12px;font-size:16px;font-weight:500}
h4{font-weight:500}
.muted{color:var(--md-on-surface-variant);font-size:13px}

/* ===== Cards ===== */
.card{background:var(--md-surface-container-low);border:none;border-radius:var(--r-md);padding:20px;margin-bottom:18px;box-shadow:var(--e1)}
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:18px}
.stat{text-align:center;background:var(--md-primary-container);color:var(--md-on-primary-container)}
.stat .num{font-size:34px;font-weight:500}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:800px){.cards{grid-template-columns:repeat(2,1fr)}.grid2{grid-template-columns:1fr}}

/* ===== Inputs ===== */
input,select,textarea{font:inherit;padding:12px 14px;border:1px solid var(--md-outline-variant);border-radius:var(--r-xs);background:var(--md-surface);color:var(--md-on-surface);transition:border .15s}
input:focus,select:focus,textarea:focus{outline:none;border:2px solid var(--md-primary);padding:11px 13px}
textarea{width:100%;min-height:90px;resize:vertical}
label{font-size:13px;color:var(--md-on-surface-variant)}

/* ===== Buttons (MD3) ===== */
button,.btn{font:inherit;font-weight:500;padding:10px 24px;border:none;border-radius:var(--r-full);background:var(--md-primary);color:var(--md-on-primary);cursor:pointer;transition:box-shadow .15s,background .15s;letter-spacing:.1px}
button:hover{box-shadow:var(--e2);background:#443bb0}
button.ghost{background:var(--md-secondary-container);color:var(--md-on-secondary-container)}
button.ghost:hover{background:#d5d2ee}
button.danger{background:var(--md-error);color:#fff}button.danger:hover{background:#9f1717}
button.linkbtn{background:none;color:var(--md-error);padding:0 6px;font-weight:400;box-shadow:none}
button.linkbtn:hover{box-shadow:none;background:none;text-decoration:underline}
.gantt-ctrls button,.rowbtns button{padding:8px 18px}

/* ===== Forms ===== */
form.inline{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
form.inline.card{padding:20px}
.taskform{display:flex;flex-direction:column;gap:12px}
.taskform label{display:flex;flex-direction:column;gap:4px}
.rowbtns{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px;align-items:center}

/* ===== Table ===== */
.tbl{width:100%;border-collapse:collapse}
.tbl th,.tbl td{text-align:left;padding:12px 10px;border-bottom:1px solid var(--md-outline-variant)}
.tbl th{font-size:12px;color:var(--md-on-surface-variant);text-transform:uppercase;letter-spacing:.5px;font-weight:500}
.tbl tr:hover td{background:var(--md-surface-container)}

/* ===== Lists ===== */
.list{list-style:none}.list li{padding:10px 0;border-bottom:1px solid var(--md-outline-variant)}
.list li:last-child{border-bottom:none}

/* ===== Chips / badges (MD3) ===== */
.badge{display:inline-block;padding:4px 12px;border-radius:var(--r-xs);font-size:12px;font-weight:500;background:var(--md-surface-container-highest);color:var(--md-on-surface-variant)}
.badge.todo{background:var(--md-surface-container-highest);color:var(--md-on-surface-variant)}
.badge.in_progress{background:var(--md-info-c);color:#00497d}
.badge.done{background:var(--md-success-c);color:#00522f}
.badge.blocked{background:var(--md-error-c);color:#410002}

/* ===== Progress ===== */
.prog{display:inline-block;width:100px;height:8px;background:var(--md-surface-container-highest);border-radius:var(--r-full);overflow:hidden;vertical-align:middle;margin-right:8px}
.prog span{display:block;height:100%;background:var(--md-primary);border-radius:var(--r-full)}

.proj{display:flex;justify-content:space-between;align-items:center}
.md p{margin:8px 0}.md h1,.md h2,.md h3{margin:12px 0 8px}.md ul{margin-left:22px}
.md code{background:var(--md-surface-container-high);padding:2px 6px;border-radius:6px}
.feedurl{padding:12px;font-family:'Roboto Mono',monospace;font-size:12px;border-radius:var(--r-xs)}
details summary{cursor:pointer;color:var(--md-primary);margin:12px 0;font-weight:500}

/* ===== Auth ===== */
.authpage{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,var(--md-primary-container),var(--md-surface-container))}
.authcard{background:var(--md-surface);padding:36px;border-radius:var(--r-lg);width:360px;display:flex;flex-direction:column;gap:14px;box-shadow:var(--e3)}
.authcard h1{font-size:24px;margin:0;font-weight:500}
.authcard input,.authcard button{width:100%}
.err{background:var(--md-error-c);color:#410002;padding:12px;border-radius:var(--r-xs);font-size:13px}
.ok{background:var(--md-success-c);color:#00522f;padding:12px;border-radius:var(--r-xs);font-size:13px}

/* ===== Kanban (Jira-style) ===== */
.kboard{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;align-items:start}
.kcol{background:#f1f2f4;border-radius:6px;padding:8px;min-height:160px}
.kcolhdr{display:flex;align-items:center;gap:8px;padding:6px 8px 10px;color:#626f86}
.kcoltitle{font-size:12px;font-weight:600;letter-spacing:.4px}
.kcolhdr .cnt{background:#dcdfe4;border-radius:var(--r-full);padding:0 8px;font-size:12px;font-weight:600;color:#44546f}
.kdrop{min-height:80px;display:flex;flex-direction:column;gap:8px;padding:2px}
.kdrop.over{outline:2px dashed #4f46c4;outline-offset:1px;border-radius:6px;background:#e9e7fb}
/* Jira ticket card */
.jcard{display:flex;background:#fff;border-radius:6px;cursor:pointer;box-shadow:0 1px 1px rgba(9,30,66,.25),0 0 1px rgba(9,30,66,.13);overflow:hidden;transition:box-shadow .12s}
.jcard:hover{box-shadow:0 2px 6px rgba(9,30,66,.28)}
.jcard.dragging{opacity:.45}
.jbar{width:4px;flex-shrink:0}
.jbody{flex:1;padding:10px 12px}
.jtitle{font-size:14px;color:#172b4d;line-height:1.35;margin-bottom:6px}
.jproj{font-size:12px;color:#626f86;margin-bottom:10px}
.jfoot{display:flex;align-items:center;gap:8px}
.jkey{font-size:12px;font-weight:600;color:#626f86;letter-spacing:.3px}
.jprio{font-size:13px}
.jdue{font-size:11px;color:#626f86;background:#f1f2f4;padding:2px 7px;border-radius:var(--r-xs)}
.jdue.over{background:var(--md-error-c);color:#9f1717;font-weight:600}
.jspace{flex:1}
.avatar{width:26px;height:26px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:11px;font-weight:600;flex-shrink:0}
.avatar.empty{background:#dcdfe4;color:#8590a2}
.kempty{color:#8590a2;font-size:13px;text-align:center;padding:14px}
@media(max-width:900px){.kboard{grid-template-columns:repeat(2,1fr)}}

/* ===== Planner (MD3) ===== */
.pweek{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;align-items:start}
.pday{background:var(--md-surface-container);border-radius:var(--r-md);padding:10px;min-height:170px}
.pday.pdayfull{min-height:320px}
.pday.ptoday{outline:2px solid var(--md-primary)}
.pdayhdr{font-size:13px;font-weight:500;color:var(--md-on-surface-variant);margin-bottom:10px}
.pdrop{min-height:120px;display:flex;flex-direction:column;gap:8px}
.pdrop.over{outline:2px dashed var(--md-primary);border-radius:var(--r-sm)}
.pchip{background:var(--md-surface);border-left:4px solid var(--md-outline);border-radius:var(--r-xs);padding:9px 11px;cursor:grab;font-size:13px;box-shadow:var(--e1)}
.pchip.in_progress{border-left-color:var(--md-info)}.pchip.done{border-left-color:var(--md-success)}
.pchip.blocked{border-left-color:var(--md-error)}.pchip.todo{border-left-color:var(--md-outline)}
.pchip span{display:block;font-size:11px}
@media(max-width:900px){.pweek{grid-template-columns:repeat(2,1fr)}}
.prioicon{font-size:12px;line-height:1;font-weight:bold}

/* Project rows (Jira-like list) */
.projrow{display:flex;align-items:center;justify-content:space-between;gap:16px;background:var(--md-surface-container-low);border-radius:var(--r-sm);padding:16px 20px;margin-bottom:10px;box-shadow:var(--e1);text-decoration:none;color:var(--md-on-surface);transition:box-shadow .12s,background .12s}
.projrow:hover{box-shadow:var(--e2);background:var(--md-surface-container);text-decoration:none}
.projrow-main{display:flex;flex-direction:column;gap:6px;flex:1;min-width:0}
.projrow-title{font-size:15px;font-weight:500}
.projrow-tags{display:flex;gap:6px;flex-wrap:wrap}
.projrow-meta{display:flex;align-items:center;gap:12px}
.projrow-arrow{font-size:22px;color:var(--md-outline)}
/* Direction tag (epic-like label) */
.dirtag{display:inline-block;padding:2px 10px;border-radius:var(--r-xs);font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;border:1px solid}
.jtags{margin-bottom:8px}
/* Direction filter chips */
.dirfilter{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.chip{padding:7px 16px;border-radius:var(--r-full);background:var(--md-surface-container);color:var(--md-on-surface-variant);font-size:13px;font-weight:500;text-decoration:none}
.chip:hover{background:var(--md-surface-container-high);text-decoration:none}
.chip.active{background:var(--md-secondary-container);color:var(--md-on-secondary-container)}

/* Projects header + dropdown menu */
.phead{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.phead h1{margin:0}
.menuwrap{position:relative}
.addbtn{background:var(--md-primary);color:#fff;border-radius:var(--r-full);padding:11px 22px;font-weight:500}
.addmenu{display:none;position:absolute;right:0;top:52px;width:380px;max-width:90vw;background:var(--md-surface);border-radius:var(--r-md);box-shadow:var(--e3);padding:20px;z-index:50}
.addmenu.open{display:block}
.addmenu h3{margin-bottom:10px}
.addmenu .taskform{gap:10px}
/* Filters */
.filters{background:var(--md-surface-container-low);border-radius:var(--r-md);padding:14px 16px;margin-bottom:14px;box-shadow:var(--e1)}
.filterrow{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:10px}
.filterrow:last-child{margin-bottom:0}
.flabel{font-size:12px;font-weight:600;color:var(--md-on-surface-variant);width:110px;flex-shrink:0;text-transform:uppercase;letter-spacing:.3px}
/* Project row badges */
.rstbadge{display:inline-block;padding:2px 10px;border-radius:var(--r-xs);font-size:11px;font-weight:600;background:var(--md-surface-container-highest);color:var(--md-on-surface-variant)}
.pbadge{display:inline-block;font-size:11px;font-weight:600}
.projrow-meta .upd{font-size:12px;min-width:96px;text-align:right}
