/*
 * FRCS Mentor – MVP styles.
 * NOTE: This is a functional baseline; pixel-perfect parity will be delivered in later UI iteration.
 */

:root{
  --frcs-bg:#f6f7fb;
  --frcs-card:#ffffff;
  --frcs-text:#0f172a;
  --frcs-muted:#64748b;
  --frcs-border:#e5e7eb;
  --frcs-blue:#1d4ed8;
  --frcs-blue-2:#2563eb;
  --frcs-green:#16a34a;
  --frcs-red:#dc2626;
}

/* Admin Viva Scenario image thumbnails + lightbox */
.frcs-admin-img-grid{display:flex;gap:10px;flex-wrap:wrap;margin:10px 0;}
.frcs-admin-img-btn{border:1px solid #dcdcde;background:#fff;padding:4px;border-radius:10px;cursor:pointer;}
.frcs-admin-img-thumb{width:72px;height:72px;object-fit:cover;display:block;border-radius:8px;}

/* Viva Scenario: delete icons */
.frcs-trash{
  border:1px solid #dcdcde;
  background:#fff;
  border-radius:10px;
  width:36px;
  height:32px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  line-height:1;
}
.frcs-trash:hover{background:#f6f7f7;}
.frcs-trash:disabled{opacity:.55;cursor:not-allowed;}

/* Viva Scenario: edit (pencil) icon */
.frcs-pencil{
  border:1px solid #dcdcde;
  background:#fff;
  border-radius:10px;
  width:36px;
  height:32px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  line-height:1;
}
.frcs-pencil:hover{background:#f6f7f7;}
.frcs-pencil:disabled{opacity:.55;cursor:not-allowed;}

/* Viva Scenario: AI edit (wand) icon */
.frcs-wand{
  border:1px solid #dcdcde;
  background:#fff;
  border-radius:10px;
  width:36px;
  height:32px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  line-height:1;
}
.frcs-wand:hover{background:#f6f7f7;}
.frcs-wand:disabled{opacity:.55;cursor:not-allowed;}

/* AI suggestion modal */
#frcs-ai-modal{position:fixed;inset:0;display:none;z-index:100003;}
#frcs-ai-modal.open{display:block;}
#frcs-ai-modal .frcs-img-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.55);} /* reuse */
#frcs-ai-modal .frcs-img-dialog{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:14px;max-width:min(1000px,96vw);width:96vw;max-height:90vh;overflow:auto;box-shadow:0 10px 30px rgba(0,0,0,.35);padding:16px;}
.frcs-ai-scores{display:flex;gap:10px;flex-wrap:wrap;align-items:center;}
.frcs-ai-score-pill{background:#f3f4f6;border:1px solid #e5e7eb;border-radius:999px;padding:4px 10px;font-size:12px;}

/* Edit Question modal (admin) */
#frcs-editq-modal{position:fixed;inset:0;display:none;z-index:100001;}
#frcs-editq-modal.open{display:block;}
#frcs-editq-modal .frcs-editq-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.55);}
#frcs-editq-modal .frcs-editq-dialog{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:14px;max-width:min(720px,94vw);width:94vw;box-shadow:0 10px 30px rgba(0,0,0,.35);overflow:hidden;}
#frcs-editq-modal .frcs-editq-head{padding:12px 48px 12px 14px;font-weight:700;border-bottom:1px solid #e5e5e5;}
#frcs-editq-modal .frcs-editq-close{position:absolute;top:6px;right:10px;border:none;background:transparent;font-size:28px;line-height:1;cursor:pointer;}
#frcs-editq-modal .frcs-editq-body{padding:14px;}
#frcs-editq-modal .frcs-editq-label{display:block;font-weight:600;margin-bottom:6px;}
#frcs-editq-modal .frcs-editq-title{width:100%;border:1px solid #dcdcde;border-radius:12px;padding:10px 12px;resize:vertical;}
#frcs-editq-modal .frcs-editq-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:10px;}

/* Add Question modal (admin) */
#frcs-addq-modal{position:fixed;inset:0;display:none;z-index:100000;}
#frcs-addq-modal.open{display:block;}
#frcs-addq-modal .frcs-addq-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.55);}
#frcs-addq-modal .frcs-addq-dialog{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:14px;max-width:min(1100px,94vw);width:94vw;max-height:90vh;box-shadow:0 10px 30px rgba(0,0,0,.35);overflow:hidden;}
#frcs-addq-modal .frcs-addq-head{padding:12px 48px 12px 14px;font-weight:700;border-bottom:1px solid #e5e5e5;}
#frcs-addq-modal .frcs-addq-close{position:absolute;top:6px;right:10px;border:none;background:transparent;font-size:28px;line-height:1;cursor:pointer;}
#frcs-addq-modal .frcs-addq-frame{width:100%;height:calc(90vh - 52px);border:0;display:block;}

#frcs-img-modal{position:fixed;inset:0;display:none;z-index:99999;}
#frcs-img-modal.open{display:block;}
#frcs-img-modal .frcs-img-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.55);}
#frcs-img-modal .frcs-img-dialog{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:14px;padding:14px;max-width:min(900px,92vw);max-height:85vh;box-shadow:0 10px 30px rgba(0,0,0,.35);}
#frcs-img-modal .frcs-img-full{max-width:100%;max-height:75vh;display:block;border-radius:10px;}
#frcs-img-modal .frcs-img-close{position:absolute;top:6px;right:10px;border:none;background:transparent;font-size:28px;line-height:1;cursor:pointer;}

/* Large in-page Preview Scenario modal (admin) */
#frcs-preview-modal{position:fixed;inset:0;display:none;z-index:99999;}
#frcs-preview-modal.open{display:block;}
#frcs-preview-modal .frcs-preview-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.55);}
#frcs-preview-modal .frcs-preview-dialog{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:14px;max-width:min(1200px,96vw);width:96vw;max-height:92vh;box-shadow:0 10px 30px rgba(0,0,0,.35);overflow:auto;}
#frcs-preview-modal .frcs-preview-close{position:sticky;top:0;float:right;border:none;background:transparent;font-size:30px;line-height:1;cursor:pointer;padding:10px 14px;margin-left:auto;}
#frcs-preview-modal .frcs-preview-body{padding:14px;}

/*
 * Taxonomy modal used inside Preview Scenario (Create Topic / Create & Edit Category).
 * This is separate from #frcs-img-modal and needs its own positioning + z-index so it
 * appears above the Preview Scenario modal.
 */
#frcs-tax-modal{position:fixed;inset:0;display:none;z-index:100002;}
#frcs-tax-modal.open{display:block;}
#frcs-tax-modal .frcs-img-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.55);}
#frcs-tax-modal .frcs-img-dialog{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:14px;padding:14px;max-width:min(720px,92vw);width:92vw;max-height:85vh;box-shadow:0 10px 30px rgba(0,0,0,.35);overflow:auto;}
#frcs-tax-modal .frcs-img-close{position:absolute;top:6px;right:10px;border:none;background:transparent;font-size:28px;line-height:1;cursor:pointer;}

*{box-sizing:border-box;}

.frcs-app{
  display:flex;
  min-height: calc(100vh - 32px);
  background: var(--frcs-bg);
  color: var(--frcs-text);
  /* Use the site/theme default font */
  font-family: inherit;
  font-size: inherit;
}

.frcs-sidebar{
  /* Slightly narrower sidebar for better content density */
  width: 230px;
  background: #0b1220;
  color:#cbd5e1;
  padding: 18px 14px;
  display:flex;
  flex-direction:column;
}

.frcs-brand{display:flex;align-items:center;gap:10px;margin-bottom:18px;min-height:44px;}
.frcs-brand-logo{display:block;max-width:170px;width:100%;height:auto;filter:brightness(0) invert(1);} /* force white logo */

.frcs-nav{display:flex;flex-direction:column;gap:6px;margin-top:10px;}
.frcs-nav-link{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius:10px;
  color:#cbd5e1;
  text-decoration:none;
}
.frcs-nav-ico{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;opacity:.95;}
.frcs-nav-ico svg{width:18px;height:18px;display:block;}
.frcs-nav-link:hover{background:rgba(255,255,255,.06);}
.frcs-nav-link.active{background:rgba(37,99,235,.25);color:#fff;}

.frcs-sidebar-footer{margin-top:auto;border-top:1px solid rgba(255,255,255,.08);padding-top:14px;}
.frcs-user{display:flex;gap:10px;align-items:center;}
.frcs-user-avatar{width:38px;height:38px;border-radius:50%;background:#111827;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;}
.frcs-user-name{color:#fff;font-weight:600;line-height:1.1;}
.frcs-user-role{color:#94a3b8;font-size:12px;margin-top:2px;}
.frcs-logout{display:inline-block;margin-top:10px;color:#94a3b8;text-decoration:none;font-size:13px;}
.frcs-logout:hover{color:#fff;}

.frcs-main{flex:1;padding:22px;}

.frcs-container{max-width:1100px;margin:0 auto;}

.frcs-page-title{font-size:34px;font-weight:800;margin:8px 0 16px;}
.frcs-page-subtitle{color:var(--frcs-muted);margin-top:-6px;margin-bottom:18px;}

.frcs-grid{display:grid;gap:16px;}
.frcs-grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr));}
.frcs-grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr));}

.frcs-card{
  background:var(--frcs-card);
  border:1px solid var(--frcs-border);
  border-radius:14px;
  padding:16px;
  box-shadow:0 1px 0 rgba(15,23,42,.03);
}

.frcs-input{
  width:100%;
  border:1px solid var(--frcs-border);
  border-radius:12px;
  padding:10px 12px;
  background:#fff;
  color:inherit;
}
.frcs-input:disabled{opacity:.7;cursor:not-allowed;background:#f8fafc;}

.frcs-card-title{font-weight:800;font-size:18px;margin:0 0 6px;}
.frcs-card-muted{color:var(--frcs-muted);font-size:13px;}

.frcs-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  border-radius:12px;
  padding:10px 12px;
  border:1px solid var(--frcs-border);
  background:#fff;
  color:var(--frcs-text);
  cursor:pointer;
  text-decoration:none;
  font-weight:600;
}

/* Simple select control (used for report jump + settings). */
.frcs-select{
  border:1px solid var(--frcs-border);
  border-radius:12px;
  padding:10px 14px;
  background:#fff;
  color:var(--frcs-text);
  font: inherit;
  line-height:1.2;
}
.frcs-btn.primary{background:var(--frcs-blue-2);color:#fff;border-color:transparent;}
.frcs-btn.primary:hover{filter:brightness(.98);}
.frcs-btn.ghost{background:transparent;}
.frcs-btn:disabled{opacity:.45;cursor:not-allowed;}

.frcs-progress{height:10px;border-radius:999px;background:#e2e8f0;overflow:hidden;}
.frcs-progress > div{height:100%;background:var(--frcs-blue-2);width:0%;transition:width .9s linear;}

.frcs-stat{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;}
.frcs-stat .value{font-size:30px;font-weight:800;}
.frcs-stat .label{color:var(--frcs-muted);font-size:13px;}

/* Scenario list */
.frcs-list{display:flex;flex-direction:column;gap:14px;}
.frcs-row{display:flex;align-items:center;justify-content:space-between;gap:12px;}
.frcs-chip{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--frcs-border);border-radius:999px;padding:6px 10px;font-size:12px;color:var(--frcs-muted);background:#fff;}
.frcs-chip.ai{border-color:#c7d2fe;background:#eef2ff;color:#3730a3;}
.frcs-chip.pending{border-color:#fde68a;background:#fffbeb;color:#92400e;}

/* Inline confirmation shown next to Submit Answer */
.frcs-inline-msg{font-weight:800;color:#16a34a;}

/* Coming Soon / Draft visibility UX */
.frcs-coming-soon .frcs-card-title{opacity:0.92;}
.frcs-coming-soon-badge{display:inline-block;margin-left:8px;padding:2px 8px;border-radius:999px;font-size:12px;font-weight:800;line-height:18px;background:#fff7ed;color:#c2410c;border:1px solid #fed7aa;}

.frcs-expand{cursor:pointer;user-select:none;}
.frcs-topic{border-top:1px dashed var(--frcs-border);margin-top:12px;padding-top:12px;}

/* Attempt layout */
.frcs-attempt-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;gap:12px;}
.frcs-attempt-top .meta{color:var(--frcs-muted);font-size:13px;}

.frcs-split{display:grid;grid-template-columns: .9fr 1.1fr;gap:16px;align-items:start;}

.frcs-viewer{background:#111827;border-radius:14px;padding:10px;border:1px solid rgba(255,255,255,.08);}
.frcs-viewer-media-wrap{border-radius:10px;overflow:hidden;}
.frcs-viewer img, .frcs-viewer iframe{max-width:100%;border-radius:10px;display:block;margin:0 auto;}
.frcs-viewer-media-wrap.frcs-can-pan{cursor:grab;touch-action:none;}
.frcs-viewer-media-wrap.frcs-panning{cursor:grabbing;}
.frcs-viewer-bar{display:flex;gap:8px;align-items:center;margin-top:10px;flex-wrap:wrap;}
.frcs-viewer-spacer{flex:1;min-width:8px;}
.frcs-viewer-bar .frcs-btn{border-color:rgba(255,255,255,.18);background:rgba(255,255,255,.08);color:#fff;}
.frcs-viewer-mini{padding:6px 10px;font-size:12px;line-height:1;border-radius:10px;}
.frcs-viewer-mini svg{display:block;}

.frcs-tabs{display:flex;gap:10px;margin:10px 0;}
.frcs-tab{padding:10px 12px;border-radius:12px;border:1px solid var(--frcs-border);background:#fff;font-weight:700;cursor:pointer;color:var(--frcs-text);}
.frcs-tab.active{background:#e0e7ff;border-color:#c7d2fe;color:#0f172a;}

.frcs-textarea{width:100%;min-height:170px;border:1px solid var(--frcs-border);border-radius:12px;padding:12px;font-size:14px;}

/* (kept for backward compatibility; unified above) */
.frcs-select{border:1px solid var(--frcs-border);border-radius:12px;padding:10px 14px;background:#fff;color:var(--frcs-text);}

.frcs-pre{white-space:pre-wrap;word-break:break-word;background:#f8fafc;border:1px solid var(--frcs-border);border-radius:12px;padding:12px;font-size:13px;line-height:1.55;}

.frcs-accordion .frcs-acc-head{display:flex;gap:12px;align-items:flex-start;justify-content:space-between;}

.frcs-report-list{margin-top:4px;}

.frcs-cover-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;}
.frcs-cover-item{border:1px solid var(--frcs-border);border-radius:12px;padding:10px;background:#fff;}
.frcs-cover-item .kp{font-weight:700;font-size:13px;}
.frcs-cover-item .qual{font-size:12px;color:var(--frcs-muted);margin-top:4px;}
.frcs-cover-item.good{border-color:#86efac;background:#f0fdf4;}
.frcs-cover-item.warn{border-color:#fed7aa;background:#fff7ed;}
.frcs-cover-item.bad{border-color:#fecaca;background:#fef2f2;}

.frcs-img-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;}
.frcs-img-grid img{width:100%;height:auto;border-radius:12px;border:1px solid var(--frcs-border);display:block;}

.frcs-footer-nav{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px;}

.frcs-pill{display:inline-flex;align-items:center;gap:8px;border-radius:999px;border:1px solid var(--frcs-border);padding:8px 12px;background:#fff;font-weight:700;}
.frcs-pill.good{border-color:#86efac;background:#f0fdf4;color:#166534;}
.frcs-pill.bad{border-color:#fecaca;background:#fef2f2;color:#991b1b;}

.frcs-kv{display:flex;align-items:center;justify-content:space-between;gap:12px;}

.frcs-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--frcs-border);border-radius:14px;overflow:hidden;}
.frcs-table th,.frcs-table td{padding:10px 12px;border-bottom:1px solid var(--frcs-border);text-align:left;font-size:13px;}
.frcs-table th{background:#f8fafc;color:#334155;font-weight:800;}
.frcs-table tr:last-child td{border-bottom:none;}

.frcs-tabs2{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap;}
.frcs-start-btn{white-space:nowrap;}

/* Progress tabs (Overview / Needs Practice / Viva Summary / All Attempts)
   Slightly rectangular with chamfered corners, and readable default text colors. */
.frcs-tab2{padding:10px 14px;border:1px solid var(--frcs-border);background:#fff;color:#0f172a;font-weight:800;cursor:pointer;border-radius:10px;clip-path:polygon(10px 0, calc(100% - 10px) 0, 100% 10px, 100% calc(100% - 10px), calc(100% - 10px) 100%, 10px 100%, 0 calc(100% - 10px), 0 10px);}
.frcs-tab2.active{background:#0b1220;color:#fff;border-color:#0b1220;}

.frcs-alert{border-radius:14px;padding:12px 14px;border:1px solid var(--frcs-border);background:#fff;}
.frcs-alert.warn{border-color:#fecaca;background:#fef2f2;}



/* Per-question report layout (matches original UX more closely) */
.frcs-q-eval-grid{display:grid;grid-template-columns:1fr 1.2fr 1.2fr;gap:14px;align-items:start;}
.frcs-q-eval-col{min-width:0;}
@media (max-width: 980px){
  .frcs-q-eval-grid{grid-template-columns:1fr;}
}

/* Responsive */
@media (max-width: 980px){
  .frcs-split{grid-template-columns:1fr;}
  .frcs-grid.cols-2,.frcs-grid.cols-3{grid-template-columns:1fr;}
  .frcs-img-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media (max-width: 780px){
  .frcs-app{flex-direction:column;}
  .frcs-sidebar{width:100%;flex-direction:row;align-items:center;gap:12px;}
  .frcs-nav{flex-direction:row;flex-wrap:wrap;margin-top:0;}
  .frcs-sidebar-footer{margin-top:0;margin-left:auto;border-top:none;padding-top:0;}
  .frcs-user-role{display:none;}
  .frcs-main{padding:14px;}
  .frcs-page-title{font-size:28px;}
  .frcs-cover-grid{grid-template-columns:1fr;}
  .frcs-img-grid{grid-template-columns:1fr;}
}

/* Admin Viva Scenario: slot numbers as separate boxes (numbers stay 1..N, questions move) */
.frcs-slot-row{display:flex;gap:12px;align-items:stretch;margin:10px 0;}
.frcs-slot-box{width:46px;min-width:46px;height:46px;display:flex;align-items:center;justify-content:center;border:1px solid #dcdcde;border-radius:10px;background:#f6f7f7;font-weight:800;color:#1d2327;}
.frcs-qcard{flex:1;border:1px solid #e5e5e5;border-radius:12px;background:#fff;padding:10px;}
.frcs-qcard-top{display:flex;gap:10px;align-items:center;}
.frcs-qtitle{flex:1;}
.frcs-qid{color:#8c8f94;}
.frcs-drag{font-weight:700;color:#50575e;cursor:move;user-select:none;}
.frcs-move-panel{margin-top:10px;padding-top:10px;border-top:1px dashed #dcdcde;}

/* Student question number badge */
.frcs-qnum-badge{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:34px;padding:0 10px;margin-right:10px;border:1px solid var(--frcs-border);border-radius:10px;background:#f8fafc;font-weight:900;}

/* =============================
   Settings: template UX helpers
   ============================= */
.frcs-effective-template{
  margin-top:6px;
  padding:6px 10px;
  border:1px solid #dcdcde;
  border-radius:8px;
  background:#fff;
  display:inline-block;
}
.frcs-effective-template .frcs-pill{
  display:inline-block;
  padding:2px 8px;
  border-radius:999px;
  font-size:12px;
  line-height:18px;
  border:1px solid #dcdcde;
  background:#f6f7f7;
  margin-right:6px;
}
.frcs-effective-template .frcs-pill.ok{background:#edfaef;border-color:#68de7c;}
.frcs-effective-template .frcs-pill.warn{background:#fff6e5;border-color:#ffb900;}

.frcs-tpl-editor-wrap.frcs-disabled textarea{
  background:#f6f7f7;
  color:#7a7a7a;
}
.frcs-tpl-editor-help{margin-top:6px;}


/* ===== Scenarios layout refresh (v104) ===== */
.frcs-station-card .frcs-station-toggle{gap:12px;}
.frcs-station-head{display:flex;align-items:center;gap:14px;}
.frcs-station-icon{width:42px;height:42px;border-radius:999px;overflow:hidden;display:flex;align-items:center;justify-content:center;background:rgba(37,99,235,.10);border:1px solid rgba(0,0,0,.06);flex:0 0 auto;}
.frcs-station-icon-img{width:100%;height:100%;object-fit:cover;display:block;}
.frcs-station-icon-text{font-weight:900;letter-spacing:.5px;}
.frcs-station-meta{margin-top:4px;display:flex;gap:8px;flex-wrap:wrap;}
.frcs-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;border:1px solid rgba(0,0,0,.12);background:#fff;font-size:12px;font-weight:700;white-space:nowrap;}
.frcs-station-chevron{font-size:22px;color:rgba(0,0,0,.45);margin-left:auto;}

.frcs-cat-grid{margin-top:10px;}
.frcs-cat-tile{position:relative;border:1px solid rgba(0,0,0,.12);border-radius:14px;background:#fff;padding:14px 14px 18px 14px;box-shadow:0 8px 18px rgba(0,0,0,.06);cursor:pointer;min-height:110px;}
.frcs-cat-tile:hover{box-shadow:0 12px 26px rgba(0,0,0,.09);}
.frcs-cat-top{display:flex;align-items:flex-start;gap:10px;}
.frcs-cat-title{font-weight:900;font-size:18px;line-height:1.2;}
.frcs-cat-right{margin-left:auto;display:flex;align-items:center;gap:10px;}
.frcs-cat-meta{margin-top:10px;display:flex;align-items:center;gap:10px;color:rgba(0,0,0,.65);font-weight:600;}
.frcs-cat-avg{margin-left:auto;white-space:nowrap;}
.frcs-cat-arrow{position:absolute;right:14px;bottom:12px;color:rgba(37,99,235,.85);font-weight:900;}

/* Start Practice pill inside category tiles */
.frcs-btn.frcs-start-pill{padding:6px 12px;border-radius:999px;font-size:13px;line-height:1;white-space:nowrap;background:rgba(34,197,94,.12);border-color:rgba(34,197,94,.25);color:rgb(22,101,52);}
.frcs-btn.frcs-start-pill:hover{background:rgba(34,197,94,.18);}

/* Viva cards inside category detail */
.frcs-viva-card{cursor:pointer;}
.frcs-viva-card:hover{box-shadow:0 10px 22px rgba(0,0,0,.07);}

@media (max-width: 980px){
  .frcs-grid.cols-3{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media (max-width: 680px){
  .frcs-grid.cols-3{grid-template-columns:repeat(1,minmax(0,1fr));}
}


/* Student post-submit choice + report loading states */
#frcs-post-submit-modal{position:fixed;inset:0;display:none;z-index:100004;}
#frcs-post-submit-modal.open{display:block;}
#frcs-post-submit-modal .frcs-post-submit-backdrop{position:absolute;inset:0;background:rgba(15,23,42,.58);backdrop-filter:blur(2px);}
#frcs-post-submit-modal .frcs-post-submit-dialog{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:min(620px,92vw);background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%);border:1px solid #dbeafe;border-radius:22px;box-shadow:0 24px 70px rgba(15,23,42,.24);padding:28px;}
#frcs-post-submit-modal .frcs-post-submit-icon{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#dbeafe;color:#1d4ed8;font-size:28px;font-weight:900;margin-bottom:14px;}
#frcs-post-submit-modal .frcs-post-submit-title{font-size:28px;line-height:1.15;font-weight:900;color:#0f172a;}
#frcs-post-submit-modal .frcs-post-submit-copy{margin-top:10px;color:#334155;font-size:16px;line-height:1.55;}
#frcs-post-submit-modal .frcs-post-submit-note{margin-top:12px;padding:12px 14px;border-radius:14px;background:#eff6ff;border:1px solid #bfdbfe;color:#1e3a8a;font-size:14px;line-height:1.5;}
#frcs-post-submit-modal .frcs-post-submit-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px;}

.frcs-report-loader-card{max-width:760px;margin:0 auto;}
.frcs-report-loader-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;background:#eff6ff;border:1px solid #bfdbfe;color:#1d4ed8;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;}
.frcs-report-loader-title{font-size:28px;font-weight:900;line-height:1.15;margin-top:14px;}
.frcs-report-loader-card .frcs-card-muted{max-width:640px;}
.frcs-report-loader-stats{margin-top:10px;color:#334155;font-size:14px;font-weight:700;}
.frcs-report-loader-notes{margin-top:16px;display:grid;gap:10px;}
.frcs-report-loader-notes > div{padding:12px 14px;border-radius:14px;background:#f8fafc;border:1px solid #e2e8f0;color:#475569;}


/* Mobile/tablet compatibility refinements */
@media (max-width: 780px){
  .frcs-sidebar{
    width:100%;
    padding:16px 14px;
    flex-direction:column;
    align-items:stretch;
  }
  .frcs-brand{justify-content:center;margin-bottom:12px;}
  .frcs-brand-logo{max-width:180px;margin:0 auto;}
  .frcs-nav{
    width:100%;
    display:flex;
    flex-direction:column;
    gap:8px;
  }
  .frcs-nav-link{
    width:100%;
    white-space:normal;
    line-height:1.35;
    min-height:50px;
    justify-content:flex-start;
  }
  .frcs-sidebar-footer{
    margin-top:12px;
    margin-left:0;
    border-top:1px solid rgba(255,255,255,.08);
    padding-top:12px;
  }
  .frcs-user{align-items:flex-start;}
  .frcs-user-name{word-break:break-word;}
  .frcs-logout{margin-top:8px;}
  .frcs-tabs2{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
  .frcs-tab2{width:100%;text-align:center;}
  .frcs-progress-top-grid,
  .frcs-billing-top-grid,
  .frcs-billing-mid-grid,
  .frcs-billing-summary-grid,
  .frcs-grid.cols-2,
  .frcs-grid.cols-3,
  .frcs-q-eval-grid,
  .frcs-cover-grid{grid-template-columns:1fr !important;}
  .frcs-row{flex-wrap:wrap;align-items:flex-start;}
  .frcs-stat{flex-direction:column;align-items:flex-start;gap:8px;}
  .frcs-card{padding:14px;}
  .frcs-page-title{font-size:24px;line-height:1.2;}
  .frcs-btn{max-width:100%;white-space:normal;}
  .frcs-table{display:block;overflow-x:auto;white-space:nowrap;}
  .frcs-report-chart{justify-content:flex-start !important;}
  #frcs-report-renew-modal [role="dialog"]{padding:22px;border-radius:18px;}
  #frcs-report-renew-modal [role="dialog"] > div:first-child{font-size:24px !important;}
}

@media (max-width: 560px){
  .frcs-main{padding:12px;}
  .frcs-tabs2{grid-template-columns:1fr;}
  .frcs-footer-nav{flex-direction:column;align-items:stretch;}
  .frcs-btn{width:100%;}
  .frcs-pill{white-space:normal;text-align:center;justify-content:center;}
  .frcs-qnum-badge{margin-right:0;margin-bottom:8px;}
}


/* Additional responsive hardening for tablets and narrow mobile browsers */
.frcs-nav-link,
.frcs-card,
.frcs-pill,
.frcs-card-title,
.frcs-page-title,
.frcs-user-name,
.frcs-table td,
.frcs-table th,
.frcs-stat .value {
  overflow-wrap:anywhere;
  word-break:break-word;
}

@media (max-width: 1100px){
  .frcs-app{flex-direction:column;}
  .frcs-sidebar{width:100%;flex-direction:column;align-items:stretch;padding:16px 14px;}
  .frcs-brand{justify-content:center;}
  .frcs-nav{width:100%;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;}
  .frcs-nav-link{min-height:52px;justify-content:flex-start;}
  .frcs-sidebar-footer{margin-top:12px;margin-left:0;border-top:1px solid rgba(255,255,255,.08);padding-top:12px;}
  .frcs-main{padding:14px;}
  .frcs-billing-top-grid{grid-template-columns:1fr !important;}
  .frcs-billing-mid-grid{grid-template-columns:1fr !important;}
  .frcs-billing-summary-grid{grid-template-columns:1fr !important;}
}

@media (max-width: 820px){
  .frcs-nav{grid-template-columns:1fr;}
  .frcs-tabs2{grid-template-columns:1fr 1fr;display:grid;gap:8px;}
  .frcs-tabs{flex-wrap:wrap;}
  .frcs-row{flex-wrap:wrap;}
  .frcs-table th,.frcs-table td{font-size:12px;padding:8px 10px;}
  .frcs-progress-top-grid{grid-template-columns:1fr !important;}
}

/* Additional mobile/tablet fixes for progress/report cards and lock states */
@media (max-width: 820px){
  .frcs-card .frcs-row{display:grid;grid-template-columns:1fr;gap:12px;}
  .frcs-card .frcs-row > div:last-child{width:100%;text-align:left !important;display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:flex-start;}
  .frcs-card .frcs-row > div:last-child .frcs-pill{min-width:120px;max-width:160px;padding:10px 12px;font-size:16px;line-height:1.2;white-space:normal;display:flex;align-items:center;justify-content:center;text-align:center;}
  .frcs-card .frcs-row > div:last-child .frcs-card-muted{font-size:15px;line-height:1.35;white-space:normal;}
  .frcs-card .frcs-row + div[style*="display:flex"]{flex-direction:column;align-items:stretch;}
  .frcs-card .frcs-row + div[style*="display:flex"] .frcs-btn{width:100%;}
}

@media (max-width: 560px){
  .frcs-alert.warn .frcs-btn{width:100%;}
  .frcs-page-title{font-size:22px;}
  .frcs-card{padding:12px;}
  .frcs-stat .value{font-size:24px;}
  .frcs-card .frcs-row > div:first-child{min-width:0;}
  .frcs-card .frcs-row > div:first-child > div[style*="font-weight:900"]{font-size:16px;line-height:1.45;}
  .frcs-card .frcs-row > div:last-child .frcs-pill{min-width:110px;max-width:130px;font-size:14px;}
  .frcs-card .frcs-row > div:last-child .frcs-card-muted{font-size:13px;}
  .frcs-tabs2{grid-template-columns:1fr;}
  .frcs-table{font-size:12px;}
  #frcs-report-renew-modal [role="dialog"]{width:min(94vw,640px);padding:20px;}
}
