/* ===================================================
   modern.css — Modernizace frontendu TKSP/Pedologie
   Přepisuje zastaralé styly z main.css, top.css, menu.css.
   Stávající soubory zůstávají beze změny pro zachování
   kompatibility — tato vrstva je načtena jako poslední.
   =================================================== */

/* ── Proměnné ── */
:root {
    --color-primary:      #7a5238;
    --color-primary-dark: #5a3a24;
    --color-primary-light:#a0714e;
    --color-sidebar:      #2e2318;
    --color-sidebar-item: #3b2e24;
    --color-sidebar-sub:  #231c14;
    --color-accent:       #c8ab8e;
    --color-bg:           #faf7f3;
    --color-bg-alt:       #f0e8de;
    --color-surface:      #ffffff;
    --color-border:       #d4c4b0;
    --color-border-light: #e8ddd0;
    --color-text:         #1e150e;
    --color-text-muted:   #6b5a4a;
    --color-link:         #7a5238;
    --color-link-hover:   #4a2e14;
    --font-body:          'Segoe UI', system-ui, -apple-system, sans-serif;
    --font-size-base:     15px;
    --line-height-base:   1.65;
    --sidebar-width:      220px;
    --header-height:      114px;
    --radius:             4px;
    --shadow-sm:          0 1px 3px rgba(0,0,0,.12);
    --shadow-md:          0 3px 8px rgba(0,0,0,.15);
}

/* ── Reset / base ── */
*, *::before, *::after {
    box-sizing: border-box;
}

html {
    text-align: left;
    scroll-behavior: smooth;
}

html, body {
    height: 100%;
    margin: 0;
    padding: 0;
}

body {
    display: flex;
    flex-direction: column;
    font-family: var(--font-body);
    font-size: var(--font-size-base);
    line-height: var(--line-height-base);
    color: var(--color-text);
    background-color: var(--color-bg);
    background-image: none;
}

/* ── Typografie ── */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-body);
    font-weight: 600;
    line-height: 1.3;
    color: var(--color-primary-dark);
    margin: 0 0 0.6em;
}

h4 {
    font-size: 1.2rem;
    padding: 14px 16px 10px;
    border-bottom: 2px solid var(--color-border);
    margin: 0 0 12px;
    background: linear-gradient(135deg, #f5ede3 0%, var(--color-surface) 100%);
}

h5 {
    font-size: 1rem;
    color: var(--color-accent);
    padding: 0 5px;
    margin: 16px 0 6px;
    text-align: right;
    font-weight: 600;
}

h6 {
    font-size: 0.9rem;
    font-weight: 600;
    margin: 8px 6px;
    color: var(--color-primary-dark);
}

p {
    margin: 0 0 0.8em;
    text-align: left;
}

a {
    color: var(--color-link);
    text-decoration: none;
    transition: color 0.15s;
}

a:hover {
    color: var(--color-link-hover);
    text-decoration: underline;
}

/* ── Grid hlavní struktury ── */
#complet {
    position: static;
    flex: 1;
    display: grid;
    grid-template-columns: var(--sidebar-width) 1fr;
    grid-template-rows: var(--header-height) 1fr;
    grid-template-areas:
        "header  header"
        "sidebar content";
    min-height: 100vh;
}

/* ── Header / Top panel ── */
#top {
    grid-area: header;
    position: relative;
    background-color: #1a100a !important;
    height: var(--header-height);
    border-bottom: 3px solid var(--color-primary);
}

#uzavr {
    position: static;
    display: flex;
    align-items: stretch;
    height: 100%;
    width: 100%;
}

#logo_left {
    position: static;
    flex-shrink: 0;
    width: 173px;
    height: 114px;
    float: none;
}

#logo_right {
    position: static;
    flex-shrink: 0;
    width: 296px;
    height: 114px;
    float: none;
}

