/* === CiCC Assessment App - Mobile-First CSS === */
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Segoe UI',Arial,sans-serif;background:#f0f2f5;padding:16px}
.app{max-width:500px;margin:0 auto;background:white;border-radius:16px;padding:20px;box-shadow:0 2px 12px rgba(0,0,0,.1);display:none}

/* ─── Typography ─── */
h1{font-size:22px;color:#1a237e;margin-bottom:16px;display:flex;align-items:center;gap:8px}
h1 small{font-size:13px;color:#666;font-weight:normal}
label{display:block;font-size:13px;font-weight:500;color:#333;margin:12px 0 4px}
select,input,textarea{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:14px;font-family:inherit}
textarea{resize:vertical;min-height:60px}

/* ─── Header (Dark Luxury) ─── */
.header-container{background:linear-gradient(135deg,#0a0e27 0%,#1a1f4e 30%,#0d1557 60%,#0a0e27 100%);display:flex;align-items:center;justify-content:space-between;padding:8px 12px;margin:-15px -15px 12px -15px;position:relative;overflow:hidden}
.header-container::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(ellipse at 20% 50%,rgba(99,179,237,.15) 0%,transparent 50%),radial-gradient(ellipse at 80% 50%,rgba(139,92,246,.12) 0%,transparent 50%),linear-gradient(90deg,transparent 0%,rgba(255,255,255,.03) 50%,transparent 100%);pointer-events:none}
.header-container::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,#22c55e,#3b82f6,#22c55e,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(34,197,94,.5),0 0 24px rgba(34,197,94,.2);border:1.5px solid rgba(255,255,255,.2)}
.header-logo h1{margin:0;font-size:16px;font-weight:800;color:white;letter-spacing:.5px;text-shadow:0 0 10px rgba(34,197,94,.5);line-height:1}
.header-logo h1 small{font-size:9px;font-weight:500;color:rgba(255,255,255,.6);display:block;letter-spacing:1.5px;text-transform:uppercase;text-shadow:none;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;text-shadow:0 1px 2px rgba(0,0,0,.3);transition:all .3s}
#currentUserDisplay:hover{background:rgba(255,255,255,.15);border-color:rgba(34,197,94,.6);box-shadow:0 0 15px rgba(34,197,94,.3);transform:translateY(-1px)}
#currentUserDisplay .user-avatar{width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,#22c55e,#3b82f6);display:flex;align-items:center;justify-content:center;font-size:10px;box-shadow:0 0 8px rgba(34,197,94,.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);backdrop-filter:blur(8px);text-transform:uppercase;letter-spacing:.5px;transition:all .3s}
#statusIndicator.online{background:rgba(34,197,94,.2);border-color:rgba(34,197,94,.5);color:#4ade80;box-shadow:0 0 8px rgba(34,197,94,.3)}
.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(34,197,94,.3);border-color:rgba(34,197,94,.5);transform:rotate(180deg);box-shadow:0 0 12px rgba(34,197,94,.4)}
.sync-btn:active{transform:rotate(360deg) scale(.9)}

/* ─── User Menu ─── */
#userMenu{position:absolute;top:100%;right:0;background:white;border-radius:14px;box-shadow:0 10px 40px rgba(0,0,0,.2),0 0 0 1px rgba(0,0,0,.05);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)}
#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,#22c55e,#3b82f6);display:flex;align-items:center;justify-content:center;font-size:22px;margin:0 auto 8px;box-shadow:0 0 16px rgba(34,197,94,.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(34,197,94,.3);color:#86efac;border:1px solid rgba(34,197,94,.4);text-transform:uppercase;letter-spacing:.5px}
.menu-divider{height:1px;background:#e2e8f0;margin:4px 0}
#userMenu div[onclick]{padding:10px 14px;font-size:12px;cursor:pointer;transition:background .2s;display:flex;align-items:center;gap:8px}
#userMenu div[onclick]:hover{background:#f1f5f9}

/* ─── Tabs ─── */
.tabs{display:flex;gap:4px;margin-bottom:16px;background:#f0f2f5;border-radius:10px;padding:4px}
.tab{flex:1;text-align:center;padding:8px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:500;transition:.2s;border:none;background:transparent}
.tab.active{background:white;color:#1a237e;box-shadow:0 1px 4px rgba(0,0,0,.1)}

/* ─── Screens ─── */
.screen{display:none;background:white;border-radius:12px;padding:15px;border:1px solid #e0e0e0;border-top:4px solid #22c55e;box-shadow:0 4px 6px rgba(0,0,0,.05)}
.screen.active{display:block}

/* ─── Buttons ─── */
.btn{width:100%;padding:12px;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;margin-top:16px;transition:.2s}
.btn:hover{opacity:.9}
.btn-green{background:#22c55e;color:#fff}
.btn-blue{background:#1565c0;color:#fff}
.btn-gray{background:#757575;color:#fff}
.btn-red{background:#d32f2f;color:#fff}
.btn-orange{background:#f57c00;color:#fff}

/* ─── Dashboard ─── */
.dashboard{margin-bottom:16px;transition:all .3s ease}
.dashboard-toggle{display:flex;justify-content:space-between;align-items:center;cursor:pointer;padding:6px 10px;background:linear-gradient(135deg,#22c55e 0%,#15803d 100%);border-radius:8px 8px 0 0;color:white;font-size:12px;font-weight:600;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:4px;overflow:hidden;transition:max-height .4s ease,opacity .3s ease,padding .3s ease;max-height:500px;opacity:1;padding-top:4px}
.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:6px;background:white;border:1px solid #e0e0e0;cursor:pointer;font-size:10px}
.compact-item .num{font-size:16px;font-weight:700;display:block}
.compact-item .lbl{font-size:9px;color:#666}
.dash-card{background:white;border-radius:6px;padding:6px 12px;border:1px solid #e0e0e0;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:background .2s,transform .15s}
.dash-card:active{transform:scale(.97)}
.dash-card:hover{background:#f5f7fa}
.dash-card .title{font-size:13px;font-weight:600;flex:2}
.dash-card .total{font-size:13px;font-weight:600;flex:1;text-align:center}

/* ─── Skeleton Loading ─── */
.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:6px}
@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}
.skeleton-card-desc{height:12px;width:70%;margin:4px 0}
.skeleton-kanban-col{min-height:200px}

/* ─── Assessment Form ─── */
.assess-item{background:#f8f9fa;border-radius:8px;padding:10px;margin-bottom:8px;border:1px solid #e0e0e0}
.assess-item .q{font-size:13px;font-weight:600;color:#1a237e;margin-bottom:4px}
.assess-item .group-header{background:linear-gradient(135deg,#1a237e,#0d47a1);color:white;padding:8px 12px;border-radius:8px;font-size:14px;font-weight:700;margin-bottom:10px;display:flex;justify-content:space-between;align-items:center}
.assess-item .group-header .score-badge{background:rgba(255,255,255,.2);padding:2px 10px;border-radius:10px;font-size:12px}
.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:4px 8px;border-radius:6px;border:1px solid #e0e0e0;transition:.2s}
.assess-score label:has(input:checked){background:#e8eaf6;border-color:#1a237e;color:#1a237e;font-weight:600}
.assess-score input[type="radio"]{width:auto}
.assess-comment{width:100%;margin-top:6px;padding:6px 8px;border:1px solid #ddd;border-radius:6px;font-size:12px;min-height:32px}
.quick-tag-btn{display:inline-block;padding:3px 10px;font-size:10px;font-weight:600;border:1px solid #f57c00;background:#fff3e0;color:#e65100;border-radius:6px;cursor:pointer;transition:all .2s}
.quick-tag-btn:hover{background:#ffe0b2;border-color:#e65100}

/* ─── Score Bar ─── */
.score-bar{height:8px;background:#e0e0e0;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)}

/* ─── Schedule Cards ─── */
.schedule-card{background:white;border-radius:10px;padding:12px;margin-bottom:10px;border:1px solid #e0e0e0;border-left:4px solid #22c55e;cursor:pointer;transition:all .2s}
.schedule-card:active{transform:scale(.98)}
.schedule-card .sc-title{font-size:13px;font-weight:600;color:#1a237e}
.schedule-card .sc-meta{font-size:11px;color:#999;margin-top:4px}
.schedule-card .sc-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:600;margin-top:6px}
.schedule-card .sc-badge.pending{background:#fff3e0;color:#e65100}
.schedule-card .sc-badge.completed{background:#e8f5e9;color:#2e7d32}
.schedule-card .sc-badge.in_progress{background:#e3f2fd;color:#1565c0}

/* ─── Radar Chart ─── */
.radar-container{position:relative;width:100%;max-width:300px;margin:0 auto}
.radar-container canvas{width:100%!important;height:auto!important}

/* ─── Observation Card ─── */
.obs-card{background:#fff8e1;border:1px solid #ffcc02;border-radius:10px;padding:12px;margin-bottom:10px}
.obs-card .obs-title{font-size:13px;font-weight:600;color:#f57c00}
.obs-card .obs-meta{font-size:11px;color:#666;margin-top:4px}
.obs-card .obs-status{display:inline-block;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:600;background:#fff3e0;color:#e65100}

/* ─── Modal & Overlays ─── */
#modalOverlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:1000;justify-content:center;align-items:center}
.modal-content{background:white;border-radius:16px;padding:24px;max-width:380px;width:90%;max-height:90vh;overflow-y:auto}

/* ─── Auth ─── */
#auth-container{position:fixed;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#1a237e 0%,#0d47a1 100%);z-index:2000;display:flex;justify-content:center;align-items:flex-start;padding:40px 20px;overflow-y:auto}
.auth-card{background:white;border-radius:16px;padding:30px 24px;width:100%;max-width:400px;box-shadow:0 15px 35px rgba(0,0,0,.3);margin-bottom:40px}
.auth-input-group{margin-bottom:16px}
.auth-input-group label{display:block;font-size:12px;margin-bottom:4px;color:#666;font-weight:bold}
.auth-input-group input,.auth-input-group select{width:100%;padding:12px 16px;border:1.5px solid #e0e0e0;border-radius:10px;font-size:14px;outline:none;background:#f9f9f9}
.auth-btn{background:#1a237e;color:white;border:none;border-radius:8px;padding:12px;width:100%;font-weight:bold;margin-top:10px;cursor:pointer}
.auth-link{text-align:center;margin-top:16px;font-size:13px;color:#1565c0;cursor:pointer}

/* ─── Toast ─── */
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:#333;color:white;padding:12px 24px;border-radius:8px;font-size:14px;opacity:0;transition:.3s;pointer-events:none;z-index:999}
.toast.show{opacity:1}

/* ─── Footer ─── */
.app-footer{text-align:center;padding:12px 0;margin:16px -15px -15px -15px;background:linear-gradient(135deg,#0a0e27 0%,#1a1f4e 50%,#0a0e27 100%);color:rgba(255,255,255,.4);font-size:10px}

/* ─── 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}
.photo-grid .img-box img{width:100%;border-radius:8px}
.photo-grid .img-box .placeholder{width:100%;height:100px;background:#f5f5f5;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#999;font-size:11px}

/* ─── Camera / 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 #22c55e;background:#dcfce7;color:#166534;border-radius:6px;cursor:pointer;transition:.2s}
.photo-capture-btn:hover{background:#bbf7d0}
.photo-capture-btn:active{transform:scale(.97)}
.photo-capture-btn.has-photo{border-color:#3b82f6;background:#dbeafe;color:#1e40af}
.photo-preview{margin-top:6px;text-align:center}
.photo-preview img{max-width:100%;max-height:200px;border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,.15)}
.photo-actions{display:flex;gap:6px;margin-top:6px;justify-content:center}
.photo-actions .btn{padding:4px 12px;font-size:11px;min-width:80px}

/* ─── Location Picker ─── */
#locPickerOverlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);z-index:3000;display:none;justify-content:center;align-items:center;padding:15px}
.loc-picker-card{background:white;border-radius:16px;width:100%;max-width:450px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden}

/* ─── Print ─── */
@media print{body *{visibility:hidden}#printArea,#printArea *{visibility:visible}#printArea{position:absolute;left:0;top:0;width:100%}.no-print{display:none!important}}

/* ─── Eval Type Selector ─── */
.eval-type-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin:12px 0}
.eval-type-card{border:2px solid #e0e0e0;border-radius:10px;padding:12px;text-align:center;cursor:pointer;transition:.2s}
.eval-type-card:hover{border-color:#22c55e;background:#f0fdf4}
.eval-type-card.selected{border-color:#22c55e;background:#dcfce7}
.eval-type-card .et-icon{font-size:24px;margin-bottom:4px}
.eval-type-card .et-label{font-size:11px;font-weight:600;color:#333}
.eval-type-card .et-desc{font-size:9px;color:#999;margin-top:2px}

/* ─── 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:#1a237e}

/* ─── Quick Action Grid ─── */
.quick-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:12px 0}
.quick-item{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;border-radius:12px;padding:16px 12px;text-align:center;cursor:pointer;transition:all .2s}
.quick-item:active{transform:scale(.95)}
.quick-item .qi-icon{font-size:28px;margin-bottom:6px}
.quick-item .qi-label{font-size:12px;font-weight:600;color:#333}
.quick-item .qi-count{font-size:18px;font-weight:800;color:#1a237e;margin-top:2px}
