/* EIP Frontend CSS v2.0 */
.eip-pub{max-width:1100px;margin:0 auto;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;color:#0f172a;}
.eip-pub *,.eip-pub *::before,.eip-pub *::after{box-sizing:border-box;}

.eip-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;margin-bottom:18px;}
.eip-kpi{background:#fff;border:1px solid #e8edf3;border-radius:12px;padding:18px 20px 16px;position:relative;overflow:hidden;box-shadow:0 1px 3px rgba(15,23,42,.05);}
.eip-kpi::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:12px 12px 0 0;}
.eip-kpi-blue::before  {background:linear-gradient(90deg,#6366f1,#a5b4fc);}
.eip-kpi-green::before {background:linear-gradient(90deg,#10b981,#6ee7b7);}
.eip-kpi-purple::before{background:linear-gradient(90deg,#8b5cf6,#c4b5fd);}
.eip-kpi-amber::before {background:linear-gradient(90deg,#f59e0b,#fde68a);}
.eip-kpi-label{display:block;font-size:11px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.07em;margin-bottom:4px;}
.eip-kpi-val  {display:block;font-size:22px;font-weight:700;color:#0f172a;line-height:1.1;margin-bottom:4px;}
.eip-kpi-sub  {display:block;font-size:12px;color:#64748b;}

.eip-bar{height:6px;background:#e2e8f0;border-radius:3px;overflow:hidden;margin-top:5px;}
.eip-bar span{display:block;height:100%;background:linear-gradient(90deg,#6366f1,#10b981);border-radius:3px;}

.eip-card{background:#fff;border:1px solid #e8edf3;border-radius:14px;padding:20px;margin-bottom:18px;box-shadow:0 1px 4px rgba(15,23,42,.05);}
.eip-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:12px;flex-wrap:wrap;}
.eip-card-title{font-size:14px;font-weight:600;color:#374151;}

/* Chart containers — fixed height prevents infinite stretch */
.eip-chart-box{position:relative;height:240px;width:100%;overflow:hidden;}
.eip-chart-box canvas{position:absolute!important;top:0!important;left:0!important;width:100%!important;height:100%!important;}
.eip-chart-box-sm{height:200px;}

.eip-date-input{padding:7px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:13px;min-width:200px;background:#f8fafc;cursor:pointer;color:#334155;}
.eip-date-input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px rgba(99,102,241,.12);}

/* Form */
.eip-pub form label{display:block;font-size:13px;font-weight:500;color:#334155;margin-bottom:10px;}
.eip-pub form input[type=text],.eip-pub form input[type=number],.eip-pub form input[type=date],
.eip-pub form select,.eip-pub form textarea{display:block;width:100%;padding:9px 12px;margin-top:4px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;background:#fff;color:#1e293b;transition:border-color .15s,box-shadow .15s;}
.eip-pub form input:focus,.eip-pub form select:focus,.eip-pub form textarea:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px rgba(99,102,241,.12);}
.eip-pub form textarea{min-height:64px;resize:vertical;}
.eip-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-bottom:14px;}
.eip-full{display:block;margin-bottom:14px;}
.eip-file-area{background:#f8fafc;padding:14px;border-radius:10px;border:1.5px dashed #cbd5e1;}
.req{color:#ef4444;}
.eip-btn{background:#6366f1;color:#fff;border:0;padding:10px 24px;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;box-shadow:0 2px 6px rgba(99,102,241,.30);transition:background .15s;}
.eip-btn:hover{background:#4f46e5;}

/* Notices */
.eip-notice{padding:12px 16px;border-radius:8px;margin-bottom:14px;font-size:14px;}
.eip-ok {background:#d1fae5;color:#065f46;border-left:3px solid #10b981;}
.eip-err{background:#fee2e2;color:#991b1b;border-left:3px solid #ef4444;}

/* Table */
.eip-table-wrap{overflow-x:auto;}
.eip-table{width:100%;border-collapse:collapse;font-size:13px;}
.eip-table th,.eip-table td{padding:10px 14px;border-bottom:1px solid #f1f5f9;text-align:left;}
.eip-table th{background:#f8fafc;font-weight:600;font-size:11px;color:#64748b;text-transform:uppercase;letter-spacing:.05em;}
.eip-table tr:hover td{background:#f8fafc;}
.eip-empty{text-align:center;color:#94a3b8;padding:24px!important;}

.eip-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px;vertical-align:middle;}
.eip-badge{display:inline-block;padding:2px 10px;border-radius:999px;font-size:11px;font-weight:600;}
.eip-badge-approved{background:#d1fae5;color:#047857;}
.eip-badge-pending {background:#fef3c7;color:#92400e;}
.eip-badge-rejected{background:#fee2e2;color:#991b1b;}

.eip-login-msg{padding:16px;background:#f8fafc;border-radius:10px;font-size:14px;}

/* Flatpickr */
.flatpickr-calendar{z-index:999999!important;border-radius:12px!important;box-shadow:0 8px 32px rgba(15,23,42,.12)!important;}
.flatpickr-day.selected,.flatpickr-day.startRange,.flatpickr-day.endRange{background:#6366f1!important;border-color:#6366f1!important;}
.flatpickr-day.inRange{background:rgba(99,102,241,.1)!important;border-color:transparent!important;}