#poznamka {
    position: static;
    flex: 1;
    display: flex;
    align-items: center;
    padding: 6px 14px 6px 8px;
    float: none;
    height: auto;
    width: auto;
    left: auto;
    top: auto;
}

#contextHelp {
    width: 100%;
    height: 96px;
    margin: 4px 0;
    border: 1px solid rgba(255,255,255,.15);
    border-radius: var(--radius);
    background: rgba(255,255,255,.04);
}

#shadow_cross,
#shadow02 {
    display: none;
}

/* ── Sidebar menu ── */
#menuDiv {
    grid-area: sidebar;
    position: static;
    top: auto;
    left: auto;
    height: 100%;
    display: flex;
    flex-direction: column;
    background-color: var(--color-sidebar);
    overflow-y: auto;
}

#menuDiv #odkazy {
    margin-top: auto;
}

/* ── Obsah / #text ── */
#text {
    grid-area: content;
    position: static;
    left: auto;
    top: auto;
    width: auto;
    min-width: 0;
    box-sizing: border-box;
    background-color: var(--color-surface);
    padding: 0;
}

/* ── Navigační panel (#navigace) ── */
#navigace {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    background: var(--color-bg-alt);
    border-bottom: 1px solid var(--color-border);
    font-size: 0.82rem;
    flex-wrap: wrap;
}

#navigace a {
    color: var(--color-text-muted);
    transition: color 0.15s;
}

#navigace a:hover {
    color: var(--color-link-hover);
    text-decoration: underline;
}

/* Ikony vpravo */
#navigace .nav-icons {
    margin-left: auto;
    display: flex;
    align-items: center;
    gap: 6px;
    flex-shrink: 0;
}

/* Ikony navigace */
#navigace img.ikona {
    opacity: 0.65;
    transition: opacity 0.15s;
    vertical-align: middle;
    margin-right: 2px;
}

#navigace img.ikona:hover {
    opacity: 1;
}

/* Breadcrumb šipka */
.breadcrumb-sep {
    color: var(--color-border);
    margin: 0 2px;
    font-size: 0.8rem;
}

/* ── Záložky (zalozky.tpl) — moderní tab bar ── */
.tabs-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 2px;
    padding: 8px 16px 0;
    border-bottom: 2px solid var(--color-border);
    background: var(--color-bg);
}

.tabs-bar a {
    display: inline-block;
    padding: 6px 14px;
    font-size: 0.82rem;
    font-weight: 600;
    text-decoration: none;
    border-radius: var(--radius) var(--radius) 0 0;
    border: 1px solid transparent;
    transition: background 0.15s, color 0.15s;
}

/* Aktivní záložka */
.tabs-bar a.tab-active {
    background: var(--color-surface);
    color: var(--color-primary-dark);
    border-color: var(--color-border);
    border-bottom-color: var(--color-surface);
    margin-bottom: -2px;
}

/* Neaktivní záložka */
.tabs-bar a.tab-inactive {
    background: var(--color-primary);
    color: #fff;
    border-color: var(--color-primary-dark);
}

.tabs-bar a.tab-inactive:hover {
    background: var(--color-primary-dark);
    text-decoration: none;
}

/* ── Iframe ── */
#podkapitola {
    padding: 0;
    margin: 0;
}

#frameKap {
    width: 100%;
    height: calc(100vh - 220px);
    min-height: 400px;
    border: none;
    display: block;
}

/* ── Hlavní menu ── */
ul#mainMenu,
ul#mainMenu li,
ul#mainMenu ul,
ul#mainMenu li li {
    width: var(--sidebar-width);
}

ul#mainMenu {
    background-color: transparent;
    margin: 0;
    padding: 0;
    list-style: none;
    font-family: var(--font-body);
}

ul#mainMenu,
ul#mainMenu ul {
    padding: 0;
    margin: 0;
    list-style-type: none;
}

