:root {
    --color-primary: #2c3e50;
    --color-secondary: #a27f4d;
    --color-accent: #ff9800;
    --color-hover: #5d80b2;
    --color-text: #2c3e50;
    --color-text-light: #7f8c8d;
    --color-bg: #fff3e0;
    --color-bg-alt: #f0f2f5;
    --font-primary: 'Playfair Display', serif;
    --font-secondary: 'Crimson Text', serif;
    --border-radius: 8px;
}

/* Dark mode support in TinyMCE */
[data-theme="dark"] {
    --color-primary: #ffffff;
    --color-secondary: #d4af37;
    --color-accent: #ffa726;
    --color-hover: #81c784;
    --color-text: #e0e0e0;
    --color-text-light: #b0b0b0;
    --color-bg: #121212;
    --color-bg-alt: #1e1e1e;
}

/* Base body styles matching .post-content - scoped to editor/preview/read containers */
.mce-content-body,
.read-post-content,
#preview-content,
.preview-box {
    font-family: var(--font-secondary);
    font-size: 1.2rem;
    line-height: 1.8;
    color: var(--color-text);
    background-color: #ffffff;
    max-width: 800px;
    margin: 0 auto;
    padding: 20px;
    word-wrap: break-word;
    overflow-wrap: break-word;
}

/* Headings matching blog styles */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-primary);
    color: var(--color-text);
    margin-top: 1.5em;
    margin-bottom: 0.8em;
    line-height: 1.3;
    font-weight: 700;
}

h1 {
    font-size: 2.8rem;
    font-weight: 900;
    line-height: 1.2;
    margin-bottom: 15px;
}

h2 {
    font-size: 2.2rem;
    font-weight: 700;
}

h3 {
    font-size: 1.8rem;
    font-weight: 600;
}

h4 {
    font-size: 1.5rem;
    font-weight: 600;
}

h5 {
    font-size: 1.3rem;
    font-weight: 600;
}

h6 {
    font-size: 1.1rem;
    font-weight: 600;
}

/* Paragraph styles */
p {
    margin-bottom: 1.2em;
    font-size: 1.2rem;
    line-height: 1.8;
    color: var(--color-text);
}

/* Drop Cap - Großer erster Buchstabe */
p:first-of-type:first-letter {
    font-family: var(--font-primary);
    font-size: 4.5rem;
    font-weight: 700;
    line-height: 0.8;
    float: left;
    margin: 8px 8px 0 0;
    color: var(--color-secondary);
    text-shadow: 2px 2px 4px rgba(0,0,0,0.1);
    background: linear-gradient(135deg, var(--color-secondary) 0%, var(--color-accent) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* Image styles - EXACTLY matching final post styles */
img {
    max-width: 100% !important;
    height: auto !important;
    border-radius: 5px !important;
    margin: 10px auto !important;
    display: block !important;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
    margin-left: auto !important;
    margin-right: auto !important;
}

/* Blockquote styles matching blog */
blockquote {
    quotes: "\\201E" "\\201C" "\\201A" "\\2018";
    border-left: 4px solid var(--color-accent);
    padding-left: 20px;
    margin: 20px 0;
    font-style: italic;
    color: #555;
    font-size: 1.1rem;
    background: var(--color-bg-alt);
    padding: 15px 20px;
    border-radius: var(--border-radius);
}

blockquote:before {
    content: open-quote;
}

blockquote:after {
    content: close-quote;
}

/* Lists */
ul, ol {
    margin: 1rem 0;
    padding-left: 2rem;
    font-size: 1.2rem;
    line-height: 1.8;
}

li {
    margin-bottom: 0.5rem;
}

/* Links */
a {
    color: var(--color-accent);
    text-decoration: none;
    transition: color 0.3s ease;
}

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

/* Code styles */
code {
    background: var(--color-bg-alt);
    padding: 2px 6px;
    border-radius: 4px;
    font-family: 'Courier New', monospace;
    font-size: 0.9em;
    color: var(--color-primary);
}

pre {
    background: var(--color-bg-alt);
    padding: 15px;
    border-radius: var(--border-radius);
    overflow-x: auto;
    margin: 1rem 0;
    border-left: 4px solid var(--color-accent);
}

pre code {
    background: none;
    padding: 0;
}

/* Tables */
table {
    width: 100%;
    border-collapse: collapse;
    margin: 1rem 0;
    background: #fff;
    border-radius: var(--border-radius);
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}

th, td {
    padding: 12px 15px;
    text-align: left;
    border-bottom: 1px solid #ddd;
}

th {
    background: var(--color-primary);
    color: white;
    font-weight: 600;
}

tr:hover {
    background: var(--color-bg-alt);
}

/* Horizontal rule */
hr {
    border: none;
    height: 2px;
    background: linear-gradient(to right, transparent, var(--color-accent), transparent);
    margin: 2rem 0;
}

/* Strong and emphasis */
strong, b {
    font-weight: 700;
    color: var(--color-primary);
}

em, i {
    font-style: italic;
    color: var(--color-text);
}

/* Text alignment utilities */
.text-center { text-align: center; }
.text-left { text-align: left; }
.text-right { text-align: right; }
.text-justify { text-align: justify; }

/* Dark mode styles for editor - scoped to editor/preview/read containers */
[data-theme="dark"] .mce-content-body,
[data-theme="dark"] .read-post-content,
[data-theme="dark"] #preview-content,
[data-theme="dark"] .preview-box {
    background-color: var(--color-bg);
    color: var(--color-text);
}

[data-theme="dark"] h1,
[data-theme="dark"] h2,
[data-theme="dark"] h3,
[data-theme="dark"] h4,
[data-theme="dark"] h5,
[data-theme="dark"] h6 {
    color: var(--color-primary);
}

[data-theme="dark"] p {
    color: var(--color-text);
}

[data-theme="dark"] blockquote {
    background: var(--color-bg);
    color: var(--color-text);
}

[data-theme="dark"] code {
    background: var(--color-bg-alt);
    color: var(--color-text);
}

[data-theme="dark"] pre {
    background: var(--color-bg-alt);
}

[data-theme="dark"] table {
    background: var(--color-bg-alt);
}

[data-theme="dark"] th {
    background: var(--color-primary);
}

[data-theme="dark"] tr:hover {
    background: var(--color-bg);
}

[data-theme="dark"] td {
    border-bottom-color: #444;
}

/* Dark Mode Drop Cap */
[data-theme="dark"] p:first-of-type:first-letter {
    background: linear-gradient(135deg, var(--color-secondary) 0%, var(--color-accent) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    color: var(--color-secondary);
    text-shadow: 2px 2px 4px rgba(0,0,0,0.3);
}