/* recipe_print.css - Styles d'impression pour les recettes */

@media print {
    /* === RESET ET PAGE A4 === */
    @page {
        size: A4 portrait;
        margin: 10mm;
    }

    * {
        -webkit-print-color-adjust: exact !important;
        print-color-adjust: exact !important;
        color-adjust: exact !important;
    }

    html, body {
        width: 210mm;
        height: 297mm;
        margin: 0;
        padding: 0;
        font-family: var(--font-family-sans);
        font-size: 10pt;
        line-height: var(--line-height-normal);
        color: var(--gray-800);
        background: var(--white) !important;
    }

    /* === MASQUER LES ÉLÉMENTS NON IMPRIMABLES === */
    .main-nav,
    .main-footer,
    .nav-buttons,
    .mobile-menu,
    .mobile-menu-btn,
    .user-menu,
    .user-dropdown,
    .messages,
    .modal,
    .timer-btn,
    .step-timer,
    .step-help-wrapper,
    .recipe-back-button,
    .fab-button,
    .fab-menu,
    .fab-overlay,
    .back-btn,
    .btn,
    button {
        display: none !important;
    }

    /* === CONTAINER PRINCIPAL === */
    .container {
        width: 100%;
        max-width: none;
        padding: 0;
        margin: 0;
    }

    main {
        padding: 0;
        margin: 0;
    }

    /* === LAYOUT 1/3 + 2/3 === */
    .recipe-header {
        display: block;
        margin-bottom: var(--spacing-md);
    }

    /* Grille principale pour le contenu */
    .container {
        display: grid;
        grid-template-columns: 1fr 2fr;
        grid-template-rows: auto auto auto 1fr;
        gap: var(--spacing-sm) var(--spacing-md);
        grid-template-areas:
            "image steps"
            "title steps"
            "ingredients steps"
            "nutrition steps";
        align-items: start;
    }

    /* === COLONNE GAUCHE (1/3) === */

    /* Image de la recette */
    .recipe-header .recipe-image {
        grid-area: image;
        width: 61mm;
        height: 61mm;
        left: 0mm;
        margin: 0mm 0mm 10mm 0mm;
        padding: 3mm;
        background: var(--white);
        border: 2px solid var(--gray-200);
        box-shadow: 4px 4px 12px rgba(0, 0, 0, 0.15);
        transform: rotate(-5deg);
        transform-origin: top right;
        overflow: hidden;
    }

    .recipe-header .recipe-image img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        display: block;
    }

    .recipe-image-placeholder {
        width: 100%;
        height: 100%;
        display: flex;
        align-items: center;
        justify-content: center;
        background: var(--gray-100);
        color: var(--gray-400);
    }

    .recipe-image-placeholder i {
        font-size: 24pt;
    }

    /* Titre et infos */
    .recipe-header .recipe-info {
        grid-area: title;
        text-align: left;
        padding: 0 var(--spacing-sm) 0 0;
    }

    .recipe-title {
        font-size: 14pt;
        font-weight: var(--font-weight-bold);
        color: var(--gray-800);
        margin: 0 0 var(--spacing-xs) 0;
        line-height: var(--line-height-tight);
    }

    .recipe-description {
        font-size: 8pt;
        color: var(--gray-600);
        margin: 0 0 var(--spacing-xs) 0;
        font-style: italic;
        text-align: justify;
    }

    /* Métadonnées */
    .recipe-meta {
        display: flex;
        flex-wrap: wrap;
        justify-content: flex-start;
        gap: var(--spacing-xs);
        font-size: 7pt;
        color: var(--gray-600);
    }

    .meta-item {
        display: inline-flex;
        align-items: center;
        gap: 2px;
    }

    .meta-item i {
        color: var(--gray-500);
        font-size: 6pt;
    }

    .meta-value {
        font-weight: var(--font-weight-semibold);
        color: var(--gray-700);
    }

    /* === SECTION NUTRITION === */
    .nutrition-section {
        grid-area: nutrition;
        background: var(--gray-50) !important;
        border: 1px solid var(--gray-200);
        border-radius: var(--border-radius-md);
        padding: var(--spacing-sm);
        page-break-inside: avoid;
        margin-top:-2mm;
    }

    .nutrition-header {
        margin-bottom: var(--spacing-xs);
        display: flex;
        align-items: center;
        justify-content: space-between;
    }

    .nutrition-title {
        font-size: 9pt;
        font-weight: var(--font-weight-semibold);
        color: var(--gray-700);
        margin: 0;
        display: flex;
        align-items: center;
        gap: var(--spacing-xs);
    }

    .nutrition-title i {
        font-size: 8pt;
        color: var(--gray-500);
    }

    /* Afficher le nutriscore en print */
    .nutriscore-badge {
        display: inline-flex !important;
        align-items: center;
        justify-content: center;
        width: 56px;
        height: 56px;
        font-size: 20pt;
        font-weight: var(--font-weight-bold);
        border-radius: var(--border-radius-full);
        color: var(--white);
        background: var(--gray-500);
        margin-bottom: 8pt;
    }

    .nutriscore-badge.nutriscore-a { background: #038141; }
    .nutriscore-badge.nutriscore-b { background: #85bb2f; }
    .nutriscore-badge.nutriscore-c { background: #fecb02; color: var(--gray-800); }
    .nutriscore-badge.nutriscore-d { background: #ee8100; }
    .nutriscore-badge.nutriscore-e { background: #e63e11; }

    .nutrition-grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: var(--spacing-xs);
    }

    .nutrition-item {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: 2px 4px;
        background: var(--white);
        border-radius: var(--border-radius-sm);
        font-size: 7pt;
    }

    .nutrition-label {
        color: var(--gray-600);
    }

    .nutrition-value {
        font-weight: var(--font-weight-semibold);
        color: var(--gray-800);
    }

    /* === SECTION INGRÉDIENTS (colonne gauche) === */
    .ingredients-section {
        grid-area: ingredients;
        border: 1px solid var(--gray-200);
        border-radius: var(--border-radius-md);
        padding: var(--spacing-sm);
        background: var(--white) !important;
        page-break-inside: avoid;
    }

    .ingredients-section .section-title {
        font-size: 10pt;
        font-weight: var(--font-weight-semibold);
        color: var(--gray-700);
        margin: 0 0 var(--spacing-xs) 0;
        padding-bottom: var(--spacing-xs);
        border-bottom: 1px solid var(--gray-300);
        display: flex;
        align-items: center;
        gap: var(--spacing-xs);
    }

    .ingredients-section .section-title i {
        color: var(--gray-500);
    }

    .ingredients-list {
        columns: 1;
        column-gap: var(--spacing-md);
    }

    .ingredient-item {
        display: flex;
        justify-content: space-between;
        align-items: baseline;
        padding: -2px 0 0px var(--spacing-xs);
        font-size: 8pt;
        break-inside: avoid;
        border-bottom: 1px dotted var(--gray-300);
        background-color: transparent;
        border-radius: 0px;
        border-left: 0px;
    }

    .ingredient-name {
        color: var(--gray-800);
        flex: 1;
    }

    .ingredient-quantity {
        font-weight: var(--font-weight-semibold);
        color: var(--gray-700);
        margin-left: var(--spacing-sm);
        white-space: nowrap;
    }

    .ingredient-splitter-wrapper {
        break-inside: avoid;
        column-span: all;
        margin-top: var(--spacing-xs);
    }

    .ingredient-splitter-title {
        font-size: 8pt;
        font-weight: var(--font-weight-semibold);
        color: var(--gray-600);
        margin: var(--spacing-xs) 0;
        padding: 2px 0 2px var(--spacing-xs);
        border-bottom: 1px solid var(--gray-300);
    }

    /* === SECTION ÉTAPES (colonne droite 2/3) === */
    .steps-section {
        grid-area: steps;
        padding: 0;
        background: linear-gradient(to bottom, var(--gray-100), --gray-50);
    }

    .steps-section .section-title {
        font-size: 12pt;
        font-weight: var(--font-weight-bold);
        color: var(--gray-800);
        margin: 0 0 var(--spacing-sm) 0;
        padding-bottom: var(--spacing-xs);
        border-bottom: 1px solid var(--gray-300);
    }

    .steps-section .section-title i {
        display: none;
    }

    .step {
        page-break-inside: avoid;
        margin-bottom: var(--spacing-sm);
        padding: var(--spacing-xs) var(--spacing-sm);
        border: 1px solid var(--gray-200);
        border-radius: var(--border-radius-sm);
        background: transparent;
    }

    .step-header {
        font-size: 9pt;
        font-weight: var(--font-weight-bold);
        color: var(--gray-700);
        margin-bottom: var(--spacing-xs);
        background: none !important;
        padding: 0;
    }

    .step-header span {
        background: none !important;
        color: var(--gray-700) !important;
        font-weight: var(--font-weight-bold) !important;
        padding: 0 !important;
    }

    .step-content {
        display: flex;
        gap: var(--spacing-sm);
        align-items: flex-start;
    }

    .step-image {
        width: 30mm;
        height: 30mm;
        flex-shrink: 0;
        border-radius: var(--border-radius-sm);
        overflow: hidden;
        border: 1px solid var(--gray-200);
    }

    .step-image img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    .step-text {
        flex: 1;
        font-size: 8pt;
        color: var(--gray-700);
        line-height: var(--line-height-relaxed);
        text-align: justify;
    }

    .step-text p {
        margin: 0 0 var(--spacing-xs) 0;
        text-align: justify;
    }

    .step-repeat-box {
        display: inline-block;
        font-size: 7pt;
        color: var(--gray-600);
        background: var(--gray-100);
        padding: 2px 6px;
        border-radius: var(--border-radius-sm);
        margin-top: var(--spacing-xs);
    }

    .step-empty {
        color: var(--gray-500);
        font-style: italic;
    }

    .empty-message {
        color: var(--gray-500);
        font-style: italic;
        font-size: 8pt;
    }

    /* === LIENS === */
    a {
        color: inherit;
        text-decoration: none;
    }

    /* === ÉVITER LES COUPURES DE PAGE === */
    h1, h2, h3 {
        page-break-after: avoid;
    }

    .nutrition-section,
    .ingredients-section,
    .step {
        page-break-inside: avoid;
    }
}