/* Hlavní položky */
ul#mainMenu > li > a {
    background-color: var(--color-sidebar-item);
    background-image: none;
    color: #e8d5bf;
    border-top: 1px solid rgba(255,255,255,.07);
    border-bottom: none;
    padding: 10px 14px;
    font-size: 0.85rem;
    font-weight: 600;
    letter-spacing: 0.01em;
    display: block;
    text-decoration: none;
    transition: background 0.15s, color 0.15s;
}

ul#mainMenu > li > a:hover,
ul#mainMenu li:hover > a,
ul#mainMenu li.hover > a {
    background-color: var(--color-primary) !important;
    background-image: none !important;
    background-position: 0 0 !important;
    color: #ffffff !important;
    text-decoration: none;
}

/* Aktivní položka */
ul#mainMenu > li > a.activMenuItem,
ul#mainMenu > li > a.activMenuItem2 {
    background-color: var(--color-primary-dark) !important;
    background-image: none !important;
    background-position: 0 0 !important;
    color: #ffffff !important;
    border-left: 3px solid var(--color-accent);
    padding-left: 11px;
}

/* Submenu — vždy viditelné */
ul#mainMenu ul {
    position: static;
    left: auto;
    top: auto;
    visibility: visible;
    background-color: var(--color-sidebar-sub);
    z-index: auto;
}

ul#mainMenu li li {
    padding: 0;
    margin: 0;
}

ul#mainMenu li li a,
ul#mainMenu li:hover ul a,
ul#mainMenu li.hover ul a {
    background-color: var(--color-sidebar-sub);
    background-image: none;
    color: var(--color-accent);
    font-size: 0.8rem;
    font-weight: 400;
    padding: 8px 12px 8px 26px;
    border-top: 1px solid rgba(255,255,255,.04);
    border-right: none;
    display: block;
    text-decoration: none;
    transition: background 0.15s, color 0.15s;
}

ul#mainMenu li li a:hover,
ul#mainMenu li:hover ul a:hover,
ul#mainMenu li.hover ul a:hover {
    background-color: var(--color-primary) !important;
    color: #ffffff !important;
    text-decoration: none;
}

/* Dolní panel odkazů */
#odkazy {
    background-color: var(--color-sidebar);
    width: var(--sidebar-width);
    margin: 0;
    padding: 0 0 12px;
    text-align: center;
    border-top: 1px solid rgba(255,255,255,.1);
}

#polozky {
    margin: 0 8px;
    padding: 0;
    text-align: right;
}

.odkaz {
    display: block;
    margin: 0;
    padding: 4px 6px;
    line-height: 1.4;
    color: var(--color-accent);
    font-size: 0.75rem;
    font-weight: 400;
    text-align: right;
    text-decoration: none;
    transition: color 0.15s;
}

a.odkaz:hover {
    color: #fff;
}

.uvt {
    margin: 0;
    padding: 0;
    line-height: 1.4;
    color: var(--color-accent);
    font-size: 0.75rem;
    font-weight: 400;
    text-decoration: none;
    transition: color 0.15s;
}

a.uvt:hover {
    color: #fff;
}

#soil {
    display: none;
}

/* ── Tabulky ── */
table {
    border-collapse: collapse;
    width: 100%;
}

/* Obecná datová tabulka */
table#table-soupis,
table.data-table {
    border-collapse: collapse;
    width: auto;
    font-size: 0.82rem;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
}

table#table-soupis tr#thead td,
table#table-soupis thead td,
table#table-soupis thead th,
table.data-table thead th,
table.data-table thead td {
    background: var(--color-primary);
    color: #fff;
    font-weight: 600;
    padding: 9px 12px;
    text-align: left;
    white-space: nowrap;
    border: none;
}

table#table-soupis td,
table.data-table td {
    padding: 7px 12px;
    border: 1px solid var(--color-border-light);
    vertical-align: top;
    width: auto;
}

table#table-soupis tr:nth-child(even),
table.data-table tr:nth-child(even) {
    background-color: var(--color-bg-alt);
}

