/* ═══════════════════════════════════════════════
   ABSOLUTE — Task Command Center
   XIX Century Classicism × Futurism · Monochrome
   ═══════════════════════════════════════════════ */

*{ margin:0; padding:0; box-sizing:border-box; }
:root{
    --bg: #fafafa;
    --bg2: #f0f0f0;
    --fg: #111;
    --fg2: #555;
    --fg3: #888;
    --border: rgba(0,0,0,0.18);
    --border2: rgba(0,0,0,0.35);
    --border3: rgba(0,0,0,0.75);
    --accent: #000;
    --danger: #c0392b;
    --success: #27ae60;
    --warning: #e67e22;
    --radius: 0px;
    --mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono","Courier New", monospace;
    --sans: 'Unbounded', sans-serif;
    --serif: 'Playfair Display SC', serif;
    --sidebar-w: 220px;
    --topbar-h: 0px;
    --transition: .18s ease;
}

html, body{ height:100%; }
body{
    font-family: var(--mono);
    font-size: 13px;
    color: var(--fg);
    background: var(--bg);
    overflow: hidden;
}

.hidden{ display:none !important; }

/* ─── AESTHETIC CURSOR ─── */
@media (hover: hover) and (pointer: fine) {
    *, *::before, *::after{ cursor:none !important; }
}
#aesthetic-cursor{
    position:fixed; left:0; top:0;
    width:0; height:0; z-index:99999;
    pointer-events:none; opacity:0;
    transform:translate3d(-9999px,-9999px,0);
    transition:opacity .18s ease;
    mix-blend-mode:multiply;
}
#aesthetic-cursor.active{ opacity:1; }

#aesthetic-cursor .ac-ring{
    position:absolute; left:0; top:0;
    width:44px; height:44px;
    transform:translate(-50%,-50%);
    border-radius:999px;
    border:1px solid rgba(0,0,0,0.55);
    outline:1px solid rgba(0,0,0,0.12);
    outline-offset:8px;
    box-shadow:0 0 0 1px rgba(0,0,0,0.08) inset, 0 14px 28px rgba(0,0,0,0.08);
    background:radial-gradient(circle at 50% 50%, rgba(0,0,0,0.04), transparent 60%);
    transition:width .12s ease, height .12s ease, border-color .12s ease,
               outline-color .12s ease, outline-offset .12s ease, box-shadow .12s ease;
}
#aesthetic-cursor .ac-ring::before{
    content:""; position:absolute; inset:7px;
    border-radius:999px; border:1px dashed rgba(0,0,0,0.25); opacity:0.75;
}

#aesthetic-cursor .ac-cross{
    position:absolute; left:0; top:0;
    width:18px; height:18px;
    transform:translate(-50%,-50%);
}
#aesthetic-cursor .ac-cross::before,
#aesthetic-cursor .ac-cross::after{
    content:""; position:absolute; left:50%; top:50%;
    transform:translate(-50%,-50%);
    background:rgba(0,0,0,0.55);
}
#aesthetic-cursor .ac-cross::before{ width:18px; height:1px; }
#aesthetic-cursor .ac-cross::after{ width:1px; height:18px; }

#aesthetic-cursor .ac-label{
    position:absolute; left:0; top:0;
    transform:translate(-50%,-50%) translateY(34px);
    font-family:var(--mono); font-size:10px;
    letter-spacing:2px; text-transform:uppercase;
    color:rgba(0,0,0,0.7); opacity:0;
    transition:opacity .12s ease, transform .12s ease, color .12s ease;
    white-space:nowrap;
}

/* hover state */
#aesthetic-cursor.is-hover .ac-ring{
    width:56px; height:56px; outline-offset:10px;
    border-color:rgba(0,0,0,0.75);
    box-shadow:0 0 0 1px rgba(0,0,0,0.10) inset, 0 18px 34px rgba(0,0,0,0.12);
}
#aesthetic-cursor.is-hover .ac-label{
    opacity:1; transform:translate(-50%,-50%) translateY(38px);
}

/* press state */
#aesthetic-cursor.is-down .ac-ring{
    width:40px; height:40px; outline-offset:6px;
}

/* invert on dark elements */
#aesthetic-cursor.inverted{ mix-blend-mode:screen; }
#aesthetic-cursor.inverted .ac-ring{
    border-color:rgba(255,255,255,0.8);
    outline-color:rgba(255,255,255,0.16);
    box-shadow:0 0 0 1px rgba(255,255,255,0.08) inset, 0 16px 34px rgba(0,0,0,0.25);
    background:radial-gradient(circle at 50% 50%, rgba(255,255,255,0.05), transparent 60%);
}
#aesthetic-cursor.inverted .ac-ring::before{ border-color:rgba(255,255,255,0.35); }
#aesthetic-cursor.inverted .ac-cross::before,
#aesthetic-cursor.inverted .ac-cross::after{ background:rgba(255,255,255,0.75); }
#aesthetic-cursor.inverted .ac-label{ color:rgba(255,255,255,0.85); }

@media (prefers-reduced-motion: reduce) {
    #aesthetic-cursor .ac-ring,
    #aesthetic-cursor .ac-label{ transition:none; }
}

/* ─── SCROLLBAR ─── */
::-webkit-scrollbar{ width:8px; height:8px; }
::-webkit-scrollbar-track{ background:transparent; }
::-webkit-scrollbar-thumb{ background:rgba(0,0,0,0.18); border-radius:0; }
::-webkit-scrollbar-thumb:hover{ background:rgba(0,0,0,0.35); }

