:root{
  --bg:#0C0C0C; --surface:#161616; --surface-2:#1D1D1D; --surface-3:#262626;
  --border:rgba(255,255,255,.07); --border-2:rgba(255,255,255,.14);
  --text:#FFFFFF; --text-2:rgba(255,255,255,.56); --text-3:rgba(255,255,255,.34);
  --lime:#D2FF4C; --lime-2:#bff03a; --ink:#0C0C0C;
  --r-card:20px; --r:13px; --r-sm:9px;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{background:var(--bg);color:var(--text);font-family:'Inter',system-ui,-apple-system,sans-serif;line-height:1.4;-webkit-font-smoothing:antialiased}
body{padding:0 0 80px}
.app{max-width:1480px;margin:0 auto;padding:22px 26px}
::selection{background:var(--lime);color:var(--ink)}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,textarea{font-family:inherit;color:var(--text);background:none;border:none;outline:none;width:100%;resize:none}
input::placeholder,textarea::placeholder{color:var(--text-3)}
::-webkit-scrollbar{height:9px;width:9px}
::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:9px}
::-webkit-scrollbar-track{background:transparent}
.ic{display:inline-block;vertical-align:-.15em;width:1em;height:1em;flex-shrink:0;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

.btn{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;padding:10px 15px;border-radius:var(--r);border:1px solid var(--border-2);background:var(--surface);transition:.15s;white-space:nowrap}
.btn:hover{background:var(--surface-2);border-color:rgba(255,255,255,.22)}
.btn .ic{font-size:16px}
.btn-lime{background:var(--lime);color:var(--ink);border-color:var(--lime)}
.btn-lime:hover{background:var(--lime-2);border-color:var(--lime-2)}
.btn-block{width:100%;justify-content:center;padding:13px;font-size:14px}
.btn-sm{padding:6px 11px;font-size:12px;border-radius:9px}
.btn-danger{color:#ff7a7a;border-color:rgba(255,122,122,.3)}
.btn-danger:hover{background:rgba(255,122,122,.1);border-color:rgba(255,122,122,.5)}

/* ---------- AUTH ---------- */
.auth-view{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px}
.auth-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-card);padding:34px 30px}
.auth-logo{width:54px;height:54px;border-radius:15px;background:var(--lime);color:var(--ink);display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
.auth-logo .ic{width:30px;height:30px}
.auth-title{font-size:23px;font-weight:700;text-align:center;letter-spacing:-.02em}
.auth-sub{font-size:13.5px;color:var(--text-2);text-align:center;margin-top:5px;margin-bottom:22px;font-weight:500}
.auth-err{background:rgba(255,122,122,.12);border:1px solid rgba(255,122,122,.3);color:#ff9b9b;font-size:13px;font-weight:500;padding:10px 13px;border-radius:var(--r);margin-bottom:14px}
.field{display:flex;align-items:center;gap:11px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r);padding:0 14px;margin-bottom:11px;transition:.15s}
.field:focus-within{border-color:var(--border-2)}
.field .ic{color:var(--text-3);font-size:18px}
.field input{font-size:14.5px;font-weight:500;padding:13px 0;color-scheme:dark}
.auth-switch{text-align:center;margin-top:18px;font-size:13.5px;color:var(--text-2);font-weight:500}
.auth-switch button{color:var(--lime);font-weight:600;font-size:13.5px}
.auth-switch button:hover{text-decoration:underline}
.auth-foot{color:var(--text-3);font-size:12px;margin-top:24px;font-weight:500}
.auth-foot b{color:var(--lime);font-weight:600}

/* ---------- Header ---------- */
.top{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:16px}
.brand{display:flex;align-items:center;gap:13px}
.logo{width:42px;height:42px;border-radius:12px;background:var(--lime);display:flex;align-items:center;justify-content:center;color:var(--ink)}
.logo .ic{width:24px;height:24px}
.brand h1{font-size:22px;font-weight:700;letter-spacing:-.02em;line-height:1.05}
.brand .sub{font-size:12.5px;color:var(--text-2);font-weight:500;margin-top:1px}
.top-right{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.datepick{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:9px 14px}
.datepick .ic{color:var(--lime);font-size:18px}
.datepick label{font-size:11px;color:var(--text-2);font-weight:500;display:block}
.datepick input[type=date]{font-size:13.5px;font-weight:600;color:var(--text);background:none;width:140px;color-scheme:dark}
.uchip{display:flex;align-items:center;gap:9px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:7px 13px 7px 8px}
.uava{width:28px;height:28px;border-radius:50%;background:var(--lime);color:var(--ink);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0}
.uname{font-size:13.5px;font-weight:600}

/* ---------- Weekbar ---------- */
.weekbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:10px 12px;margin-bottom:18px}
.navbtn{width:36px;height:36px;border-radius:10px;border:1px solid var(--border-2);display:flex;align-items:center;justify-content:center;background:var(--surface-2);transition:.15s;flex-shrink:0}
.navbtn:hover{background:var(--surface-3);border-color:var(--lime);color:var(--lime)}
.navbtn .ic{font-size:18px}
.wb-range{font-size:15px;font-weight:700;letter-spacing:-.01em;white-space:nowrap}
.wb-tag{font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}
.wb-tag.now{background:var(--lime);color:var(--ink)}
.wb-tag.past{background:var(--surface-3);color:var(--text-2)}
.wb-tag.future{background:rgba(210,255,76,.14);color:var(--lime)}
.wb-spacer{flex:1;min-width:8px}
.toggle{display:flex;align-items:center;gap:8px;font-size:12.5px;font-weight:600;color:var(--text-2);cursor:pointer;user-select:none}
.toggle .sw{width:38px;height:22px;border-radius:20px;background:var(--surface-3);position:relative;transition:.15s;flex-shrink:0}
.toggle .sw::after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:var(--text-2);transition:.15s}
.toggle.on{color:var(--text)}
.toggle.on .sw{background:var(--lime)}
.toggle.on .sw::after{background:var(--ink);transform:translateX(16px)}

