:root { --bg: #f3f4f6; --surface: #ffffff; --surface-muted: #f8fafc; --border: #d6dbe3; --border-strong: #c1c8d2; --text: #0f172a; --muted: #475569; --primary: #111827; --accent: #0f766e; --accent-soft: #ecfdf5; --success: #166534; --warning: #92400e; --danger: #b91c1c; --shadow: 0 10px 30px rgba(15, 23, 42, 0.05); --radius-sm: 10px; --radius-md: 14px; --radius-lg: 18px; --font-ui: "IBM Plex Sans Arabic", "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(15, 118, 110, 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; 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: #eef2f7; 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: 1240px; } .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: #eef2f7; 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(15, 118, 110, 0.45); box-shadow: 0 0 0 0.18rem rgba(15, 118, 110, 0.13); } .btn { border-radius: 12px; padding: 0.68rem 1rem; font-weight: 600; } .btn-dark { background: var(--primary); border-color: var(--primary); } .btn-dark:hover, .btn-dark:focus { background: #0b1220; border-color: #0b1220; } .btn-outline-secondary { color: var(--primary); border-color: var(--border-strong); } .btn-outline-secondary:hover { background: #eef2f7; 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%, #f7fafc 60%, #eef6f5 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: #e6f6f4; 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(15, 118, 110, 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, #0f766e 0%, #14b8a6 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(15, 118, 110, 0.12), transparent 35%), linear-gradient(135deg, #ffffff 0%, #f8fafc 55%, #ecfdf5 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(15, 118, 110, 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); } /* Admin Sidebar */ .admin-sidebar { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); box-shadow: var(--shadow); padding: 1.25rem; } .sidebar-nav { display: flex; flex-direction: column; gap: 0.35rem; } .sidebar-link { display: flex; 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: #eef2f7; color: var(--primary); } .sidebar-label { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.05em; margin-top: 1rem; margin-bottom: 0.5rem; padding: 0 1rem; }