@page {
    size: A4;
    margin: 2.2cm 2cm 2.2cm 2cm;
    @bottom-center {
        content: counter(page);
        font-size: 10pt;
        color: #555;
        font-family: "Liberation Serif", "DejaVu Serif", Georgia, serif;
    }
    @top-left {
        content: string(konyv-cim);
        font-size: 8.5pt;
        color: #888;
        font-family: "Liberation Sans", "DejaVu Sans", Helvetica, sans-serif;
    }
    @top-right {
        content: string(fejezet-cim, first);
        font-size: 8.5pt;
        font-style: italic;
        color: #888;
        font-family: "Liberation Serif", "DejaVu Serif", Georgia, serif;
    }
}

/* Borítóoldal: nulla margó, a kép kitölti az egész lapot */
@page :first {
    margin: 0;
    padding: 0;
    @bottom-center { content: none; }
    @top-left { content: none; }
    @top-right { content: none; }
}

/* Cím oldal: nincs szám, nincs fejléc */
@page cimlap {
    size: A4;
    margin: 2.2cm 2cm 2.2cm 2cm;
    @bottom-center { content: none; }
    @top-left { content: none; }
    @top-right { content: none; }
}

/* Előlapok (szerzői jog + tartalomjegyzék): nincs szám, nincs fejléc */
@page elolap {
    size: A4;
    margin: 2.2cm 2cm 2.2cm 2cm;
    @bottom-center { content: none; }
    @top-left { content: none; }
    @top-right { content: none; }
}

html, body {
    margin: 0;
    padding: 0;
}

body {
    font-family: "Liberation Serif", "DejaVu Serif", Georgia, serif;
    font-size: 11pt;
    line-height: 1.55;
    max-width: 780px;
    margin: 0 auto;
    padding: 1.5em 2em;
    color: #1a1a1a;
    text-align: justify;
    hyphens: auto;
}

/* Fejezetek (h1) és alfejezetek (h2) mindig új oldalon */
h1 { page-break-before: always; string-set: fejezet-cim content(text); }
h2 { page-break-before: always; string-set: fejezet-cim content(text); }

h1, h2, h3, h4 {
    font-family: "Liberation Sans", "DejaVu Sans", Helvetica, sans-serif;
    color: #222;
    line-height: 1.25;
    page-break-after: avoid;
}
h1 { font-size: 22pt; margin-top: 0; border-bottom: 2px solid #333; padding-bottom: .4em; }
h2 { font-size: 17pt; margin-top: 1.5em; border-bottom: 1px solid #777; padding-bottom: .2em; }
h3 { font-size: 14pt; margin-top: 1.2em; }
h4 { font-size: 12pt; color: #444; }

p { margin: 0 0 .7em; }

/* Általános képek */
img {
    max-width: 85%;
    height: auto;
    display: block;
    margin: 1em auto;
    page-break-inside: avoid;
}

figure:first-of-type figcaption {
    display: none;
}

figcaption {
    text-align: center;
    font-size: 9.5pt;
    color: #555;
    font-style: italic;
    margin-top: 0.5em;
    page-break-before: avoid;
}

blockquote {
    border-left: 3px solid #888;
    padding: .2em 1em;
    margin: 1em 0 1em 1em;
    color: #333;
    font-style: italic;
}

em, i { color: #333; }
strong, b { color: #000; }

table { border-collapse: collapse; margin: 1em 0; }
th, td { border: 1px solid #888; padding: .3em .6em; }
th { background: #eee; }

hr { border: 0; border-top: 1px solid #aaa; margin: 1.5em 0; }
code { background: #f0f0f0; padding: 0 .2em; border-radius: 3px; font-size: 90%; }
a { color: #003366; text-decoration: none; }

#TOC { border: 1px solid #888; padding: 1em 1.5em; background: #fafafa; margin: 1em 0 2em; page-break-after: always; }
#TOC ul { padding-left: 1.2em; }

.title { text-align: center; }
.subtitle { text-align: center; color: #555; font-weight: normal; }

.konyv-cim {
    font-family: "Liberation Sans", "DejaVu Sans", Helvetica, sans-serif;
    font-size: 28pt;
    font-weight: bold;
    text-align: center;
    margin: 1em 0 0.5em;
    string-set: konyv-cim content(text);
}

.szakasz-cim {
    font-family: "Liberation Sans", "DejaVu Sans", Helvetica, sans-serif;
    font-size: 15pt;
    font-weight: bold;
    margin: 1.2em 0 0.5em;
}

/* Névvel ellátott oldaltípusok – szám és fejléc nélkül */
.cimlap { page: cimlap; }
.elolap { page: elolap; }

/* Főtartalom első h2-je (BEVEZETÉS) indítja az 1-es oldalszámot */
h2:first-of-type { counter-reset: page 1; }