/* ---------- Hero ---------- */
.hero{display:grid;grid-template-columns:auto 1fr;gap:30px;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-card);padding:24px 30px;margin-bottom:22px}
.ring{position:relative;width:128px;height:128px;flex-shrink:0}
.ring .val{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.ring .val b{font-size:30px;font-weight:800;letter-spacing:-.02em}
.ring .val span{font-size:11px;color:var(--text-2);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.hero-stats{display:flex;gap:30px;flex-wrap:wrap}
.hstat .n{font-size:25px;font-weight:800;letter-spacing:-.02em}
.hstat .n.lime{color:var(--lime)}
.hstat .l{font-size:11.5px;color:var(--text-2);font-weight:600;text-transform:uppercase;letter-spacing:.03em;margin-top:1px}

/* ---------- Section ---------- */
.section{margin-bottom:24px}
.sec-head{display:flex;align-items:center;gap:10px;margin:0 2px 13px}
.sec-head .ic{color:var(--lime);font-size:20px}
.sec-head h3{font-size:16px;font-weight:700;letter-spacing:-.01em}
.sec-head .count{margin-left:auto;font-size:12px;color:var(--text-2);font-weight:600;background:var(--surface-2);padding:4px 11px;border-radius:20px}
.count{font-size:12px;color:var(--text-2);font-weight:600;background:var(--surface-2);padding:4px 11px;border-radius:20px}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-card)}

/* ---------- Goals ---------- */
.goals{padding:18px 20px;display:flex;flex-direction:column;gap:11px}
.goal{display:flex;align-items:center;gap:13px}
.goal .num{width:26px;height:26px;border-radius:8px;background:var(--surface-2);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--text-2);flex-shrink:0}
.goal input{font-size:15px;font-weight:500;padding:8px 0;border-bottom:1px solid transparent;transition:.15s}
.goal input:focus{border-bottom-color:var(--border-2)}
.goal.done input{color:var(--text-3);text-decoration:line-through}

/* ---------- Checkbox ---------- */
.chk{width:24px;height:24px;border-radius:50%;border:2px solid var(--border-2);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:.15s;cursor:pointer;color:var(--ink)}
.chk .ic{font-size:13px;opacity:0;transition:.12s;stroke-width:3}
.chk:hover{border-color:var(--lime)}
.chk.on{background:var(--lime);border-color:var(--lime)}
.chk.on .ic{opacity:1}
.chk.sq{border-radius:7px}