/* ═══════════ LOGIN ═══════════ */
.login-screen{
    position:fixed; inset:0; z-index:9999;
    display:flex; align-items:center; justify-content:center;
    background:
        radial-gradient(900px 520px at 50% 42%, rgba(0,0,0,0.04), rgba(0,0,0,0) 62%),
        linear-gradient(180deg, rgba(0,0,0,0.015), rgba(0,0,0,0));
}
.login-bg{
    position:absolute; inset:0; pointer-events:none;
}
.login-grid{
    position:absolute; inset:-10%;
    background:
        linear-gradient(to right, rgba(0,0,0,0.04) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(0,0,0,0.03) 1px, transparent 1px);
    background-size: 60px 60px;
    opacity:0.7;
    mask-image: radial-gradient(circle at 50% 50%, black 0%, black 40%, transparent 75%);
}
.login-box{
    position:relative; z-index:1;
    width:min(460px, calc(100vw - 40px));
    border: 2px solid var(--border3);
    padding: 38px 34px 30px;
    background: rgba(255,255,255,0.92);
    backdrop-filter: blur(10px);
    box-shadow: 0 28px 60px rgba(0,0,0,0.10), 0 0 0 1px rgba(255,255,255,0.55) inset;
    overflow:hidden;
    animation: loginIn .55s cubic-bezier(0.16, 1, 0.3, 1) both;
}
.login-box::before{
    content:"";
    position:absolute;
    inset:12px;
    border:1px solid rgba(0,0,0,0.12);
    pointer-events:none;
}
.login-box::after{
    content:"";
    position:absolute;
    inset:-2px;
    border:2px solid transparent;
    background:
        linear-gradient(90deg, rgba(0,0,0,0.82) 0 30%, transparent 30% 100%) top left / 0% 2px no-repeat,
        linear-gradient(180deg, rgba(0,0,0,0.82) 0 30%, transparent 30% 100%) top right / 2px 0% no-repeat,
        linear-gradient(270deg, rgba(0,0,0,0.82) 0 30%, transparent 30% 100%) bottom right / 0% 2px no-repeat,
        linear-gradient(0deg, rgba(0,0,0,0.82) 0 30%, transparent 30% 100%) bottom left / 2px 0% no-repeat;
    opacity:0;
    pointer-events:none;
    animation:contactFrame .8s cubic-bezier(0.16, 1, 0.3, 1) .28s forwards, loginFrameFade .01s linear .28s forwards;
}
@keyframes loginIn{
    0%{ opacity:0; transform:translateY(24px) scale(0.975); filter:blur(4px); }
    100%{ opacity:1; transform:translateY(0) scale(1); }
}
@keyframes loginFrameFade{
    to{ opacity:1; }
}
.login-corner{
    position:absolute; width:14px; height:14px;
    border-color: var(--border3); border-style:solid;
    animation:loginCornerIn .45s ease both;
}
.login-corner.tl{ top:-6px; left:-6px; border-width:2px 0 0 2px; }
.login-corner.tr{ top:-6px; right:-6px; border-width:2px 2px 0 0; }
.login-corner.bl{ bottom:-6px; left:-6px; border-width:0 0 2px 2px; }
.login-corner.br{ bottom:-6px; right:-6px; border-width:0 2px 2px 0; }
@keyframes loginCornerIn{
    0%{ opacity:0; transform:scale(0.7); }
    100%{ opacity:1; transform:scale(1); }
}

.login-header{
    display:flex; align-items:center; justify-content:space-between;
    gap:18px;
    margin-bottom:14px;
}
.login-kicker{
    font-family:var(--mono); font-size:11px; letter-spacing:2px;
    text-transform:uppercase; color:var(--fg2);
    animation:trackingIn .7s cubic-bezier(0.16, 1, 0.3, 1) both;
}
.login-stamp{
    border:2px solid var(--danger); padding:4px 10px;
    font-family:var(--sans); font-size:10px; letter-spacing:2px;
    color:var(--danger); transform:rotate(-4deg);
    background:rgba(255,255,255,0.75);
    animation:stampSettle .9s cubic-bezier(0.2, 1, 0.3, 1) .08s both;
}
.login-divider{
    height:2px; background:var(--border3); margin-bottom:24px;
    transform-origin:left center;
    animation:drawLine .9s cubic-bezier(0.16, 1, 0.3, 1) .08s both;
}
.login-title{
    font-family:var(--sans); font-size:clamp(28px, 6vw, 42px);
    letter-spacing:4px; font-weight:700; line-height:1;
    clip-path:inset(0 100% 0 0);
    animation:clipLeft .9s cubic-bezier(0.16, 1, 0.3, 1) .14s forwards;
}
.login-subtitle{
    font-family:var(--mono); font-size:12px; letter-spacing:2px;
    text-transform:uppercase; color:var(--fg2); margin-top:8px;
    opacity:0;
    transform:translateY(10px);
    animation:fadeUp .55s cubic-bezier(0.16, 1, 0.3, 1) .22s forwards;
}
.login-form{ margin-top:30px; display:flex; flex-direction:column; gap:12px; }
.login-label{
    display:block; font-size:11px; letter-spacing:2px;
    text-transform:uppercase; color:var(--fg2); margin-bottom:8px;
}
.login-input-wrap{
    display:flex; gap:0;
    border:2px solid var(--border3);
    background:rgba(255,255,255,0.82);
    transition:border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}
