/* ============================================================
   AMARCA OJT Task Tracker — Design System
   Aesthetic: Clean Journal / Warm Professional
   Palette:
     Primary:  #2D7A5E (forest teal)
     Accent:   #C8860A (warm amber)
     Bg:       #F5F3EE (warm cream)
     Surface:  #FFFFFF
     Text:     #1E293B
     Muted:    #64748B
   Fonts: Lora (headings) + Nunito (body)
   ============================================================ */

:root {
  --bg:        #F5F3EE;
  --surface:   #FFFFFF;
  --border:    #E2DDD4;
  --primary:   #2D7A5E;
  --primary-d: #1F5C45;
  --accent:    #C8860A;
  --accent-l:  #FFF3D6;
  --text:      #1E293B;
  --text-2:    #475569;
  --muted:     #64748B;
  --danger:    #C0392B;
  --danger-l:  #FDE8E6;
  --green-l:   #EDF7F2;
  --blue-l:    #EEF6FF;
  --sidebar-w: 265px;
  --top-h:     60px;
  --r:         12px;
  --r-sm:      8px;
  --shadow:    0 2px 14px rgba(45,122,94,.07);
  --shadow-md: 0 6px 28px rgba(45,122,94,.12);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Nunito',sans-serif;background:var(--bg);color:var(--text);font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased;}
a{color:var(--primary);text-decoration:none;}a:hover{color:var(--primary-d);}
img{max-width:100%;}

/* ── Sidebar ─────────────────────────────────────────────── */
.sidebar{
  position:fixed;top:0;left:0;width:var(--sidebar-w);height:100vh;
  background:var(--surface);border-right:1px solid var(--border);
  display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;
  z-index:200;transition:transform .28s cubic-bezier(.4,0,.2,1);
}
.sb-brand{display:flex;align-items:center;gap:.85rem;padding:1.3rem 1.3rem 1.1rem;border-bottom:1px solid var(--border);}
.sb-icon{width:42px;height:42px;background:var(--primary);border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.sb-icon i{font-size:1.2rem;color:#fff;}
.sb-name{font-family:'Lora',serif;font-size:1rem;font-weight:700;color:var(--text);line-height:1.2;}
.sb-sub{font-size:.7rem;color:var(--muted);letter-spacing:.03em;}
.sb-section{font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:700;padding:1.1rem 1.3rem .35rem;}
.nav-link{display:flex;align-items:center;gap:.65rem;padding:.65rem 1.3rem;color:var(--text-2);font-size:.875rem;font-weight:600;transition:background .14s,color .14s;position:relative;}
.nav-link i{font-size:1rem;width:20px;flex-shrink:0;}
.nav-link:hover{background:var(--green-l);color:var(--primary);}
.nav-link.active{background:var(--green-l);color:var(--primary);}
.nav-link.active::before{content:'';position:absolute;left:0;top:7px;bottom:7px;width:3px;background:var(--primary);border-radius:0 3px 3px 0;}
.nav-danger{color:var(--danger)!important;}
.nav-danger:hover{background:var(--danger-l)!important;}
.sb-footer{margin-top:auto;border-top:1px solid var(--border);background:var(--bg);}
.sb-user{display:flex;align-items:center;gap:.7rem;padding:1rem 1.3rem .4rem;}
.sb-avatar{width:34px;height:34px;background:var(--green-l);color:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.95rem;}
.sb-uname{font-size:.85rem;font-weight:700;color:var(--text);}
.sb-urole{font-size:.7rem;color:var(--muted);}

/* ── Topbar ──────────────────────────────────────────────── */
.topbar{display:none;position:fixed;top:0;left:0;right:0;height:var(--top-h);background:var(--surface);border-bottom:1px solid var(--border);align-items:center;justify-content:space-between;padding:0 1rem;z-index:150;box-shadow:var(--shadow);}
.tb-title{font-family:'Lora',serif;font-size:.95rem;font-weight:700;}
.sb-toggle,.tb-btn{width:38px;height:38px;background:var(--bg);border:none;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text);font-size:1.1rem;transition:background .14s;text-decoration:none;}
.sb-toggle:hover,.tb-btn:hover{background:var(--green-l);}

/* ── Overlay ─────────────────────────────────────────────── */
.overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.3);z-index:190;opacity:0;transition:opacity .28s;}
.overlay.show{display:block;opacity:1;}

