/* Import Satoshi font - using CDN or local files */
@import url('satoshi.css');

/* CSS Variables from old version */
:root {
    --primary: #00003b;
    --secondary: #a8c3f5;
    --success: #c5e4e3;
    --info: #4e69ea;
    --warning: #ff9699;
    --danger: #CA3337;
    --light: #e8eefc;
    --mid: #dcdefe;
    --dark: #00003b;
    --blue: #4e69ea;
    --lightBlue: #a8c3f5;
    --Status-Red: #CA3337; 
    --Status-Green: #1FB74C;
    --white: #ffffff;

    /* Shared semantic tokens */
    --text-primary: var(--dark);
    --text-secondary: var(--blue);
    --surface: var(--white);
    --surface-muted: var(--mid);
    --border-soft: var(--mid);
    --state-overdue-bg: #ffeaeb;
    --state-overdue-text: var(--danger);
    --state-near-bg: #fff3e4;
    --state-near-text: #b15d00;
    --state-ok-bg: var(--success);
    --state-ok-text: var(--dark);
}

html, body {
    font-family: 'Satoshi', 'Helvetica Neue', Helvetica, Arial, sans-serif;
    width: 100%;
    background-color: var(--light);
    color: var(--dark);
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
    overflow-y: auto;
    font-size: 1rem;
}

a {
    color: var(--blue);
}

/* Keep Mud palette variables aligned with app-level tokens in CSS contexts */
:root {
    --mud-palette-primary: var(--primary);
    --mud-palette-secondary: var(--secondary);
    --mud-palette-info: var(--info);
    --mud-palette-success: var(--Status-Green);
    --mud-palette-warning: var(--warning);
    --mud-palette-error: var(--danger);
    --mud-palette-dark: var(--dark);
    --mud-palette-surface: var(--surface);
    --mud-palette-background: var(--light);
    --mud-palette-background-grey: var(--mid);
    --mud-palette-text-primary: var(--text-primary);
    --mud-palette-text-secondary: var(--text-secondary);
    --mud-palette-divider: var(--border-soft);
}

/* Sidomenyn: länkar ska alltid vara vita, aldrig blå/understrukna */
.sidebar a,
.sidebar a:hover,
.sidebar a:focus,
.sidebar a:visited,
.sidebar a.active {
    color: #FFF !important;
    text-decoration: none !important;
}

/* Sidomenyn hover/aktiv – i global CSS så att :hover inte bryts av Blazor scoped CSS */
.sidebar .sidenav a.nav-row:hover {
    background-color: rgba(255, 255, 255, 0.2) !important;
}
.sidebar .sidenav a.nav-row.active {
    background-color: rgba(255, 255, 255, 0.28) !important;
}

/* Preloader visas direkt vid klick via JS (body-klass) innan Blazor hinner rendera */
body.nav-loading-active .nav-loading-overlay {
    display: flex !important;
}

/* Button/form styles removed - using MudBlazor components */

.content {
    padding-top: 1.1rem;
}

h1:focus {
    outline: none;
}

.h1, h1 {
    font-family: 'Satoshi', sans-serif;
    font-weight: 700;
    font-size: 2.0rem;
}

.h2, h2 {
    font-size: 1.5rem;
}

.h3, h3 {
    margin: 70px 0 25px 0;
    font-family: 'Satoshi', sans-serif;
    font-weight: 900;
    font-size: 1.3rem;
}

.h4, h4 {
    font-size: 0.9rem;
}

.h5, h5 {
    font-size: 1.1rem;
}

.h6, h6 {
    font-size: 1rem;
    font-family: 'Satoshi', sans-serif;
    font-weight: 700;
}

/* Shared page header primitives */
.section-title,
.ux-section-title {
    font-size: 1.4rem;
    font-weight: 700;
    margin: 0 0 .25rem;
    color: var(--text-primary);
}

.section-subtitle,
.ux-section-subtitle {
    margin: 0;
    color: var(--text-secondary);
}

.ux-helper-text {
    font-size: 0.82rem;
    color: var(--text-secondary);
}

.ux-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    border-radius: 999px;
    border: 1px solid var(--border-soft);
    background: var(--surface-muted);
    color: var(--text-primary);
}

/* Input styles removed - using MudBlazor components */

.bg-info {
    background-color: var(--blue) !important;
}

.bg-blue {
    background-color: var(--blue) !important;
}

.bg-lightBlue {
    background-color: var(--lightBlue) !important;
}

.valid.modified:not([type=checkbox]) {
    outline: 1px solid var(--Status-Green);
}

.invalid {
    outline: 1px solid var(--danger);
}

.validation-message {
    color: var(--danger);
}

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

