/* ==========================================================================
   OFFICIAL ULTRA-MODERN MINIMALIST PRINT LAYOUT - PERFECT 1 PAGE FILL
   ========================================================================== */

@media screen {
    .print-only-container {
        display: none !important;
    }
}

@media print {
    /* 1. Reset Screen Styles & Layouts to Clean Modern Aesthetics */
    html, body {
        background-color: #ffffff !important;
        color: #1f2937 !important; /* Elegant slate gray */
        font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
        font-size: 9.8pt;
        line-height: 1.45;
        margin: 0;
        padding: 0;
        width: 210mm; /* A4 Width */
        height: 297mm; /* A4 Height */
    }

    /* Hide screen elements during print */
    .public-header,
    .countdown-wrapper,
    .search-card,
    .result-card,
    .result-actions,
    .alert {
        display: none !important;
    }

    /* Show print container */
    .print-only-container {
        display: block !important;
        padding: 0;
        margin: 0;
    }

    /* Page Breaks */
    .page-break {
        display: block !important;
        page-break-after: always;
        height: 0;
        border: none;
        margin: 0;
        padding: 0;
    }

    /* 2. Sleek Modern Page Container with Teal Top Border Accent - Balanced Perfect Fill */
    .print-page {
        box-sizing: border-box;
        padding: 10mm 15mm !important; /* Balanced margins to fill the page perfectly */
        min-height: 297mm;
        position: relative;
        background: #ffffff !important;
        border-top: 6px solid #0d9488 !important; /* Modern Teal Accent */
        margin: 0;
    }

    /* 3. Kop Surat (Letterhead) */
    .print-kop {
        display: flex !important;
        align-items: center;
        justify-content: flex-start;
        gap: 15px;
        margin-bottom: 10px;
        text-align: left;
        width: 100%;
    }

    .kop-logo {
        display: block !important;
        width: 65px;
        height: 65px;
        object-fit: contain;
        flex-shrink: 0;
        border-radius: 8px;
    }

    .kop-text {
        flex-grow: 1;
    }

    .kop-text h2 {
        font-size: 8.5pt !important;
        font-weight: 700;
        margin-bottom: 2px;
        color: #0d9488 !important; /* Modern Teal */
        letter-spacing: 1.5px;
        text-transform: uppercase;
    }

    .kop-text h1 {
        font-size: 13.5pt !important;
        font-weight: 800;
        margin: 0 0 4px 0;
        color: #1f2937 !important;
        letter-spacing: 0.5px;
        text-transform: uppercase;
    }

    .kop-text p {
        font-size: 8pt !important;
        color: #4b5563 !important;
        margin-bottom: 2px;
    }

    /* Modern clean separator */
    .print-divider {
        display: block !important;
        border: none;
        height: 1px;
        background-color: #e5e7eb;
        margin: 6px 0 12px 0;
        width: 100%;
    }

    /* 4. Document Title */
    .cert-title {
        text-align: center;
        margin-bottom: 15px;
    }

    .cert-title h3 {
        font-size: 12pt !important;
        font-weight: 800;
        margin-bottom: 3px;
        color: #1f2937 !important;
        letter-spacing: 0.5px;
        text-transform: uppercase;
    }

    .cert-title p {
        font-size: 9pt !important;
        color: #6b7280 !important;
        margin: 0;
        font-weight: 500;
    }

    /* 5. Document Content / Metadata */
    .cert-body {
        text-align: justify;
    }

    .cert-body p {
        font-size: 10.5pt !important;
        color: #374151 !important;
        text-indent: 25px;
        margin-bottom: 12px;
        line-height: 1.55;
    }

    /* Modern Card Layout for Student Details - Perfect Fill */
    .table-print-meta {
        display: table !important;
        width: 100%;
        margin: 10px auto 15px auto;
        border-collapse: collapse;
        font-size: 9.5pt;
        background-color: #f9fafb !important;
        border: 1px solid #f3f4f6 !important;
        border-radius: 8px !important;
    }

    .table-print-meta tr {
        display: table-row !important;
    }

    .table-print-meta td {
        display: table-cell !important;
        padding: 7px 12px;
        vertical-align: middle;
        border-bottom: 1px solid #f3f4f6;
    }

    .table-print-meta td strong {
        font-weight: 700;
        color: #1f2937;
    }

    .table-print-meta td:first-child {
        color: #4b5563;
        font-weight: 600;
        width: 140px;
    }

    /* Statement styling */
    p.cert-statement {
        text-indent: 25px;
        margin: 12px 0;
        line-height: 1.6;
    }

    /* Modern badge status container */
    .print-status-box {
        display: block !important;
        border: 2px solid #0d9488;
        border-radius: 6px;
        width: 140px;
        padding: 6px 0;
        text-align: center;
        font-size: 14pt !important;
        font-weight: 800;
        margin: 15px auto;
        letter-spacing: 2px;
        background-color: #ffffff !important;
        color: #0d9488;
    }

    p.cert-note {
        font-size: 9.5pt !important;
        font-style: italic;
        text-indent: 0;
        margin-top: 15px;
        line-height: 1.4;
        color: #6b7280 !important;
    }

    /* 6. Signature Block - Perfect Fill */
    .cert-footer {
        display: flex !important;
        justify-content: space-between;
        align-items: flex-end;
        margin-top: 25px;
        width: 100%;
    }

    .signature-box {
        display: block !important;
        width: 250px;
        text-align: left;
    }

    .signature-box p {
        font-size: 9.5pt !important;
        color: #374151 !important;
        margin: 0 0 2px 0;
    }

    .signature-space {
        display: block !important;
        height: 50px;
    }

    .sig-img {
        display: block !important;
        height: 50px;
        width: auto;
        object-fit: contain;
        margin: 4px 0;
    }

    .signature-box strong {
        font-weight: 700;
        color: #1f2937;
    }

    /* 7. Transcript Grades Table - Clean Minimal Style Perfect Fill */
    .table-print-meta.short {
        width: 100%;
        margin: 10px 0 15px 0;
        border: none !important;
        background: transparent !important;
    }

    .table-print-meta.short td {
        padding: 4px 0;
        border: none !important;
    }

    .table-print-grades {
        display: table !important;
        width: 100%;
        border-collapse: collapse;
        margin-top: 12px;
    }

    .table-print-grades tr {
        display: table-row !important;
    }

    .table-print-grades th, 
    .table-print-grades td {
        display: table-cell !important;
        border: none !important;
        border-bottom: 1px solid #f3f4f6 !important;
        padding: 5.5px 8px;
        font-size: 8.5pt;
        color: #374151;
    }

    .table-print-grades th {
        font-weight: 700;
        background-color: #0d9488 !important;
        color: #ffffff !important;
        text-align: center;
        text-transform: uppercase;
        font-size: 8.5pt;
        letter-spacing: 0.5px;
        border-bottom: none !important;
    }

    .table-print-grades th:first-child {
        border-top-left-radius: 6px;
        border-bottom-left-radius: 6px;
    }

    .table-print-grades th:last-child {
        border-top-right-radius: 6px;
        border-bottom-right-radius: 6px;
    }

    .table-print-grades td[align="center"] {
        text-align: center !important;
    }

    .table-print-grades td.font-bold {
        font-weight: bold;
    }

    /* Category striping */
    .table-print-grades tr[style*="background-color: #f0f0f0"] td,
    .table-print-grades .category-row td {
        font-weight: 800;
        background-color: #f3f4f6 !important;
        color: #1f2937 !important;
        font-size: 8.5pt;
        text-transform: uppercase;
        letter-spacing: 0.5px;
    }

    .row-print-average {
        display: table-row !important;
        background-color: #f0fdfa !important;
    }

    .row-print-average td {
        font-weight: 800;
        font-size: 9.5pt;
        color: #0d9488 !important;
        border-top: 1.5px solid #0d9488 !important;
        border-bottom: 1.5px solid #0d9488 !important;
    }
}
