/* === CiCC 6S Activities Board - Premium Dark Theme === */
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Segoe UI',Arial,sans-serif;background:#0d1117;padding:16px;color:#e2e8f0}
.app{max-width:500px;margin:0 auto;background:linear-gradient(180deg,#161b22 0%,#0d1117 100%);border-radius:20px;padding:20px;box-shadow:0 8px 32px rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.06);display:none}

/* ─── Typography ─── */
h1{font-size:22px;color:#fff;margin-bottom:16px;display:flex;align-items:center;gap:8px;text-shadow:0 0 20px rgba(245,158,11,.3)}
h1 small{font-size:12px;color:#64748b;font-weight:normal}
h2{font-size:16px;color:#f1f5f9}
label{display:block;font-size:12px;font-weight:600;color:#94a3b8;margin:12px 0 4px;text-transform:uppercase;letter-spacing:.5px}
select,input,textarea{width:100%;padding:10px 12px;border:1px solid rgba(255,255,255,.12);border-radius:10px;font-size:14px;font-family:inherit;background:rgba(255,255,255,.06);color:#e2e8f0;outline:none;transition:border-color .2s}
select:focus,input:focus,textarea:focus{border-color:#f59e0b;box-shadow:0 0 0 3px rgba(245,158,11,.15)}
select option{background:#1a1f4e;color:#e2e8f0}
textarea{resize:vertical;min-height:60px}
::placeholder{color:#64748b}

/* ─── Header ─── */
.header-container{background:linear-gradient(135deg,#0a0e27 0%,#1a1f4e 30%,#0d1557 60%,#0a0e27 100%);display:flex;align-items:center;justify-content:space-between;padding:10px 14px;margin:-20px -20px 12px -20px;position:relative;overflow:hidden;border-radius:20px 20px 0 0}
.header-container::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(ellipse at 20% 50%,rgba(245,158,11,.15) 0%,transparent 50%),radial-gradient(ellipse at 80% 50%,rgba(139,92,246,.12) 0%,transparent 50%);pointer-events:none}
.header-container::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,#f59e0b,#3b82f6,#f59e0b,transparent)}
.header-logo{display:flex;align-items:center;gap:8px;position:relative;z-index:1;text-decoration:none}
.header-logo img{height:32px;width:32px;border-radius:8px;box-shadow:0 0 12px rgba(245,158,11,.5),0 0 24px rgba(245,158,11,.2);border:1.5px solid rgba(255,255,255,.2)}
.header-logo h1{margin:0;font-size:15px;font-weight:800;color:white;letter-spacing:.5px;text-shadow:0 0 10px rgba(245,158,11,.5);line-height:1}
.header-logo h1 small{font-size:8px;font-weight:500;color:rgba(255,255,255,.5);display:block;letter-spacing:1.5px;text-transform:uppercase;margin-top:2px}
.header-user{position:relative;z-index:1;display:flex;align-items:center;gap:8px}
#currentUserDisplay{font-size:11px;font-weight:600;color:white;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;padding:5px 14px;border-radius:20px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.2);backdrop-filter:blur(10px);display:flex;align-items:center;gap:6px;transition:all .3s}
#currentUserDisplay:hover{background:rgba(255,255,255,.15);border-color:rgba(245,158,11,.6);box-shadow:0 0 15px rgba(245,158,11,.3)}
#currentUserDisplay .user-avatar{width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,#f59e0b,#d97706);display:flex;align-items:center;justify-content:center;font-size:10px;box-shadow:0 0 8px rgba(245,158,11,.4)}
.header-actions{position:relative;z-index:1;display:flex;align-items:center;gap:6px}
#statusIndicator{font-size:8px;font-weight:700;padding:3px 8px;border-radius:12px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.25);color:rgba(255,255,255,.7);text-transform:uppercase;letter-spacing:.5px}
#statusIndicator.online{background:rgba(34,197,94,.2);border-color:rgba(34,197,94,.5);color:#4ade80}
.sync-btn{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);color:white;cursor:pointer;font-size:14px;padding:5px 8px;border-radius:8px;transition:all .3s;backdrop-filter:blur(8px)}
.sync-btn:hover{background:rgba(245,158,11,.3);border-color:rgba(245,158,11,.5);transform:rotate(180deg)}
.sync-btn:active{transform:rotate(360deg) scale(.9)}

/* ─── User Menu ─── */
#userMenu{position:absolute;top:100%;right:0;background:#1e293b;border-radius:14px;box-shadow:0 10px 40px rgba(0,0,0,.4);min-width:220px;z-index:1000;overflow:hidden;opacity:0;transform:translateY(-10px) scale(.95);pointer-events:none;transition:all .25s cubic-bezier(.4,0,.2,1);border:1px solid rgba(255,255,255,.08)}
#userMenu.show{opacity:1;transform:translateY(0) scale(1);pointer-events:all}
.menu-profile{padding:16px 14px 12px;background:linear-gradient(135deg,#0a0e27 0%,#1a1f4e 100%);text-align:center}
.menu-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#f59e0b,#d97706);display:flex;align-items:center;justify-content:center;font-size:22px;margin:0 auto 8px;box-shadow:0 0 16px rgba(245,158,11,.5);border:2px solid rgba(255,255,255,.3)}
.menu-name{font-size:13px;font-weight:700;color:white;margin-bottom:4px}
.menu-role-badge{display:inline-block;font-size:9px;font-weight:600;padding:2px 10px;border-radius:10px;background:rgba(245,158,11,.3);color:#fcd34d;border:1px solid rgba(245,158,11,.4);text-transform:uppercase;letter-spacing:.5px}
.menu-divider{height:1px;background:rgba(255,255,255,.08);margin:4px 0}
#userMenu div[onclick]{padding:10px 14px;font-size:12px;cursor:pointer;transition:background .2s;display:flex;align-items:center;gap:8px;color:#cbd5e1}
#userMenu div[onclick]:hover{background:rgba(255,255,255,.06);color:#fff}

/* ─── Tabs ─── */
.tabs{display:flex;gap:4px;margin-bottom:16px;background:rgba(255,255,255,.06);border-radius:12px;padding:4px}
.tab{flex:0 0 auto;text-align:center;padding:8px 10px;border-radius:8px;cursor:pointer;font-size:11px;font-weight:600;transition:.2s;border:none;background:transparent;color:#94a3b8;white-space:nowrap}
.tab.active{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;box-shadow:0 2px 12px rgba(245,158,11,.3)}

/* ─── Screens ─── */
.screen{display:none;background:rgba(255,255,255,.04);border-radius:16px;padding:16px;border:1px solid rgba(255,255,255,.06);border-top:3px solid #f59e0b;}
.screen.active{display:block}

/* ─── Buttons ─── */
.btn{width:100%;padding:12px;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;margin-top:12px;transition:.2s;color:#fff}
.btn:hover{opacity:.9;transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn-green{background:linear-gradient(135deg,#22c55e,#16a34a)}
.btn-blue{background:linear-gradient(135deg,#3b82f6,#2563eb)}
.btn-amber{background:linear-gradient(135deg,#f59e0b,#d97706)}
.btn-red{background:linear-gradient(135deg,#ef4444,#dc2626)}
.btn-gray{background:linear-gradient(135deg,#64748b,#475569)}
.btn-outline{background:transparent;border:1.5px solid rgba(245,158,11,.5);color:#f59e0b}
.btn-outline:hover{background:rgba(245,158,11,.1);border-color:#f59e0b}
.btn-xanh{background:linear-gradient(135deg,#3b82f6,#1d4ed8)}
.btn-xam{background:linear-gradient(135deg,#64748b,#475569)}

/* ─── Dashboard ─── */
.dashboard{margin-bottom:16px}
.dashboard-toggle{display:flex;justify-content:space-between;align-items:center;cursor:pointer;padding:8px 12px;background:linear-gradient(135deg,#f59e0b 0%,#d97706 100%);border-radius:10px 10px 0 0;color:white;font-size:12px;font-weight:700;user-select:none}
.dashboard-toggle .chevron{transition:transform .3s;font-size:10px}
.dashboard.collapsed .dashboard-toggle .chevron{transform:rotate(-90deg)}
.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;overflow:hidden;transition:max-height .4s ease,opacity .3s ease,padding .3s ease;max-height:500px;opacity:1;padding-top:6px}
.dashboard.collapsed .dashboard-grid{max-height:0;opacity:0;padding-top:0;gap:0}
.dashboard-compact{display:none;grid-template-columns:repeat(4,1fr);gap:4px;padding:8px 0}
.dashboard.collapsed .dashboard-compact{display:grid}
.compact-item{text-align:center;padding:6px 2px;border-radius:8px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);cursor:pointer;font-size:10px;color:#94a3b8}
.compact-item .num{font-size:16px;font-weight:700;display:block;color:#f59e0b}
.compact-item .lbl{font-size:9px;color:#64748b}
.dash-card{background:rgba(255,255,255,.06);border-radius:10px;padding:10px 14px;border:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:all .2s}
.dash-card:active{transform:scale(.97)}
.dash-card:hover{background:rgba(255,255,255,.1);border-color:#f59e0b}
.dash-card .title{font-size:12px;font-weight:600;flex:2;color:#94a3b8}
.dash-card .total{font-size:16px;font-weight:800;flex:1;text-align:center}

/* ─── Skeleton Loading ─── */
.skeleton{background:linear-gradient(90deg,rgba(255,255,255,.06) 25%,rgba(255,255,255,.12) 50%,rgba(255,255,255,.06) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:8px}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.skeleton-card{height:80px;margin:4px 0}
.skeleton-card-header{height:16px;margin-bottom:8px;width:60%}
.skeleton-card-desc{height:12px;width:80%;margin:4px 0}
.skeleton-kanban-col{min-height:200px}

/* ─── Activity Board ─── */
.activity-timeline{position:relative;padding-left:20px}
.activity-timeline::before{content:'';position:absolute;left:8px;top:0;bottom:0;width:2px;background:linear-gradient(180deg,#f59e0b,transparent)}
.activity-item{padding:10px 12px;margin-bottom:8px;background:rgba(255,255,255,.04);border-radius:10px;border:1px solid rgba(255,255,255,.06);position:relative;transition:all .2s}
.activity-item:hover{background:rgba(255,255,255,.08);border-color:rgba(245,158,11,.3)}
.activity-item::before{content:'';position:absolute;left:-16px;top:14px;width:10px;height:10px;border-radius:50%;border:2px solid}
.activity-item.tag-item::before{border-color:#3b82f6;background:rgba(59,130,246,.3)}
.activity-item.assess-item::before{border-color:#22c55e;background:rgba(34,197,94,.3)}
.activity-item.obs-item::before{border-color:#f59e0b;background:rgba(245,158,11,.3)}
.activity-item .ai-icon{font-size:18px;margin-bottom:4px}
.activity-item .ai-title{font-size:13px;font-weight:600;color:#e2e8f0}
.activity-item .ai-meta{font-size:11px;color:#64748b;margin-top:2px;display:flex;gap:8px;flex-wrap:wrap}
.activity-item .ai-badge{display:inline-block;padding:1px 8px;border-radius:8px;font-size:9px;font-weight:600}
.activity-item .ai-badge.tag{background:rgba(59,130,246,.2);color:#93c5fd}
.activity-item .ai-badge.assess{background:rgba(34,197,94,.2);color:#86efac}
.activity-item .ai-badge.obs{background:rgba(245,158,11,.2);color:#fcd34d}

/* ─── Assessment Form ─── */
.assess-item{background:rgba(255,255,255,.04);border-radius:10px;padding:12px;margin-bottom:8px;border:1px solid rgba(255,255,255,.06)}
.assess-item .q{font-size:13px;font-weight:600;color:#e2e8f0;margin-bottom:6px}
.assess-item .group-header{background:linear-gradient(135deg,#0a0e27,#1a1f4e);color:white;padding:8px 14px;border-radius:10px;font-size:14px;font-weight:700;margin-bottom:10px;display:flex;justify-content:space-between;align-items:center;border:1px solid rgba(255,255,255,.08)}
.assess-item .group-header .score-badge{background:rgba(255,255,255,.15);padding:2px 10px;border-radius:10px;font-size:12px;color:#f59e0b}
.assess-score{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.assess-score label{font-size:11px;display:flex;align-items:center;gap:3px;cursor:pointer;padding:5px 10px;border-radius:8px;border:1px solid rgba(255,255,255,.1);transition:.2s;color:#94a3b8;margin:0}
.assess-score label:has(input:checked){background:rgba(245,158,11,.2);border-color:#f59e0b;color:#f59e0b;font-weight:600}
.assess-score input[type="radio"]{width:auto}
.assess-comment{width:100%;margin-top:6px;padding:8px;border:1px solid rgba(255,255,255,.1);border-radius:8px;font-size:12px;min-height:32px;background:rgba(255,255,255,.04);color:#e2e8f0}
.quick-tag-btn{display:inline-block;padding:3px 10px;font-size:10px;font-weight:600;border:1px solid #f59e0b;background:rgba(245,158,11,.15);color:#fcd34d;border-radius:6px;cursor:pointer;transition:all .2s}
.quick-tag-btn:hover{background:rgba(245,158,11,.25)}

/* ─── Schedule Cards ─── */
.schedule-card{background:rgba(255,255,255,.04);border-radius:12px;padding:14px;margin-bottom:10px;border:1px solid rgba(255,255,255,.08);border-left:4px solid #f59e0b;cursor:pointer;transition:all .2s}
.schedule-card:active{transform:scale(.98)}
.schedule-card .sc-title{font-size:13px;font-weight:600;color:#f1f5f9}
.schedule-card .sc-meta{font-size:11px;color:#64748b;margin-top:4px}
.schedule-card .sc-badge{display:inline-block;padding:2px 10px;border-radius:10px;font-size:10px;font-weight:600;margin-top:6px}
.schedule-card .sc-badge.pending{background:rgba(245,158,11,.2);color:#fcd34d}
.schedule-card .sc-badge.completed{background:rgba(34,197,94,.2);color:#86efac}
.schedule-card .sc-badge.in_progress{background:rgba(59,130,246,.2);color:#93c5fd}

/* ─── Score Bar ─── */
.score-bar{height:8px;background:rgba(255,255,255,.08);border-radius:4px;overflow:hidden;margin:4px 0}
.score-bar-fill{height:100%;border-radius:4px;transition:width .5s ease}
.score-bar-fill.excellent{background:linear-gradient(90deg,#22c55e,#16a34a)}
.score-bar-fill.good{background:linear-gradient(90deg,#3b82f6,#2563eb)}
.score-bar-fill.fair{background:linear-gradient(90deg,#f59e0b,#d97706)}
.score-bar-fill.poor{background:linear-gradient(90deg,#ef4444,#dc2626)}

/* ─── Kanban / Tag List ─── */
.kanban-filters{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:8px}
.kanban-filters input,.kanban-filters select{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.1);color:#e2e8f0;padding:6px 10px;font-size:12px}
.kanban-column{background:rgba(255,255,255,.03);border-radius:12px;padding:12px;margin-bottom:12px;border:1px solid rgba(255,255,255,.06)}
.kanban-column .kc-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:13px;font-weight:700;color:#f1f5f9}
.kanban-column .kc-count{font-size:11px;color:#64748b}
.kanban-card{background:rgba(255,255,255,.06);border-radius:10px;padding:10px;margin-bottom:6px;border:1px solid rgba(255,255,255,.06);transition:all .2s;cursor:pointer}
.kanban-card:hover{background:rgba(255,255,255,.1);border-color:rgba(245,158,11,.3)}
.kanban-card .kc-tags{display:flex;gap:4px;margin-bottom:4px}
.kanban-card .kc-tag{font-size:9px;padding:1px 6px;border-radius:4px;font-weight:600}
.kanban-card .kc-tag.vang{background:rgba(245,158,11,.2);color:#fcd34d}
.kanban-card .kc-tag.do{background:rgba(239,68,68,.2);color:#fca5a5}
.kanban-card .kc-title{font-size:12px;color:#e2e8f0;margin-bottom:4px}
.kanban-card .kc-meta{font-size:10px;color:#64748b;display:flex;gap:8px}

/* ─── Report / Charts ─── */
.report-tabs{display:flex;gap:4px;margin-bottom:12px;background:rgba(255,255,255,.06);border-radius:10px;padding:3px;overflow-x:auto}
.report-tabs button{flex:1;text-align:center;padding:6px 8px;border-radius:8px;cursor:pointer;font-size:10px;font-weight:600;transition:.2s;border:none;background:transparent;color:#94a3b8;white-space:nowrap}
.report-tabs button.active{background:rgba(245,158,11,.2);color:#fcd34d}
.report-section{display:none}
.report-section.active{display:block}
.report-chart-card{background:rgba(255,255,255,.04);border-radius:12px;margin-bottom:12px;border:1px solid rgba(255,255,255,.06);overflow:hidden}
.report-chart-head{padding:10px 14px;font-size:12px;font-weight:700;color:#94a3b8;border-bottom:1px solid rgba(255,255,255,.06)}
.report-chart-body{padding:12px 14px;min-height:200px}
.report-chart-body canvas{width:100%!important;max-width:100%!important;height:auto!important}

/* ─── Activity Board Filters ─── */
.activity-filters{display:flex;gap:6px;margin-bottom:12px;flex-wrap:wrap}
.activity-filters .af-btn{padding:6px 14px;border-radius:20px;border:1px solid rgba(255,255,255,.1);background:transparent;color:#94a3b8;font-size:11px;font-weight:600;cursor:pointer;transition:all .2s}
.activity-filters .af-btn:hover{border-color:rgba(245,158,11,.3);color:#fcd34d}
.activity-filters .af-btn.active{background:rgba(245,158,11,.2);border-color:#f59e0b;color:#fcd34d}

/* ─── Auth ─── */
#auth-container{position:fixed;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#0a0e27 0%,#1a1f4e 50%,#0d1117 100%);z-index:2000;display:flex;justify-content:center;align-items:flex-start;padding:60px 20px;overflow-y:auto}
.auth-card{background:#1e293b;border-radius:20px;padding:30px 24px;width:100%;max-width:400px;box-shadow:0 20px 60px rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.08)}
.auth-card h2{color:#fff;font-size:18px}
.auth-card p{color:#64748b}
.auth-input-group{margin-bottom:16px}
.auth-input-group label{display:block;font-size:12px;margin-bottom:4px;color:#94a3b8;font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.auth-input-group input,.auth-input-group select{width:100%;padding:12px 16px;border:1.5px solid rgba(255,255,255,.12);border-radius:12px;font-size:14px;outline:none;background:rgba(255,255,255,.06);color:#e2e8f0;transition:border-color .2s}
.auth-input-group input:focus,.auth-input-group select:focus{border-color:#f59e0b}
.auth-btn{background:linear-gradient(135deg,#f59e0b,#d97706);color:white;border:none;border-radius:12px;padding:14px;width:100%;font-weight:700;font-size:14px;margin-top:12px;cursor:pointer;transition:all .2s;box-shadow:0 4px 16px rgba(245,158,11,.3)}
.auth-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(245,158,11,.4)}
.auth-btn:active{transform:translateY(0)}
.auth-link{text-align:center;margin-top:16px;font-size:13px;color:#f59e0b;cursor:pointer;opacity:.8}
.auth-link:hover{opacity:1}

/* ─── Toast ─── */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:#1e293b;color:#f1f5f9;padding:12px 24px;border-radius:12px;font-size:14px;opacity:0;transition:.3s;pointer-events:none;z-index:9999;border:1px solid rgba(255,255,255,.1);box-shadow:0 8px 32px rgba(0,0,0,.4)}
.toast.show{opacity:1}

/* ─── Footer ─── */
.app-footer{text-align:center;padding:12px 0;margin:16px -16px -16px -16px;background:linear-gradient(135deg,#0a0e27 0%,#1a1f4e 50%,#0a0e27 100%);color:rgba(255,255,255,.3);font-size:10px;border-radius:0 0 16px 16px}

/* ─── Quick Action ─── */
.quick-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:12px 0}
.quick-item{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:16px 12px;text-align:center;cursor:pointer;transition:all .2s}
.quick-item:active{transform:scale(.95)}
.quick-item:hover{background:rgba(255,255,255,.08);border-color:rgba(245,158,11,.3)}
.quick-item .qi-icon{font-size:28px;margin-bottom:6px}
.quick-item .qi-label{font-size:12px;font-weight:600;color:#94a3b8}

/* ─── Modal ─── */
#modalOverlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);z-index:1000;justify-content:center;align-items:center;backdrop-filter:blur(4px)}
.modal-content{background:#1e293b;border-radius:20px;padding:24px;max-width:380px;width:90%;max-height:90vh;overflow-y:auto;border:1px solid rgba(255,255,255,.1);box-shadow:0 20px 60px rgba(0,0,0,.5)}
.modal-content h3{color:#f1f5f9;margin-bottom:12px}

/* ─── Tree Picker ─── */
#treePickerOverlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);z-index:3000;justify-content:center;align-items:center;padding:15px}
.loc-picker-card{background:#1e293b;border-radius:20px;width:100%;max-width:450px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden;border:1px solid rgba(255,255,255,.1)}

/* ─── QR Scanner ─── */
#qrScannerOverlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999;background:#000;flex-direction:column}

/* ─── Photo Grid ─── */
.photo-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:6px}
.photo-grid .img-box{text-align:center}
.photo-grid .img-box .label{font-size:11px;font-weight:600;margin-bottom:4px;color:#94a3b8}
.photo-grid .img-box img{width:100%;border-radius:8px;border:1px solid rgba(255,255,255,.1)}
.photo-grid .img-box .placeholder{width:100%;height:100px;background:rgba(255,255,255,.04);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#64748b;font-size:11px;border:1px dashed rgba(255,255,255,.1)}

/* ─── Eval Type ─── */
.eval-type-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin:12px 0}
.eval-type-card{border:2px solid rgba(255,255,255,.1);border-radius:12px;padding:12px;text-align:center;cursor:pointer;transition:.2s;background:rgba(255,255,255,.04)}
.eval-type-card:hover{border-color:#f59e0b;background:rgba(245,158,11,.1)}
.eval-type-card.selected{border-color:#f59e0b;background:rgba(245,158,11,.15)}
.eval-type-card .et-icon{font-size:24px;margin-bottom:4px}
.eval-type-card .et-label{font-size:11px;font-weight:600;color:#e2e8f0}
.eval-type-card .et-desc{font-size:9px;color:#64748b}

/* ─── Treo Thẻ ─── */
.radio-group{display:flex;gap:10px}
.radio-group label{padding:8px 16px;border-radius:10px;border:2px solid rgba(255,255,255,.1);cursor:pointer;transition:.2s;margin:0;text-transform:none;letter-spacing:0;font-weight:500}
.radio-group label.selected{border-color:#f59e0b;background:rgba(245,158,11,.15)}

/* ─── Small helpers ─── */
.cicc-dash-header{background:linear-gradient(135deg,rgba(245,158,11,.15) 0%,rgba(59,130,246,.12) 50%,rgba(245,158,11,.08) 100%);border-radius:12px;padding:14px;margin-bottom:14px;border:1px solid rgba(255,255,255,.06)}
.stat-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:12px}

/* ─── Photo capture ─── */
.photo-capture-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 10px;font-size:11px;font-weight:600;border:1px solid #f59e0b;background:rgba(245,158,11,.15);color:#fcd34d;border-radius:8px;cursor:pointer;transition:.2s}
.photo-capture-btn:hover{background:rgba(245,158,11,.25)}
.photo-capture-btn.has-photo{border-color:#3b82f6;background:rgba(59,130,246,.2);color:#93c5fd}
.photo-preview{margin-top:6px;text-align:center}
.photo-preview img{max-width:100%;max-height:200px;border-radius:8px;box-shadow:0 2px 12px rgba(0,0,0,.3);border:1px solid rgba(255,255,255,.1)}
.photo-actions{display:flex;gap:6px;margin-top:6px;justify-content:center}

/* ─── Progress Ring ─── */
.progress-ring{position:relative;display:inline-flex;align-items:center;justify-content:center}
.progress-ring svg{transform:rotate(-90deg)}
.progress-ring .ring-text{position:absolute;font-size:14px;font-weight:800;color:#f59e0b}

@media print{body *{visibility:hidden}#printArea,#printArea *{visibility:visible}#printArea{position:absolute;left:0;top:0;width:100%}.no-print{display:none!important}}

/* ─── Observation ─── */
.obs-card{background:rgba(245,158,11,.08);border:1px solid rgba(245,158,11,.3);border-radius:12px;padding:12px;margin-bottom:10px}
.obs-card .obs-title{font-size:13px;font-weight:600;color:#fcd34d}
.obs-card .obs-meta{font-size:11px;color:#64748b;margin-top:4px}
.obs-card .obs-status{display:inline-block;padding:2px 10px;border-radius:10px;font-size:10px;font-weight:600;background:rgba(245,158,11,.2);color:#fcd34d}

/* ─── Location Drawers ─── */
.location-drawer{background:rgba(255,255,255,.03);border-radius:10px;margin-bottom:8px;border:1px solid rgba(255,255,255,.06);overflow:hidden}
.location-drawer .ld-header{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;cursor:pointer;font-size:12px;font-weight:600;color:#94a3b8;transition:background .2s}
.location-drawer .ld-header:hover{background:rgba(255,255,255,.06)}
.location-drawer .ld-body{padding:8px 12px;border-top:1px solid rgba(255,255,255,.06)}

/* ─── BBHN / AP / OPL cards ─── */
.bbhn-card:hover,.ap-card:hover,.opl-card:hover{background:rgba(255,255,255,.08)!important;border-color:rgba(245,158,11,.3)!important}
.form-row{display:flex;gap:10px;margin-bottom:8px}
.form-col{flex:1}
.form-group{margin-bottom:12px}
.form-group label{display:block;font-size:11px;font-weight:600;color:#94a3b8;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}
