/* ===== TRANSCRIPT EDITOR ===== */
:root{--tr-primary:#1a3a6b;--tr-border:#d1d9e6;--tr-bg:#f5f7fa;--tr-radius:12px}

.tr-layout{display:grid;grid-template-columns:minmax(260px,300px) minmax(0,1fr);gap:12px;align-items:start;padding:16px 0}

/* ── Responsive breakpoints ── */
/* Tablet ≤900px: stack vertically */
@media(max-width:900px){
  .tr-layout{grid-template-columns:1fr;gap:10px;padding:12px 0}
  .tr-panel{position:static;top:auto;max-height:none}
  .tr-preview-col{position:sticky;top:80px;align-self:start;padding:12px}
  .tr-panel-body{max-height:52vh;padding:12px}
}
/* Mobile ≤600px */
@media(max-width:600px){
  .tr-layout{padding:10px 0}
  .tr-panel-tabs{flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;gap:0;scrollbar-width:none}
  .tr-panel-tabs::-webkit-scrollbar{display:none}
  .tr-panel-tab{flex:1 0 auto;min-width:64px;height:34px;padding:0 8px;font-size:11px;letter-spacing:0}
  .tr-panel-body{padding:10px;max-height:none}
  .tr-tpl-grid{grid-template-columns:1fr 1fr}
  .tr-row2{grid-template-columns:1fr}
  .tr-row3{grid-template-columns:1fr 1fr}
  .tr-preview-col{position:static;top:auto;padding:8px;overflow-x:auto;overflow-y:visible;align-items:flex-start}
  .tr-preview-toolbar{max-width:100%;gap:8px}
  .tr-preview-wrap{margin:0;flex:0 0 auto}
  .tr-paper-grid{grid-template-columns:repeat(2,1fr)}
  .tr-actions{padding:8px 10px;gap:6px}
  .tr-btn{height:32px;padding:0 10px;font-size:11px}
}

/* ── Panel ── */
.tr-panel{background:#fff;border:1px solid var(--tr-border);border-radius:var(--tr-radius);overflow:hidden;position:sticky;top:80px;max-height:calc(100vh - 100px);display:flex;flex-direction:column;min-width:0}
.tr-panel-tabs{display:flex;border-bottom:1px solid var(--tr-border);flex-shrink:0}
.tr-panel-tab{flex:1;height:38px;display:flex;align-items:center;justify-content:center;gap:0;font-size:11px;font-weight:700;letter-spacing:.02em;text-transform:none;color:#64748b;cursor:pointer;border:none;background:none;font-family:inherit;border-bottom:2px solid transparent;transition:all .18s;padding:0 8px;white-space:nowrap}
.tr-panel-tab.is-active{color:var(--tr-primary);border-bottom-color:var(--tr-primary)}
/* min-height:0 is critical — without it flex:1 won't shrink and overflow-y:auto won't scroll */
.tr-panel-body{padding:14px;overflow-y:auto;flex:1;min-height:0}
.tr-panel-tab-pane{display:none}.tr-panel-tab-pane.is-active{display:block}

/* ── Form elements ── */
.tr-section{margin-bottom:14px}
.tr-section-title{font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#94a3b8;margin-bottom:8px;padding-bottom:5px;border-bottom:1px solid var(--tr-border)}
.tr-field{margin-bottom:8px}
.tr-field label{display:block;font-size:11px;font-weight:600;color:#475569;margin-bottom:4px}
.tr-input,.tr-select,.tr-textarea{width:100%;border:1.5px solid var(--tr-border);border-radius:7px;padding:7px 10px;font-size:12px;font-family:inherit;color:#1e293b;outline:none;background:#fff;box-sizing:border-box;transition:border-color .18s}
.tr-input:focus,.tr-select:focus,.tr-textarea:focus{border-color:var(--tr-primary)}
.tr-textarea{resize:vertical;min-height:60px}
.tr-row2{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.tr-row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px}

/* ── Template selector ── */
.tr-tpl-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:2px}
.tr-tpl-btn{padding:8px 6px;border-radius:8px;border:1.5px solid var(--tr-border);background:var(--tr-bg);cursor:pointer;font-family:inherit;font-size:11px;font-weight:600;color:#64748b;text-align:center;transition:all .18s;line-height:1.25}
.tr-tpl-btn:hover{border-color:var(--tr-primary);color:var(--tr-primary)}
.tr-tpl-btn.is-active{border-color:var(--tr-primary);background:rgba(26,58,107,.07);color:var(--tr-primary)}
.tr-tpl-btn small{display:block;font-size:9px;font-weight:400;color:#94a3b8;margin-top:2px}

/* ── Course table editor ── */
.tr-course-table{width:100%;border-collapse:collapse;font-size:11px;margin-bottom:8px}
.tr-course-table th{background:var(--tr-bg);padding:5px 6px;text-align:left;font-size:10px;font-weight:700;color:#64748b;border:1px solid var(--tr-border)}
.tr-course-table td{padding:3px 4px;border:1px solid var(--tr-border)}
.tr-course-table td input,.tr-course-table td select{width:100%;border:none;outline:none;font-size:11px;font-family:inherit;background:transparent;padding:2px 3px}
.tr-course-table td input:focus,.tr-course-table td select:focus{background:rgba(26,58,107,.05);border-radius:3px}
.tr-del-row{width:20px;height:20px;border-radius:4px;border:none;background:none;cursor:pointer;color:#94a3b8;font-size:14px;line-height:1;padding:0;display:flex;align-items:center;justify-content:center}
.tr-del-row:hover{color:#dc2626;background:rgba(220,38,38,.08)}
.tr-add-row-btn{display:flex;align-items:center;gap:5px;padding:6px 10px;border-radius:7px;border:1.5px dashed var(--tr-border);background:none;cursor:pointer;font-size:11px;font-weight:600;color:#64748b;font-family:inherit;width:100%;justify-content:center;transition:all .18s;margin-bottom:6px}
.tr-add-row-btn:hover{border-color:var(--tr-primary);color:var(--tr-primary)}

/* ── Semester block ── */
.tr-semester-block{margin-bottom:12px;border:1px solid var(--tr-border);border-radius:8px;overflow:hidden}
.tr-semester-header{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--tr-bg);border-bottom:1px solid var(--tr-border)}
.tr-semester-header input{flex:1;border:none;outline:none;font-size:12px;font-weight:600;background:transparent;font-family:inherit;color:#1e293b}
.tr-del-semester{width:24px;height:24px;border-radius:5px;border:none;background:none;cursor:pointer;color:#94a3b8;font-size:16px;display:flex;align-items:center;justify-content:center}
.tr-del-semester:hover{color:#dc2626;background:rgba(220,38,38,.08)}
.tr-semester-body{padding:8px}
.tr-add-semester-btn{display:flex;align-items:center;gap:5px;padding:7px 12px;border-radius:7px;border:1.5px dashed var(--tr-border);background:none;cursor:pointer;font-size:11px;font-weight:600;color:#64748b;font-family:inherit;width:100%;justify-content:center;transition:all .18s}
.tr-add-semester-btn:hover{border-color:var(--tr-primary);color:var(--tr-primary)}

/* ── GPA display ── */
.tr-gpa-box{background:rgba(26,58,107,.05);border:1px solid rgba(26,58,107,.15);border-radius:8px;padding:10px 12px;margin-top:8px}
.tr-gpa-row{display:flex;justify-content:space-between;align-items:center;font-size:12px;margin-bottom:4px}
.tr-gpa-row:last-child{margin-bottom:0;font-weight:700;font-size:13px;color:var(--tr-primary)}
.tr-gpa-label{color:#64748b}
.tr-gpa-val{font-weight:600;color:#1e293b}

/* ── Action buttons ── */
.tr-actions{display:flex;gap:8px;flex-wrap:wrap;padding:12px 16px;border-top:1px solid var(--tr-border);flex-shrink:0}
.tr-btn{display:inline-flex;align-items:center;gap:6px;height:36px;padding:0 14px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;border:none;font-family:inherit;transition:all .18s;white-space:nowrap}
.tr-btn--primary{background:var(--tr-primary);color:#fff}
.tr-btn--primary:hover{background:#0f2a5a}
.tr-btn--ghost{background:transparent;color:#64748b;border:1.5px solid var(--tr-border)}
.tr-btn--ghost:hover{border-color:var(--tr-primary);color:var(--tr-primary)}
.tr-btn .site-icon{width:16px;height:16px}

/* ── Preview column ── */
.tr-preview-col{background:#c8cdd6;border-radius:var(--tr-radius);padding:12px;min-height:400px;display:flex;flex-direction:column;align-items:stretch;gap:10px;min-width:0;overflow:visible;position:sticky;top:80px;align-self:start}
.tr-preview-toolbar{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:none;gap:10px;flex-wrap:wrap}
.tr-preview-label{font-size:11px;font-weight:700;color:#fff;letter-spacing:.05em;text-transform:uppercase}
.tr-zoom-select{border:1.5px solid rgba(255,255,255,.3);border-radius:6px;padding:4px 8px;font-size:12px;font-family:inherit;color:#fff;background:rgba(0,0,0,.2);outline:none;cursor:pointer}
.tr-preview-wrap{background:#fff;box-shadow:0 4px 24px rgba(0,0,0,.25);transform-origin:top center;transition:transform .2s;max-width:100%;margin:0 auto}

/* ===== TRANSCRIPT DOCUMENT STYLES ===== */
/* These apply inside .tr-doc */

.tr-doc{font-family:"Times New Roman",Times,serif;color:#000;background:#fff;position:relative;overflow:hidden;box-sizing:border-box}
.tr-doc *{box-sizing:border-box}

/* Watermark */
.tr-doc .tr-watermark{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(-30deg);font-size:72px;font-weight:900;color:rgba(0,0,0,.08);white-space:nowrap;pointer-events:none;z-index:0;letter-spacing:.1em;text-transform:uppercase}

/* Content above watermark */
.tr-doc .tr-doc-content{position:relative;z-index:1}

/* ── US University ── */
/* 1.5in top=144px, 1.25in sides=120px, 1in bottom=96px */
.tr-doc.tpl-us-univ{padding:144px 120px 96px}
.tr-doc.tpl-us-univ .tr-doc-school{font-size:22px;font-weight:700;text-align:center;letter-spacing:.02em;margin-bottom:4px}
.tr-doc.tpl-us-univ .tr-doc-subtitle{font-size:14px;font-weight:700;text-align:center;letter-spacing:.15em;text-transform:uppercase;margin-bottom:4px}
.tr-doc.tpl-us-univ .tr-doc-address{font-size:10px;text-align:center;color:#444;margin-bottom:20px}
.tr-doc.tpl-us-univ .tr-doc-divider{border:none;border-top:2px solid #000;margin:0 0 16px}
.tr-doc.tpl-us-univ .tr-doc-divider2{border:none;border-top:1px solid #000;margin:0 0 16px}

/* ── Canada University ── */
/* 1.5in top=144px, 1in sides=96px, 1in bottom=96px */
.tr-doc.tpl-ca-univ{padding:144px 96px 96px;font-family:Arial,sans-serif}
.tr-doc.tpl-ca-univ .tr-doc-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px}
.tr-doc.tpl-ca-univ .tr-doc-school{font-size:18px;font-weight:700}
.tr-doc.tpl-ca-univ .tr-doc-subtitle{font-size:13px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;text-align:right;margin-top:4px}

/* ── Germany University ── */
/* 2.5cm top/sides=95px, 2cm bottom=76px */
.tr-doc.tpl-de-univ{padding:95px 95px 76px;font-family:Helvetica,Arial,sans-serif}
.tr-doc.tpl-de-univ .tr-doc-school{font-size:16px;font-weight:700;text-align:center;margin-bottom:3px}
.tr-doc.tpl-de-univ .tr-doc-subtitle{font-size:13px;text-align:center;letter-spacing:.08em;text-transform:uppercase;margin-bottom:16px}

/* ── Australia University ── */
/* 2cm all sides=76px */
.tr-doc.tpl-au-univ{padding:76px 76px 76px;font-family:Arial,sans-serif}
.tr-doc.tpl-au-univ .tr-doc-school{font-size:20px;font-weight:700;text-align:center;margin-bottom:3px}
.tr-doc.tpl-au-univ .tr-doc-subtitle{font-size:13px;font-weight:700;text-align:center;letter-spacing:.12em;text-transform:uppercase;margin-bottom:16px}

/* ── US High School ── */
/* 1in all sides=96px */
.tr-doc.tpl-us-hs{padding:96px 96px 96px}
.tr-doc.tpl-us-hs .tr-doc-school{font-size:20px;font-weight:700;text-align:center;margin-bottom:2px}
.tr-doc.tpl-us-hs .tr-doc-address{font-size:11px;text-align:center;color:#444;margin-bottom:4px}
.tr-doc.tpl-us-hs .tr-doc-subtitle{font-size:13px;font-weight:700;text-align:center;letter-spacing:.15em;text-transform:uppercase;margin-bottom:16px}

/* ── Canada High School ── */
/* 1in all sides=96px */
.tr-doc.tpl-ca-hs{padding:96px 96px 96px;font-family:Arial,sans-serif}
.tr-doc.tpl-ca-hs .tr-doc-school{font-size:20px;font-weight:700;text-align:center;margin-bottom:2px}
.tr-doc.tpl-ca-hs .tr-doc-subtitle{font-size:13px;font-weight:700;text-align:center;letter-spacing:.12em;text-transform:uppercase;margin-bottom:16px}

/* ── Shared student info table ── */
.tr-info-table{width:100%;border-collapse:collapse;margin-bottom:16px;font-size:11px}
.tr-info-table td{padding:3px 6px;vertical-align:top}
.tr-info-table td:first-child{font-weight:700;white-space:nowrap;width:38%}
.tr-info-table.bordered td{border:1px solid #999;padding:4px 8px}

/* ── Course table ── */
.tr-ct{width:100%;border-collapse:collapse;font-size:11px;margin-bottom:12px}
.tr-ct th{background:#1a3a6b;color:#fff;padding:5px 8px;text-align:left;font-size:10px;font-weight:700;letter-spacing:.04em}
.tr-ct td{padding:4px 8px;border-bottom:1px solid #e2e8f0}
.tr-ct tr:nth-child(even) td{background:#f8fafc}
.tr-ct .tr-ct-total td{font-weight:700;border-top:2px solid #1a3a6b;background:#f0f4ff;text-align:right;padding-right:8px}

/* Germany table style */
.tr-doc.tpl-de-univ .tr-ct th{background:#333}
.tr-doc.tpl-de-univ .tr-ct .tr-ct-total td{border-top-color:#333}

/* ── Semester heading ── */
.tr-sem-heading{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:6px 0 4px;border-bottom:1px solid #000;margin-bottom:4px;margin-top:12px}
.tr-sem-heading:first-child{margin-top:0}

/* ── GPA summary box ── */
.tr-gpa-summary{border:1px solid #999;padding:10px 14px;margin-top:16px;font-size:11px}
.tr-gpa-summary-title{font-weight:700;font-size:12px;margin-bottom:6px;text-transform:uppercase;letter-spacing:.06em}
.tr-gpa-summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.tr-gpa-summary-item{text-align:center}
.tr-gpa-summary-item .val{font-size:18px;font-weight:700;display:block}
.tr-gpa-summary-item .lbl{font-size:9px;color:#555;text-transform:uppercase;letter-spacing:.05em}

/* ── Signature area ── */
.tr-sig-area{display:flex;justify-content:space-between;align-items:flex-end;margin-top:24px;padding-top:12px;border-top:1px solid #999;font-size:10px}
.tr-sig-block{text-align:center;min-width:140px}
.tr-sig-line{border-top:1px solid #000;margin-bottom:4px;margin-top:32px}
.tr-sig-label{font-size:9px;color:#555;text-transform:uppercase;letter-spacing:.05em}

/* ── Logo in doc ── */
.tr-doc-logo{max-height:60px;max-width:160px;object-fit:contain;display:block}
.tr-doc-logo-center{margin:0 auto 8px;display:block}

/* ── Seal in doc ── */
.tr-doc-seal{width:80px;height:80px;object-fit:contain;opacity:.85}

/* ── Official copy watermark band ── */
.tr-official-band{background:#1a3a6b;color:#fff;text-align:center;font-size:9px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;padding:3px 0;margin-bottom:12px}

/* ── Toast ── */
.tr-toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:#1e293b;color:#fff;padding:10px 20px;border-radius:999px;font-size:13px;font-weight:600;opacity:0;transition:all .3s;z-index:99999;pointer-events:none}
.tr-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── Paper background grid ── */
.tr-paper-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:8px}
.tr-paper-btn{border:1.5px solid var(--tr-border);border-radius:7px;background:#fff;cursor:pointer;padding:4px;display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10px;color:#64748b;font-family:inherit;transition:all .18s;overflow:hidden}
.tr-paper-btn img{width:100%;height:40px;object-fit:cover;border-radius:4px}
.tr-paper-btn:hover{border-color:var(--tr-primary);color:var(--tr-primary)}
.tr-paper-btn.is-active{border-color:var(--tr-primary);background:rgba(26,58,107,.06);color:var(--tr-primary)}
.tr-paper-btn--none{justify-content:center;min-height:56px}

/* ── Modal ── */
.tr-modal{display:none;position:fixed;inset:0;z-index:99990;align-items:center;justify-content:center}
.tr-modal.is-open{display:flex}
.tr-modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(2px)}
.tr-modal__box{position:relative;background:#fff;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.25);width:90vw;max-width:680px;max-height:90vh;overflow-y:auto;z-index:1}
.tr-modal__close{position:absolute;top:14px;right:14px;width:32px;height:32px;border-radius:50%;border:none;background:#f1f5f9;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#64748b;z-index:2}
.tr-modal__close:hover{background:#e2e8f0;color:#1e293b}

/* ── Logo / Seal grid items in modals ── */
.tr-logo-grid-item{border:1.5px solid var(--tr-border);border-radius:8px;background:#fff;cursor:pointer;padding:6px;display:flex;align-items:center;justify-content:center;aspect-ratio:1;overflow:hidden;transition:border-color .18s}
.tr-logo-grid-item img{width:100%;height:100%;object-fit:contain}
.tr-logo-grid-item:hover{border-color:var(--tr-primary)}
.tr-logo-grid-item.is-active{border-color:var(--tr-primary);background:rgba(26,58,107,.06);box-shadow:0 0 0 2px rgba(26,58,107,.2)}

.tr-seal-grid-item{border:1.5px solid var(--tr-border);border-radius:8px;background:#f8fafc;cursor:pointer;padding:6px;display:flex;align-items:center;justify-content:center;aspect-ratio:1;overflow:hidden;transition:border-color .18s}
.tr-seal-grid-item img{width:100%;height:100%;object-fit:contain}
.tr-seal-grid-item:hover{border-color:var(--tr-primary)}
.tr-seal-grid-item.is-active{border-color:var(--tr-primary);background:rgba(26,58,107,.06);box-shadow:0 0 0 2px rgba(26,58,107,.2)}

/* ── Upload label button ── */
.tr-upload-label{display:flex;align-items:center;gap:6px;padding:7px 10px;border-radius:7px;border:1.5px dashed var(--tr-border);background:none;cursor:pointer;font-size:11px;font-weight:600;color:#64748b;font-family:inherit;width:100%;box-sizing:border-box;transition:all .18s}
.tr-upload-label:hover{border-color:var(--tr-primary);color:var(--tr-primary)}
.tr-upload-label .site-icon{width:15px;height:15px;flex-shrink:0}