/* ── Main ────────────────────────────────────────────────── */
.main-wrap{margin-left:var(--sidebar-w);min-height:100vh;padding:2rem 2.2rem;}

/* ── Flash ───────────────────────────────────────────────── */
.flash{display:flex;align-items:center;gap:.55rem;padding:.8rem 1rem;border-radius:var(--r-sm);margin-bottom:1.4rem;font-size:.875rem;font-weight:600;opacity:1;transition:opacity .5s;}
.flash-success{background:var(--green-l);color:var(--primary);border:1px solid #A7D7C0;}
.flash-error{background:var(--danger-l);color:var(--danger);border:1px solid #F5C6C2;}
.mb-2{margin-bottom:1rem;}

/* ── Page header ─────────────────────────────────────────── */
.page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.8rem;gap:1rem;flex-wrap:wrap;}
.page-title{font-family:'Lora',serif;font-size:1.7rem;font-weight:700;color:var(--text);line-height:1.2;}
.page-sub{color:var(--muted);font-size:.875rem;margin-top:.2rem;}
.section-heading{font-family:'Lora',serif;font-size:1.1rem;font-weight:700;color:var(--text);margin-bottom:.9rem;}
.mt-2{margin-top:2rem;}

/* ── Buttons ─────────────────────────────────────────────── */
.btn-primary{display:inline-flex;align-items:center;gap:.4rem;background:var(--primary);color:#fff!important;border:none;border-radius:var(--r-sm);padding:.6rem 1.1rem;font-size:.875rem;font-weight:700;cursor:pointer;transition:background .14s,transform .1s;white-space:nowrap;font-family:inherit;}
.btn-primary:hover{background:var(--primary-d);transform:translateY(-1px);}
.btn-outline{display:inline-flex;align-items:center;gap:.4rem;background:none;color:var(--text-2)!important;border:1.5px solid var(--border);border-radius:var(--r-sm);padding:.6rem 1rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .14s;white-space:nowrap;font-family:inherit;}
.btn-outline:hover{background:var(--bg);border-color:var(--primary);color:var(--primary)!important;}
.btn-full{width:100%;display:flex;align-items:center;justify-content:center;gap:.45rem;background:var(--primary);color:#fff;border:none;border-radius:var(--r-sm);padding:.8rem;font-size:.95rem;font-weight:700;cursor:pointer;transition:background .14s;font-family:inherit;}
.btn-full:hover{background:var(--primary-d);}
.icon-btn{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);background:var(--surface);border-radius:var(--r-sm);cursor:pointer;color:var(--text-2);font-size:.85rem;transition:background .12s,color .12s;text-decoration:none;}
.icon-btn:hover{background:var(--green-l);color:var(--primary);border-color:var(--primary);}

/* ── Forms ───────────────────────────────────────────────── */
.form-group{margin-bottom:1.1rem;}
.form-label{display:block;font-size:.83rem;font-weight:700;color:var(--text-2);margin-bottom:.4rem;}
.form-ctrl{width:100%;padding:.6rem .85rem;border:1.5px solid var(--border);border-radius:var(--r-sm);font-family:inherit;font-size:.9rem;color:var(--text);background:var(--bg);outline:none;transition:border-color .14s;}
.form-ctrl:focus{border-color:var(--primary);background:var(--surface);box-shadow:0 0 0 3px rgba(45,122,94,.1);}
.form-ctrl.textarea{resize:vertical;min-height:90px;}
.input-icon{position:relative;}
.input-icon>i{position:absolute;left:.85rem;top:50%;transform:translateY(-50%);color:var(--muted);font-size:.95rem;pointer-events:none;}
.input-icon .form-ctrl{padding-left:2.45rem;}
.date-input{padding:.55rem .85rem;border:1.5px solid var(--border);border-radius:var(--r-sm);font-family:inherit;font-size:.875rem;color:var(--text);background:var(--surface);outline:none;cursor:pointer;}
.date-input:focus{border-color:var(--primary);}
.filter-select{padding:.55rem .85rem;border:1.5px solid var(--border);border-radius:var(--r-sm);font-family:inherit;font-size:.875rem;color:var(--text);background:var(--surface);outline:none;cursor:pointer;}
.mt-1{margin-top:.6rem;}

/* ── Stats grid ──────────────────────────────────────────── */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.8rem;}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:1.2rem 1.3rem;display:flex;align-items:center;gap:.9rem;box-shadow:var(--shadow);transition:transform .14s,box-shadow .14s;}
.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);}
.stat-icon{width:46px;height:46px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0;}
.stat-val{font-family:'Lora',serif;font-size:1.7rem;font-weight:700;line-height:1;color:var(--text);}
.stat-lbl{font-size:.73rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-top:.2rem;}

