/* ============================================================
   PMO Banking — CSS fiel al estilo de pmoadmin.html
   DM Sans + DM Mono | Paleta accent #1A3A5C | Light/Dark auto
   ============================================================ */

*{margin:0;padding:0;box-sizing:border-box;}

:root{
  --bg:#F5F4F0;
  --card:#FFFFFF;
  --card2:#F1EFE8;
  --border:#E0DED6;
  --border2:#C8C6BC;
  --text:#1A1A18;
  --muted:#6B6A64;
  --hint:#9E9C96;
  --accent:#1A3A5C;
  --accent2:#1D9E75;
  --r:12px;
  --rm:8px;
  --shadow:0 1px 3px rgba(0,0,0,0.08), 0 1px 2px rgba(0,0,0,0.04);
  --shadow-lg:0 4px 16px rgba(0,0,0,0.10), 0 2px 6px rgba(0,0,0,0.06);
}
@media(prefers-color-scheme:dark){
  :root{
    --bg:#111110;--card:#1C1C1A;--card2:#242422;
    --border:#2E2E2C;--border2:#3E3E3C;
    --text:#E8E6DE;--muted:#9E9C96;--hint:#6B6A64;
    --shadow:0 1px 3px rgba(0,0,0,0.3);--shadow-lg:0 4px 16px rgba(0,0,0,0.4);
  }
}

body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;line-height:1.5;}

/* ── LOGIN ── */
.login-overlay{
  position:fixed;inset:0;
  background:radial-gradient(ellipse at 30% 60%, rgba(26,58,92,0.12) 0%, transparent 60%), var(--bg);
  display:flex;align-items:center;justify-content:center;z-index:9999;
}
.login-overlay.hidden{display:none;}