/* ---------- Days ---------- */
.days-nav{display:flex;align-items:center;gap:8px;margin-bottom:14px;overflow-x:auto;padding-bottom:2px;scrollbar-width:none}
.days-nav::-webkit-scrollbar{display:none}
.daypill{flex-shrink:0;padding:8px 15px;border-radius:11px;background:var(--surface);border:1px solid var(--border);font-size:13px;font-weight:600;color:var(--text-2);display:flex;flex-direction:column;align-items:center;line-height:1.2;min-width:62px;transition:.15s}
.daypill small{font-size:10.5px;color:var(--text-3);font-weight:600;margin-top:1px}
.daypill.active{background:var(--lime);border-color:var(--lime);color:var(--ink)}
.daypill.active small{color:rgba(12,12,12,.6)}
.daypill .dot{width:5px;height:5px;border-radius:50%;background:var(--lime);margin-top:3px}
.daypill.active .dot,.daypill .dot.hide{opacity:0}

.days{display:flex;gap:14px;overflow-x:auto;padding:2px 2px 12px;scroll-snap-type:x mandatory}
.day{scroll-snap-align:start;flex:0 0 272px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-card);display:flex;flex-direction:column;overflow:hidden}
.day.is-today{border-color:rgba(210,255,76,.4)}
.day-head{padding:16px 17px 14px;display:flex;align-items:center;justify-content:space-between;gap:10px;border-bottom:1px solid var(--border)}
.day-head .dname{font-size:15px;font-weight:700;text-transform:capitalize}
.day-head .ddate{font-size:12px;color:var(--text-2);font-weight:500;margin-top:1px}
.badge-today{font-size:10px;font-weight:700;color:var(--ink);background:var(--lime);padding:3px 8px;border-radius:20px;text-transform:uppercase;letter-spacing:.03em}
.minidonut{position:relative;width:52px;height:52px;flex-shrink:0}
.minidonut .p{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800}
.day-body{padding:13px 15px 6px;flex:1}
.task{display:flex;align-items:center;gap:10px;padding:5px 0}
.task input{font-size:14px;font-weight:500;padding:3px 0}
.task.done input{color:var(--text-3);text-decoration:line-through}
.task .del{opacity:0;color:var(--text-3);font-size:16px;transition:.12s;flex-shrink:0;cursor:pointer;padding:4px;margin:-4px}
.task:hover .del{opacity:1}
.task .del:hover{color:#ff6b6b}
@media(hover:none){ .task .del{opacity:.5;font-size:18px} }
.add-task{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--text-2);padding:8px 0 4px;transition:.15s}
.add-task:hover{color:var(--lime)}
.add-task .ic{font-size:17px}
.day-foot{padding:12px 15px;border-top:1px solid var(--border);display:flex;gap:8px}
.df{flex:1;background:var(--surface-2);border-radius:var(--r);padding:8px 11px}
.df .n{font-size:18px;font-weight:800}
.df .n.lime{color:var(--lime)}
.df .l{font-size:10.5px;color:var(--text-2);font-weight:600;margin-top:1px}
.notes{padding:11px 15px 15px}
.notes-t{font-size:11px;font-weight:700;color:var(--text-2);text-transform:uppercase;letter-spacing:.04em;margin-bottom:7px;display:flex;align-items:center;gap:6px}
.notes-t .ic{font-size:13px;color:var(--text-2)}
.note{display:flex;align-items:flex-start;gap:8px;padding:2px 0}
.note span{color:var(--text-3);font-size:13px;font-weight:600;line-height:1.9}
.note input{font-size:13px;padding:3px 0}

/* ---------- Analytics ---------- */
.analytics{display:grid;grid-template-columns:1.15fr 1fr;gap:16px}
.metrics{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.metric{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:16px 17px}
.metric .ic{font-size:19px;color:var(--lime)}
.metric .n{font-size:27px;font-weight:800;letter-spacing:-.02em;margin-top:9px}
.metric .l{font-size:12px;color:var(--text-2);font-weight:600;margin-top:2px}
.metric.wide{grid-column:span 2;display:flex;align-items:center;gap:16px}
.metric.wide .n{margin-top:0;font-size:23px}
.metric.wide .txt{flex:1}
.chart-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-card);padding:18px 20px;display:flex;flex-direction:column}
.chart-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.chart-head .t{font-size:14px;font-weight:700}
.legend{display:flex;gap:14px;font-size:11.5px;color:var(--text-2);font-weight:500}
.legend span{display:flex;align-items:center;gap:5px}
.legend i{width:10px;height:10px;border-radius:3px;display:inline-block}
#weekChart{width:100%;flex:1;min-height:170px}