/* ── Progress bar ────────────────────────────────────────── */
.progress-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:1.2rem 1.4rem;margin-bottom:1.8rem;box-shadow:var(--shadow);}
.progress-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:.7rem;font-size:.875rem;font-weight:600;}
.progress-pct{color:var(--primary);font-weight:700;}
.progress-track{height:10px;background:var(--border);border-radius:8px;overflow:hidden;}
.progress-fill{height:100%;background:var(--accent);border-radius:8px;transition:width .4s cubic-bezier(.4,0,.2,1);}
.progress-fill.complete{background:var(--primary);}

/* ── Section cards (dashboard) ───────────────────────────── */
.section-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.9rem;margin-bottom:2rem;}
.sec-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:1.1rem;box-shadow:var(--shadow);transition:transform .14s;}
.sec-card:hover{transform:translateY(-2px);}
.sec-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem;}
.sec-badge{display:inline-flex;align-items:center;gap:.3rem;padding:.25rem .6rem;border-radius:20px;font-size:.75rem;font-weight:700;}
.sec-pct{font-size:.85rem;font-weight:700;}
.sec-title{font-size:.83rem;font-weight:600;color:var(--text);margin-bottom:.6rem;line-height:1.3;}
.sec-bar-track{height:6px;background:var(--border);border-radius:4px;overflow:hidden;margin-bottom:.35rem;}
.sec-bar-fill{height:100%;border-radius:4px;transition:width .4s;}
.sec-count{font-size:.75rem;color:var(--muted);}