table#table-soupis tr:hover,
table.data-table tr:hover {
    background-color: #f0e0ce;
}

/* Vizuální oddělení skupin sloupců podle taxonomie (každá skupina = 2 sloupce) */

/* Záhlaví — bílá linka mezi skupinami */
table#table-soupis thead td + td {
    border-left: 2px solid rgba(255, 255, 255, 0.45) !important;
}

/* Tělo — výraznější linka na začátku každé skupiny (každý lichý sloupec kromě prvního) */
table#table-soupis tbody td:nth-child(odd):not(:first-child) {
    border-left: 2px solid var(--color-primary) !important;
}

/* Tabulka kategorií (#table-in) */
table#table-in {
    border-collapse: collapse;
    margin: 8px 16px;
    font-size: 0.88rem;
}

table#table-in td {
    padding: 5px 16px 5px 0;
    vertical-align: top;
    white-space: nowrap;
}

table#table-in td a {
    display: inline-block;
    padding: 4px 10px;
    border-radius: var(--radius);
    border: 1px solid var(--color-border-light);
    background: var(--color-bg-alt);
    font-size: 0.84rem;
    color: var(--color-link);
    transition: background 0.15s, border-color 0.15s;
}

table#table-in td a:hover {
    background: var(--color-primary);
    border-color: var(--color-primary);
    color: #fff;
    text-decoration: none;
}

/* ── Formuláře ── */
.pole,
input[type="text"].pole,
input[type="password"].pole {
    width: 200px;
    padding: 8px 10px;
    font-size: 0.9rem;
    font-family: var(--font-body);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    background: #fff;
    color: var(--color-text);
    outline: none;
    transition: border-color 0.2s, box-shadow 0.2s;
    -webkit-appearance: none;
}

.pole:focus,
input[type="text"].pole:focus,
input[type="password"].pole:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(122,82,56,.15);
}

input.odeslat,
input[type="submit"].odeslat {
    padding: 8px 24px;
    font-size: 0.9rem;
    font-weight: 600;
    font-family: var(--font-body);
    background: var(--color-primary);
    color: #fff;
    border: none;
    border-radius: var(--radius);
    cursor: pointer;
    transition: background 0.15s, box-shadow 0.15s;
    -webkit-appearance: none;
}

input.odeslat:hover,
input[type="submit"].odeslat:hover {
    background: var(--color-primary-dark);
    box-shadow: var(--shadow-sm);
}

/* Login / OTP info panel */
.info-panel {
    background: #fef3cd;
    border: 1px solid #e0c96e;
    border-radius: var(--radius);
    color: #5a4a10;
    padding: 10px 14px;
    margin: 12px 16px;
    font-size: 0.88rem;
}

/* Tabulka přihlašovacího formuláře */
table.login-table {
    border: none;
    background: transparent;
    width: auto;
    box-shadow: none;
}

table.login-table td {
    padding: 6px 8px;
    border: none;
    background: transparent;
    vertical-align: middle;
    font-size: 0.9rem;
}

table.login-table td:first-child {
    text-align: right;
    color: var(--color-text-muted);
    font-weight: 500;
    white-space: nowrap;
}

/* Přihlašovací wrapper */
.login-wrapper {
    padding: 20px 16px 16px;
}

/* ── Kontextový help link ── */
a.hrefContextHelp {
    font-style: italic;
    color: var(--color-primary-light);
    font-weight: 600;
    text-decoration: none;
}

a.hrefContextHelp:hover {
    color: var(--color-primary-dark);
    text-decoration: underline;
}

/* ── Obal pro velké tabulky ── */
#obal {
    margin: 8px 16px;
    overflow-x: auto;
    border-radius: var(--radius);
    box-shadow: var(--shadow-sm);
}

/* ── Kontakty ── */
table.contacts-table {
    border-collapse: collapse;
    width: 100%;
    max-width: 620px;
    margin: 12px 16px;
    font-size: 0.88rem;
    box-shadow: var(--shadow-sm);
    border-radius: var(--radius);
    overflow: hidden;
}

