﻿/* =============================== Semaca.Go.ro — app.css (clean) Tema “newspaper” light + dark auto =============================== */ /* ---- Design tokens (light implicit) ---- */

:root { /* Paletă / suprafețe */
    --page-bg: #f6f7f9; /* gri foarte deschis (fundal pagină) */
    --paper: #fffdfa; /* alb-gălbui (carduri/articole) */
    --card-bd: #e5e7eb; /* Text & accente */
    --ink: #111; /* text principal */
    --muted: #6b7280; /* subtitluri/texte slabe */
    --link: #0b63c9;
    --link-visited: #6a2dcf; /* Brand & focus */
    --brand: #1b6ec2;
    --brand-dark: #1861ac;
    --focus-ring: #258cfb;
}
/* ---- Dark mode (respectă setarea sistemului) ---- */

@media (prefers-color-scheme: dark) {
    :root {
        --page-bg: #0f172a;
        --paper: #111827;
        --card-bd: #243045;
        --ink: #e5e7eb;
        --muted: #94a3b8;
        --link: #7cc2ff;
        --link-visited: #b7a6ff;
        --brand: #2a8af4;
        --brand-dark: #1f6fc5;
        --focus-ring: #5aa9ff;
    }
}
/* ---- Bază ---- */

html, body {
    background: var(--page-bg);
    color: var(--ink);
    font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
    color-scheme: light dark; /* lasă browserul să-și ajusteze input-urile */
}

h1:focus {
    outline: none;
}

a, .btn-link {
    color: var(--link);
    text-decoration: none;
}

    a:hover, a:focus {
        text-decoration: underline;
    }

    a:visited {
        color: var(--link-visited);
    }
/* ---- Butoane ---- */

.btn-primary {
    color: #fff;
    background-color: var(--brand);
    border-color: var(--brand-dark);
}
/* Focus ring accesibil pe toate controalele */

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus, .form-select:focus {
    box-shadow: 0 0 0 0.1rem #fff, 0 0 0 0.25rem var(--focus-ring);
    outline: none;
}
/* ---- Layout mic ---- */

.content {
    padding-top: 1.1rem;
}
/* ---- Validare ---- */

.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid #e50000;
}

.validation-message {
    color: #e50000;
}
/* ---- Eroare Blazor ---- */

.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: #fff;
}

    .blazor-error-boundary::after {
        content: "An error has occurred.";
    }
/* ---- Diverse mici ---- */

.darker-border-checkbox.form-check-input {
    border-color: #929292;
}

.muted, .text-muted {
    color: var(--muted) !important;
}
/* ---- Carduri / listă articole ---- */

.card {
    background: var(--paper);
    border: 1px solid var(--card-bd);
}

    .card .card-title a {
        color: var(--link);
    }
/* imagine în card-uri de presă */

.press-card .card-img-top, .article-img {
    width: 100%;
    height: 190px;
    object-fit: cover;
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
}
/* titluri compacte pe mobil */

@media (max-width: 576px) {
    .press-card h2 {
        font-size: 1rem;
    }
}
/* ---- Sidebar (MainLayout standard Blazor) ---- */