/* ── Log list ────────────────────────────────────────────── */
.log-list{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);margin-bottom:1.5rem;}
.log-row{display:flex;align-items:center;gap:1rem;padding:.9rem 1.2rem;border-bottom:1px solid var(--border);transition:background .12s;}
.log-row:last-child{border-bottom:none;}
.log-row:hover{background:var(--bg);}
.log-date-badge{width:46px;text-align:center;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r-sm);padding:.4rem .3rem;flex-shrink:0;}
.ldb-day{font-family:'Lora',serif;font-size:1.15rem;font-weight:700;line-height:1;color:var(--text);}
.ldb-mon{font-size:.65rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);}
.log-info{flex:1;min-width:0;}
.log-title{font-weight:700;font-size:.875rem;margin-bottom:.3rem;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;}
.log-bar-wrap{display:flex;align-items:center;gap:.6rem;}
.log-bar-track{flex:1;height:6px;background:var(--border);border-radius:4px;overflow:hidden;}
.log-bar-fill{height:100%;background:var(--accent);border-radius:4px;}
.log-pct{font-size:.75rem;color:var(--muted);font-weight:700;white-space:nowrap;}
.log-actions{display:flex;gap:.35rem;flex-shrink:0;}
.badge-done{display:inline-flex;align-items:center;gap:.2rem;padding:.18rem .55rem;border-radius:12px;font-size:.7rem;font-weight:700;background:var(--green-l);color:#1A5C35;}
.badge-pending{display:inline-flex;padding:.18rem .55rem;border-radius:12px;font-size:.7rem;font-weight:700;background:var(--accent-l);color:#7A4F00;}
.link-more{font-size:.85rem;font-weight:700;color:var(--primary);display:inline-flex;align-items:center;gap:.3rem;}

/* ── Filter bar ──────────────────────────────────────────── */
.filter-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:.9rem 1.2rem;margin-bottom:1.2rem;box-shadow:var(--shadow);}
.filter-form{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;}

/* ── Task sections ───────────────────────────────────────── */
.task-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);margin-bottom:1rem;box-shadow:var(--shadow);overflow:hidden;}
.ts-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.2rem;cursor:pointer;background:var(--surface);transition:background .14s;user-select:none;}
.ts-header:hover{background:var(--bg);}
.ts-left{display:flex;align-items:center;gap:.8rem;}
.ts-badge{display:inline-flex;align-items:center;gap:.3rem;padding:.3rem .7rem;border-radius:20px;font-size:.78rem;font-weight:700;white-space:nowrap;}
.ts-title{font-size:.93rem;font-weight:700;color:var(--text);}
.ts-sub{font-size:.75rem;color:var(--muted);margin-top:.1rem;}
.ts-chevron{font-size:.9rem;color:var(--muted);transition:transform .2s;}
.mini-ring{flex-shrink:0;}
.ts-body{border-top:1px solid var(--border);}

