
:root{--p:#0f2f5f;--p2:#174a8b;--a:#f59e0b;--g:#16a34a;--r:#dc2626;--bg:#f3f6fb;--b:#d8e0ef}
*{box-sizing:border-box}body{margin:0;font-family:Segoe UI,Arial,sans-serif;background:var(--bg);color:#111827}
.header{background:linear-gradient(135deg,var(--p),var(--p2));color:#fff;padding:14px 24px;display:flex;justify-content:space-between;align-items:center;gap:12px;position:sticky;top:0;z-index:10}
.brand{display:flex;gap:12px;align-items:center}.logo{background:#fff;color:var(--p);height:44px;width:44px;border-radius:12px;display:grid;place-items:center;font-weight:900}.brand small{display:block;opacity:.85}
.wrap{max-width:1260px;margin:24px auto;padding:0 16px}.card{background:#fff;border:1px solid var(--b);border-radius:18px;box-shadow:0 10px 30px #14233c12;padding:20px;margin-bottom:18px}
.grid{display:grid;gap:16px}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media(max-width:850px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.header{flex-direction:column;align-items:flex-start}}
.btn{border:0;border-radius:10px;padding:10px 14px;font-weight:700;cursor:pointer;background:#e5e7eb;color:#111;text-decoration:none;display:inline-block}.btn-primary{background:var(--p2);color:#fff}.btn-accent{background:var(--a);color:#111}.btn-success{background:var(--g);color:#fff}.btn-danger{background:var(--r);color:#fff}.btn-light{background:#fff;color:var(--p)}.btn-small{padding:7px 10px;font-size:13px}
.stat{padding:18px;border-radius:16px;background:linear-gradient(135deg,#eff6ff,#fff);border:1px solid #dbeafe}.stat b{font-size:28px;display:block}.muted{color:#6b7280}.tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}.tab{padding:10px 14px;border:1px solid var(--b);background:#fff;border-radius:999px;font-weight:700;text-decoration:none;color:#111}.tab.active{background:var(--p);color:#fff}
input,select,textarea{width:100%;padding:11px 12px;border:1px solid var(--b);border-radius:12px;font:inherit;background:#fff}textarea{min-height:110px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media(max-width:700px){.form-row{grid-template-columns:1fr}}label{font-weight:700;font-size:14px;margin:10px 0 6px;display:block}.help{font-size:12px;color:#6b7280}
table{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden}th,td{padding:12px;border-bottom:1px solid var(--b);text-align:left;vertical-align:top}th{background:#eef4ff;color:#0f2f5f;font-size:13px}
.pill{display:inline-block;padding:5px 10px;border-radius:999px;font-size:12px;font-weight:800}.pill-green{background:#dcfce7;color:#166534}.pill-red{background:#fee2e2;color:#991b1b}.pill-blue{background:#dbeafe;color:#1e40af}
.login-box{max-width:700px;margin:36px auto}.notice{padding:12px 14px;border-radius:12px;background:#fff7ed;border:1px solid #fed7aa;color:#9a3412}.successbox{padding:12px 14px;border-radius:12px;background:#ecfdf5;border:1px solid #bbf7d0;color:#166534}.dangerbox{padding:12px 14px;border-radius:12px;background:#fef2f2;border:1px solid #fecaca;color:#991b1b}
.exam-layout{display:grid;grid-template-columns:minmax(0,1fr) 330px;gap:16px}@media(max-width:980px){.exam-layout{grid-template-columns:1fr}}.timer{font-size:30px;font-weight:900;color:#fff;background:var(--r);padding:12px;border-radius:14px;text-align:center}.question-card{border:1px solid var(--b);border-radius:16px;padding:16px;margin-bottom:14px;background:#fbfdff}.answer-box{min-height:150px}.video-box{background:#050816;border-radius:16px;overflow:hidden;border:4px solid #0f2f5f}video{width:100%;display:block;min-height:210px;background:#111}.overlay{position:fixed;inset:0;background:rgba(127,29,29,.96);color:#fff;z-index:999;display:none;align-items:center;justify-content:center;text-align:center;padding:24px}.progress{height:10px;background:#e5e7eb;border-radius:999px;overflow:hidden}.bar{height:100%;background:var(--g);width:0}.answer-preview{white-space:pre-wrap;max-height:220px;overflow:auto;background:#f8fafc;border-radius:10px;padding:10px;border:1px solid var(--b)}
.footer-note{text-align:center;color:#64748b;font-size:12px;margin:28px 0}@media print{.header,.btn,.footer-note{display:none!important}.wrap{max-width:100%;margin:0}.card{box-shadow:none;border:0}}



/* ===============================
   FULL RESPONSIVE UPDATE
   Mobile + Tablet + Laptop
   =============================== */

html, body {
  width: 100%;
  max-width: 100%;
  overflow-x: hidden;
}

img, video, canvas, iframe {
  max-width: 100%;
}

.wrap {
  width: 100%;
}

/* Better desktop width */
@media (min-width: 1200px) {
  .wrap {
    max-width: 1280px;
  }
}

/* Tablet layout */
@media (max-width: 1024px) {
  .wrap {
    max-width: 100%;
    margin: 16px auto;
    padding: 0 14px;
  }

  .header {
    padding: 12px 16px;
  }

  .brand strong {
    font-size: 15px;
    line-height: 1.25;
  }

  .brand small {
    font-size: 12px;
  }

  .grid-4 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .grid-3 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .form-row {
    grid-template-columns: 1fr 1fr;
  }

  .exam-layout {
    grid-template-columns: 1fr;
  }

  .proctor {
    position: relative !important;
    top: auto !important;
  }
}

/* Mobile layout */
@media (max-width: 768px) {
  body {
    font-size: 14px;
  }

  .header {
    position: relative;
    flex-direction: column;
    align-items: stretch;
    padding: 12px;
  }

  .brand {
    width: 100%;
    align-items: center;
  }

  .logo {
    min-width: 40px;
    width: 40px;
    height: 40px;
    border-radius: 10px;
    font-size: 14px;
  }

  .brand strong {
    font-size: 14px;
  }

  .brand small {
    font-size: 11px;
  }

  .top-actions {
    width: 100%;
    display: flex;
    justify-content: flex-start;
    gap: 8px;
    flex-wrap: wrap;
  }

  .top-actions .btn {
    width: auto;
  }

  .wrap {
    margin: 10px auto;
    padding: 0 10px;
  }

  .card {
    padding: 14px;
    border-radius: 14px;
    margin-bottom: 12px;
  }

  h1 { font-size: 24px; }
  h2 { font-size: 20px; }
  h3 { font-size: 17px; }
  h4 { font-size: 15px; }

  .grid,
  .grid-2,
  .grid-3,
  .grid-4 {
    grid-template-columns: 1fr !important;
    gap: 10px;
  }

  .stat {
    padding: 14px;
  }

  .stat b {
    font-size: 22px;
  }

  .tabs {
    gap: 6px;
    overflow-x: auto;
    flex-wrap: nowrap;
    padding-bottom: 8px;
    -webkit-overflow-scrolling: touch;
  }

  .tab {
    flex: 0 0 auto;
    padding: 9px 12px;
    font-size: 13px;
    white-space: nowrap;
  }

  .form-row {
    grid-template-columns: 1fr !important;
    gap: 8px;
  }

  label {
    margin-top: 8px;
    font-size: 13px;
  }

  input,
  select,
  textarea {
    font-size: 14px;
    padding: 10px;
    border-radius: 10px;
  }

  textarea {
    min-height: 100px;
  }

  .btn {
    padding: 10px 12px;
    font-size: 14px;
    border-radius: 9px;
    text-align: center;
  }

  .btn-small {
    padding: 7px 9px;
    font-size: 12px;
    margin-bottom: 4px;
  }

  .login-box {
    max-width: 100%;
    margin: 14px auto;
  }

  .notice,
  .successbox,
  .dangerbox {
    padding: 10px;
    font-size: 13px;
  }

  /* Responsive tables */
  table {
    display: block;
    width: 100%;
    overflow-x: auto;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
    border-radius: 10px;
  }

  th, td {
    padding: 9px;
    font-size: 12px;
  }

  td input[type="text"],
  td input:not([type]),
  td input[readonly] {
    min-width: 220px;
  }

  .pill {
    padding: 4px 8px;
    font-size: 11px;
  }

  /* Exam mobile */
  .exam-layout {
    grid-template-columns: 1fr !important;
    gap: 10px;
  }

  .timer {
    font-size: 24px;
    padding: 10px;
  }

  .question-card {
    padding: 12px;
    border-radius: 12px;
  }

  .answer-box {
    min-height: 130px;
  }

  .video-box video,
  video {
    min-height: 170px;
  }

  .overlay h1 {
    font-size: 28px;
  }

  .answer-preview {
    max-height: 180px;
  }
}

/* Small mobile */
@media (max-width: 480px) {
  .wrap {
    padding: 0 8px;
  }

  .header {
    padding: 10px;
  }

  .brand {
    gap: 8px;
  }

  .logo {
    min-width: 36px;
    width: 36px;
    height: 36px;
    font-size: 13px;
  }

  .brand strong {
    font-size: 13px;
  }

  .brand small {
    font-size: 10px;
  }

  .card {
    padding: 12px;
    border-radius: 12px;
  }

  .top-actions .btn,
  .card .btn {
    width: 100%;
    margin-bottom: 4px;
  }

  .tabs {
    margin-bottom: 10px;
  }

  .tab {
    font-size: 12px;
    padding: 8px 10px;
  }

  input,
  select,
  textarea {
    font-size: 13px;
    padding: 9px;
  }

  .stat b {
    font-size: 20px;
  }

  th, td {
    padding: 8px;
    font-size: 11px;
  }

  .timer {
    font-size: 22px;
  }

  .question-title {
    font-size: 14px;
  }

  .answer-box {
    min-height: 120px;
  }
}

/* Landscape small screens */
@media (max-width: 900px) and (orientation: landscape) {
  .header {
    position: relative;
  }

  .wrap {
    margin-top: 10px;
  }

  .video-box video,
  video {
    min-height: 140px;
  }
}

/* Print clean */
@media print {
  .header,
  .top-actions,
  .tabs,
  .btn,
  .footer-note {
    display: none !important;
  }

  .wrap {
    max-width: 100%;
    margin: 0;
    padding: 0;
  }

  .card {
    box-shadow: none;
    border: 0;
    padding: 0;
  }

  table {
    display: table;
    white-space: normal;
  }
}

/* Logo branding update */
.brand-logo-img{
  height:44px;
  width:auto;
  max-width:150px;
  object-fit:contain;
  background:#fff;
  border-radius:10px;
  padding:4px;
}
@media(max-width:768px){
  .brand-logo-img{height:38px;max-width:120px;}
}
@media(max-width:480px){
  .brand-logo-img{height:34px;max-width:105px;}
}