.login-input-wrap:focus-within{
    border-color:#000;
    box-shadow:inset 0 0 0 1px rgba(0,0,0,0.08);
    transform:translateY(-1px);
}
.login-input{
    flex:1; border:none; outline:none;
    padding:14px 16px; font-family:var(--mono); font-size:16px;
    letter-spacing:2px; background:transparent;
}
.login-input + .login-submit{
    border-left:2px solid var(--border3);
}
.login-actions{
    display:grid;
    grid-template-columns:1fr;
    gap:12px;
    margin-top:6px;
}
.login-submit{
    min-height:64px;
    padding:16px 20px; border:none;
    background:#000; color:#fff; font-family:var(--sans); font-size:12px;
    letter-spacing:2px; cursor:pointer; transition:transform .18s ease, background var(--transition), box-shadow .18s ease, border-color .18s ease;
    text-transform:uppercase;
}
.login-submit:hover{
    background:#222;
    transform:translateY(-1px);
    box-shadow:0 14px 24px rgba(0,0,0,0.12);
}
.login-submit:active{ transform:translateY(0); }
.login-submit-secondary{
    background:#fff;
    color:#000;
    border:2px solid var(--border3);
}
.login-submit-secondary:hover{
    background:#f5f5f5;
}
.login-account-hint{
    margin-top:2px;
    font-size:10px;
    letter-spacing:1.6px;
    text-transform:uppercase;
    color:var(--fg2);
    opacity:0.85;
}
.login-account-hint span{
    color:var(--fg);
}
.login-error{
    min-height:16px;
    margin-top:2px; font-size:11px; letter-spacing:1px;
    color:var(--danger); opacity:0; transition:opacity .2s;
}
.login-error.show{ opacity:1; }
.login-switch{
    background:none; border:none; padding:0;
    font-family:var(--mono); font-size:10px; letter-spacing:1.5px;
    text-transform:uppercase; color:var(--fg);
    cursor:pointer; transition:color .18s ease;
}
.login-switch:hover{ color:#000; text-decoration:underline; text-underline-offset:3px; }
.login-footer{
    margin-top:26px; padding-top:16px; border-top:1px solid var(--border);
    display:flex; align-items:center; justify-content:space-between;
    font-size:10px; letter-spacing:1.5px; text-transform:uppercase;
    color:var(--fg3);
}

@keyframes contactFrame{
    0%{ background-size:0% 2px, 2px 0%, 0% 2px, 2px 0%; }
    100%{ background-size:100% 2px, 2px 100%, 100% 2px, 2px 100%; }
}
@keyframes trackingIn{
    0%{ letter-spacing:0.45em; opacity:0; filter:blur(4px); }
    100%{ letter-spacing:2px; opacity:1; filter:blur(0); }
}
@keyframes drawLine{
    0%{ transform:scaleX(0); }
    100%{ transform:scaleX(1); }
}
@keyframes clipLeft{
    0%{ clip-path:inset(0 100% 0 0); }
    100%{ clip-path:inset(0 0 0 0); }
}
@keyframes fadeUp{
    0%{ opacity:0; transform:translateY(12px); }
    100%{ opacity:1; transform:translateY(0); }
}
@keyframes stampSettle{
    0%{ opacity:0; transform:rotate(-10deg) translateY(-8px); }
    100%{ opacity:1; transform:rotate(-4deg) translateY(0); }
}

/* ═══════════ APP LAYOUT ═══════════ */
.app{
    display:grid;
    grid-template-columns: var(--sidebar-w) 1fr;
    grid-template-rows: 1fr;
    height:100vh;
}

/* ─── SIDEBAR ─── */
.sidebar{
    background:#000; color:#fff;
    display:flex; flex-direction:column;
    padding:20px 0;
    border-right:2px solid rgba(255,255,255,0.08);
}
.sidebar-logo{
    padding:0 20px 20px;
    border-bottom:1px solid rgba(255,255,255,0.12);
    margin-bottom:10px;
}
.sidebar-logo-img{ height:24px; filter:invert(1); }
.sidebar-nav{ flex:1; display:flex; flex-direction:column; gap:2px; padding:10px 10px; }
.sidebar-btn{
    display:flex; align-items:center; gap:12px;
    width:100%; padding:12px 14px;
    border:1px solid transparent; border-radius:var(--radius);
    background:transparent; color:rgba(255,255,255,0.6);
    font-family:var(--mono); font-size:12px; letter-spacing:1px;
    text-transform:uppercase; cursor:pointer;
    transition:all var(--transition);
    text-align:left;
}
.sidebar-btn:hover{
    color:#fff; background:rgba(255,255,255,0.06);
    border-color:rgba(255,255,255,0.08);
}
.sidebar-btn.active{
    color:#fff; background:rgba(255,255,255,0.10);
    border-color:rgba(255,255,255,0.15);
    box-shadow:inset 3px 0 0 #fff;
}
.sidebar-btn svg{ flex-shrink:0; opacity:0.7; }
.sidebar-btn.active svg{ opacity:1; }
.sidebar-footer{ padding:10px; border-top:1px solid rgba(255,255,255,0.08); }
.logout-btn{ color:rgba(255,255,255,0.4); }
.logout-btn:hover{ color:#fff; background:rgba(255,255,255,0.05); }

/* Sidebar backdrop (mobile) */
.sidebar-backdrop{
    display:none;
    position:fixed; inset:0; z-index:3999;
    background:rgba(0,0,0,0.45);
    backdrop-filter:blur(3px);
    opacity:0;
    transition:opacity .25s ease;
    cursor:pointer;
}
.sidebar-backdrop.active{
    display:block;
    opacity:1;
}

/* ─── TOPBAR (mobile) ─── */
.topbar{
    display:none; height:56px;
    background:#000; color:#fff;
    align-items:center; justify-content:space-between;
    padding:0 16px;
    border-bottom:2px solid rgba(255,255,255,0.08);
}
.topbar-title{
    font-family:var(--sans); font-size:14px; letter-spacing:3px; font-weight:700;
}
.topbar-burger{
    width:28px; height:20px; position:relative;
    background:none; border:none; cursor:pointer;
}
.topbar-burger span{
    display:block; width:100%; height:2px; background:#fff;
    position:absolute; left:0; transition:all .2s;
}
.topbar-burger span:nth-child(1){ top:0; }
.topbar-burger span:nth-child(2){ top:50%; transform:translateY(-50%); }
.topbar-burger span:nth-child(3){ bottom:0; }
.topbar-add{
    width:40px; height:40px;
    border:1px solid rgba(255,255,255,0.3);
    background:transparent; color:#fff;
    font-size:22px; font-family:var(--mono);
    cursor:pointer; display:flex; align-items:center; justify-content:center;
    transition:background .15s ease, border-color .15s ease;
}
.topbar-add:active{
    background:rgba(255,255,255,0.12);
    border-color:rgba(255,255,255,0.5);
}

/* ─── MAIN ─── */
.main{
    overflow-y:auto; overflow-x:hidden;
    padding:32px 40px;
    background:var(--bg);
    position:relative;
    -webkit-overflow-scrolling:touch;
    scroll-behavior:smooth;
}

/* ─── VIEWS ─── */
.view{ display:none; animation:viewIn .35s cubic-bezier(0.16, 1, 0.3, 1) both; }
.view.active{ display:block; }
@keyframes viewIn{
    0%{ opacity:0; transform:translateY(14px); filter:blur(2px); }
    100%{ opacity:1; transform:translateY(0); filter:blur(0); }
}

.view-header{
    display:flex; align-items:flex-start; justify-content:space-between;
    gap:16px; margin-bottom:28px;
    padding-bottom:16px; border-bottom:2px solid var(--border3);
}
.view-title{
    font-family:var(--sans); font-weight:700;
    font-size:clamp(24px, 4vw, 36px);
    letter-spacing:3px; text-transform:uppercase; line-height:1;
}
.view-subtitle{
    font-family:var(--mono); font-size:12px; letter-spacing:1.5px;
    text-transform:uppercase; color:var(--fg2); margin-top:6px;
}

/* ─── BUTTONS ─── */
.btn-primary{
    padding:12px 22px; border:2px solid #000;
    background:#000; color:#fff;
    font-family:var(--mono); font-size:12px; letter-spacing:1.5px;
    text-transform:uppercase; cursor:pointer;
    transition:all var(--transition); white-space:nowrap;
    min-height:44px;
}
.btn-primary:hover{ background:#333; border-color:#333; }
.btn-primary:active{ transform:scale(0.97); }
.btn-secondary{
    padding:10px 20px; border:1px solid var(--border2);
    background:transparent; color:var(--fg);
    font-family:var(--mono); font-size:12px; letter-spacing:1.5px;
    text-transform:uppercase; cursor:pointer;
    transition:all var(--transition);
}
.btn-secondary:hover{ background:var(--bg2); }
.btn-secondary:active{ transform:scale(0.97); }
.btn-small{
    padding:6px 14px; border:1px solid var(--border2);
    background:transparent; color:var(--fg);
    font-family:var(--mono); font-size:11px; letter-spacing:1px;
    text-transform:uppercase; cursor:pointer;
    transition:all var(--transition);
}
.btn-small:hover{ background:var(--bg2); }
.btn-danger{
    padding:10px 20px; border:2px solid var(--danger);
    background:transparent; color:var(--danger);
    font-family:var(--mono); font-size:12px; letter-spacing:1.5px;
    text-transform:uppercase; cursor:pointer;
    transition:all var(--transition);
}
.btn-danger:hover{ background:var(--danger); color:#fff; }
.btn-danger:active{ transform:scale(0.97); }

/* ═══════════ DASHBOARD ═══════════ */
.stats-row{
    display:grid;
    grid-template-columns:repeat(auto-fit, minmax(160px, 1fr));
    gap:16px; margin-bottom:28px;
}
.stat-card{
    border:1px solid var(--border2);
    padding:18px 16px;
    position:relative;
    transition:transform var(--transition), border-color var(--transition);
}
.stat-card:hover{ transform:translateY(-2px); border-color:var(--border3); }
.stat-card::before{
    content:"";
    position:absolute; top:-1px; left:12px; right:12px;
    height:2px; background:var(--accent);
    transform:scaleX(0); transition:transform .3s ease;
}
.stat-card:hover::before{ transform:scaleX(1); }
.stat-kicker{
    font-size:11px; letter-spacing:1.5px; text-transform:uppercase;
    color:var(--fg2); margin-bottom:8px;
}
.stat-value{
    font-family:var(--sans); font-size:28px; font-weight:700;
    letter-spacing:2px;
}
.stat-danger{ color:var(--danger); }

.dash-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:20px;
}
.dash-panel{
    border:1px solid var(--border2);
    display:flex; flex-direction:column;
}
.panel-head{
    display:flex; align-items:center; justify-content:space-between;
    padding:12px 16px;
    border-bottom:1px solid var(--border);
    background:rgba(0,0,0,0.02);
}
.panel-title{
    font-family:var(--mono); font-size:12px; letter-spacing:1.5px;
    text-transform:uppercase; color:var(--fg2);
}
.panel-badge{
    font-family:var(--mono); font-size:11px;
    padding:2px 8px; border:1px solid var(--border2);
    letter-spacing:1px;
}
.panel-body{
    padding:16px; flex:1; min-height:0;
}
.chart-wrap{
    position:relative; min-height:200px;
    display:flex; align-items:center; justify-content:center;
}
.chart-large{ min-height:280px; }

/* ─── TASK ITEMS (dashboard + task list) ─── */
.task-item{
    display:grid;
    grid-template-columns: 28px 1fr auto;
    gap:12px; align-items:center;
    padding:12px 14px;
    border:1px solid var(--border);
    margin-bottom:8px;
    cursor:pointer;
    transition:all var(--transition);
    position:relative;
}
.task-item:hover{
    border-color:var(--border2);
    background:rgba(0,0,0,0.015);
    transform:translateY(-1px);
}
.task-item:active{
    transform:translateY(0);
    background:rgba(0,0,0,0.03);
}
.task-item.compact{ padding:8px 12px; }

.task-check{
    width:24px; height:24px;
    border:2px solid var(--border2);
    background:transparent;
    cursor:pointer;
    display:flex; align-items:center; justify-content:center;
    transition:all var(--transition); flex-shrink:0;
    padding:0;
}
.task-check:hover{ border-color:#000; }
.task-check.checked{
    background:#000; border-color:#000;
}
.task-check.checked::after{
    content:"✓"; color:#fff; font-size:12px; line-height:1;
}
.task-check.in-progress{
    border-color:var(--warning);
    background:var(--warning);
}
.task-check.in-progress::after{
    content:"›"; color:#fff; font-size:16px; font-weight:bold; line-height:1;
}

.task-info{ min-width:0; }
.task-name{
    font-family:var(--mono); font-size:13px;
    letter-spacing:0.5px; white-space:nowrap;
    overflow:hidden; text-overflow:ellipsis;
}
.task-item.done .task-name{
    text-decoration:line-through; opacity:0.5;
}
.task-meta{
    display:flex; gap:8px; align-items:center;
    margin-top:4px; flex-wrap:wrap;
}
.task-meta-item{
    font-size:10px; letter-spacing:1px; text-transform:uppercase;
    color:var(--fg3);
}
.task-meta-item.overdue{ color:var(--danger); font-weight:bold; }
.task-priority-dot{
    width:8px; height:8px; border-radius:0;
    display:inline-block; flex-shrink:0;
}
.task-priority-dot.urgent{ background:var(--danger); }
.task-priority-dot.high{ background:#e67e22; }
.task-priority-dot.medium{ background:#f1c40f; }
.task-priority-dot.low{ background:#95a5a6; }
.task-project-tag{
    font-size:10px; letter-spacing:1px; text-transform:uppercase;
    padding:2px 6px; border:1px solid var(--border);
    color:var(--fg2);
}
.task-actions{
    display:flex; gap:6px; opacity:0;
    transition:opacity var(--transition);
}
.task-item:hover .task-actions{ opacity:1; }
.task-item:focus-within .task-actions{ opacity:1; }
.task-action-btn{
    width:32px; height:32px;
    border:1px solid var(--border);
    background:transparent; cursor:pointer;
    display:flex; align-items:center; justify-content:center;
    font-size:14px; color:var(--fg2);
    transition:all var(--transition);
}
.task-action-btn:hover{
    background:var(--bg2); border-color:var(--border2);
}
.task-action-btn.delete:hover{
    background:var(--danger); color:#fff; border-color:var(--danger);
}

/* empty state */
.empty-state{
    text-align:center; padding:48px 24px;
    color:var(--fg3);
}
.empty-state-icon{
    font-size:52px; margin-bottom:14px; opacity:0.25;
}
.empty-state-text{
    font-size:12px; letter-spacing:1.5px; text-transform:uppercase;
    line-height:1.7;
}
.empty-state-hint{
    font-size:11px; letter-spacing:1px; text-transform:none;
    color:var(--fg3); opacity:0.7;
    margin-top:8px;
}

/* ═══════════ TASKS TOOLBAR ═══════════ */
.tasks-toolbar{
    display:flex; gap:12px; margin-bottom:20px;
    flex-wrap:wrap; align-items:center;
}
.search-input{
    flex:1; min-width:200px;
    padding:12px 14px;
    border:1px solid var(--border2);
    background:transparent;
    font-family:var(--mono); font-size:14px; letter-spacing:1px;
    outline:none; transition:border-color var(--transition), box-shadow var(--transition);
    min-height:44px;
}
.search-input:focus{
    border-color:var(--border3);
    box-shadow:inset 0 0 0 1px rgba(0,0,0,0.06);
}
.filter-group{
    display:flex; gap:8px; flex-wrap:wrap;
}
.filter-select{
    padding:10px 12px;
    border:1px solid var(--border2);
    background:var(--bg);
    font-family:var(--mono); font-size:11px; letter-spacing:1px;
    text-transform:uppercase;
    cursor:pointer; outline:none;
    transition:border-color var(--transition);
    min-height:44px;
}
.filter-select:focus{ border-color:var(--border3); }

/* ═══════════ PROJECTS ═══════════ */
.projects-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));
    gap:16px;
}
.project-card{
    border:1px solid var(--border2);
    padding:20px;
    position:relative;
    cursor:pointer;
    transition:all var(--transition);
}
.project-card:hover{
    border-color:var(--border3);
    transform:translateY(-2px);
}
.project-card:active{
    transform:translateY(0);
}
.project-card-bar{
    position:absolute; top:0; left:0; right:0; height:3px;
}
.project-card-name{
    font-family:var(--sans); font-size:16px; letter-spacing:2px;
    text-transform:uppercase; font-weight:700;
    margin-top:6px;
}
.project-card-count{
    font-size:11px; letter-spacing:1.5px; text-transform:uppercase;
    color:var(--fg2); margin-top:8px;
}
.project-card-progress{
    margin-top:14px; height:6px;
    border:1px solid var(--border2);
    background:var(--bg2);
    position:relative; overflow:hidden;
}
.project-card-fill{
    position:absolute; top:0; left:0; bottom:0;
    background:#000;
    transition:width .4s ease;
}
.project-card-stats{
    display:flex; justify-content:space-between;
    margin-top:8px; font-size:10px; letter-spacing:1px;
    text-transform:uppercase; color:var(--fg3);
}

/* ═══════════ ANALYTICS ═══════════ */
.analytics-tabs{
    display:flex; gap:0; margin-bottom:20px;
    border:1px solid var(--border2);
    width:fit-content;
}
.tab-btn{
    padding:10px 20px;
    border:none; border-right:1px solid var(--border);
    background:transparent; color:var(--fg2);
    font-family:var(--mono); font-size:11px; letter-spacing:1.5px;
    text-transform:uppercase; cursor:pointer;
    transition:all var(--transition);
}
.tab-btn:last-child{ border-right:none; }
.tab-btn:hover{ background:var(--bg2); }
.tab-btn.active{ background:#000; color:#fff; }

.custom-range{
    display:flex; align-items:center; gap:12px;
    margin-bottom:20px;
}
.date-input{
    padding:8px 12px;
    border:1px solid var(--border2);
    background:transparent;
    font-family:var(--mono); font-size:12px;
    outline:none;
}
.range-sep{ color:var(--fg3); }

.analytics-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:20px;
}
.analytics-panel{
    border:1px solid var(--border2);
    display:flex; flex-direction:column;
}
.analytics-panel.full{ grid-column:1/-1; }
.analytics-stats{
    grid-column:1/-1;
    display:grid;
    grid-template-columns:repeat(auto-fit, minmax(160px, 1fr));
    gap:16px;
}
.a-stat{
    border:1px solid var(--border2);
    padding:16px;
}
.a-stat-label{
    font-size:10px; letter-spacing:1.5px;
    text-transform:uppercase; color:var(--fg2);
    margin-bottom:6px;
}
.a-stat-value{
    font-family:var(--sans); font-size:20px;
    letter-spacing:1px; font-weight:700;
}

/* ═══════════ SETTINGS ═══════════ */
.settings-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill, minmax(340px, 1fr));
    gap:20px;
}
.settings-panel{
    border:1px solid var(--border2);
}
.setting-row{
    display:flex; align-items:center; justify-content:space-between;
    padding:14px 16px; gap:12px;
    border-bottom:1px solid var(--border);
}
.setting-row:last-child{ border-bottom:none; }
.setting-row label{
    font-size:12px; letter-spacing:1px; text-transform:uppercase;
}
.danger-row{ background:rgba(192,57,43,0.03); }

/* Toggle switch */
.toggle{
    position:relative; width:44px; height:24px;
    display:inline-block; cursor:pointer;
}
.toggle input{ display:none; }
.toggle-slider{
    position:absolute; inset:0;
    border:1px solid var(--border2);
    background:var(--bg2);
    transition:all .2s;
}
.toggle-slider::after{
    content:"";
    position:absolute; left:3px; top:50%; transform:translateY(-50%);
    width:16px; height:16px;
    background:#000; transition:all .2s;
}
.toggle input:checked + .toggle-slider{
    background:#000; border-color:#000;
}
.toggle input:checked + .toggle-slider::after{
    left:23px; background:#fff;
}

.file-input{
    font-family:var(--mono); font-size:11px;
    max-width:150px;
}

.shortcuts-body{
    display:flex; flex-direction:column; gap:0;
}
.shortcut-row{
    display:flex; align-items:center; gap:14px;
    padding:10px 0;
    border-bottom:1px solid var(--border);
    font-size:12px; letter-spacing:1px; text-transform:uppercase;
}
.shortcut-row:last-child{ border-bottom:none; }
kbd{
    display:inline-flex; align-items:center; justify-content:center;
    min-width:28px; height:26px; padding:0 8px;
    border:1px solid var(--border2);
    background:var(--bg2);
    font-family:var(--mono); font-size:11px; letter-spacing:1px;
}

/* ═══════════ MODALS ═══════════ */
.modal-overlay{
    position:fixed; inset:0; z-index:5000;
    background:rgba(0,0,0,0.55);
    display:flex; align-items:center; justify-content:center;
    backdrop-filter:blur(8px);
    -webkit-backdrop-filter:blur(8px);
    animation:overlayIn .2s ease both;
}
@keyframes overlayIn{
    0%{ opacity:0; }
    100%{ opacity:1; }
}
.modal{
    position:relative;
    width:min(560px, calc(100vw - 32px));
    max-height:calc(100vh - 48px);
    overflow-y:auto;
    overflow-x:hidden;
    background:#fff;
    border:2px solid #000;
    padding:0;
    box-shadow:0 40px 100px rgba(0,0,0,0.25);
    animation:modalIn .3s cubic-bezier(0.16, 1, 0.3, 1) both;
}
.modal-sm{ width:min(440px, calc(100vw - 32px)); }
@keyframes modalIn{
    0%{ opacity:0; transform:translateY(20px) scale(0.97); }
    100%{ opacity:1; transform:translateY(0) scale(1); }
}

.modal-header{
    display:flex; align-items:flex-start; justify-content:space-between;
    gap:16px;
    padding:24px 28px 20px;
    background:#000; color:#fff;
}
.modal-header-left{ flex:1; min-width:0; }
.modal-kicker{
    font-family:var(--mono); font-size:10px; letter-spacing:2.5px;
    text-transform:uppercase; opacity:0.5;
    margin-bottom:6px;
}
.modal-title{
    font-family:var(--sans); font-size:20px; letter-spacing:3px;
    text-transform:uppercase; font-weight:700;
    color:#fff; line-height:1.2;
}
.modal-close{
    width:36px; height:36px;
    border:1px solid rgba(255,255,255,0.25); background:transparent;
    font-size:20px; cursor:pointer; color:#fff;
    display:flex; align-items:center; justify-content:center;
    transition:all var(--transition);
    flex-shrink:0; margin-top:2px;
}
.modal-close:hover{ background:rgba(255,255,255,0.15); border-color:rgba(255,255,255,0.4); }
.modal-close:active{ transform:scale(0.9); }

/* Confirm modal — no black header */
.modal-confirm .modal-header{
    background:transparent; color:var(--fg);
    padding:24px 28px 12px;
}
.modal-confirm .modal-close{
    border-color:var(--border2); color:var(--fg);
}
.modal-confirm .modal-close:hover{
    background:var(--bg2); border-color:var(--border3);
}

.modal-form{
    display:flex; flex-direction:column; gap:16px;
    padding:24px 28px 28px;
}

/* Section labels */
.form-section-label{
    font-family:var(--mono); font-size:10px; letter-spacing:2.5px;
    text-transform:uppercase; color:var(--fg3);
    margin-bottom:-6px;
}

.form-group{
    display:flex; flex-direction:column; gap:6px;
}
.form-group label{
    font-family:var(--mono); font-size:10px; letter-spacing:2px;
    text-transform:uppercase; color:var(--fg3);
}
.form-hint{ font-size:10px; letter-spacing:0.5px; color:var(--fg3); text-transform:none; }

/* Inputs */
.form-input{
    padding:12px 14px;
    border:1.5px solid var(--border);
    background:#fff;
    font-family:var(--mono); font-size:16px;
    outline:none;
    transition:border-color .15s ease, box-shadow .15s ease;
    min-height:44px;
}
.form-input:focus{
    border-color:#000;
    box-shadow:0 0 0 3px rgba(0,0,0,0.06);
}
.form-input::placeholder{
    color:var(--fg3); letter-spacing:0.5px;
}

/* Title input — bigger */
.form-input-title{
    font-size:20px;
    font-family:var(--sans);
    font-weight:700;
    letter-spacing:1px;
    padding:16px 14px;
    border-width:0 0 2px 0;
    background:transparent;
}
.form-input-title:focus{
    border-color:#000;
    box-shadow:none;
}
.form-input-title::placeholder{
    font-weight:400; color:var(--fg3);
}

.form-textarea{
    min-height:80px; resize:vertical;
    line-height:1.6; font-size:14px;
}
.form-row{
    display:grid; grid-template-columns:1fr 1fr; gap:14px;
}

/* ─── PILL SELECTORS ─── */
.pill-group{
    display:flex; gap:8px; flex-wrap:wrap;
}
.pill{
    display:flex; align-items:center; gap:8px;
    padding:10px 16px;
    border:1.5px solid var(--border);
    background:#fff;
    font-family:var(--mono); font-size:11px; letter-spacing:1.5px;
    text-transform:uppercase;
    cursor:pointer;
    transition:all .15s ease;
    color:var(--fg2);
    white-space:nowrap;
}
.pill:hover{
    border-color:var(--border3);
    background:var(--bg2);
}
.pill.active{
    border-color:#000;
    background:#000;
    color:#fff;
}
.pill:active{ transform:scale(0.96); }

/* Status dots */
.pill-dot{
    width:8px; height:8px;
    border:1.5px solid var(--border2);
    background:transparent;
    flex-shrink:0;
    transition:all .15s ease;
}
.pill.active .pill-dot{ border-color:#fff; }
.pill-dot.in-progress{ background:var(--warning); border-color:var(--warning); }
.pill.active .pill-dot.in-progress{ background:var(--warning); border-color:var(--warning); }
.pill-dot.done{ background:var(--success); border-color:var(--success); }
.pill.active .pill-dot.done{ background:var(--success); border-color:var(--success); }

/* Priority bars */
.pill-bar{
    width:4px; height:14px;
    flex-shrink:0;
    transition:all .15s ease;
}
.pill-bar.low{ background:#95a5a6; }
.pill-bar.medium{ background:#f1c40f; }
.pill-bar.high{ background:#e67e22; }
.pill-bar.urgent{ background:var(--danger); }

.modal-actions{
    display:flex; gap:10px; justify-content:flex-end;
    margin-top:8px;
    padding-top:16px;
    border-top:1.5px solid var(--border);
}
.modal-save{
    padding:14px 32px !important;
    font-size:12px; letter-spacing:2px;
}
.modal-save:hover{
    box-shadow:0 6px 20px rgba(0,0,0,0.15);
    transform:translateY(-1px);
}
.modal-delete{ margin-right:auto; }

/* Subtasks */
.subtask-list{ display:flex; flex-direction:column; gap:6px; }
.subtask-item{
    display:flex; align-items:center; gap:10px;
    padding:10px 12px;
    border:1px solid var(--border);
    background:rgba(0,0,0,0.01);
    transition:border-color .15s ease, background .15s ease;
}
.subtask-item:hover{
    border-color:var(--border2);
    background:rgba(0,0,0,0.02);
}
.subtask-check{
    width:18px; height:18px;
    border:2px solid var(--border2);
    background:transparent; cursor:pointer;
    display:flex; align-items:center; justify-content:center;
    transition:all var(--transition); flex-shrink:0; padding:0;
}
.subtask-check:hover{ border-color:#000; }
.subtask-check.checked{ background:#000; border-color:#000; }
.subtask-check.checked::after{ content:"✓"; color:#fff; font-size:10px; }
.subtask-text{
    flex:1; font-size:13px; letter-spacing:0.5px;
    font-family:var(--mono);
}
.subtask-item.done .subtask-text{ text-decoration:line-through; opacity:0.4; }
.subtask-remove{
    width:24px; height:24px; border:none; background:transparent;
    font-size:15px; cursor:pointer; color:var(--fg3);
    display:flex; align-items:center; justify-content:center;
    transition:color .15s ease;
}
.subtask-remove:hover{ color:var(--danger); }
.subtask-add-row{
    display:flex; gap:8px;
}
.subtask-add-row .btn-small{
    min-width:44px; min-height:44px;
    font-size:18px; font-weight:700;
    display:flex; align-items:center; justify-content:center;
}
.subtask-input{ flex:1; }

/* Color picker */
.color-picker{
    display:flex; gap:8px; flex-wrap:wrap;
}
.color-swatch{
    width:36px; height:36px;
    border:2px solid transparent;
    cursor:pointer;
    transition:all .15s ease;
}
.color-swatch:hover{ transform:translateY(-2px); box-shadow:0 4px 12px rgba(0,0,0,0.15); }
.color-swatch:active{ transform:translateY(0); }
.color-swatch.active{
    border-color:#000;
    box-shadow:0 0 0 3px var(--bg), 0 0 0 5px #000;
}

/* Confirm modal */
.confirm-body{
    padding:8px 28px 20px; font-size:14px; letter-spacing:0.5px;
    line-height:1.7; color:var(--fg2);
}
.modal-confirm .modal-actions{
    padding:16px 28px 24px;
}

/* ═══════════ TOAST ═══════════ */
.toast-container{
    position:fixed; bottom:24px; right:24px; left:auto;
    z-index:6000;
    display:flex; flex-direction:column-reverse; gap:8px;
    max-width:min(360px, calc(100vw - 32px));
}
.toast{
    padding:12px 20px;
    border:1px solid var(--border3);
    background:#fff;
    font-family:var(--mono); font-size:12px; letter-spacing:1px;
    text-transform:uppercase;
    animation:toastIn .2s ease both;
    box-shadow:0 4px 20px rgba(0,0,0,0.1);
}
.toast.success{ border-left:3px solid var(--success); }
.toast.error{ border-left:3px solid var(--danger); }
.toast.info{ border-left:3px solid #000; }
@keyframes toastIn{
    0%{ opacity:0; transform:translateX(20px); }
    100%{ opacity:1; transform:translateX(0); }
}
@keyframes toastOut{
    0%{ opacity:1; transform:translateX(0); }
    100%{ opacity:0; transform:translateX(20px); }
}

/* ═══════════ ACTIVITY LIST ═══════════ */
.activity-item{
    display:flex; gap:10px; align-items:flex-start;
    padding:10px 0;
    border-bottom:1px solid var(--border);
    font-size:12px; letter-spacing:0.5px;
}
.activity-item:last-child{ border-bottom:none; }
.activity-dot{
    width:8px; height:8px; margin-top:4px;
    flex-shrink:0;
}
.activity-dot.created{ background:var(--accent); }
.activity-dot.completed{ background:var(--success); }
.activity-dot.updated{ background:var(--warning); }
.activity-time{
    font-size:10px; letter-spacing:1px;
    color:var(--fg3); text-transform:uppercase;
    margin-top:3px;
}

/* ═══════════ RESPONSIVE ═══════════ */
@media (max-width:900px) {
    .login-box{ width:min(460px, calc(100vw - 28px)); padding:28px 22px 24px; }
    .login-title{ letter-spacing:3px; }
    .login-footer{ gap:12px; flex-wrap:wrap; }
    .app{
        grid-template-columns:1fr;
        grid-template-rows:56px 1fr;
    }
    .sidebar{
        position:fixed; left:0; top:0; bottom:0;
        width:260px; z-index:4000;
        transform:translateX(-100%);
        transition:transform .25s cubic-bezier(0.16, 1, 0.3, 1);
    }
    .sidebar.open{ transform:translateX(0); }
    .sidebar-btn{ padding:14px 16px; font-size:13px; }
    .topbar{ display:flex; }
    .main{ padding:20px 16px; }
    .dash-grid{ grid-template-columns:1fr; }
    .analytics-grid{ grid-template-columns:1fr; }
    .stats-row{ grid-template-columns:repeat(2, 1fr); }
    .form-row{ grid-template-columns:1fr; }
    .tasks-toolbar{ flex-direction:column; }
    .search-input{ min-width:unset; width:100%; font-size:16px; }
    .filter-group{ width:100%; }
    .filter-select{ flex:1; min-width:0; font-size:12px; }
    .settings-grid{ grid-template-columns:1fr; }
    .view-header{ flex-direction:column; gap:12px; }
    .analytics-tabs{ width:100%; }
    .tab-btn{ flex:1; padding:12px 8px; font-size:10px; min-height:44px; }

    /* Task actions always visible on touch */
    .task-actions{ opacity:1; }
    .task-action-btn{ width:36px; height:36px; }

    /* Task items bigger touch target */
    .task-item{ padding:14px 14px; gap:14px; }
    .task-check{ width:28px; height:28px; }

    /* Modal improvements */
    .modal{
        width:calc(100vw - 24px);
        max-height:calc(100vh - 24px);
        max-height:calc(100dvh - 24px);
    }
    .modal-sm{ width:calc(100vw - 24px); }
    .modal-header{ padding:20px 20px 16px; }
    .modal-form{ padding:20px 20px 24px; }
    .pill{ padding:10px 12px; font-size:10px; flex:1; justify-content:center; }
    .modal-actions{ flex-wrap:wrap; }
    .modal-actions .btn-primary,
    .modal-actions .btn-secondary,
    .modal-actions .btn-danger{ min-height:48px; flex:1; min-width:100px; }
    .confirm-body{ padding:8px 20px 16px; }
    .modal-confirm .modal-actions{ padding:12px 20px 20px; }

    /* Project cards */
    .projects-grid{ grid-template-columns:1fr; }

    /* Toast */
    .toast-container{ right:16px; left:16px; bottom:16px; max-width:none; }

    /* Settings */
    .setting-row{ padding:16px; gap:14px; }
    .setting-row label{ font-size:13px; }

    /* Color swatches bigger */
    .color-swatch{ width:40px; height:40px; }

    /* Subtask touch */
    .subtask-check{ width:22px; height:22px; }
    .subtask-item{ padding:10px 12px; }
    .subtask-remove{ width:28px; height:28px; }
}

@media (max-width:600px) {
    .login-box{ width:min(100vw - 20px, 460px); padding:24px 16px 20px; }
    .login-header{ align-items:flex-start; }
    .login-stamp{ padding:4px 8px; font-size:9px; letter-spacing:1.6px; }
    .login-title{ font-size:26px; letter-spacing:2.4px; }
    .login-subtitle{ font-size:11px; letter-spacing:1.6px; }
    .login-input{ font-size:16px; padding:13px 12px; }
    .login-submit{ min-height:54px; padding:14px 12px; font-size:11px; letter-spacing:1.4px; }
    .login-actions{ grid-template-columns:1fr; gap:10px; }
    .login-footer{ justify-content:flex-start; }
    .stats-row{ grid-template-columns:1fr 1fr; }

    /* Full-screen modal on small screens */
    .modal{
        width:100vw; max-height:100vh; max-height:100dvh;
        border:none;
        animation:modalSlideUp .25s cubic-bezier(0.16, 1, 0.3, 1) both;
    }
    .modal-sm{ width:100vw; }
    .modal-overlay{ align-items:flex-end; }
    .modal-header{ padding:18px 16px 14px; }
    .modal-form{ padding:18px 16px 22px; }
    .modal-title{ font-size:16px; letter-spacing:2px; }
    .form-input-title{ font-size:18px; padding:12px 10px; }
    .pill{ flex:1; justify-content:center; padding:10px 10px; font-size:9px; }
    .confirm-body{ padding:6px 16px 14px; }
    .modal-confirm .modal-actions{ padding:12px 16px 18px; }

    /* View title */
    .view-title{ font-size:22px; letter-spacing:2px; }

    /* Stat cards */
    .stat-card{ padding:14px 12px; }
    .stat-value{ font-size:22px; }
    .stat-kicker{ font-size:10px; }

    /* Filter selects stack */
    .filter-group{ flex-direction:column; }
    .filter-select{ width:100%; }

    /* Compact task meta */
    .task-meta{ gap:6px; }
    .task-name{ font-size:12px; }

    /* Analytics stats */
    .analytics-stats{ grid-template-columns:1fr 1fr; }
    .a-stat{ padding:12px; }
    .a-stat-value{ font-size:16px; }
}

@keyframes modalSlideUp{
    0%{ opacity:0; transform:translateY(100%); }
    100%{ opacity:1; transform:translateY(0); }
}

/* Safe area for notched phones */
@supports (padding-bottom: env(safe-area-inset-bottom)) {
    .toast-container{ bottom:calc(16px + env(safe-area-inset-bottom)); }
    .topbar{ padding-top:env(safe-area-inset-top); }
    @media (max-width:600px) {
        .modal{ padding-bottom:calc(20px + env(safe-area-inset-bottom)); }
    }
}
