/* ===========================================
   Editorial Magazine Design System
   编辑杂志设计系统
   =========================================== */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;0,800;1,400;1,600&family=Source+Sans+3:ital,wght@0,300;0,400;0,600;0,700;1,400&family=Noto+Serif+SC:wght@400;600;700&family=Noto+Sans+SC:wght@300;400;500;700&display=swap');

:root {
    --cream: #FAF8F5;
    --warm-white: #FFFDF9;
    --parchment: #F2EDE6;
    --terracotta: #C45832;
    --terracotta-light: #D97856;
    --terracotta-dark: #A23E20;
    --forest: #2D5F3E;
    --forest-light: #3D7A52;
    --ink: #2C1810;
    --ink-light: #4A3728;
    --ink-muted: #6B5B4E;
    --stone: #8C7E72;
    --sand: #B8AD9E;
    --mist: #D6CEC4;
    --cloud: #E8E2DA;
    --white: #FFFFFF;

    --font-display: 'Playfair Display', 'Noto Serif SC', 'Georgia', serif;
    --font-body: 'Source Sans 3', 'Noto Sans SC', -apple-system, BlinkMacSystemFont, 'PingFang SC', 'Microsoft YaHei', sans-serif;

    --hairline: 0.5px solid var(--mist);
    --rule: 1px solid var(--cloud);
    --rule-dark: 1px solid var(--ink);

    --max-w: 1200px;
    --max-w-narrow: 800px;

    --space-xs: 4px;
    --space-sm: 8px;
    --space-md: 16px;
    --space-lg: 24px;
    --space-xl: 40px;
    --space-2xl: 64px;
    --space-3xl: 96px;
    --space-4xl: 128px;
    --space-5xl: 160px;

    --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
    --transition: 0.3s var(--ease-out);
}

*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    font-size: 16px;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    scroll-behavior: smooth;
    scroll-padding-top: 72px;
}

body {
    font-family: var(--font-body);
    color: var(--ink);
    background-color: var(--cream);
    line-height: 1.7;
    min-height: 100vh;
    overflow-x: hidden;
}

img { max-width: 100%; display: block; }
ul, ol { list-style: none; }
a { color: inherit; text-decoration: none; }
button { border: none; background: none; cursor: pointer; font: inherit; }

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-display);
    font-weight: 700;
    line-height: 1.15;
    letter-spacing: -0.02em;
    color: var(--ink);
    text-wrap: balance;
}

h1 { font-size: clamp(2.8rem, 8vw, 5.5rem); font-weight: 800; }
h2 { font-size: clamp(1.8rem, 4vw, 3rem); }
h3 { font-size: clamp(1.2rem, 2.2vw, 1.6rem); }
h4 { font-size: clamp(1rem, 1.5vw, 1.2rem); }

p {
    font-size: 1rem;
    line-height: 1.85;
    color: var(--ink-muted);
    font-weight: 300;
}

.container {
    max-width: var(--max-w);
    margin: 0 auto;
    padding: 0 var(--space-xl);
}

.container-narrow {
    max-width: var(--max-w-narrow);
    margin: 0 auto;
    padding: 0 var(--space-xl);
}

.section {
    padding: var(--space-4xl) 0;
}

.section-head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    border-bottom: var(--rule-dark);
    padding-bottom: var(--space-md);
    margin-bottom: var(--space-2xl);
    gap: var(--space-lg);
}

.section-head h2 {
    font-size: clamp(1.6rem, 3.5vw, 2.4rem);
    font-style: italic;
}

.section-head .meta {
    font-family: var(--font-body);
    font-size: 0.7rem;
    color: var(--stone);
    text-transform: uppercase;
    letter-spacing: 0.15em;
    white-space: nowrap;
    font-weight: 600;
}

.divider {
    border: none;
    border-top: var(--rule);
    margin: 0;
}

.btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 32px;
    font-family: var(--font-body);
    font-size: 0.85rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    border: var(--rule-dark);
    background: transparent;
    color: var(--ink);
    cursor: pointer;
    transition: background-color var(--transition), color var(--transition), transform var(--transition);
    text-decoration: none;
    line-height: 1;
    position: relative;
}

.btn:hover {
    background: var(--ink);
    color: var(--cream);
    transform: translateY(-1px);
}

.btn:focus-visible {
    outline: 2px solid var(--terracotta);
    outline-offset: 2px;
}

.btn-fill {
    background: var(--terracotta);
    color: var(--white);
    border-color: var(--terracotta);
}

.btn-fill:hover {
    background: var(--terracotta-dark);
    border-color: var(--terracotta-dark);
    color: var(--white);
}

.btn-ghost {
    background: transparent;
    color: var(--cream);
    border: 1px solid rgba(250, 248, 245, 0.4);
}

.btn-ghost:hover {
    background: var(--cream);
    color: var(--ink);
    border-color: var(--cream);
}

.btn-ghost-muted {
    border-color: rgba(250, 248, 245, 0.2);
    color: rgba(250, 248, 245, 0.7);
}

.btn-ghost-muted:hover {
    background: rgba(250, 248, 245, 0.1);
    color: var(--cream);
    border-color: rgba(250, 248, 245, 0.4);
}

.tag {
    display: inline-block;
    font-family: var(--font-body);
    font-size: 0.65rem;
    font-weight: 600;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    border: var(--rule);
    padding: 4px 12px;
    color: var(--stone);
    border-radius: 2px;
}

::selection {
    background: var(--terracotta);
    color: var(--white);
}

@media (max-width: 768px) {
    .container {
        padding: 0 var(--space-lg);
    }
    .container-narrow {
        padding: 0 var(--space-lg);
    }
    .section {
        padding: var(--space-3xl) 0;
    }
    .section-head {
        flex-direction: column;
        gap: var(--space-sm);
        margin-bottom: var(--space-xl);
    }
}