.login-card{
  background:var(--card);border:1px solid var(--border2);
  border-radius:var(--r);padding:36px 32px;width:100%;max-width:400px;
  box-shadow:var(--shadow-lg);
}
.login-logo{
  width:52px;height:52px;background:var(--accent);border-radius:var(--rm);
  display:grid;place-items:center;font-size:22px;color:#5AB4FF;
  margin:0 auto 16px;
}
.login-title{text-align:center;font-size:20px;font-weight:600;letter-spacing:-0.3px;margin-bottom:4px;}
.login-sub{text-align:center;font-size:12px;color:var(--muted);margin-bottom:24px;}
.login-error{
  background:#FCEBEB;border:1px solid #F09595;border-radius:var(--rm);
  color:#791F1F;font-size:12px;padding:8px 12px;margin-bottom:12px;
  display:flex;align-items:center;gap:6px;
}
@media(prefers-color-scheme:dark){
  .login-error{background:rgba(226,75,74,0.15);border-color:rgba(226,75,74,0.4);color:#F09595;}
}
.btn-login{
  width:100%;padding:10px;background:var(--accent);color:#fff;
  border:none;border-radius:var(--rm);font-family:'DM Sans',sans-serif;
  font-size:13px;font-weight:600;cursor:pointer;margin-top:8px;
  transition:background .15s;
}
.btn-login:hover{background:#12294A;}
.login-hint{
  margin-top:16px;padding:10px 12px;
  background:rgba(26,58,92,0.06);border:1px solid rgba(26,58,92,0.12);
  border-radius:var(--rm);font-size:11px;color:var(--muted);text-align:center;
}
.pw-toggle{
  position:absolute;right:10px;top:50%;transform:translateY(-50%);
  background:none;border:none;color:var(--muted);cursor:pointer;font-size:13px;
}

/* ── TOPBAR ── */
.topbar{background:var(--accent);color:#fff;padding:0 24px;position:sticky;top:0;z-index:200;box-shadow:0 2px 8px rgba(0,0,0,0.2);}
.topbar-inner{max-width:1280px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:54px;gap:8px;}
.logo{font-size:15px;font-weight:600;letter-spacing:-0.3px;display:flex;align-items:center;gap:8px;white-space:nowrap;}
.logo i{font-size:18px;color:#5AB4FF;}
.topbar-right{display:flex;align-items:center;gap:6px;flex-wrap:wrap;}
.topbar-user{font-size:12px;color:rgba(255,255,255,0.7);padding:0 8px;border-right:1px solid rgba(255,255,255,0.2);margin-right:2px;}

.tbtn{font-family:'DM Sans',sans-serif;font-size:12px;padding:6px 12px;border-radius:var(--rm);cursor:pointer;font-weight:500;border:none;display:flex;align-items:center;gap:5px;transition:all .15s;white-space:nowrap;}
.tbtn-ghost{background:rgba(255,255,255,0.12);color:#fff;}
.tbtn-ghost:hover{background:rgba(255,255,255,0.22);}
.tbtn-primary{background:#5AB4FF;color:#0a2340;}
.tbtn-primary:hover{background:#7AC8FF;}
.tbtn-danger{background:rgba(226,75,74,0.25);color:#FFB3B3;}
.tbtn-danger:hover{background:rgba(226,75,74,0.4);}

/* ── LAYOUT ── */
.app{max-width:1280px;margin:0 auto;padding:0 24px 60px;}

/* ── PAGE HEADER ── */
.page-header{padding:28px 0 20px;border-bottom:1px solid var(--border);margin-bottom:24px;}
.ph-top{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap;}
.ph-title{font-size:22px;font-weight:600;letter-spacing:-0.4px;}
.ph-sub{font-size:13px;color:var(--muted);margin-top:3px;}
.ph-actions{display:flex;gap:8px;flex-wrap:wrap;}

.btn{font-family:'DM Sans',sans-serif;font-size:12px;padding:7px 14px;border-radius:var(--rm);cursor:pointer;font-weight:500;border:1px solid var(--border2);background:var(--card);color:var(--text);display:inline-flex;align-items:center;gap:6px;transition:all .15s;box-shadow:var(--shadow);}
.btn:hover{background:var(--card2);}
.btn-accent{background:var(--accent);color:#fff;border-color:var(--accent);}
.btn-accent:hover{background:#12294A;}
.btn-green{background:#1D9E75;color:#fff;border-color:#1D9E75;}
.btn-green:hover{background:#17835E;}

/* ── KPI CARDS ── */
.kpi-row{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:24px;}
@media(max-width:900px){.kpi-row{grid-template-columns:repeat(3,1fr);}}
@media(max-width:600px){.kpi-row{grid-template-columns:repeat(2,1fr);}}

.kpi{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:16px 18px;box-shadow:var(--shadow);position:relative;overflow:hidden;cursor:pointer;transition:box-shadow .15s;}
.kpi:hover{box-shadow:var(--shadow-lg);}
.kpi::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:3px 0 0 3px;}
.kpi.k-blue::before{background:#185FA5;}
.kpi.k-green::before{background:#1D9E75;}
.kpi.k-amber::before{background:#BA7517;}
.kpi.k-red::before{background:#E24B4A;}
.kpi.k-gray::before{background:#888780;}
.kpi label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:0.6px;display:block;margin-bottom:8px;font-weight:500;cursor:pointer;}
.kpi .val{font-size:28px;font-weight:600;line-height:1;font-family:'DM Mono',monospace;letter-spacing:-1px;}
.kpi.k-blue .val{color:#185FA5;}
.kpi.k-green .val{color:#1D9E75;}
.kpi.k-amber .val{color:#BA7517;}
.kpi.k-red .val{color:#E24B4A;}
.kpi.k-gray .val{color:#888780;}
.kpi .sub{font-size:11px;color:var(--muted);margin-top:5px;}

/* ── SEMÁFORO ── */
.semaforo-bar{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:14px 18px;margin-bottom:20px;display:flex;align-items:center;gap:16px;flex-wrap:wrap;box-shadow:var(--shadow);}
.sem-title{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:0.5px;white-space:nowrap;}
.sem-group{display:flex;align-items:center;gap:8px;flex:1;min-width:180px;}
.sem-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;}
.sem-dot.green{background:#1D9E75;}
.sem-dot.amber{background:#BA7517;}
.sem-dot.red{background:#E24B4A;}
.sem-label{font-size:12px;color:var(--muted);white-space:nowrap;}
.sem-input{font-family:'DM Mono',monospace;font-size:12px;width:52px;padding:4px 6px;border-radius:var(--rm);border:1px solid var(--border2);background:var(--card2);color:var(--text);text-align:center;}
.sem-apply{font-family:'DM Sans',sans-serif;font-size:11px;padding:5px 12px;border-radius:var(--rm);border:1px solid var(--border2);background:var(--accent);color:#fff;cursor:pointer;font-weight:500;}

/* ── FILTROS ── */
.filter-bar{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap;align-items:center;}
.flt{font-family:'DM Sans',sans-serif;font-size:12px;padding:5px 14px;border-radius:99px;border:1px solid var(--border2);background:var(--card);color:var(--muted);cursor:pointer;transition:all .15s;font-weight:500;}
.flt:hover,.flt.active{background:var(--accent);color:#fff;border-color:var(--accent);}
.search-wrap{margin-left:auto;position:relative;}
.search-wrap i{position:absolute;left:10px;top:50%;transform:translateY(-50%);font-size:13px;color:var(--muted);}
.search-inp{font-family:'DM Sans',sans-serif;font-size:12px;background:var(--card);border:1px solid var(--border2);border-radius:99px;padding:5px 12px 5px 30px;color:var(--text);outline:none;width:240px;box-shadow:var(--shadow);}
.search-inp:focus{border-color:var(--accent);}

/* ── API STATUS BAR ── */
.api-status-bar{
  display:flex;align-items:center;gap:8px;padding:8px 14px;margin-bottom:12px;
  background:rgba(26,158,117,0.08);border:1px solid rgba(26,158,117,0.2);
  border-radius:var(--rm);font-size:12px;color:var(--muted);
}
.api-status-bar.warn{background:rgba(186,117,23,0.08);border-color:rgba(186,117,23,0.25);}
.api-status-bar.error{background:rgba(226,75,74,0.08);border-color:rgba(226,75,74,0.25);}

/* ── PROJECT CARD ── */
.proj-list{display:flex;flex-direction:column;gap:12px;}
.proj-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow);overflow:hidden;transition:box-shadow .15s,border-color .15s;}
.proj-card:hover{box-shadow:var(--shadow-lg);border-color:var(--border2);}

.card-head{padding:16px 20px 12px;cursor:pointer;display:flex;gap:14px;align-items:flex-start;position:relative;}
.status-stripe{position:absolute;left:0;top:0;bottom:0;width:4px;}
.card-body{flex:1;padding-left:4px;}
.card-name{font-size:15px;font-weight:600;letter-spacing:-0.2px;margin-bottom:4px;}
.card-meta{font-size:12px;color:var(--muted);display:flex;gap:14px;flex-wrap:wrap;}
.card-meta span{display:flex;align-items:center;gap:4px;}
.card-right{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0;}
.pct-num{font-size:26px;font-weight:700;font-family:'DM Mono',monospace;line-height:1;letter-spacing:-1px;}
.badges{display:flex;gap:5px;flex-wrap:wrap;justify-content:flex-end;}

.badge{font-size:10px;font-weight:600;padding:3px 8px;border-radius:99px;white-space:nowrap;letter-spacing:0.2px;}
.b-en_tiempo{background:#EAF3DE;color:#27500A;}
.b-en_riesgo{background:#FAEEDA;color:#633806;}
.b-retrasado{background:#FCEBEB;color:#791F1F;}
.b-completado{background:#E1F5EE;color:#04342C;}
.b-pausado{background:#F1EFE8;color:#444441;}
.b-p-high{background:#FCEBEB;color:#791F1F;border:1px solid #F09595;}
.b-p-med{background:#FAEEDA;color:#633806;border:1px solid #EF9F27;}
.b-p-low{background:#F1EFE8;color:#444441;border:1px solid #B4B2A9;}
@media(prefers-color-scheme:dark){
  .b-en_tiempo{background:rgba(29,158,117,0.15);color:#5DCAA5;}
  .b-en_riesgo{background:rgba(186,117,23,0.15);color:#EF9F27;}
  .b-retrasado{background:rgba(226,75,74,0.15);color:#F09595;}
  .b-completado{background:rgba(24,95,165,0.15);color:#7ABFFF;}
  .b-pausado{background:rgba(136,135,128,0.15);color:#9E9C96;}
  .b-p-high{background:rgba(226,75,74,0.12);color:#F09595;border-color:rgba(226,75,74,0.3);}
  .b-p-med{background:rgba(186,117,23,0.12);color:#EF9F27;border-color:rgba(186,117,23,0.3);}
  .b-p-low{background:rgba(136,135,128,0.1);color:#9E9C96;border-color:rgba(136,135,128,0.3);}
}

/* ── PROGRESS BAR ── */
.prog-wrap{padding:0 20px 0 24px;margin-bottom:10px;}
.prog-bar{height:6px;background:var(--card2);border-radius:99px;overflow:hidden;border:1px solid var(--border);}
.prog-fill{height:100%;border-radius:99px;transition:width .8s cubic-bezier(.4,0,.2,1);}
.f-green{background:linear-gradient(90deg,#1D9E75,#5DCAA5);}
.f-amber{background:linear-gradient(90deg,#BA7517,#EF9F27);}
.f-red{background:linear-gradient(90deg,#A32D2D,#E24B4A);}
.f-blue{background:linear-gradient(90deg,#185FA5,#378ADD);}
.f-gray{background:linear-gradient(90deg,#5F5E5A,#888780);}

/* ── MILESTONES ── */
.milestones{padding:4px 20px 12px 24px;display:flex;gap:5px;flex-wrap:wrap;}
.ms{font-size:10px;padding:3px 8px;border-radius:99px;display:flex;align-items:center;gap:4px;font-weight:500;}
.ms-done{background:var(--card2);color:var(--muted);}
.ms-done i{color:#1D9E75;font-size:11px;}
.ms-next{background:#FFF3E0;color:#633806;border:1px solid #EF9F27;}
.ms-next i{color:#BA7517;font-size:11px;}
.ms-pend{background:var(--card2);color:var(--hint);}
.ms-pend i{font-size:11px;}
@media(prefers-color-scheme:dark){
  .ms-next{background:rgba(186,117,23,0.12);color:#EF9F27;border-color:rgba(186,117,23,0.3);}
}

/* ── DETALLE EXPANDIBLE ── */
.proj-detail{display:none;border-top:1px solid var(--border);padding:18px 20px 20px 24px;}
.proj-detail.open{display:block;}

.tl-section{margin-bottom:16px;}
.tl-header{font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:0.5px;margin-bottom:6px;display:flex;align-items:center;gap:6px;}
.tl-bar{height:32px;background:var(--card2);border-radius:var(--rm);position:relative;overflow:hidden;border:1px solid var(--border);}
.tl-fill{height:100%;border-radius:var(--rm);}
.tl-today-line{position:absolute;top:0;bottom:0;width:2px;background:#E24B4A;z-index:2;}
.tl-today-label{position:absolute;top:50%;transform:translateY(-50%);font-size:9px;color:#fff;background:#E24B4A;padding:1px 4px;border-radius:3px;white-space:nowrap;z-index:3;}
.tl-dates{display:flex;justify-content:space-between;font-size:10px;color:var(--hint);margin-top:3px;}

.detail-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:14px;}
@media(max-width:700px){.detail-grid{grid-template-columns:1fr;}}
.dbox{background:var(--card2);border-radius:var(--rm);padding:12px 14px;border:1px solid var(--border);}
.dbox h4{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:8px;display:flex;align-items:center;gap:5px;font-weight:600;}
.dbox ul{list-style:none;}
.dbox ul li{font-size:12px;padding:4px 0;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;gap:7px;line-height:1.4;}
.dbox ul li:last-child{border-bottom:none;}
.dbox ul li i{font-size:12px;margin-top:1px;flex-shrink:0;}
.li-blocker i{color:#E24B4A;}
.li-advance i{color:#1D9E75;}
.li-risk i{color:#BA7517;}

.actions-box{background:var(--card2);border-radius:var(--rm);padding:14px;border:1px solid var(--border);margin-bottom:12px;}
.actions-box h4{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:8px;display:flex;align-items:center;gap:5px;font-weight:600;}
.action-row{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--border);font-size:12px;}
.action-row:last-child{border-bottom:none;}
.action-owner{font-size:11px;background:var(--card);border:1px solid var(--border2);border-radius:99px;padding:2px 8px;color:var(--muted);white-space:nowrap;}
.action-due{font-size:11px;color:var(--hint);margin-left:auto;white-space:nowrap;}

/* ── TEAM / FOOTER ── */
.card-footer{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.team-row{display:flex;align-items:center;}
.avatar{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;border:2px solid var(--card);margin-left:-4px;}
.avatar:first-child{margin-left:0;}
.av0{background:#EEEDFE;color:#3C3489;}
.av1{background:#E1F5EE;color:#085041;}
.av2{background:#FAEEDA;color:#633806;}
.av3{background:#E6F1FB;color:#0C447C;}
.av4{background:#FAECE7;color:#712B13;}
.av5{background:#EAF3DE;color:#27500A;}
@media(prefers-color-scheme:dark){
  .av0{background:rgba(60,52,137,0.3);color:#B0ACFF;}
  .av1{background:rgba(8,80,65,0.3);color:#5DCAA5;}
  .av2{background:rgba(99,56,6,0.3);color:#EF9F27;}
  .av3{background:rgba(12,68,124,0.3);color:#7ABFFF;}
  .av4{background:rgba(113,43,19,0.3);color:#FFB39A;}
  .av5{background:rgba(39,80,10,0.3);color:#A3CF7A;}
}
.card-btns{margin-left:auto;display:flex;gap:6px;flex-wrap:wrap;}
.cbtn{font-family:'DM Sans',sans-serif;font-size:11px;padding:4px 12px;border-radius:var(--rm);border:1px solid var(--border2);background:var(--card);color:var(--muted);cursor:pointer;display:flex;align-items:center;gap:5px;transition:all .15s;}
.cbtn:hover{background:var(--card2);color:var(--text);}
.cbtn-danger:hover{background:#FCEBEB;color:#A32D2D;border-color:#F09595;}
@media(prefers-color-scheme:dark){
  .cbtn-danger:hover{background:rgba(226,75,74,0.15);color:#F09595;border-color:rgba(226,75,74,0.3);}
}

/* ── MODAL ── */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:500;align-items:center;justify-content:center;padding:16px;}
.modal-bg.open{display:flex;}
.modal{background:var(--card);border:1px solid var(--border2);border-radius:var(--r);padding:28px;width:640px;max-width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);}
.modal h3{font-size:17px;font-weight:600;margin-bottom:18px;display:flex;align-items:center;gap:8px;}
.form-grid{display:grid;gap:12px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.form-row.three{grid-template-columns:1fr 1fr 1fr;}
.form-group{display:flex;flex-direction:column;gap:4px;}
.form-group label{font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:0.4px;}
.finp{font-family:'DM Sans',sans-serif;font-size:13px;background:var(--card2);border:1px solid var(--border2);border-radius:var(--rm);padding:8px 12px;color:var(--text);outline:none;width:100%;transition:border-color .15s;}
.finp:focus{border-color:var(--accent);}
textarea.finp{resize:vertical;min-height:70px;}
.modal-footer{display:flex;justify-content:flex-end;gap:8px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border);}

/* ── TOAST ── */
.toast-wrap{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px;}
.toast{font-size:13px;background:var(--accent);color:#fff;padding:10px 16px;border-radius:var(--rm);box-shadow:var(--shadow-lg);animation:toastin .25s ease;display:flex;align-items:center;gap:8px;}
.toast.success{background:#1D9E75;}
.toast.warning{background:#BA7517;}
.toast.danger{background:#A32D2D;}
@keyframes toastin{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:translateY(0);}}

/* ── NO RESULTS ── */
.no-results{text-align:center;padding:48px;color:var(--muted);font-size:14px;}
.no-results i{font-size:32px;display:block;margin-bottom:10px;color:var(--hint);}

/* ── LOADING SKELETON ── */
.skeleton{background:linear-gradient(90deg,var(--card2) 25%,var(--border) 50%,var(--card2) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;}
@keyframes shimmer{0%{background-position:200% 0;}100%{background-position:-200% 0;}}
.skel-card{height:90px;border-radius:var(--r);margin-bottom:12px;}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:6px;height:6px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px;}

/* ── PRINT ── */
@media print{
  .topbar,.filter-bar,.ph-actions,.card-btns,.semaforo-bar,.milestones,.proj-detail{display:none!important;}
  .proj-card{box-shadow:none!important;break-inside:avoid;}
  body{background:#fff;}
}

/* ── PDF SELECTION MODAL ── */
.pdf-sel-modal { width: 500px; max-height: 85vh; }
.pdf-proj-list { 
  margin-top: 10px; 
  max-height: 320px; 
  overflow-y: auto; 
  border: 1px solid var(--border); 
  border-radius: var(--rm);
  background: var(--card2);
}
.pdf-item {
  display: flex;
  align-items: center;
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
  transition: background .15s;
  cursor: pointer;
}
.pdf-item:last-child { border-bottom: none; }
.pdf-item:hover { background: var(--card); }
.pdf-item .pi-info { flex: 1; display: flex; flex-direction: column; gap: 2px; }
.pdf-item .pi-name { font-size: 13px; font-weight: 600; }
.pdf-item .pi-meta { font-size: 11px; color: var(--muted); }

/* Custom Checkbox */
.check-container {
  display: block;
  position: relative;
  padding-left: 30px;
  margin-bottom: 0;
  cursor: pointer;
  font-size: 12px;
  user-select: none;
  font-weight: 600;
  color: var(--muted);
}
.check-container input { position: absolute; opacity: 0; cursor: pointer; height: 0; width: 0; }
.checkmark {
  position: absolute;
  top: 0;
  left: 0;
  height: 18px;
  width: 18px;
  background-color: var(--card);
  border: 1px solid var(--border2);
  border-radius: 4px;
}
.check-container:hover input ~ .checkmark { background-color: var(--card2); }
.check-container input:checked ~ .checkmark { background-color: var(--accent); border-color: var(--accent); }
.checkmark:after {
  content: "";
  position: absolute;
  display: none;
}
.check-container input:checked ~ .checkmark:after { display: block; }
.check-container .checkmark:after {
  left: 6px;
  top: 2px;
  width: 4px;
  height: 9px;
  border: solid white;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

.pdf-list-controls {
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
  margin-bottom: 10px;
}
/* ── MOBILE OPTIMIZATIONS (Max 480px) ── */
@media(max-width:480px){
  .app { padding: 0 16px 40px; }
  .topbar { padding: 0 12px; }
  .logo { font-size: 13px; }
  .topbar-user { display: none; } /* Hide user in topbar to save space */
  .topbar-right { gap: 4px; }
  .tbtn { padding: 6px 8px; font-size: 11px; }
  .tbtn span { display: none; } /* Hide text in some buttons if they have icons */
  .tbtn i { margin: 0; font-size: 14px; }

  .ph-title { font-size: 18px; }
  .ph-actions { width: 100%; display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
  .ph-actions .btn { justify-content: center; width: 100%; }
  .ph-actions .btn-accent { grid-column: span 2; }

  .kpi-row { grid-template-columns: 1fr; gap: 10px; }
  .kpi { padding: 12px 16px; }
  .kpi .val { font-size: 24px; }

  .semaforo-bar { flex-direction: column; align-items: flex-start; gap: 12px; }
  .sem-group { width: 100%; justify-content: space-between; }
  .sem-apply { width: 100%; margin-top: 4px; }

  .filter-bar { flex-direction: column; align-items: stretch; gap: 10px; }
  .search-wrap { margin-left: 0; width: 100%; }
  .search-inp { width: 100%; }
  .flt { flex: 1; text-align: center; padding: 6px 4px; font-size: 11px; }

  .card-head { flex-direction: column; gap: 8px; padding: 12px 16px; }
  .card-right { align-items: flex-start; width: 100%; border-top: 1px solid var(--border); pt: 8px; margin-top: 4px; }
  .card-name { font-size: 14px; }
  .pct-num { font-size: 22px; }
  .badges { justify-content: flex-start; width: 100%; }
  
  .prog-wrap { padding: 0 16px; }
  .milestones { padding: 4px 16px 12px; }
  .proj-detail { padding: 16px; }
  .detail-grid { grid-template-columns: 1fr; }
  
  .card-footer { flex-direction: column; align-items: flex-start; gap: 12px; }
  .card-btns { width: 100%; display: grid; grid-template-columns: 1fr; gap: 6px; margin-left: 0; }
  .cbtn { justify-content: center; padding: 8px; }

  .form-row, .form-row.three { grid-template-columns: 1fr; gap: 12px; }
  .modal { padding: 20px 16px; }
  .modal-footer { flex-direction: column; }
  .modal-footer .btn { width: 100%; justify-content: center; }

  .pdf-sel-modal { width: 100%; height: 100%; border-radius: 0; max-height: 100vh; }
}