/* ── Task item ───────────────────────────────────────────── */
.task-item{display:flex;align-items:flex-start;gap:.85rem;padding:.85rem 1.2rem;border-bottom:1px solid var(--border);transition:background .12s;}
.task-item:last-of-type{border-bottom:none;}
.task-item:hover{background:#FAFAF8;}
.task-item.task-done{background:var(--green-l);}
.task-item.task-done .task-text{text-decoration:line-through;color:var(--muted);}

/* Custom checkbox */
.task-check{display:inline-flex;align-items:flex-start;cursor:pointer;flex-shrink:0;margin-top:2px;}
.task-check input{display:none;}
.checkmark{width:20px;height:20px;border:2px solid var(--border);border-radius:5px;display:flex;align-items:center;justify-content:center;background:#fff;transition:background .14s,border-color .14s;}
.task-check input:checked + .checkmark{background:var(--primary);border-color:var(--primary);}
.task-check input:checked + .checkmark::after{content:'✓';font-size:.7rem;color:#fff;font-weight:700;}

.task-body{flex:1;min-width:0;}
.task-text{font-size:.875rem;color:var(--text);line-height:1.5;}
.task-ts{font-size:.72rem;color:var(--muted);margin-top:.2rem;}
.note-toggle{display:inline-flex;align-items:center;gap:.25rem;font-size:.75rem;color:var(--muted);cursor:pointer;margin-top:.35rem;transition:color .12s;}
.note-toggle:hover{color:var(--primary);}
.note-box{margin-top:.5rem;}
.note-area{width:100%;border:1.5px solid var(--border);border-radius:var(--r-sm);padding:.5rem .75rem;font-family:inherit;font-size:.83rem;color:var(--text);background:var(--bg);outline:none;resize:vertical;min-height:60px;}
.note-area:focus{border-color:var(--primary);background:#fff;}

.output-field{padding:.9rem 1.2rem 1rem;background:#F9FAF8;border-top:1px dashed var(--border);}
.of-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--primary);margin-bottom:.5rem;display:flex;align-items:center;gap:.3rem;}

/* ── Journal ─────────────────────────────────────────────── */
.journal-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:1.4rem 1.6rem;margin-bottom:1rem;box-shadow:var(--shadow);}
.journal-hdr{font-family:'Lora',serif;font-size:1.05rem;font-weight:700;color:var(--primary);margin-bottom:1.2rem;display:flex;align-items:center;gap:.5rem;padding-bottom:.6rem;border-bottom:2px solid var(--border);}
.journal-field{margin-bottom:1rem;}
.journal-label{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-2);margin-bottom:.4rem;display:block;}

/* ── Self-assessment ─────────────────────────────────────── */
.sa-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:1.4rem 1.6rem;margin-bottom:1rem;box-shadow:var(--shadow);}
.sa-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.85rem;}
.sa-item{border:1px solid var(--border);border-radius:var(--r-sm);padding:.85rem 1rem;background:var(--bg);}
.sa-label{font-size:.8rem;font-weight:700;color:var(--text);margin-bottom:.55rem;}
.sa-stars{display:flex;align-items:center;gap:.35rem;flex-wrap:wrap;}
.sa-opt{cursor:pointer;}
.sa-pill{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:1.5px solid var(--border);border-radius:50%;font-size:.78rem;font-weight:700;color:var(--muted);background:#fff;transition:all .14s;}
.sa-opt:hover .sa-pill,.sa-opt.active .sa-pill{background:var(--primary);border-color:var(--primary);color:#fff;}
.sa-cur-label{font-size:.72rem;font-weight:700;margin-left:.3rem;padding:.2rem .55rem;border-radius:10px;}
.sa-none{background:#F1F5F9;color:#64748B;}.sa-developing{background:#FFF8E7;color:#92600A;}
.sa-proficient{background:var(--blue-l);color:#1555A0;}.sa-excellent{background:var(--green-l);color:#1A5C35;}

/* ── Save bar ────────────────────────────────────────────── */
.form-save-bar{display:flex;align-items:center;gap:.75rem;margin-top:1.5rem;padding:1.2rem 1.6rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow);flex-wrap:wrap;}
.btn-save{padding:.75rem 1.6rem;font-size:.95rem;}

/* ── Empty state ─────────────────────────────────────────── */
.empty-state{text-align:center;padding:3rem 2rem;color:var(--muted);}
.empty-state i{font-size:2.5rem;display:block;margin-bottom:.7rem;opacity:.35;}
.empty-state a{color:var(--primary);font-weight:700;}

/* ── Responsive ───────────────────────────────────────────── */
@media(max-width:1100px){.section-grid{grid-template-columns:repeat(2,1fr);}.stats-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:860px){
  .sidebar{transform:translateX(-100%);}
  .sidebar.open{transform:translateX(0);box-shadow:6px 0 40px rgba(0,0,0,.15);}
  .topbar{display:flex;}
  .main-wrap{margin-left:0;padding:calc(var(--top-h)+1.1rem) 1rem 1.5rem;}
}
@media(max-width:600px){
  .stats-grid{grid-template-columns:repeat(2,1fr);}
  .section-grid{grid-template-columns:1fr;}
  .sa-grid{grid-template-columns:1fr;}
  .page-hdr{flex-direction:column;}
  .page-title{font-size:1.4rem;}
  .filter-form{flex-direction:column;align-items:stretch;}
  .task-section .ts-title{font-size:.85rem;}
  .form-save-bar{flex-direction:column;align-items:stretch;}
  .btn-save,.btn-outline{width:100%;justify-content:center;}
  .journal-section,.sa-section{padding:1rem 1.1rem;}
}
@media(max-width:420px){
  .main-wrap{padding-left:.8rem;padding-right:.8rem;}
  .stat-card{padding:.85rem;gap:.6rem;}
  .stat-val{font-size:1.5rem;}
}