/* ---------- Tracker / tables ---------- */
.tbl-wrap{overflow-x:auto;padding:6px}
table.tracker{width:100%;border-collapse:collapse;min-width:560px}
.tracker th,.tracker td{padding:11px 9px;text-align:center;border-bottom:1px solid var(--border)}
.tracker th{font-size:11px;font-weight:700;color:var(--text-2);text-transform:uppercase;letter-spacing:.03em}
.tracker th.h-name,.tracker td.c-name{text-align:left;min-width:150px;padding-left:14px}
.tracker tr:last-child td{border-bottom:none}
.tracker td.c-name input{font-size:14px;font-weight:600}
.tracker .day-th small{display:block;font-size:9.5px;color:var(--text-3);font-weight:500}
.tracker .chk{margin:0 auto}
.stars{display:flex;gap:2px;justify-content:center}
.stars svg{width:15px;height:15px}
.pct-cell{font-size:13px;font-weight:700;color:var(--lime);min-width:46px}

/* admin table */
.admin-tbl td{font-size:13.5px}
.admin-tbl td.c-name{font-weight:600}
.admin-tbl .uemail{font-size:12px;color:var(--text-2);font-weight:500}
.role-pill{font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;text-transform:uppercase}
.role-pill.admin{background:var(--lime);color:var(--ink)}
.role-pill.user{background:var(--surface-3);color:var(--text-2)}
.status-pill{font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px}
.status-pill.active{background:rgba(93,202,165,.18);color:#7fe3c2}
.status-pill.blocked{background:rgba(255,122,122,.16);color:#ff9b9b}
.row-actions{display:flex;gap:6px;justify-content:center;flex-wrap:wrap}

.footer{text-align:center;color:var(--text-3);font-size:12px;margin-top:32px;font-weight:500}
.footer b{color:var(--lime);font-weight:600}

@media(max-width:960px){ .analytics{grid-template-columns:1fr} .hero{grid-template-columns:1fr} }
@media(max-width:680px){
  .app{padding:16px 14px}
  body{padding-bottom:60px}
  .brand h1{font-size:19px}
  .logo{width:38px;height:38px}
  .uname{display:none}
  .hero{padding:18px;gap:18px}
  .ring{width:104px;height:104px}
  .hero-stats{gap:18px 22px}
  .wb-spacer{display:none}
  .weekbar{gap:9px}
  .days{display:block;padding:0}
  .day{flex:none;width:100%;display:none}
  .day.show{display:flex}
  .task .del{opacity:.5;font-size:18px}
  .metrics{gap:9px}
  .metric{padding:13px 14px}
  .metric .n{font-size:23px}
  .metric.wide .n{font-size:20px}
}

/* ---------- Diary (один день) ---------- */
.diary{padding:16px 18px}
.diary-nav{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.diary-day{min-width:170px;text-align:center}
.diary-day b{display:block;font-size:16px;font-weight:700;text-transform:capitalize;line-height:1.2}
.diary-day span{font-size:12.5px;color:var(--text-2);font-weight:500}
.diary-nav .badge-today,.diary-nav [data-dtoday]{margin-left:auto}
.navbtn[disabled]{opacity:.35;cursor:default;pointer-events:none}
.diary-short{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:12px}
.dfield,.dlong{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r);padding:11px 13px}
.dfield .fl,.dlong .fl{font-size:10.5px;font-weight:700;color:var(--text-2);text-transform:uppercase;letter-spacing:.03em;display:flex;align-items:center;gap:6px;margin-bottom:7px}
.dfield .fl .ic,.dlong .fl .ic{color:var(--lime);font-size:14px}
.dfield input{font-size:14.5px;font-weight:500}
.diary-long{display:flex;flex-direction:column;gap:12px}
.dlong textarea{width:100%;min-height:46px;font-size:14px;font-weight:500;line-height:1.55;resize:vertical;overflow-wrap:anywhere}
@media(max-width:680px){ .diary-short{grid-template-columns:1fr} }
