﻿:root{--bg:#09090e;--s1:#111117;--s2:#16161e;--s3:#1d1d28;--b1:rgba(255,255,255,.055);--b2:rgba(255,255,255,.1);--b3:rgba(255,255,255,.16);--text:#eeeef5;--muted:#7a7a96;--faint:#383852;--fabric:#3b82f6;--fabric-bg:rgba(59,130,246,.1);--copilot:#a855f7;--copilot-bg:rgba(168,85,247,.1);--azure:#10b981;--azure-bg:rgba(16,185,129,.1);--sql:#f59e0b;--sql-bg:rgba(245,158,11,.1);--done:#10b981;--inprog:#3b82f6;--rdonly:#6366f1;--accent:#6366f1;--danger:#ef4444}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);font-size:14px;min-height:100vh;overflow-x:hidden}
::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--faint);border-radius:5px}

/* HEADER */
.app-header{position:sticky;top:0;z-index:200;background:rgba(9,9,14,.94);backdrop-filter:blur(14px);border-bottom:1px solid var(--b1);padding:0 28px;display:flex;align-items:center;gap:24px;height:56px}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.logo-icon{width:30px;height:30px;border-radius:9px;background:linear-gradient(135deg,var(--accent),#a855f7);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.logo-text{font-family:'Syne',sans-serif;font-size:13px;font-weight:700;line-height:1.1;white-space:nowrap}
.logo-sub{font-family:'DM Mono',monospace;font-size:9px;color:var(--muted);letter-spacing:.06em}
.nav{display:flex;gap:3px;flex:1}
.nav-btn{padding:5px 13px;border-radius:8px;border:none;background:transparent;color:var(--muted);font-family:'DM Sans',sans-serif;font-size:12px;cursor:pointer;transition:all .15s;position:relative;display:flex;align-items:center;gap:6px}
.nav-btn:hover{color:var(--text);background:var(--s2)}
.nav-btn.active{background:var(--s2);color:var(--text);border:1px solid var(--b2)}
.nav-badge{background:var(--accent);color:white;font-family:'DM Mono',monospace;font-size:9px;padding:1px 5px;border-radius:100px;min-width:16px;text-align:center;line-height:1.4}
.hdr-right{margin-left:auto;display:flex;align-items:center;gap:14px}
.hdr-pct{font-family:'DM Mono',monospace;font-size:11px;color:var(--muted)}
.hdr-pct strong{color:var(--done)}
.hdr-last{font-family:'DM Mono',monospace;font-size:10px;color:var(--faint)}

/* TABS */
.tab{display:none;animation:fadeUp .25s ease}
.tab.active{display:block}
.page{max-width:1160px;margin:0 auto;padding:36px 28px 80px}

/* DASHBOARD */
.dash-title{font-family:'Syne',sans-serif;font-size:32px;font-weight:800;line-height:1.05;background:linear-gradient(135deg,#fff 0%,#9090b8 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:6px}
.dash-sub{font-size:13px;color:var(--muted);margin-bottom:28px}
.stats-row{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:24px}
.sc{background:var(--s1);border:1px solid var(--b1);border-radius:12px;padding:16px;position:relative;overflow:hidden}
.sc::after{content:'';position:absolute;top:0;left:0;right:0;height:2px}
.sc.total::after{background:linear-gradient(90deg,#6366f1,#a855f7)}.sc.cdone::after{background:var(--done)}.sc.cinp::after{background:var(--inprog)}.sc.cro::after{background:var(--rdonly)}.sc.cpend::after{background:var(--faint)}
.sc-lbl{font-family:'DM Mono',monospace;font-size:10px;color:var(--muted);letter-spacing:.06em;margin-bottom:8px}
.sc-val{font-family:'Syne',sans-serif;font-size:28px;font-weight:700;line-height:1}
.sc.total .sc-val{color:#a5b4fc}.sc.cdone .sc-val{color:var(--done)}.sc.cinp .sc-val{color:var(--inprog)}.sc.cro .sc-val{color:var(--rdonly)}.sc.cpend .sc-val{color:var(--muted)}
.sc-sub{font-size:11px;color:var(--muted);margin-top:5px}
.cat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:32px}
.cc{background:var(--s1);border:1px solid var(--b1);border-radius:12px;padding:16px}
.cc-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.cc-name{font-size:12px;font-weight:500;display:flex;align-items:center;gap:6px}
.cc-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.cc-count{font-family:'DM Mono',monospace;font-size:11px;color:var(--muted)}
.cc-bar-bg{height:3px;background:var(--b1);border-radius:3px;overflow:hidden;margin-bottom:8px}
.cc-bar{height:100%;border-radius:3px;transition:width 1s cubic-bezier(.34,1.56,.64,1)}
.cc-pct{font-family:'DM Mono',monospace;font-size:22px;font-weight:500}
.fabric{color:var(--fabric)}.copilot{color:var(--copilot)}.azure{color:var(--azure)}.sql{color:var(--sql)}
.cc-bar.fabric{background:var(--fabric)}.cc-bar.copilot{background:var(--copilot)}.cc-bar.azure{background:var(--azure)}.cc-bar.sql{background:var(--sql)}

/* SECTION HEADER */
.sec-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.sec-title{font-family:'Syne',sans-serif;font-size:17px;font-weight:700}
.sec-eye{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}

/* PILLS */
.cpill{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:100px;font-size:11px;font-weight:500}
.cpill.fabric{background:var(--fabric-bg);color:var(--fabric);border:1px solid rgba(59,130,246,.18)}
.cpill.copilot{background:var(--copilot-bg);color:var(--copilot);border:1px solid rgba(168,85,247,.18)}
.cpill.azure{background:var(--azure-bg);color:var(--azure);border:1px solid rgba(16,185,129,.18)}
.cpill.sql{background:var(--sql-bg);color:var(--sql);border:1px solid rgba(245,158,11,.18)}
.spill{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:100px;font-size:11px;font-weight:500;cursor:pointer;transition:opacity .15s;white-space:nowrap;user-select:none}
.spill:hover{opacity:.75}
.spill.done{background:rgba(16,185,129,.1);color:var(--done);border:1px solid rgba(16,185,129,.2)}
.spill.in-progress{background:rgba(59,130,246,.1);color:var(--inprog);border:1px solid rgba(59,130,246,.2)}
.spill.readonly{background:rgba(99,102,241,.1);color:#818cf8;border:1px solid rgba(99,102,241,.2)}
.spill.not-started{background:transparent;color:var(--faint);border:1px solid var(--b1)}
.sdot{width:5px;height:5px;border-radius:50%;flex-shrink:0}
.sdot.done{background:var(--done)}.sdot.in-progress{background:var(--inprog)}.sdot.readonly{background:#818cf8}.sdot.not-started{background:var(--faint)}

/* FILTER BAR */
.fbar{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:12px}
.fb{padding:4px 11px;border-radius:100px;border:1px solid var(--b1);background:transparent;color:var(--muted);font-size:11px;cursor:pointer;transition:all .15s;font-family:'DM Sans',sans-serif}
.fb:hover,.fb.active{border-color:var(--b2);color:var(--text);background:var(--s2)}
.fb.fabric.active{border-color:var(--fabric);color:var(--fabric);background:var(--fabric-bg)}
.fb.copilot.active{border-color:var(--copilot);color:var(--copilot);background:var(--copilot-bg)}
.fb.azure.active{border-color:var(--azure);color:var(--azure);background:var(--azure-bg)}
.fb.sql.active{border-color:var(--sql);color:var(--sql);background:var(--sql-bg)}
.fb.fdone.active{border-color:var(--done);color:var(--done);background:rgba(16,185,129,.1)}
.fb.finp.active{border-color:var(--inprog);color:var(--inprog);background:rgba(59,130,246,.1)}
.srch{margin-left:auto;background:var(--s1);border:1px solid var(--b1);border-radius:8px;padding:5px 12px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:12px;width:200px;outline:none;transition:border-color .15s}
.srch:focus{border-color:var(--b2)}.srch::placeholder{color:var(--faint)}

/* MODULE TABLE */
.tbl-wrap{background:var(--s1);border:1px solid var(--b1);border-radius:14px;overflow:hidden}
table{width:100%;border-collapse:collapse}
thead tr{background:var(--s2);border-bottom:1px solid var(--b1)}
thead th{padding:9px 13px;text-align:left;font-family:'DM Mono',monospace;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.mrow{border-bottom:1px solid var(--b1);transition:background .1s;cursor:pointer}
.mrow:hover{background:rgba(255,255,255,.014)}
.mrow.exp{background:rgba(99,102,241,.04);border-bottom:none}
.drow{display:none;border-bottom:1px solid var(--b1)}
.drow.open{display:table-row}
td{padding:10px 13px;vertical-align:middle}
.td-arrow{width:36px;text-align:center;color:var(--faint);font-size:11px;transition:transform .2s,color .15s;user-select:none}
.mrow.exp .td-arrow{transform:rotate(90deg);color:var(--accent)}
.td-num{font-family:'DM Mono',monospace;font-size:10px;color:var(--faint);width:36px;text-align:center}
.td-name{font-size:13px}
.td-date{font-family:'DM Mono',monospace;font-size:11px;color:var(--muted)}
.td-proof{font-family:'DM Mono',monospace;font-size:10px;color:var(--muted);background:var(--s2);border:1px solid var(--b1);padding:1px 7px;border-radius:5px;cursor:pointer}
.td-proof.has-proof{color:var(--done);border-color:rgba(16,185,129,.2);background:rgba(16,185,129,.07)}

/* DETAIL PANEL */
.dp{background:var(--s2);border-top:1px solid var(--b1);padding:20px 20px 20px 46px}
.dp-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.dp-full{grid-column:1/-1}
.dp-lbl{font-family:'DM Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:5px}
.dp-input,.dp-ta{width:100%;background:var(--s1);border:1px solid var(--b1);border-radius:8px;padding:7px 11px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:13px;outline:none;transition:border-color .15s}
.dp-input:focus,.dp-ta:focus{border-color:var(--b2)}
.dp-ta{resize:vertical;min-height:68px;line-height:1.55}
.dp-date{width:160px}
input[type=date]::-webkit-calendar-picker-indicator{filter:invert(.5);cursor:pointer}
.dp-actions{display:flex;align-items:center;gap:8px}

/* UPLOAD ZONE */
.uz{border:1px dashed var(--b2);border-radius:10px;padding:14px;text-align:center;cursor:pointer;transition:all .2s;background:var(--s1)}
.uz:hover,.uz.drag{border-color:var(--accent);background:rgba(99,102,241,.04)}
.uz input{display:none}
.uz-icon{font-size:18px;margin-bottom:4px}
.uz-txt{font-size:11px;color:var(--muted)}.uz-txt strong{color:var(--accent)}
.thumb-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.thumb{position:relative;width:72px;height:72px;border-radius:8px;overflow:hidden;border:1px solid var(--b1);cursor:pointer;flex-shrink:0;transition:transform .15s}
.thumb:hover{transform:scale(1.05)}
.thumb img{width:100%;height:100%;object-fit:cover}
.thumb-del{position:absolute;top:3px;right:3px;width:18px;height:18px;border-radius:50%;background:rgba(0,0,0,.75);border:none;color:white;font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s}
.thumb:hover .thumb-del{opacity:1}

/* BUTTONS */
.btn-primary{padding:7px 18px;background:var(--accent);color:white;border:none;border-radius:8px;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;cursor:pointer;transition:opacity .15s}
.btn-primary:hover{opacity:.85}
.btn-ghost{padding:7px 13px;background:transparent;color:var(--muted);border:1px solid var(--b1);border-radius:8px;font-family:'DM Sans',sans-serif;font-size:12px;cursor:pointer;transition:all .15s}
.btn-ghost:hover{color:var(--text);border-color:var(--b2)}
.btn-danger{padding:7px 13px;background:rgba(239,68,68,.1);color:#f87171;border:1px solid rgba(239,68,68,.2);border-radius:8px;font-family:'DM Sans',sans-serif;font-size:12px;cursor:pointer;transition:all .15s}
.btn-danger:hover{background:rgba(239,68,68,.18)}

/* PROJECTS */
.proj-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.pcard{background:var(--s1);border:1px solid var(--b1);border-radius:16px;padding:22px;position:relative;overflow:hidden;cursor:pointer;transition:all .2s}
.pcard::before{content:'';position:absolute;top:0;left:0;right:0;height:3px}
.pcard.p1::before{background:linear-gradient(90deg,var(--fabric),#60a5fa)}
.pcard.p2::before{background:linear-gradient(90deg,var(--copilot),#c084fc)}
.pcard.p3::before{background:linear-gradient(90deg,var(--azure),#34d399)}
.pcard.p4::before{background:linear-gradient(90deg,var(--sql),#fcd34d)}
.pcard:hover{border-color:var(--b2);transform:translateY(-2px)}
.pcard.locked{opacity:.72;cursor:not-allowed}
.pcard.locked:hover{transform:none;border-color:var(--b1)}
.lock-note{margin-top:10px;font-size:11px;color:var(--muted)}
.all-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.all-card{background:var(--s1);border:1px solid var(--b1);border-radius:14px;padding:16px}
.all-kpi{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px}
.all-k{background:var(--s2);border:1px solid var(--b1);border-radius:10px;padding:10px}
.all-k .lbl{font-family:'DM Mono',monospace;font-size:10px;color:var(--muted);text-transform:uppercase}
.all-k .val{font-family:'Syne',sans-serif;font-size:20px;line-height:1.1;margin-top:4px}
.all-bar-bg{height:4px;background:var(--b1);border-radius:4px;overflow:hidden;margin-top:8px}
.all-bar{height:100%;background:var(--accent)}
.trend-wrap{margin-top:14px}
.trend-legend{display:flex;gap:14px;align-items:center;font-size:11px;color:var(--muted);margin-bottom:8px}
.legend-dot{width:10px;height:10px;border-radius:50%;display:inline-block;margin-right:5px}
.trend-svg{width:100%;height:260px;background:var(--s2);border:1px solid var(--b1);border-radius:10px}
.pcard-num{font-family:'DM Mono',monospace;font-size:10px;color:var(--muted);margin-bottom:7px;letter-spacing:.08em;text-transform:uppercase}
.pcard-title{font-family:'Syne',sans-serif;font-size:15px;font-weight:700;margin-bottom:8px;line-height:1.3}
.pcard-desc{font-size:12px;color:var(--muted);line-height:1.6;margin-bottom:14px}
.pcard-meta{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}
.pcard-tags{display:flex;gap:5px;flex-wrap:wrap}
.ptag{padding:2px 7px;border-radius:4px;background:var(--s2);color:var(--muted);border:1px solid var(--b1);font-family:'DM Mono',monospace;font-size:10px}
.pcard-prog-wrap{margin-top:14px}
.pcard-prog-lbl{display:flex;justify-content:space-between;font-size:11px;color:var(--muted);margin-bottom:5px}
.pcard-bar{height:3px;background:var(--b1);border-radius:3px;overflow:hidden}
.pcard-bar-fill{height:100%;border-radius:3px;transition:width .6s ease}
.p1 .pcard-bar-fill{background:var(--fabric)}.p2 .pcard-bar-fill{background:var(--copilot)}.p3 .pcard-bar-fill{background:var(--azure)}.p4 .pcard-bar-fill{background:var(--sql)}
.pcard-shots{font-size:11px;color:var(--muted)}

/* PROJECT DETAIL */
.proj-detail{display:none}
.proj-detail.open{display:block;animation:fadeUp .25s ease}
.back-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 13px;border-radius:8px;border:1px solid var(--b1);background:transparent;color:var(--muted);font-family:'DM Sans',sans-serif;font-size:12px;cursor:pointer;margin-bottom:22px;transition:all .15s}
.back-btn:hover{color:var(--text);border-color:var(--b2)}
.pd-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px}
.pd-title{font-family:'Syne',sans-serif;font-size:24px;font-weight:800;margin-bottom:6px}
.pd-badge{padding:4px 12px;border-radius:100px;font-size:11px;font-weight:500}
.pd-badge.not-started{background:transparent;color:var(--faint);border:1px solid var(--b1)}
.pd-badge.in-progress{background:rgba(59,130,246,.1);color:var(--inprog);border:1px solid rgba(59,130,246,.2)}
.pd-badge.done{background:rgba(16,185,129,.1);color:var(--done);border:1px solid rgba(16,185,129,.2)}
.dtabs{display:flex;gap:2px;background:var(--s1);padding:4px;border-radius:10px;border:1px solid var(--b1);margin-bottom:22px;width:fit-content}
.dtab{padding:6px 15px;border-radius:7px;border:none;background:transparent;color:var(--muted);font-family:'DM Sans',sans-serif;font-size:12px;cursor:pointer;transition:all .15s}
.dtab.active{background:var(--s2);color:var(--text);border:1px solid var(--b1)}
.dtab-content{display:none}.dtab-content.active{display:block}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:20px}
.form-grid .fg-full{grid-column:1/-1}
.fg{margin-bottom:0}
.fg-lbl{font-family:'DM Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:5px}
.fg-input,.fg-ta,.fg-sel{width:100%;background:var(--s1);border:1px solid var(--b1);border-radius:8px;padding:7px 11px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:13px;outline:none;transition:border-color .15s}
.fg-input:focus,.fg-ta:focus,.fg-sel:focus{border-color:var(--b2)}
.fg-ta{resize:vertical;min-height:80px;line-height:1.55}
.fg-sel option{background:var(--s2)}
.prog-row{display:flex;align-items:center;gap:12px}
input[type=range]{-webkit-appearance:none;appearance:none;height:4px;background:var(--b1);border-radius:4px;outline:none;cursor:pointer;flex:1}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);border:2px solid var(--bg);cursor:pointer}
.prog-num{font-family:'DM Mono',monospace;font-size:15px;font-weight:500;min-width:38px}
.shot-grid{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px}
.shot-item{position:relative;width:160px;border-radius:10px;overflow:hidden;border:1px solid var(--b1);background:var(--s1)}
.shot-img{width:100%;height:110px;object-fit:cover;display:block;cursor:pointer;transition:opacity .15s}
.shot-img:hover{opacity:.85}
.shot-cap{padding:6px 8px;font-size:10px;color:var(--muted);border-top:1px solid var(--b1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:text}
.shot-del{position:absolute;top:5px;right:5px;width:22px;height:22px;border-radius:50%;background:rgba(0,0,0,.8);border:none;color:white;font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s}
.shot-item:hover .shot-del{opacity:1}
.update-list{margin-bottom:16px}
.update-item{display:flex;gap:13px;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--b1)}
.update-item:last-child{border-bottom:none}
.upd-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);flex-shrink:0;margin-top:4px}
.upd-date{font-family:'DM Mono',monospace;font-size:10px;color:var(--muted);margin-bottom:3px}
.upd-text{font-size:13px;line-height:1.55}
.add-upd-row{display:flex;gap:9px;align-items:flex-start}
.add-upd-ta{flex:1;background:var(--s1);border:1px solid var(--b1);border-radius:8px;padding:8px 11px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:13px;outline:none;resize:none;min-height:68px;line-height:1.55}
.add-upd-ta:focus{border-color:var(--b2)}
.metric-tbl-wrap{background:var(--s1);border:1px solid var(--b1);border-radius:10px;overflow:hidden;margin-bottom:14px}
.metric-tbl{width:100%;border-collapse:collapse}
.metric-tbl th{padding:8px 13px;background:var(--s2);font-family:'DM Mono',monospace;font-size:9px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);border-bottom:1px solid var(--b1);text-align:left}
.metric-tbl td{padding:9px 13px;border-bottom:1px solid var(--b1);font-size:13px}
.metric-tbl tr:last-child td{border-bottom:none}
.mtr-del{background:none;border:none;color:var(--muted);cursor:pointer;font-size:14px;transition:color .15s;padding:0 4px}
.mtr-del:hover{color:var(--danger)}
.add-mtr-row{display:grid;grid-template-columns:1fr 1fr auto;gap:8px}
.metric-empty{padding:20px;text-align:center;color:var(--muted);font-size:12px}

/* DAILY LOG */
.log-empty{text-align:center;padding:60px 20px;color:var(--muted);font-size:14px;line-height:1.8}
.log-empty strong{display:block;font-size:16px;color:var(--faint);margin-bottom:6px}
.new-entry-form{background:var(--s1);border:1px solid var(--accent);border-radius:14px;padding:22px;margin-bottom:22px;display:none}
.new-entry-form.open{display:block;animation:fadeUp .25s ease}
.nef-title{font-family:'Syne',sans-serif;font-size:15px;font-weight:700;margin-bottom:18px}
.nef-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.nef-grid .nef-full{grid-column:1/-1}
.nef-lbl{font-family:'DM Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:5px}
.nef-input,.nef-ta{width:100%;background:var(--s2);border:1px solid var(--b1);border-radius:8px;padding:7px 11px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:13px;outline:none;transition:border-color .15s}
.nef-input:focus,.nef-ta:focus{border-color:var(--b2)}
.nef-ta{resize:vertical;min-height:68px;line-height:1.55}
.mod-picker{background:var(--s2);border:1px solid var(--b1);border-radius:8px;padding:10px;max-height:180px;overflow-y:auto}
.mcheck{display:flex;align-items:center;gap:8px;padding:4px 6px;border-radius:6px;cursor:pointer;transition:background .1s;font-size:12px}
.mcheck:hover{background:var(--s3)}
.mcheck input{accent-color:var(--accent);flex-shrink:0}
.mcheck-cat{font-size:9px;font-family:'DM Mono',monospace;margin-left:auto;color:var(--muted);text-transform:uppercase}
.energy-row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.energy-item{display:flex;align-items:center;gap:7px;font-size:12px;padding:7px 10px;background:var(--s2);border:1px solid var(--b1);border-radius:8px;cursor:pointer;transition:all .15s}
.energy-item:hover{border-color:var(--b2)}
.energy-item input{accent-color:var(--accent)}
.energy-item.checked{background:rgba(99,102,241,.08);border-color:rgba(99,102,241,.25);color:var(--text)}
.log-entry{background:var(--s1);border:1px solid var(--b1);border-radius:14px;padding:20px;margin-bottom:12px;transition:border-color .2s}
.log-entry:hover{border-color:var(--b2)}
.le-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:14px}
.le-date{font-family:'Syne',sans-serif;font-size:14px;font-weight:700}
.le-day{font-family:'DM Mono',monospace;font-size:10px;color:var(--muted);margin-top:2px}
.le-del{background:none;border:none;color:var(--faint);cursor:pointer;font-size:14px;transition:color .15s;padding:4px}
.le-del:hover{color:var(--danger)}
.le-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.le-grid .le-full{grid-column:1/-1}
.le-sec-lbl{font-family:'DM Mono',monospace;font-size:9px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:5px}
.le-sec-val{font-size:13px;line-height:1.55}
.le-mods{display:flex;flex-wrap:wrap;gap:4px}
.le-mod-tag{padding:2px 7px;border-radius:4px;background:var(--s2);border:1px solid var(--b1);font-size:11px;color:var(--muted);font-family:'DM Mono',monospace}
.le-energy{display:flex;flex-wrap:wrap;gap:5px}
.le-eitem{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--azure);background:var(--azure-bg);border:1px solid rgba(16,185,129,.18);padding:2px 8px;border-radius:100px}

/* LIGHTBOX */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.93);display:none;align-items:center;justify-content:center;z-index:9999;cursor:pointer}
.lightbox.open{display:flex}
.lightbox img{max-width:90vw;max-height:90vh;border-radius:8px;object-fit:contain;pointer-events:none}

/* TOAST */
.toast{position:fixed;bottom:24px;right:24px;background:var(--s2);border:1px solid var(--b2);border-radius:10px;padding:11px 16px;font-size:13px;color:var(--text);box-shadow:0 16px 40px rgba(0,0,0,.5);z-index:8888;opacity:0;transform:translateY(8px);transition:all .25s;pointer-events:none;display:flex;align-items:center;gap:8px}
.toast.show{opacity:1;transform:translateY(0)}
.toast.ok .toast-icon{color:var(--done)}.toast.err .toast-icon{color:var(--danger)}

/* DIVIDER */
.div{border:none;border-top:1px solid var(--b1);margin:20px 0}

@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* STORAGE METER */
.stor-pill{display:flex;align-items:center;gap:7px;padding:4px 10px;border-radius:100px;background:var(--s1);border:1px solid var(--b1);font-family:'DM Mono',monospace;font-size:10px;color:var(--muted);cursor:default}
.stor-bar-bg{width:60px;height:4px;background:var(--b1);border-radius:4px;overflow:hidden}
.stor-bar-fill{height:100%;border-radius:4px;transition:width .5s ease;background:var(--done)}
.stor-bar-fill.warn{background:var(--sql)}.stor-bar-fill.danger{background:var(--danger)}

/* POMODORO TIMER */
.timer-fab{position:fixed;bottom:28px;left:28px;z-index:500;background:var(--s2);border:1px solid var(--b2);border-radius:16px;padding:14px 18px;min-width:220px;box-shadow:0 16px 48px rgba(0,0,0,.55);transition:all .3s}
.timer-fab.collapsed{min-width:0;width:56px;height:56px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:50%;cursor:pointer}
.timer-fab.collapsed .timer-body{display:none}
.timer-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.timer-label{font-family:'DM Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}
.timer-collapse{background:none;border:none;color:var(--muted);cursor:pointer;font-size:16px;padding:0 2px;transition:color .15s}
.timer-collapse:hover{color:var(--text)}
.timer-display{font-family:'Syne',sans-serif;font-size:38px;font-weight:800;text-align:center;letter-spacing:-.02em;margin:6px 0;line-height:1}
.timer-display.work{color:#a5b4fc}.timer-display.break{color:var(--done)}
.timer-phase{text-align:center;font-size:11px;font-family:'DM Mono',monospace;color:var(--muted);margin-bottom:12px}
.timer-controls{display:flex;gap:6px;justify-content:center}
.tbtn{padding:6px 14px;border-radius:8px;border:none;font-family:'DM Sans',sans-serif;font-size:12px;cursor:pointer;transition:all .15s;font-weight:500}
.tbtn.start{background:var(--accent);color:#fff}.tbtn.start:hover{opacity:.85}
.tbtn.reset{background:var(--s1);color:var(--muted);border:1px solid var(--b1)}.tbtn.reset:hover{color:var(--text)}
.timer-sessions{text-align:center;font-family:'DM Mono',monospace;font-size:10px;color:var(--muted);margin-top:8px}
.timer-fab-icon{font-size:22px}

/* STREAK CARD */
.streak-card{background:var(--s1);border:1px solid var(--b1);border-radius:12px;padding:16px;position:relative;overflow:hidden;grid-column:span 1}
.streak-card::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,#f59e0b,#ef4444)}
.streak-val{font-family:'Syne',sans-serif;font-size:28px;font-weight:700;color:#fbbf24}
.streak-fire{font-size:18px}

/* WEEKLY TARGETS */
.wt-card{background:var(--s1);border:1px solid var(--b1);border-radius:14px;padding:20px;margin-bottom:18px}
.wt-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.wt-title{font-family:'Syne',sans-serif;font-size:14px;font-weight:700}
.wt-week{font-family:'DM Mono',monospace;font-size:10px;color:var(--muted)}
.wt-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.wt-lbl{font-size:12px;min-width:160px;color:var(--muted)}
.wt-inp{background:var(--s2);border:1px solid var(--b1);border-radius:7px;padding:5px 9px;color:var(--text);font-family:'DM Mono',monospace;font-size:12px;width:60px;outline:none;text-align:center}
.wt-inp:focus{border-color:var(--b2)}
.wt-progress{flex:1;height:4px;background:var(--b1);border-radius:4px;overflow:hidden}
.wt-fill{height:100%;border-radius:4px;background:var(--accent);transition:width .5s ease}
.wt-pct{font-family:'DM Mono',monospace;font-size:10px;color:var(--muted);min-width:36px;text-align:right}

/* RESPONSIVE */
@media (max-width:1024px){
  .app-header{
    height:auto;
    min-height:56px;
    padding:10px 14px;
    gap:10px;
    flex-wrap:wrap;
    align-items:flex-start;
  }
  .nav{
    order:3;
    flex:1 1 100%;
    overflow-x:auto;
    overflow-y:hidden;
    white-space:nowrap;
    padding-bottom:2px;
    -webkit-overflow-scrolling:touch;
  }
  .nav-btn{flex:0 0 auto}
  .hdr-right{
    margin-left:auto;
    flex-wrap:wrap;
    gap:8px;
    justify-content:flex-end;
  }
  .page{padding:24px 14px 80px}
  .stats-row{grid-template-columns:repeat(3,minmax(0,1fr))}
  .cat-row{grid-template-columns:repeat(2,minmax(0,1fr))}
  .proj-grid,.all-grid{grid-template-columns:1fr}
  .dp-grid,.form-grid,.nef-grid,.le-grid{grid-template-columns:1fr}
  .energy-row{grid-template-columns:repeat(2,minmax(0,1fr))}
  .wt-row{flex-wrap:wrap;align-items:flex-start}
  .wt-lbl{min-width:100%}
  .wt-pct{text-align:left;min-width:0}
  .srch{width:100%;margin-left:0}
  .tbl-wrap{overflow:auto}
  table{min-width:760px}
  .dp{padding:16px}
  .dtabs{width:100%;overflow:auto}
  .shot-item{width:calc(50% - 6px)}
  .timer-fab{left:14px;right:14px;bottom:14px;min-width:0}
  .timer-fab.collapsed{right:auto}
}

@media (max-width:700px){
  .dash-title{font-size:26px}
  .dash-sub{font-size:12px}
  .stats-row{grid-template-columns:1fr !important}
  .cat-row{grid-template-columns:1fr}
  .sec-hdr{flex-direction:column;align-items:flex-start;gap:8px}
  .add-badge-row,.add-upd-row,.add-mtr-row{grid-template-columns:1fr;display:grid}
  .shot-item{width:100%}
  .hdr-last{display:none}
  .stor-pill{display:none}
  .wt-card{padding:14px}
}

@media (max-width:480px){
  .page{padding:18px 10px 84px}
  .logo-text{font-size:12px}
  .logo-sub{font-size:8px}
  .nav-btn{padding:5px 10px;font-size:11px}
  .stats-row{grid-template-columns:1fr}
  .sc-val{font-size:24px}
  .timer-display{font-size:34px}
  .timer-controls{flex-direction:column}
  .tbtn{width:100%}
}

/* BADGE TRACKER */
.badge-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px}
.badge-item{background:var(--s1);border:1px solid var(--b1);border-radius:10px;padding:13px;cursor:pointer;transition:all .15s;position:relative}
.badge-item:hover{border-color:var(--b2)}
.badge-item.claimed{background:rgba(16,185,129,.06);border-color:rgba(16,185,129,.25)}
.badge-icon{font-size:22px;margin-bottom:6px}
.badge-name{font-size:12px;line-height:1.4;margin-bottom:5px}
.badge-cat{font-family:'DM Mono',monospace;font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.badge-check{position:absolute;top:8px;right:8px;font-size:14px;color:var(--done)}
.badge-date{font-family:'DM Mono',monospace;font-size:9px;color:var(--muted);margin-top:4px}
.add-badge-row{display:flex;gap:8px;align-items:center}

/* MODULE TIME LOG */
.mtime-row{display:flex;align-items:center;gap:8px;margin-top:8px}
.mtime-inp{width:80px;background:var(--s1);border:1px solid var(--b1);border-radius:7px;padding:5px 9px;color:var(--text);font-family:'DM Mono',monospace;font-size:12px;outline:none;text-align:center}
.mtime-inp:focus{border-color:var(--b2)}
.mtime-lbl{font-size:12px;color:var(--muted)}

/* PRINT EXPORT */
@media print{
  .app-header,.nav,.hdr-right,.timer-fab,.btn-primary,.btn-ghost,.btn-danger,.fbar,.dp-actions,.le-del,.shot-del,.thumb-del,.back-btn,.dtabs,.add-upd-row,.add-mtr-row,.uz,.new-entry-form,.no-print{display:none!important}
  body{background:#fff!important;color:#111!important;font-size:12pt}
  .tab{display:block!important}
  .sc,.cc,.pcard,.log-entry,.wt-card,.badge-item{border:1px solid #ddd!important;background:#fff!important;break-inside:avoid}
  .dash-title{color:#111!important;-webkit-text-fill-color:#111!important}
  .muted,.hdr-last{color:#666!important}
  :root{--text:#111;--muted:#666;--s1:#fff;--s2:#f9f9f9;--s3:#f0f0f0;--b1:#ddd;--b2:#ccc}
}
.print-only{display:none}
@media print{.print-only{display:block}}