.sidebar {
    background: linear-gradient(180deg, #f3f4f6, #eaeef3);
    border-right: 1px solid var(--card-bd);
}

    .sidebar .top-row {
        background: transparent;
        border-bottom: 1px solid var(--card-bd);
    }
/* ---- Inputuri / select-uri ---- */

.form-control, .form-select {
    background: #fff;
    border-color: #d1d5db;
}

@media (prefers-color-scheme: dark) {
    .form-control, .form-select {
        background: #0b1320;
        color: var(--ink);
        border-color: #253047;
    }
}
/* ==== NAVBAR — Newspaper look, light/dark, fără schimbări în HTML ==== */ /* variabile dedicate navbar-ului */

:root {
    --nav-bg: #ffffff;
    --nav-ink: #1f2937; /* text */
    --nav-muted: #6b7280;
    --nav-border: #e5e7eb;
    --nav-hover: #0b63c9; /* accent pe hover/active */
}

@media (prefers-color-scheme: dark) {
    :root {
        --nav-bg: #0f172a;
        --nav-ink: #e5e7eb;
        --nav-muted: #94a3b8;
        --nav-border: #1f2937;
        --nav-hover: #7cc2ff;
    }
}
/* prinde orice combinație obișnuită din template (bg-dark, navbar-dark etc.) */

header .navbar, .top-row.navbar, .navbar.navbar-dark, .navbar.bg-dark {
    background: var(--nav-bg) !important;
    color: var(--nav-ink) !important;
    border-bottom: 1px solid var(--nav-border);
    box-shadow: 0 6px 12px rgba(16,24,40,.04);
}
/* brand (stânga) */

.navbar .navbar-brand {
    color: var(--nav-ink) !important;
    font-weight: 800;
    letter-spacing: .2px;
    display: inline-flex;
    align-items: center;
    gap: .4rem;
}

    .navbar .navbar-brand:hover, .navbar .navbar-brand:focus {
        color: var(--nav-hover) !important;
        text-decoration: none;
    }
/* link-uri din meniu */

.navbar .nav-link {
    color: var(--nav-ink) !important;
    opacity: .9;
    padding: .45rem .7rem;
    border-radius: .5rem;
    transition: background-color .15s ease, color .15s ease, opacity .15s;
}

    .navbar .nav-link:hover, .navbar .nav-link:focus {
        color: var(--nav-hover) !important;
        background: color-mix(in srgb, var(--nav-hover) 12%, transparent);
        text-decoration: none;
        opacity: 1;
    }

    .navbar .nav-link.active, .navbar .nav-link[aria-current="page"] {
        color: var(--nav-hover) !important;
        background: color-mix(in srgb, var(--nav-hover) 18%, transparent);
        font-weight: 600;
    }
/* butoanele din dreapta (ex. LoginDisplay) arată la fel ca link-urile */

.navbar .btn, .navbar .btn-outline-light, .navbar .btn-outline-primary {
    --btn-bg: transparent;
    --btn-bd: transparent;
    --btn-fg: var(--nav-ink);
    color: var(--btn-fg);
    background: var(--btn-bg);
    border-color: var(--btn-bd);
    border-radius: .6rem;
    padding: .45rem .7rem;
}

    .navbar .btn:hover, .navbar .btn:focus {
        color: var(--nav-hover);
        background: color-mix(in srgb, var(--nav-hover) 12%, transparent);
        border-color: color-mix(in srgb, var(--nav-hover) 20%, transparent);
        text-decoration: none;
    }
/* dropdown în navbar – hârtie, nu “gri bootstrap” */

.navbar .dropdown-menu {
    background: var(--paper);
    color: var(--ink);
    border: 1px solid var(--card-bd);
    box-shadow: 0 12px 24px rgba(16,24,40,.08);
    border-radius: .6rem;
    overflow: hidden;
}

.navbar .dropdown-item {
    color: var(--ink);
    padding: .5rem .9rem;
}

    .navbar .dropdown-item:hover, .navbar .dropdown-item:focus, .navbar .dropdown-item.active {
        color: var(--nav-hover);
        background: color-mix(in srgb, var(--nav-hover) 12%, transparent);
    }
/* toggler mobil – vizibil pe ambele teme */

.navbar .navbar-toggler {
    border: 1px solid var(--nav-border);
    border-radius: .6rem;
    padding: .35rem .5rem;
}

    .navbar .navbar-toggler:focus {
        box-shadow: 0 0 0 .25rem color-mix(in srgb, var(--nav-hover) 35%, transparent);
    }
/* folosește iconița default, dar asigură contrastul */

.navbar .navbar-toggler-icon {
    filter: invert(0); /* light */
}

@media (prefers-color-scheme: dark) {
    .navbar .navbar-toggler-icon {
        filter: invert(1);
    }
    /* dark */
}
/* micro-aliniere pentru zona superioară din template-ul Blazor */

.top-row {
    border-bottom: 1px solid var(--nav-border);
    background: var(--nav-bg);
}
    /* NAVBAR – seamless cu pagina (fără linie vizibilă) */

    header .navbar, .top-row.navbar, .navbar.navbar-dark, .navbar.bg-dark {
        background: var(--page-bg) !important; /* aceeași culoare ca pagina */
        border-bottom: 0 !important; /* elimină linia */
        box-shadow: 0 6px 12px rgba(16, 24, 40, .05); /* separare subtilă */
    }
/* Dark mode – aceeași idee */

@media (prefers-color-scheme: dark) {
    header .navbar, .top-row.navbar, .navbar.navbar-dark, .navbar.bg-dark {
        background: var(--page-bg) !important;
        border-bottom: 0 !important;
        box-shadow: 0 8px 18px rgba(0, 0, 0, .35);
    }
}
/* —— Page palette —— */

:root {
    --page-bg: #f6f7f9; /* gri foarte deschis */
    --paper: #fffdfa; /* alb-gălbui pal */
    --ink: #111; /* text */
    --muted: #6b7280; /* subtitluri */
    --brand: #0b63c9; /* linkuri */
}
/* corp & carduri */

html, body {
    background: var(--page-bg);
    color: var(--ink);
}

.card {
    background: var(--paper);
    border-color: #e5e7eb;
}
/* linkuri și nav */

a {
    color: var(--brand);
}

.nav-link {
    color: inherit;
}

    .nav-link.active {
        font-weight: 600;
    }
    /* hover simplu, fără color-mix */

    .nav-link:hover, .nav-link:focus {
        background: rgba(0,0,0,.06);
    }

@media (prefers-color-scheme: dark) {
    .nav-link:hover, .nav-link:focus {
        background: rgba(255,255,255,.08);
    }
}
/* DARK */

@media (prefers-color-scheme: dark) {
    :root {
        --page-bg: #0f172a; /* slate-900 */
        --paper: #0b1320; /* foarte închis, dar diferit de bg */
        --ink: #e5e7eb;
        --muted: #94a3b8;
        --brand: #8ab4ff; /* linkuri în dark */
    }

    .card {
        border-color: #243045;
    }

    a {
        color: var(--brand);
    }
}
/* Burger vizibil in ambele teme, fara filtre care-l fac invizibil */
.navbar .navbar-toggler {
    border: 1px solid rgba(0,0,0,.15);
    border-radius: .5rem;
    padding: .35rem .5rem;
}

@media (prefers-color-scheme: dark) {
    .navbar .navbar-toggler {
        border-color: rgba(255,255,255,.25);
    }
}

/* Forțăm iconița (3 liniuțe) cu contrast bun */
.navbar .navbar-toggler-icon {
    background-image: none;
    position: relative;
    width: 1.5rem;
    height: 1.5rem;
}

    .navbar .navbar-toggler-icon::before,
    .navbar .navbar-toggler-icon::after,
    .navbar .navbar-toggler-icon span {
        content: "";
        display: block;
        height: 2px;
        border-radius: 1px;
        margin: 5px 0;
        background: rgba(17,24,39,.9); /* aproape negru, bun pe light */
    }

@media (prefers-color-scheme: dark) {
    .navbar .navbar-toggler-icon::before,
    .navbar .navbar-toggler-icon::after,
    .navbar .navbar-toggler-icon span {
        background: rgba(229,231,235,.95); /* aproape alb, bun pe dark */
    }
}
/* Necesita un span in interior - Bootstrap il pune oricum */
.navbar .navbar-toggler .navbar-toggler-icon span {
    display: block;
}
.hero {
    background: var(--paper);
    border: 1px solid var(--card-bd);
    border-radius: 16px;
}

.hero-card {
    background: rgba(0,0,0,.02);
    border: 1px solid var(--card-bd);
    border-radius: 12px;
}

.article-thumb {
    width: 92px;
    height: 69px;
    object-fit: cover;
    flex: 0 0 auto;
    border: 1px solid var(--card-bd);
}

.article-link:hover {
    text-decoration: underline;
}
/* Mini weather */
.weather-mini .temp {
    font-size: 1.4rem;
    line-height: 1;
}

.weather-mini .card-footer {
    border-top: 1px solid var(--card-bd);
}

.article-img {
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    max-height: 320px;
}