table.contacts-table thead tr {
    background: var(--color-primary);
    color: #fff;
}

table.contacts-table thead th {
    padding: 8px 16px;
    text-align: left;
    font-weight: 600;
    border: none;
}

table.contacts-table tbody tr:nth-child(even) {
    background: var(--color-bg-alt);
}

table.contacts-table tbody td {
    padding: 9px 16px;
    border-bottom: 1px solid var(--color-border-light);
}

/* ── Iframe obsahující šablony (pudniSubtypy, pudniTypy atd.) ── */
/* Styly pro stránky renderované UVNITŘ iframe */

/* ── Obsah #text — vnitřní padding pro texty ── */
#text > h4 + p,
#text > p:not([class]) {
    padding: 0 16px;
}

/* ── Kontaktní tabulka (přepis inline stylů) ── */
#text table[style*="max-width: 600px"],
#text table.contacts {
    border-collapse: collapse;
    width: 100%;
    max-width: 620px;
    margin: 12px 16px;
    font-size: 0.88rem;
    box-shadow: 0 1px 3px rgba(0,0,0,.12);
    border-radius: var(--radius);
    overflow: hidden;
}

/* ── Přepisy textarea.css zastaralých hodnot ── */

/* #text — přepis absolutního pozicování */
#text {
    position: static !important;
    left: auto !important;
    top: auto !important;
    width: auto !important;
    _width: auto !important;
    z-index: auto !important;
    padding: 0 !important;
    margin: 0 !important;
    text-align: left !important;
    box-sizing: border-box;
}

/* Obsah stránky — padding pro čitelnost */
#text > h4 {
    /* Již definováno výše */
}

#text > p,
#text .text-content {
    padding: 8px 16px;
    margin: 0 0 8px;
}

/* Přepis float ikonky — moderní flex v #navigace */
.ikona {
    float: none;
}

/* Přepis table background */
table {
    background-color: transparent;
}

/* #frameKap přepis border */
#frameKap {
    border: none !important;
    border-top: none !important;
}

/* Sitemap seznam */
.sitemap-list {
    list-style: none;
    padding: 0;
    margin: 0;
    font-size: 0.9rem;
}

.sitemap-list li {
    padding: 3px 0;
    line-height: 1.5;
    width: auto;
    margin: 0;
    display: block;
}

.sitemap-list li a {
    color: var(--color-link);
    font-weight: 500;
}

.sitemap-list li a:hover {
    color: var(--color-link-hover);
    text-decoration: underline;
}

.sitemap-list ul {
    list-style: none;
    padding-left: 20px;
    margin: 4px 0 0;
}

/* ── Přepis zastaralých image floatů ── */

/* Obrázky v obsahu — nechme float jen tam, kde je to záměrné */
#text img {
    max-width: 100%;
    height: auto;
}

/* ── Responzivní úprava pro #text obsah ── */
#text > *:not(#navigace):not(h4) {
    max-width: 100%;
}

/* ── Responsivita ── */
@media (max-width: 860px) {
    #complet {
        grid-template-columns: 1fr;
        grid-template-rows: auto auto 1fr;
        grid-template-areas:
            "header"
            "sidebar"
            "content";
    }

    #menuDiv {
        height: auto;
        overflow: visible;
    }

    #top {
        height: auto;
        min-height: 60px;
    }

    #logo_left,
    #logo_right {
        display: none;
    }

    #poznamka {
        width: 100%;
        padding: 8px;
    }

    #contextHelp {
        height: 80px;
    }

    ul#mainMenu,
    ul#mainMenu li,
    ul#mainMenu ul,
    ul#mainMenu li li {
        width: 100%;
    }

    #odkazy {
        width: 100%;
    }

    #frameKap {
        height: calc(100vh - 160px);
    }
}