.blazor-error-boundary::after {
    content: "An error has occurred."
}

.darker-border-checkbox.form-check-input {
    border-color: #929292;
}


/* Table styling */
.table-hover tbody tr:hover {
    background-color: rgba(220, 222, 254, 0.4);
}

/* Card styling */
.card-block {
    background-color: var(--white);
    border-radius: 3px;
    box-shadow: 1px 1px 10px rgba(220, 222, 254, 0.3);
}

/* Badge colors */
.badge.bg-info {
    background-color: var(--blue) !important;
}

.badge.bg-success {
    background-color: var(--Status-Green) !important;
}

.badge.bg-danger {
    background-color: var(--danger) !important;
}

.badge.bg-warning {
    background-color: var(--warning) !important;
}

/* Login page (from old project) */
.login-main {
    position: fixed;
    left: 0;
    top: 0;
    height: 100%;
    width: 100%;
    background-color: var(--light);
}

.login-logo {
    position: absolute;
    top: 0;
    left: 10px;
    z-index: 2000;
}

.login-logo img {
    margin-top: 15px;
    height: 27px;
    padding-left: 40px;
    margin-bottom: 40px;
}

.login-background-pattern {
    position: fixed;
    width: 100%;
    height: 100%;
    background-color: #F7F8FD;
    top: 0;
    left: 0;
}

.pattern-cls-1 {
    fill: rgba(168, 195, 245, 0.5);
}

.pattern-cls-2 {
    fill: rgba(220, 222, 254, 0.75);
}

.login-background-pattern #pattern-1 {
    width: 77%;
    float: right;
    position: relative;
    top: 0;
}

.login-background-pattern #pattern-2 {
    width: 77%;
    position: absolute;
    bottom: 0;
    left: 0;
}

div.card-block-padding.login-container {
    position: relative;
    width: 30%;
    min-width: 350px;
    height: auto;
    min-height: 430px;
    padding: 25px;
    padding-bottom: 25px !important;
    display: block;
    top: 50%;
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    margin: auto;
    background-color: var(--white);
    border-radius: 3px;
    box-shadow: 1px 1px 10px rgba(220, 222, 254, 0.3);
}

.login-container h1 {
    padding: 20px 0 10px 0;
    text-align: center;
}

.login-container h4 {
    text-align: center;
    margin-bottom: 50px;
    font-weight: 400;
}

.login-container input {
    border: none;
    border-bottom: solid 2px var(--light);
    box-shadow: none;
}

.login-container button {
    color: white;
    font-size: 0.7rem;
    height: 35px;
    margin: 0;
    width: 100%;
    display: block;
    text-align: center;
    line-height: 35px;
    padding: 0 12px;
    border-radius: 2px;
    border: none;
    border-bottom: solid 2px var(--light);
    box-shadow: none;
    background-color: var(--blue);
}

.login-container form {
    display: block;
    width: 100%;
}

.login-container .form-control {
    display: block;
    width: 100%;
    height: 25px;
    margin-bottom: 3px;
    border-radius: 3px;
    font-size: 0.8rem;
    background-color: transparent;
}

.login-container .form-group {
    height: 40px;
    margin-bottom: 1rem;
    position: relative;
}

.login-container .form-group p {
    margin: 0;
}

.login-container .login-form-group--auto {
    height: auto;
}

.login-container .login-back-row {
    margin-top: -16px;
    margin-bottom: 14px;
}

.login-container .login-back-link {
    background: none;
    color: var(--blue);
    border: none;
    box-shadow: none;
    width: auto;
    height: auto;
    line-height: normal;
    padding: 0;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.75rem;
    font-weight: 500;
}

.login-container .login-back-link:hover:not(:disabled) {
    text-decoration: underline;
}

.login-container .google-signin-btn {
    background-color: #fff;
    color: #1f1f1f;
    border: 1px solid #d8d8d8;
    border-bottom: 1px solid #d8d8d8;
    font-size: 0.9rem;
    font-weight: 500;
    height: 42px;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.7rem;
}

.login-container .google-signin-btn:hover:not(:disabled) {
    background-color: #f8f9fa;
}

.login-container .google-signin-btn:disabled {
    opacity: 0.75;
}

.login-container .google-signin-btn__icon {
    width: 20px;
    height: 20px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    color: inherit;
}

.login-container .form-group label {
    position: absolute;
    font-size: 1rem;
    padding-bottom: 20px;
    padding-top: 3px;
    padding-left: 5px;
}

.login-container .form-group .checkbox label {
    position: relative;
    font-size: 0.7rem;
}

.login-container .form-group .checkbox input {
    height: 10px;
    width: 10px;
}

