﻿html, body {
    font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
    min-width: 360px;
    overflow-x: auto;
    min-height: 100vh;
    color: black;
    background-color: #E1F5FE;
}

a, .btn-link {
    color: #006bb7;
}

.btn-primary {
    color: #E1F5FE;
    background-color: #1b6ec2;
    border-color: #1861ac;
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
    box-shadow: 0 0 0 0.1rem #E1F5FE, 0 0 0 0.25rem #258cfb;
}

.content {
    padding-top: 1.1rem;
}

h1:focus {
    outline: none;
}

/* Customized */
/* ========== */

.text-blurry {
    filter: blur(1px);
}

.card {
    border-width: 1px;
    border-color: #142b78;
}

.card-header.bg-primary {
    /* Vertikaler Verlauf von oben blau zu unten dunkelblau */
    background: linear-gradient(to bottom, #1976d2 0%, #142b78 100%);
}

.card-header.bg-secondary {
    /* Vertikaler Verlauf von oben grau zu unten dunkelgrau */
    background: linear-gradient(to bottom, #767676 0%, #2d2d2d 100%);
}

/* These required input field have a blue frame to guide the user*/
.field-required {
    border-width: 1.5px;
    border-color: #258cfb;
}


/* Modal */
.modal-header {
    padding-top: 8px;
    padding-bottom: 8px;
}

.modal-header.bg-primary {
    /* Vertikaler Verlauf von oben blau zu unten dunkelblau */
    background: linear-gradient(to bottom, #1976d2 0%, #142b78 100%);
}

/* Symbol Aussen bzw. Innen mit Erklärungstext */
.symbol-with-label {
    display: inline-block;
    position: relative;
    transform: translateY(6px);
    z-index: 10;
}

.symbol-label {
    display: none;
    position: absolute;
    background-color: #FFFFCC;
    color: #333;
    padding: 2px 8px;
    border: 1px solid #333;
    border-radius: 0.25rem;
    box-shadow: 2px 6px 8px rgba(128,128,128,0.5);
    font-size: .8rem;
    font-weight: 500;
    /*    white-space: nowrap;*/
    z-index: 10;
    text-align: center;
    transition: opacity .3s ease-in;
    pointer-events: none;
}

.symbol-label-left { transform: translate(-100%, -200%); }
.symbol-label-right { transform: translate(16px, -200%); }

.symbol-with-label:hover .symbol-label-left,
.symbol-with-label:focus .symbol-label-left,
.symbol-with-label:active .symbol-label-left,
.symbol-with-label:hover .symbol-label-right,
.symbol-with-label:focus .symbol-label-right,
.symbol-with-label:active .symbol-label-right {
    display: block;
}
@media (hover: none) and (pointer: coarse) {
    .symbol-with-label:active .symbol-label-left,
    .symbol-with-label:focus .symbol-label-left,
    .symbol-with-label:active .symbol-label-right,
    .symbol-with-label:focus .symbol-label-right {
        display: block;
    }
}

/* ------------------- MudBlazor ---------------- */

/* MudButton */

/* Nav-Menu */
.mud-navmenu {
    color: rgba(225, 245, 254, 0.9); /* Entspricht #E1F5FE; 80% opak*/
    display: flex;
    flex-direction: column;
    height: 100%;
}

/* Expand-icon in the Nav-Menu */
.mud-navmenu .mud-nav-link-expand-icon {
    background-color: #E1F5FE;
    opacity: 0.6;
}
/* MudSwitch */
.mud-switch-track .mud-inherit {
    background-color: #CCFFCC !important; /* Farbe für den Schiebebalken */
    opacity: 1.0 !important;
}

/* MudCarousel */
.mud-carousel .mud-icon-root.mud-svg-icon {
    fill: black;
    border: 1px solid black;
    border-radius: 11.98px;
    background: #CCFFCC;
}

.mud-width-full, #carousel-content, .mud-swipearea {
    transition: min-height 0.2s cubic-bezier(0.4,0,0.2,1); /* Fliessend bei Breitenänderung z.B. durch Browserfenster */
}

.mud-swipearea .mud-carousel-swipe,
.carousel-item-selected {
    height: 100vh;
}

@media (hover: none) and (pointer: coarse) {
    .mud-carousel mud-carousel-item-default, 
    .mud-carousel mud-carousel-item,
    .carousel-touch-scroll, .mud-swipearea {
        touch-action: pan-y !important;
        overscroll-behavior-y: contain;
    }
}


/* Indikator für das Laden von Daten aus dem SessionStorage 
    des Browsers (oder später evtl. aus DB)*/
.load-indicator-container {
    display: inline-block;
    margin-left: 0.5rem;
    vertical-align: middle;
}

.load-indicator {
    display: inline-block;
    width: 1em;
    height: 1em;
    border-radius: 50%;
    border: 2px solid transparent;
    vertical-align: middle;
}

    .load-indicator.loading {
        background: orange;
        animation: pulse 1s infinite alternate;
    }

    .load-indicator.success {
        background: #2ecc40;
    }

    .load-indicator.error {
        background: #ff4136;
        opacity: 0.5;
    }

@keyframes pulse {
    from {
        box-shadow: 0 0 0 0 orange;
    }

    to {
        box-shadow: 0 0 0 0.3em orange;
    }
}


/* Dropdown - projektweit */
.custom-dropdown-menu {
    max-height: 240px;
    overflow-y: auto;
    padding: 0;
    margin: 0;
    width: 100%;
}

.custom-dropdown-item-wrapper {
    margin: 0;
    padding: 0;
    list-style: none;
}

.dropdown-menu .dropdown-item.custom-dropdown-item {
    width: 100%;
    text-align: left;
    border: none;
    background-color: #f2f2f2; /* Standard-Hinterlegung */
    transition: background-color 120ms ease-in-out;
}

.dropdown-menu .dropdown-item.custom-dropdown-item:hover {
    background-color: lightgray; /* Hover-Hinterlegung */
}

.hover-notes-group {
    position: relative;
    display: block; /* lässt die Gruppe die volle Zeile einnehmen */
}

.hover-notes {
    position: absolute;
    left: 0;
    top: 100%;
    z-index: 1000;
    display: none;
    margin-top: 4px;
    padding: 1px 6px;
    width: 100%; /* gleiche Breite wie die umschließende Gruppe */
    box-sizing: border-box; /* Innenabstände einrechnen */
    max-width: none; /* keine separate Maximalbreite mehr */

    color: black;
    background-color: #FFFFCC;
    border: 1px solid #333;
    border-radius: .25rem;
    box-shadow: 2px 6px 8px rgba(128,128,128,0.5);
    font-size: .8rem;
    font-weight: 500;
    line-height: 1.25rem;
    opacity: 0;
    transition: opacity .3s ease-in;
}

.hover-notes-group:hover .hover-notes,
.hover-notes-group:focus-within .hover-notes {
    display: block;
    opacity: 1; /* Sichtbar bei Hover oder Fokus innerhalb der Gruppe */
}

.hover-notes.fixed-two-line {
    max-height: calc(2 * 1.25em + 2px); /* Feste Höhe aus 2 Zeilen + Border errechnet*/
    overflow: hidden;
}

/* MudDialogs */
.bg-blurry {
    backdrop-filter: blur(3px);
}

/* Ansicht der Glasabmessungen bei Geometrie-Eingabe */
.sketch-transition {
    transition: max-width 0.3s;
}


/* MudCharts für nichtlineare Konvergenz */

.nl-convergence-chart {
    text-align: center;
}

.nl-convergence-chart .mud-charts-yaxis text,
.nl-convergence-chart .mud-charts-xaxis text {
    font-size: 12px !important;
}

.nl-convergence-chart svg {
    overflow: visible;
    margin-top: -8px;
}
/* Erste path in gridlines-yaxis = unterste horizontale Linie (X-Achse),
           erste path in gridlines-xaxis-lines = linkeste vertikale Linie (Y-Achse). */
.nl-convergence-chart .mud-charts-gridlines-yaxis path:first-child,
.nl-convergence-chart .mud-charts-gridlines-xaxis-lines path:first-child {
    stroke: #333 !important;
    stroke-width: 0.75px !important;
}

.nl-convergence-chart .svg-tooltip {
    transform: scale(2.5);
    transform-box: fill-box;
    transform-origin: center;
}

/* Customized for MudBlazor carousel controls: */
@media (max-width: 640.98px) {
    .custom-controls-row {
        flex-direction: column !important;
        align-items: stretch !important;
    }

    .custom-switches-group {
        flex-direction: column !important;
        align-items: center !important;
    }
}

.custom-controls-row > div {
    min-width: 200px;
    flex-basis: 0;
    flex-grow: 1;
    display: flex;
    justify-content: center;
    align-items: center;
}

/* Customized to print a PDF: */
@media print {
    @page {
        size: A4 portrait;
        margin: 1.0cm 1.0cm 1.2cm 1.5cm;
        font-size: 12px;

        @top-left-corner {
            content: "";
        }

        @top-center {
            content: "";
        }

        @bottom-left {
            padding-left: 0.4cm;
            font-size: 8px;
            content: "IsolierglasAnalyse.ch";
        }

        @bottom-center {
            align-content: center;
            font-size: 8px;
            content: "Gedruckt: " var(--print-date, "");
        }

        @bottom-right {
            padding-right: 0.0cm;
            content: "Seite " counter(page) " von " counter(pages);
        }
    }

    body * {
        visibility: hidden !important;
    }

    .mud-appbar {
        display: none;
    }

    .printarea, .printarea * {
        visibility: visible !important;
    }

    .printarea {
        position: static;
        width: 17.5cm !important;
        margin: 0;
        background-color: white;
    }

    /* Bootstrap .container hat beim Druck responsive max-width-Werte die zu schmal sind → überschreiben */
    .printarea.container,
    .printarea .container,
    .printarea .container-fluid,
    .printarea .container-sm,
    .printarea .container-md,
    .printarea .container-lg,
    .printarea .container-xl {
        max-width: 100% !important;
        width: 100% !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
        background: white;
        margin: 0;
    }

    /* Bootstrap-Grid beim Drucken erzwingen:
       Breakpoints greifen beim Druck nicht (Viewport ≠ Papierbreite).
       col-lg-* und col-md-* explizit auf ihre Spaltenbreiten setzen. */
    .printarea .col-lg-6  { flex: 0 0 50.00% !important; max-width: 50.00% !important; }
    .printarea .col-lg-5  { flex: 0 0 41.67% !important; max-width: 41.67% !important; }
    .printarea .col-lg-4  { flex: 0 0 33.33% !important; max-width: 33.33% !important; }
    .printarea .col-lg-3  { flex: 0 0 25.00% !important; max-width: 25.00% !important; }

    .printarea .col-md-6  { flex: 0 0 50.00% !important; max-width: 50.00% !important; }
    .printarea .col-md-5  { flex: 0 0 41.67% !important; max-width: 41.67% !important; }
    .printarea .col-md-4  { flex: 0 0 33.33% !important; max-width: 33.33% !important; }
    .printarea .col-md-3  { flex: 0 0 25.00% !important; max-width: 25.00% !important; }

    .hide-in-print, .hide-in-print * {
        display: none !important;
        visibility: hidden !important;
    }

    .card {
        break-inside: avoid;
        border-color: #929292;
    }

    .card-header, .bg-primary {
        color: black !important;
        background: lightgray !important;
    }

    img {
        max-height: 11.75cm !important;
        object-fit: contain;
    }
}



/* Editform inputs and validations: */
/* ================================ */

.darker-border-checkbox.form-check-input {
    border-color: #929292;
}

.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid #e50000;
}

.validation-message {
    color: #e50000;
}

.form-control::placeholder,
.mud-input input::placeholder,
.mud-input textarea::placeholder {
    font-size: 0.8em;
}

/* Side errors: */
/* Bootstrap 5: table-light auf thead-Zellen erzwingen */
.table > thead.table-light > tr > th,
.table > thead.table-light > tr > td {
    background-color: lightgray !important;
}

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDg2Ni4wMTgzIDI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

    .blazor-error-boundary::after {
        content: "An error has occurred."
    }



/* NLConvergenceChart: Achsenbeschriftung global (Blazor Scoped CSS erreicht SVG-Kindelemente nicht) */
.nl-convergence-chart .mud-charts-yaxis text,
.nl-convergence-chart .mud-charts-xaxis text {
    font-size: 24px !important;
}

