:root { --bs-primary: #0284c7; --bs-primary-rgb: 2, 132, 199; --bs-border-color: var(--border); --bs-body-bg: var(--bg); --bs-body-color: var(--text); --bg: #f0f9ff; --surface: #ffffff; --surface-muted: #f8fafc; --border: #d6dbe3; --border-strong: #c1c8d2; --text: #1e293b; --muted: #475569; --primary: #0284c7; --accent: #ea580c; --accent-soft: #ffedd5; --success: #166534; --warning: #92400e; --danger: #b91c1c; --shadow: 0 10px 30px rgba(2, 132, 199, 0.08); --radius-sm: 10px; --radius-md: 14px; --radius-lg: 18px; --font-ui: "Cairo", "Segoe UI", Tahoma, Arial, sans-serif; } * { box-sizing: border-box; } html { scroll-behavior: smooth; } body { margin: 0; background: var(--bg); color: var(--text); font-family: var(--font-ui); font-weight: 400; line-height: 1.7; text-rendering: optimizeLegibility; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; } body, .form-control, .form-select, .btn, .table { font-size: 0.96rem; } input, select, textarea, button { font: inherit; } h1, h2, h3, h4, h5, h6, .brand-title, .hero-title, .stat-label, .section-title, .footer-title, .timeline-title, .empty-title { font-family: var(--font-ui); letter-spacing: 0; } ::selection { background: rgba(2, 132, 199, 0.18); } .app-shell { min-height: 100vh; } .site-header, .site-footer { background: rgba(255, 255, 255, 0.92); backdrop-filter: blur(8px); } .site-header { position: sticky; border-top: 4px solid var(--primary); background: linear-gradient(to right, rgba(255,255,255,0.95), rgba(240, 249, 255, 0.95)); top: 0; z-index: 1020; } .navbar-brand, .nav-link { color: var(--text); } .navbar-brand:hover, .nav-link:hover { color: var(--primary); } .nav-link { border-radius: 999px; padding: 0.55rem 0.9rem; color: var(--muted); font-weight: 500; transition: background-color 0.2s ease, color 0.2s ease; } .nav-link.active, .nav-link:hover { background: #e0f2fe; color: var(--primary); } .brand-mark { text-decoration: none; } .brand-badge { width: 2.4rem; height: 2.4rem; display: inline-flex; align-items: center; justify-content: center; border-radius: 12px; background: var(--primary); color: #fff; font-weight: 700; } .brand-title { font-weight: 700; font-size: 1.02rem; } .brand-subtitle, .footer-meta, .section-copy, .hero-copy, .text-muted { color: var(--muted) !important; } .brand-subtitle { font-size: 0.82rem; font-weight: 500; } .header-chip, .eyebrow, .pill-count { display: inline-flex; align-items: center; gap: 0.35rem; border: 1px solid var(--border); border-radius: 999px; background: #fff; color: var(--muted); padding: 0.38rem 0.7rem; font-size: 0.78rem; font-weight: 500; } .container-xxl { max-width: min(1540px, calc(100vw - 2rem)); } @media (min-width: 992px) { .admin-layout.row { --bs-gutter-x: 0; --bs-gutter-y: 0; display: flex; flex-wrap: nowrap; align-items: flex-start; gap: 1.5rem; margin-left: 0; margin-right: 0; } .admin-layout.row > .layout-sidebar-column, .admin-layout.row > .layout-content-column { width: auto; max-width: none; padding-left: 0; padding-right: 0; flex: 0 1 auto; } .admin-layout.row > .layout-sidebar-column { order: 1; flex: 0 0 clamp(280px, 22vw, 320px); max-width: clamp(280px, 22vw, 320px); align-self: flex-start; } .admin-layout.row > .layout-content-column { order: 2; flex: 1 1 auto; min-width: 0; } } .hero-section { padding-top: 2rem; } .hero-title { font-size: clamp(2.05rem, 2.9vw, 3.1rem); line-height: 1.3; font-weight: 700; margin: 0; max-width: 15ch; } .hero-copy { max-width: 58ch; font-size: 1rem; } .hero-meta { display: flex; flex-wrap: wrap; gap: 0.7rem; color: var(--muted); font-size: 0.84rem; } .hero-meta span { padding: 0.45rem 0.75rem; background: var(--surface-muted); border: 1px solid var(--border); border-radius: 999px; } .app-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); box-shadow: var(--shadow); padding: 1.35rem; } .compact-card, .sidebar-card { padding: 1.1rem; } .hero-card { padding: 1.7rem; } .form-card, .detail-card { padding: 1.4rem; } .stat-card { display: flex; flex-direction: column; gap: 0.4rem; min-height: 160px; } .stat-label, .section-title, .footer-title, .timeline-title, .empty-title { font-weight: 700; } .section-head { display: flex; align-items: center; justify-content: space-between; gap: 1rem; } .section-title { font-size: 1.08rem; } .small-title { font-size: 0.96rem; } .stat-value { font-size: clamp(1.8rem, 3vw, 2.4rem); font-weight: 700; color: var(--primary); letter-spacing: -0.02em; } .stat-note, .workflow-list, .check-list, .timeline-copy, .summary-row span { color: var(--muted); } .module-list { display: grid; gap: 0.9rem; } .module-item { border: 1px solid var(--border); border-radius: var(--radius-md); background: var(--surface-muted); padding: 1rem; } .module-item h2 { font-size: 0.98rem; margin: 0 0 0.35rem; } .module-item p, .summary-row, .detail-item span, .detail-item strong, .timeline-copy, .notes-block p { margin: 0; } .workflow-list, .check-list { padding-right: 1.2rem; margin: 0; display: grid; gap: 0.65rem; } .filter-pills { display: flex; flex-wrap: wrap; gap: 0.65rem; } .filter-pill { display: inline-flex; align-items: center; gap: 0.45rem; border: 1px solid var(--border); border-radius: 999px; padding: 0.55rem 0.8rem; background: #fff; color: var(--muted); text-decoration: none; font-weight: 500; } .filter-pill.active, .filter-pill:hover { color: var(--primary); background: #e0f2fe; border-color: var(--border-strong); } .pill-count { padding: 0.2rem 0.5rem; background: transparent; } .app-table { --bs-table-bg: transparent; --bs-table-border-color: #e6e8ee; margin: 0; } .app-table thead th { font-size: 0.8rem; font-weight: 600; letter-spacing: 0; color: #64748b; white-space: nowrap; border-bottom-width: 1px; } .app-table tbody td { padding-top: 0.5rem; padding-bottom: 0.5rem; vertical-align: middle; } .table-link { color: var(--primary); text-decoration: none; font-weight: 700; } .table-link:hover { text-decoration: underline; } .status-badge { display: inline-flex; align-items: center; justify-content: center; border-radius: 999px; padding: 0.35rem 0.7rem; font-size: 0.78rem; font-weight: 600; border: 1px solid transparent; } .status-submitted { background: #eff6ff; color: #1d4ed8; border-color: #bfdbfe; } .status-review { background: #fff7ed; color: var(--warning); border-color: #fed7aa; } .status-approved { background: #ecfdf5; color: var(--success); border-color: #bbf7d0; } .status-rejected { background: #fef2f2; color: var(--danger); border-color: #fecaca; } .status-muted { background: #f8fafc; color: var(--muted); border-color: var(--border); } .form-label { font-weight: 600; margin-bottom: 0.45rem; } .form-control, .form-select { min-height: 2.9rem; border-color: var(--border-strong); border-radius: 12px; padding: 0.7rem 0.9rem; background-color: #fff; } textarea.form-control { min-height: 120px; } .form-control:focus, .form-select:focus, .btn:focus, .nav-link:focus, .filter-pill:focus { border-color: rgba(2, 132, 199, 0.45); box-shadow: 0 0 0 0.18rem rgba(2, 132, 199, 0.13); } .btn { border-radius: 12px; padding: 0.68rem 1rem; font-weight: 600; } .btn-primary { background: var(--primary); border-color: var(--primary); } .btn-primary:hover, .btn-primary:focus { background: #0369a1; border-color: #0369a1; } .btn-outline-secondary { color: var(--primary); border-color: var(--border-strong); } .btn-outline-secondary:hover { background: #e0f2fe; border-color: var(--border-strong); color: var(--primary); } .detail-grid .detail-item, .summary-row, .notes-block, .timeline-item { border: 1px solid var(--border); border-radius: var(--radius-md); background: var(--surface-muted); padding: 0.95rem 1rem; } .detail-item { display: flex; align-items: center; justify-content: space-between; gap: 1rem; height: 100%; } .detail-item span { font-size: 0.84rem; color: var(--muted); } .detail-item strong, .summary-row strong { font-size: 0.94rem; font-weight: 600; } .timeline-list, .summary-stack { display: grid; gap: 0.75rem; } .timeline-item { position: relative; } .timeline-item::before { content: ""; position: absolute; inset-inline-start: 0; top: 0; bottom: 0; width: 3px; border-radius: 999px; background: var(--accent); opacity: 0.16; } .notes-block { line-height: 1.85; } .summary-row { display: flex; align-items: center; justify-content: space-between; gap: 1rem; } .empty-state { border: 1px dashed var(--border-strong); border-radius: var(--radius-md); background: var(--surface-muted); } .toast { border-radius: 14px; box-shadow: var(--shadow); } .alert { border-radius: 14px; } .footer-title { font-size: 0.98rem; } @media (max-width: 991.98px) { .site-header { position: static; } .hero-card, .app-card, .form-card, .detail-card { padding: 1rem; } .header-actions { margin-top: 1rem; } } .link-card { display: flex; flex-direction: column; justify-content: space-between; gap: 0.8rem; min-height: 220px; } .link-card p { margin: 0; } .page-banner { padding: 1.5rem 1.7rem; border: 1px solid var(--border); border-radius: var(--radius-lg); background: linear-gradient(135deg, #ffffff 0%, #f0f9ff 60%, #e0f2fe 100%); box-shadow: var(--shadow); } .page-title { font-size: clamp(1.8rem, 2.5vw, 2.6rem); line-height: 1.35; font-weight: 700; margin: 0; } .page-copy { color: var(--muted); max-width: 60ch; font-size: 1rem; } .page-banner-panel, .stat-tile, .form-section-block { border: 1px solid var(--border); border-radius: var(--radius-md); background: rgba(255, 255, 255, 0.88); } .page-banner-panel, .stat-tile { padding: 1.15rem; } .mini-stat-label { color: var(--muted); font-size: 0.82rem; font-weight: 600; } .mini-stat-value { font-size: clamp(1.7rem, 2.2vw, 2.3rem); font-weight: 700; color: var(--primary); margin-top: 0.35rem; } .mini-stat-copy { color: var(--muted); margin-top: 0.45rem; line-height: 1.75; } .form-section-block { padding: 1.1rem; background: var(--surface-muted); } .form-section-heading { display: flex; align-items: flex-start; justify-content: space-between; gap: 1rem; margin-bottom: 1rem; } .form-section-title { font-size: 1rem; font-weight: 700; margin: 0 0 0.2rem; } .form-section-copy, .table-toolbar-copy, .process-item small, .quick-link-item span { color: var(--muted); } .form-section-copy { margin: 0; } .process-list, .quick-link-stack { display: grid; gap: 0.85rem; } .process-item, .quick-link-item { display: flex; align-items: flex-start; gap: 0.85rem; padding: 0.9rem 0.95rem; border: 1px solid var(--border); border-radius: var(--radius-md); background: var(--surface-muted); } .process-item span { width: 2rem; height: 2rem; flex: 0 0 2rem; display: inline-flex; align-items: center; justify-content: center; border-radius: 999px; background: #ffedd5; color: var(--accent); font-weight: 700; } .process-item.active span { background: var(--accent); color: #fff; } .process-item strong, .quick-link-item strong { display: block; margin-bottom: 0.15rem; } .quick-link-item { text-decoration: none; color: inherit; transition: transform 0.18s ease, border-color 0.18s ease, background-color 0.18s ease; } .quick-link-item:hover { transform: translateY(-1px); border-color: var(--border-strong); background: #fff; } .quick-link-item.is-current { border-color: rgba(234, 88, 12, 0.32); background: linear-gradient(135deg, #ffffff 0%, var(--accent-soft) 100%); box-shadow: var(--shadow); } .quick-link-item.is-current strong { color: var(--accent); } .table-toolbar { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 0.75rem; padding-top: 0.95rem; border-top: 1px solid #e9edf3; } .score-bar { width: 100%; height: 0.65rem; background: #e8edf3; border-radius: 999px; overflow: hidden; } .score-bar span { display: block; height: 100%; border-radius: inherit; background: linear-gradient(90deg, #ea580c 0%, #f97316 100%); } .status-panel .status-badge { font-size: 0.86rem; padding-inline: 0.85rem; padding-block: 0.45rem; } @media (max-width: 991.98px) { .page-banner { padding: 1.1rem; } .form-section-block, .stat-tile, .page-banner-panel { padding: 1rem; } } .approved-hero { background: radial-gradient(circle at top left, rgba(234, 88, 12, 0.12), transparent 35%), linear-gradient(135deg, #ffffff 0%, #f0f9ff 55%, #e0f2fe 100%); overflow: hidden; } .approved-hero .page-title, .approved-hero .page-copy { max-width: 20ch; } .approved-kicker { display: inline-flex; align-items: center; gap: 0.45rem; border-radius: 999px; background: rgba(234, 88, 12, 0.1); color: var(--accent); padding: 0.45rem 0.8rem; font-size: 0.82rem; font-weight: 700; } .highlight-grid, .next-step-grid, .contact-stack, .launch-metrics { display: grid; gap: 1rem; } .highlight-item, .next-step-card, .contact-item, .launch-metric { border: 1px solid var(--border); border-radius: var(--radius-md); background: var(--surface-muted); padding: 1rem; } .highlight-item strong, .next-step-card strong, .contact-item strong, .launch-metric strong { display: block; margin-bottom: 0.35rem; font-size: 0.98rem; } .highlight-item p, .next-step-card p, .contact-item span, .launch-metric span { margin: 0; color: var(--muted); } .approved-note { border-inline-start: 4px solid var(--accent); background: #f8fffd; } .score-display { display: flex; align-items: baseline; gap: 0.4rem; } .score-display strong { font-size: clamp(2rem, 4vw, 2.8rem); line-height: 1; color: var(--accent); } .score-display span { color: var(--muted); font-weight: 600; } .cta-stack { display: flex; flex-wrap: wrap; gap: 0.75rem; } @media (min-width: 768px) { .highlight-grid, .next-step-grid, .launch-metrics { grid-template-columns: repeat(3, minmax(0, 1fr)); } } .capacity-note, .section-subtle { color: var(--muted); } .school-data-item { border: 1px solid var(--border); border-radius: var(--radius-md); background: var(--surface-muted); padding: 1rem; height: 100%; } .school-data-item strong { display: block; margin-bottom: 0.3rem; font-size: 0.82rem; color: var(--muted); } .school-data-item span { display: block; font-size: 1rem; font-weight: 700; color: var(--primary); } .module-roadmap-list { list-style: none; padding: 0; display: grid; gap: 0.85rem; } .module-roadmap-list li { border: 1px solid var(--border); border-radius: var(--radius-md); background: var(--surface-muted); padding: 0.95rem 1rem; } .module-roadmap-list strong { display: block; margin-bottom: 0.15rem; } .app-table td small { display: block; margin-top: 0.2rem; color: var(--muted); } .table-action-cell { white-space: nowrap; } .table-icon-actions { display: inline-flex; align-items: center; justify-content: flex-end; gap: 0.45rem; flex-wrap: nowrap; } .icon-action { width: 2rem; height: 2rem; padding: 0; display: inline-flex; align-items: center; justify-content: center; border-radius: 0.8rem; line-height: 1; } .icon-action svg { width: 0.95rem; height: 0.95rem; flex-shrink: 0; } .teacher-subject-picker { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 0.65rem; } .teacher-subject-option { display: flex; align-items: center; gap: 0.55rem; border: 1px solid var(--border); border-radius: 0.95rem; background: #fff; padding: 0.7rem 0.85rem; min-height: 100%; cursor: pointer; transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease; } .teacher-subject-option:hover { border-color: rgba(14, 165, 233, 0.35); box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06); transform: translateY(-1px); } .teacher-subject-option .form-check-input { margin: 0; flex-shrink: 0; } .teacher-subject-badges { display: flex; flex-wrap: wrap; gap: 0.35rem; } .teacher-subject-badge { display: inline-flex; align-items: center; border: 1px solid rgba(14, 165, 233, 0.18); border-radius: 999px; background: #f8fbff; color: var(--primary); padding: 0.18rem 0.55rem; font-size: 0.78rem; font-weight: 600; line-height: 1.4; } /* Admin Sidebar */ .admin-sidebar { position: sticky; top: 2rem; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); box-shadow: var(--shadow); padding: 1.25rem; max-height: calc(100vh - 2.5rem); overflow: auto; } .sidebar-nav { display: flex; flex-direction: column; gap: 0.35rem; } .sidebar-link { display: flex; white-space: nowrap; align-items: center; gap: 0.85rem; padding: 0.65rem 1rem; border-radius: var(--radius-md); color: var(--muted); text-decoration: none; font-weight: 500; transition: all 0.2s ease; } .sidebar-link svg { flex-shrink: 0; } .sidebar-link:hover, .sidebar-link.active { background: #e0f2fe; color: var(--primary); } .sidebar-label { font-size: 0.75rem; white-space: nowrap; text-transform: uppercase; letter-spacing: 0.05em; margin-top: 1rem; margin-bottom: 0.5rem; padding: 0 1rem; } .student-certificate-page { padding-top: 2rem; } .certificate-toolbar { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; gap: 1rem; margin-bottom: 1.5rem; } .certificate-toolbar-actions { display: inline-flex; flex-wrap: wrap; gap: 0.75rem; } .student-certificate-card { position: relative; overflow: hidden; border-radius: 1.8rem; border: 1px solid rgba(15, 23, 42, 0.08); background: radial-gradient(circle at top left, rgba(14, 165, 233, 0.16), transparent 34%), radial-gradient(circle at top right, rgba(245, 158, 11, 0.18), transparent 32%), linear-gradient(135deg, #ffffff 0%, #f8fbff 55%, #fdf7eb 100%); box-shadow: 0 28px 60px rgba(15, 23, 42, 0.12); } .student-certificate-card::before, .student-certificate-card::after { content: ''; position: absolute; border-radius: 999px; pointer-events: none; } .student-certificate-card::before { width: 220px; height: 220px; top: -90px; left: -70px; background: rgba(14, 165, 233, 0.12); } .student-certificate-card::after { width: 180px; height: 180px; bottom: -80px; right: -55px; background: rgba(245, 158, 11, 0.14); } .student-certificate-body { position: relative; z-index: 1; padding: 2rem; } .certificate-kicker { display: inline-flex; align-items: center; gap: 0.45rem; padding: 0.5rem 0.9rem; border-radius: 999px; background: rgba(255, 255, 255, 0.8); border: 1px solid rgba(15, 23, 42, 0.08); color: var(--muted); font-size: 0.92rem; } .certificate-title { font-size: clamp(2rem, 4vw, 3rem); font-weight: 700; margin: 1rem 0 0.75rem; } .certificate-subtitle { max-width: 58rem; color: var(--muted); font-size: 1.02rem; } .certificate-student-name { font-size: clamp(1.8rem, 3vw, 2.5rem); font-weight: 700; margin: 1.25rem 0 0.35rem; } .certificate-grid { display: grid; grid-template-columns: minmax(0, 1.5fr) minmax(280px, 0.9fr); gap: 1.35rem; margin-top: 1.75rem; } .certificate-panel { border-radius: 1.35rem; border: 1px solid rgba(15, 23, 42, 0.08); background: rgba(255, 255, 255, 0.82); padding: 1.2rem 1.25rem; backdrop-filter: blur(8px); } .certificate-meta-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 0.9rem; margin-top: 1.25rem; } .certificate-meta-item { border-radius: 1rem; background: rgba(248, 250, 252, 0.95); padding: 0.9rem 1rem; border: 1px solid rgba(148, 163, 184, 0.2); } .certificate-meta-item strong, .certificate-signature strong, .certificate-panel strong { display: block; margin-bottom: 0.25rem; } .performance-pill { display: inline-flex; align-items: center; justify-content: center; padding: 0.7rem 1.15rem; border-radius: 999px; font-weight: 700; font-size: 1rem; background: rgba(14, 165, 233, 0.12); color: #075985; border: 1px solid rgba(14, 165, 233, 0.18); } .performance-pill.performance-excellent { background: rgba(22, 163, 74, 0.14); color: #166534; border-color: rgba(22, 163, 74, 0.2); } .performance-pill.performance-very_good { background: rgba(14, 165, 233, 0.14); color: #075985; border-color: rgba(14, 165, 233, 0.18); } .performance-pill.performance-good { background: rgba(245, 158, 11, 0.16); color: #92400e; border-color: rgba(245, 158, 11, 0.18); } .performance-pill.performance-poor { background: rgba(239, 68, 68, 0.14); color: #991b1b; border-color: rgba(239, 68, 68, 0.18); } .certificate-stat-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 0.9rem; margin-top: 1rem; } .certificate-stat { border-radius: 1rem; background: rgba(255, 255, 255, 0.9); border: 1px solid rgba(148, 163, 184, 0.2); padding: 0.9rem 1rem; } .certificate-stat strong { font-size: 1.4rem; margin-bottom: 0.15rem; } .certificate-table-wrap { overflow-x: auto; } .certificate-table { width: 100%; border-collapse: collapse; } .certificate-table th, .certificate-table td { padding: 0.85rem 0.9rem; border-bottom: 1px solid rgba(148, 163, 184, 0.18); text-align: right; vertical-align: top; } .certificate-table thead th { color: var(--muted); font-size: 0.92rem; font-weight: 600; background: rgba(248, 250, 252, 0.9); } .certificate-table tbody tr:last-child td { border-bottom: none; } .certificate-signature-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1rem; margin-top: 1.5rem; } .certificate-signature { border-top: 1px dashed rgba(100, 116, 139, 0.55); padding-top: 0.85rem; } .certificate-empty-state { text-align: center; padding: 3rem 1.25rem; } @media (max-width: 991.98px) { .certificate-grid { grid-template-columns: 1fr; } } @media print { body { background: #fff; } .site-header, .site-footer, .certificate-toolbar, .toast-container { display: none !important; } .student-certificate-page, .student-certificate-body { padding: 0; } .student-certificate-card, .certificate-panel, .certificate-meta-item, .certificate-stat { box-shadow: none !important; background: #fff !important; backdrop-filter: none !important; } .student-certificate-card { border: 2px solid rgba(148, 116, 18, 0.65); border-radius: 1rem; } .student-certificate-card::before, .student-certificate-card::after { display: none; } } .completion-certificate-page { padding-top: 2rem; } .completion-certificate-card { position: relative; overflow: hidden; border-radius: 2rem; border: 1px solid rgba(148, 163, 184, 0.24); box-shadow: 0 28px 60px rgba(15, 23, 42, 0.12); } .completion-template-modern { background: radial-gradient(circle at top left, rgba(14, 165, 233, 0.18), transparent 30%), radial-gradient(circle at bottom right, rgba(251, 191, 36, 0.18), transparent 28%), linear-gradient(145deg, #fffdf7 0%, #ffffff 38%, #f5fbff 100%); } .completion-template-classic { background: linear-gradient(180deg, rgba(255, 251, 235, 0.9) 0%, rgba(255, 255, 255, 1) 24%, rgba(255, 251, 235, 0.82) 100%); } .completion-template-classic::before { content: ''; position: absolute; inset: 1.1rem; border: 2px solid rgba(180, 146, 42, 0.42); border-radius: 1.5rem; pointer-events: none; } .completion-certificate-layer { position: absolute; border-radius: 999px; pointer-events: none; } .completion-certificate-layer-one { width: 260px; height: 260px; top: -90px; right: -80px; background: rgba(14, 165, 233, 0.14); } .completion-certificate-layer-two { width: 220px; height: 220px; bottom: -110px; left: -70px; background: rgba(245, 158, 11, 0.15); } .completion-template-classic .completion-certificate-layer-one, .completion-template-classic .completion-certificate-layer-two { background: rgba(180, 146, 42, 0.08); } .completion-certificate-inner { position: relative; z-index: 1; padding: 2.2rem; } .completion-certificate-header { display: flex; justify-content: space-between; align-items: flex-start; gap: 1.25rem; margin-bottom: 2rem; } .completion-branding { display: flex; align-items: center; gap: 1rem; } .completion-brand-logo { width: 96px; height: 96px; object-fit: cover; border-radius: 1.35rem; border: 1px solid rgba(148, 163, 184, 0.24); background: rgba(255, 255, 255, 0.92); box-shadow: 0 16px 35px rgba(15, 23, 42, 0.08); } .completion-brand-badge { display: inline-flex; align-items: center; justify-content: center; font-size: 2rem; font-weight: 700; color: #075985; } .completion-overline { color: var(--muted); text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.85rem; margin-bottom: 0.4rem; } .completion-certificate-title { font-size: clamp(2.1rem, 4vw, 3.4rem); font-weight: 700; margin: 0; } .completion-certificate-center { color: var(--muted); font-size: 1.05rem; margin-top: 0.4rem; } .completion-certificate-stamps { display: inline-flex; flex-direction: column; align-items: flex-end; gap: 0.7rem; } .completion-stamp { display: inline-flex; align-items: center; justify-content: center; min-height: 2.75rem; padding: 0.7rem 1rem; border-radius: 999px; background: rgba(255, 255, 255, 0.86); border: 1px solid rgba(148, 163, 184, 0.2); font-weight: 600; } .completion-stamp-accent { background: rgba(250, 204, 21, 0.18); color: #854d0e; border-color: rgba(202, 138, 4, 0.22); } .completion-certificate-content { text-align: center; max-width: 54rem; margin: 0 auto; } .completion-intro { color: var(--muted); font-size: 1rem; } .completion-student-name { font-size: clamp(2.35rem, 5vw, 4.35rem); font-weight: 700; line-height: 1.1; margin-bottom: 0.5rem; } .completion-student-code { display: inline-flex; align-items: center; justify-content: center; min-height: 2.2rem; padding: 0.45rem 0.95rem; border-radius: 999px; background: rgba(255, 255, 255, 0.72); border: 1px solid rgba(148, 163, 184, 0.2); color: var(--muted); margin-bottom: 1.2rem; } .completion-message { font-size: 1.2rem; line-height: 2; margin: 0 auto 0.8rem; max-width: 48rem; } .completion-honor-line { color: #92400e; font-weight: 600; font-size: 1.05rem; } .completion-certificate-grid { display: grid; grid-template-columns: minmax(260px, 0.8fr) minmax(0, 1.3fr); gap: 1.1rem; margin-top: 2rem; align-items: stretch; } .completion-summary-card, .completion-meta-item, .completion-note, .completion-signature-block { border-radius: 1.25rem; background: rgba(255, 255, 255, 0.82); border: 1px solid rgba(148, 163, 184, 0.2); backdrop-filter: blur(8px); } .completion-summary-card { padding: 1.25rem; text-align: center; display: flex; flex-direction: column; justify-content: center; gap: 0.6rem; } .completion-summary-label { color: var(--muted); font-size: 0.92rem; } .completion-performance-pill { margin: 0 auto; } .completion-honor-title { font-size: 1.5rem; font-weight: 700; } .completion-honor-subtitle { color: var(--muted); } .completion-meta-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1rem; } .completion-meta-item { padding: 1rem 1.05rem; } .completion-meta-item strong, .completion-signature-block strong { display: block; margin-bottom: 0.35rem; } .completion-signature-block strong, .completion-signature-block span { white-space: nowrap; } .completion-signature-block strong { display: inline-block; margin-bottom: 0; flex: 0 0 auto; } .completion-signature-block span { flex: 0 1 auto; } .completion-note { padding: 1rem 1.1rem; margin-top: 1rem; text-align: center; color: var(--muted); } .completion-signature-row { display: grid; grid-template-columns: minmax(0, 1.2fr) minmax(200px, 0.8fr); gap: 1rem; margin-top: 1.5rem; } .completion-signature-block { padding: 1rem 1.1rem; text-align: center; display: flex; align-items: center; justify-content: center; gap: 0.45rem; flex-wrap: nowrap; } @media (max-width: 991.98px) { .completion-certificate-header, .completion-branding { flex-direction: column; align-items: center; text-align: center; } .completion-certificate-stamps { align-items: center; } .completion-certificate-grid, .completion-signature-row, .completion-meta-grid { grid-template-columns: 1fr; } } @media print { @page { size: A4 landscape; margin: 8mm; } html, body { margin: 0 !important; padding: 0 !important; width: auto !important; min-height: auto !important; height: auto !important; background: #fff !important; } body { -webkit-print-color-adjust: exact; print-color-adjust: exact; } .app-shell, main { margin: 0 !important; padding: 0 !important; } .site-header, .site-footer, .certificate-toolbar, .toast-container { display: none !important; } .completion-certificate-page { padding: 0 !important; margin: 0 !important; } .completion-certificate-page .container-xl { width: 100% !important; max-width: none !important; padding: 0 !important; margin: 0 !important; } .completion-certificate-card, .completion-summary-card, .completion-meta-item, .completion-note, .completion-signature-block, .completion-brand-logo { box-shadow: none !important; backdrop-filter: none !important; } .completion-certificate-card { border: 2px solid rgba(180, 146, 42, 0.62); border-radius: 1rem; height: 188mm; min-height: 188mm; max-height: 188mm; overflow: hidden; page-break-inside: avoid; break-inside: avoid-page; } .completion-template-classic::before { inset: 0.45rem; border-radius: 0.8rem; } .completion-certificate-inner { min-height: 100%; padding: 0.7rem 0.9rem; display: flex; flex-direction: column; justify-content: space-between; gap: 0.5rem; } .completion-certificate-layer-one { width: 150px; height: 150px; top: -62px; right: -48px; opacity: 0.75; } .completion-certificate-layer-two { width: 130px; height: 130px; bottom: -62px; left: -34px; opacity: 0.75; } .completion-certificate-header { align-items: center; gap: 0.55rem; margin-bottom: 0; } .completion-branding { gap: 0.6rem; } .completion-brand-logo { width: 58px; height: 58px; border-radius: 0.85rem; } .completion-brand-badge { font-size: 1.25rem; } .completion-overline { font-size: 0.62rem; margin-bottom: 0.1rem; } .completion-certificate-title { font-size: 1.55rem; line-height: 1.15; } .completion-certificate-center { font-size: 0.82rem; margin-top: 0.1rem; } .completion-certificate-stamps { gap: 0.3rem; } .completion-stamp { min-height: 1.7rem; padding: 0.32rem 0.62rem; font-size: 0.76rem; line-height: 1.2; } .completion-certificate-content { max-width: none; } .completion-intro { font-size: 0.76rem; margin-bottom: 0.15rem !important; } .completion-student-name { font-size: 1.95rem; line-height: 1.05; margin-bottom: 0.15rem; } .completion-student-code { min-height: 1.55rem; padding: 0.18rem 0.55rem; font-size: 0.72rem; margin-bottom: 0.42rem; } .completion-message { font-size: 0.88rem; line-height: 1.48; max-width: none; margin-bottom: 0.3rem; } .completion-honor-line { font-size: 0.82rem; line-height: 1.35; } .completion-certificate-grid { grid-template-columns: minmax(190px, 0.7fr) minmax(0, 1.3fr); gap: 0.55rem; margin-top: 0.6rem; align-items: stretch; } .completion-summary-card, .completion-meta-item, .completion-note, .completion-signature-block { border-radius: 0.75rem; padding: 0.5rem 0.62rem; background: rgba(255, 255, 255, 0.98) !important; } .completion-summary-card { gap: 0.2rem; } .completion-summary-label { font-size: 0.72rem; } .completion-performance-pill { padding: 0.32rem 0.6rem; font-size: 0.76rem; } .completion-honor-title { font-size: 0.98rem; line-height: 1.2; } .completion-honor-subtitle { display: none; } .completion-meta-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 0.45rem; } .completion-meta-item span, .completion-signature-block span, .completion-note { font-size: 0.76rem; line-height: 1.28; } .completion-meta-item strong, .completion-signature-block strong { margin-bottom: 0.08rem; font-size: 0.69rem; line-height: 1.2; } .completion-note { margin-top: 0.45rem; padding-top: 0.45rem; padding-bottom: 0.45rem; } .completion-signature-row { grid-template-columns: minmax(0, 1.25fr) minmax(150px, 0.75fr); gap: 0.55rem; margin-top: 0.55rem; } .completion-signature-block { gap: 0.3rem; padding-left: 0.5rem; padding-right: 0.5rem; } } .completion-batch-page .certificate-toolbar { position: sticky; top: 1rem; z-index: 5; } .batch-certificate-stack { display: flex; flex-direction: column; gap: 1.5rem; } .completion-batch-item { page-break-inside: avoid; break-inside: avoid-page; } @media print { .completion-batch-page { padding: 0 !important; } .batch-certificate-stack { gap: 0 !important; } .completion-batch-item { margin: 0 !important; page-break-after: always; break-after: page; } .completion-batch-item:last-child { page-break-after: auto; break-after: auto; } }