.login-container .form-group input {
    width: 100%;
    padding-left: 35px;
}

.login-container .form-group input:focus {
    border: 0;
    border-bottom: solid 2px var(--light);
    box-shadow: none;
    outline: none;
}

.login-container .form-group:focus-within label {
    color: var(--blue);
}

.login-container .form-group input::placeholder {
    color: rgba(0, 0, 0, 0.5);
}

.login-container input[type=checkbox] {
    position: relative;
    cursor: pointer;
}

.login-container input[type=checkbox]:before {
    content: "";
    display: block;
    position: absolute;
    width: 11px;
    height: 11px;
    top: 0;
    left: 0;
    border: 2px solid var(--primary);
    border-radius: 3px;
    background-color: var(--white);
}

.login-container input[type=checkbox]:checked:before {
    border: 2px solid var(--secondary);
    border-radius: 3px;
    background-color: var(--secondary);
}

.login-container input[type=checkbox]:checked:after {
    content: "";
    display: block;
    width: 5px;
    height: 8px;
    border: solid var(--white);
    border-width: 0 2px 2px 0;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
    position: absolute;
    top: 1px;
    left: 3px;
}

.login-container .checkbox {
    margin-top: 20px;
    padding-left: 6px;
}

.login-container label.alido-checkbox {
    display: inline;
    margin-top: -6px;
    margin-left: 5px;
    position: relative;
}

.login-container #forgot-password {
    font-size: 0.85rem;
}

.login-error-message {
    margin-bottom: 14px;
    padding: 8px 10px;
    border-radius: 3px;
    border: 1px solid rgba(202, 51, 55, 0.35);
    background-color: rgba(202, 51, 55, 0.12);
    color: #7d1f22;
    font-size: 0.8rem;
    line-height: 1.3;
}

/* Bäst-i-kolumn-markering i statistiktabeller */
.bg_highlight td, td.bg_highlight {
    background-color: rgba(197, 228, 227, 0.55) !important;
    font-weight: 600;
}

/* TB-oversikt: compact table rows */
.tb-overview-table .mud-table-cell {
    padding: 10px;
}

.tb-overview-table .tb-dev-positive {
    color: #1b5e20;
    background-color: rgba(76, 175, 80, 0.14);
    font-weight: 600;
}

.tb-overview-table .tb-dev-negative {
    color: #b71c1c;
    background-color: rgba(244, 67, 54, 0.14);
    font-weight: 600;
}

/* MudBlazor: ta bort max-width-begränsningen på Large containers */
@media (min-width: 1280px) {
    .mud-container-maxwidth-lg {
        max-width: 100% !important;
    }
}

/* S-M-L-Y / R12: fem nivåer – higher, higher-minor, same, lower-minor, lower */
.r12-higher {
    font-weight: 600;
    background-color: var(--success);
    color: var(--dark);
}
.r12-higher-minor {
    background-color: rgba(197, 228, 227, 0.5);
    color: var(--dark);
}
.r12-same {
    background-color: var(--mid);
    color: var(--dark);
}
.r12-lower-minor {
    background-color: rgba(255, 150, 153, 0.4);
    color: var(--dark);
}
.r12-lower {
    background-color: var(--danger);
    color: #FFF;
}

/* Kundkort: projekt-tidslinje (global så att MudPaper får stylingen) */
.project-section-container {
    max-width: 54rem;
    min-width: 54rem;
}
.project-timeline-scroll-host {
    overflow-x: auto;
    overflow-y: hidden;
    width: 100%;
    min-width: 0;
    max-width: 100%;
    scroll-behavior: smooth;
    cursor: grab;
    user-select: none;
    -webkit-overflow-scrolling: touch;
}
@media (min-width: 960px) {
    .project-timeline-scroll-host {
        /* Keep a stable desktop viewport matching the 3-card reference layout */
        width: min(100%, 55.5rem);
    }
}
.project-timeline-scroll-host:active {
    cursor: grabbing;
}
.project-timeline-row {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 0.75rem;
    align-items: stretch;
    justify-content: flex-end;
    flex: 0 0 auto;
    width: max-content;
    min-width: 100%;
}
.project-timeline-card {
    width: 18rem !important;
    min-width: 18rem !important;
    max-width: 18rem !important;
    flex: 0 0 18rem !important;
    box-sizing: border-box;
    border-left: 4px solid var(--project-status-color, #6f7a94);
    border-radius: 8px;
    transition: box-shadow 0.15s ease-in-out, transform 0.15s ease-in-out;
}
.project-timeline-card:hover {
    box-shadow: 0 6px 14px rgba(0, 0, 0, 0.08);
    transform: translateY(-1px);
}