:root {
    --color-burgundy: #731b18;
    --color-burgundy-dark: #54120f;
    --color-olive: #6f6d22;
    --color-coffee: #4a2e1e;
    --color-cream: #f6efe3;
    --color-paper: #fffaf2;
    --color-muted: #786b58;
    --color-line: rgba(74, 46, 30, .22);
    --shadow-soft: 0 24px 70px rgba(74, 46, 30, .13);
    --radius-large: 28px;
    --radius-medium: 18px;
    --container: 1180px;
    --font-title: Impact, Haettenschweiler, 'Arial Narrow Bold', sans-serif;
    --font-body: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    margin: 0;
    color: var(--color-coffee);
    background: var(--color-paper);
    font-family: var(--font-body);
    line-height: 1.6;
}
img { max-width: 100%; display: block; }
a { color: inherit; }

.site-header { background: var(--color-burgundy); }
.topbar {
    position: fixed;
    z-index: 20;
    inset: 0 0 auto 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    padding: 16px clamp(18px, 4vw, 56px);
    background: rgba(84, 18, 15, .88);
    color: #fff;
    backdrop-filter: blur(14px);
}

.brand {
    display: inline-flex;
    align-items: center;
    gap: .75rem;
    text-decoration: none;
}

.brand-logo {
    display: block;
    width: auto;
    height: 54px;
    max-width: 220px;
    object-fit: contain;
}

@media (max-width: 640px) {
    .brand-logo {
        height: 42px;
        max-width: 180px;
    }
}

.brand-mark {
    display: grid;
    place-items: center;
    width: 44px;
    height: 44px;
    border: 2px solid currentColor;
    border-radius: 12px;
    letter-spacing: -2px;
}
.main-menu { display: flex; gap: 20px; font-size: .92rem; }
.main-menu a { text-decoration: none; opacity: .86; }
.main-menu a:hover { opacity: 1; }
.menu-toggle { display: none; }

.hero {
    min-height: 100svh;
    position: relative;
    display: grid;
    align-items: center;
    padding: 124px clamp(20px, 6vw, 88px) 156px;
    isolation: isolate;
    overflow: hidden;
    background:
        linear-gradient(180deg, rgba(255,250,242,.78), rgba(246,239,227,.35) 42%, rgba(84,18,15,.18)),
        var(--hero-image) center / cover no-repeat;
}
.hero::before,
.hero::after {
    content: '';
    position: absolute;
    z-index: -1;
    opacity: .25;
    border-radius: 999px;
    background: radial-gradient(circle, rgba(255,255,255,.75), transparent 62%);
}
.hero::before { width: 420px; height: 420px; top: 9%; left: 8%; }
.hero::after { width: 560px; height: 560px; right: -10%; bottom: 5%; }
.hero__content {
    max-width: 900px;
    margin: auto;
    text-align: center;
}
.eyebrow,
.section-kicker {
    margin: 0 0 10px;
    color: var(--color-burgundy);
    text-transform: uppercase;
    letter-spacing: .16em;
    font-weight: 800;
    font-size: .82rem;
}
.hero h1,
.content-section h2,
.cta-section h2 {
    margin: 0;
    color: var(--color-burgundy);
    font-family: var(--font-title);
    text-transform: uppercase;
    letter-spacing: .055em;
    line-height: .98;
}
.hero h1 { font-size: clamp(1.5rem, 6vw, 4.5rem); }
.hero__subtitle {
    max-width: 760px;
    margin: 24px auto 0;
    color: var(--color-coffee);
    font-size: clamp(1rem, 2vw, 1.3rem);
    font-weight: 650;
}
.hero__actions,
.cta-actions { display: flex; flex-wrap: wrap; justify-content: center; gap: 14px; margin-top: 34px; }
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    padding: 12px 22px;
    border-radius: 999px;
    border: 1px solid transparent;
    text-decoration: none;
    font-weight: 800;
    transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.btn:hover { transform: translateY(-2px); box-shadow: 0 12px 28px rgba(84, 18, 15, .22); }
.btn-primary { background: var(--color-burgundy); color: #fff; }
.btn-outline { color: var(--color-burgundy); border-color: currentColor; background: rgba(255,250,242,.55); }
.btn-outline-light { color: #fff; border-color: rgba(255,255,255,.72); }
.btn-small { min-height: 40px; padding: 8px 16px; background: var(--color-olive); color: #fff; font-size: .9rem; }
.hero__band {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 18px;
    padding: 28px 20px;
    color: #fff;
    background: rgba(115, 27, 24, .92);
    text-align: center;
}
.hero__band strong { font-size: 1.4rem; text-transform: uppercase; }

.section-dark {
    display: grid;
    grid-template-columns: minmax(320px, .75fr) 1.25fr;
    min-height: 650px;
    background: var(--color-burgundy-dark) url('../img/coffee-branches.svg') left bottom / 45% auto no-repeat;
    color: #fff;
}
.index-panel { padding: clamp(48px, 8vw, 104px) clamp(32px, 6vw, 76px); }
.index-panel h2 { margin: 0; font-size: clamp(2.4rem, 5vw, 4.3rem); font-family: Georgia, serif; font-weight: 500; }
.ornament { width: 160px; height: 1px; margin: 20px 0 34px; background: rgba(255,255,255,.72); }
.index-list { list-style: none; padding: 0; margin: 0; }
.index-list li { border-bottom: 1px solid rgba(255,255,255,.45); }
.index-list a { display: flex; align-items: center; gap: 18px; padding: 22px 0; text-decoration: none; font-size: 1.2rem; font-weight: 750; }
.index-list span { font-family: var(--font-title); font-size: 2.4rem; letter-spacing: .04em; }
.quote-panel {
    margin: 0;
    display: grid;
    align-content: center;
    min-height: 540px;
    padding: clamp(42px, 7vw, 90px);
    background: linear-gradient(90deg, rgba(0,0,0,.08), rgba(0,0,0,.54)), url('../img/quote-cafe-hand.svg') center / cover no-repeat;
}
.quote-panel span { font-size: 8rem; line-height: .5; font-family: Georgia, serif; }
.quote-panel p { max-width: 420px; margin: 0; font-family: Georgia, serif; font-size: clamp(1.8rem, 4vw, 3rem); line-height: 1.24; }

.content-section { max-width: var(--container); margin: 0 auto; padding: clamp(64px, 9vw, 116px) clamp(20px, 4vw, 48px); }
.section-heading { max-width: 780px; margin-bottom: 38px; }
.section-heading.centered { text-align: center; margin-left: auto; margin-right: auto; }
.content-section h2 { font-size: clamp(2.4rem, 5vw, 4.5rem); }
.section-number {
    display: inline-grid;
    place-items: center;
    width: 54px;
    height: 62px;
    margin: 0 0 16px;
    color: #fff;
    background: var(--color-olive);
    font-family: var(--font-title);
    font-size: 1.8rem;
}
.two-column { display: grid; grid-template-columns: repeat(2, 1fr); gap: 32px; font-size: 1.12rem; }

.split-layout { display: grid; grid-template-columns: .82fr 1.18fr; gap: clamp(24px, 5vw, 70px); align-items: stretch; }
.visual-card,
.details-card,
.sensory-card,
.value-card,
.presentation-card,
.initiative-card,
.benefit-card {
    background: rgba(255,250,242,.72);
    border: 1px solid var(--color-line);
    border-radius: var(--radius-large);
    box-shadow: var(--shadow-soft);
}
.visual-card { display: grid; align-content: center; min-height: 560px; padding: 34px; text-align: center; overflow: hidden; }
.visual-card img { margin: auto; max-height: 340px; }
.logo-placeholder { color: var(--color-burgundy); font-family: var(--font-title); font-size: 2.2rem; text-transform: uppercase; letter-spacing: .05em; }
.placeholder-note { color: var(--color-muted); font-size: .88rem; }
.details-card { padding: clamp(28px, 5vw, 58px); position: relative; }
.script-title { margin: 4px 0 24px; color: var(--color-olive); font-family: Georgia, serif; font-style: italic; font-size: 2rem; }
.attribute-list { border-top: 2px solid var(--color-olive); }
.attribute-row { display: grid; grid-template-columns: 42px minmax(140px, .45fr) 1fr; gap: 16px; align-items: center; padding: 20px 0; border-bottom: 1px solid var(--color-line); }
.line-icon { width: 30px; height: 30px; border: 2px solid var(--color-coffee); border-radius: 50%; opacity: .72; }
.line-icon--mountain { border-radius: 0; clip-path: polygon(50% 0, 100% 100%, 0 100%); }
.line-icon--leaf { border-radius: 70% 0 70% 0; transform: rotate(45deg); }
.line-icon--seedling { border-radius: 50% 50% 6px 6px; }

.section-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px, 5vw, 70px); }
.sensory-card,
.value-card { padding: clamp(28px, 5vw, 56px); }
.sensory-card h2,
.value-card h2 { margin-bottom: 34px; font-size: clamp(2.2rem, 4vw, 3.8rem); border-bottom: 3px solid var(--color-burgundy); width: fit-content; }
.sensory-row { display: grid; grid-template-columns: 1fr auto; gap: 16px; align-items: center; margin: 18px 0; }
.bean-rating { display: inline-flex; gap: 9px; }
.bean { width: 24px; height: 38px; border: 2px solid var(--color-coffee); border-radius: 50%; transform: rotate(18deg); background: transparent; }
.bean.is-filled { background: var(--color-coffee); }
.score-box { margin-top: 34px; padding: 28px; text-align: center; border-radius: var(--radius-medium); background: #f0e7d7; }
.score-box span { display: block; text-transform: uppercase; }
.score-box strong { display: block; color: var(--color-burgundy); font-family: var(--font-title); font-size: clamp(3rem, 7vw, 5.8rem); line-height: .98; }
.value-card article { padding: 18px 0 18px 78px; border-bottom: 1px solid var(--color-line); position: relative; }
.value-card article::before { content: '✦'; position: absolute; left: 16px; top: 18px; color: var(--color-olive); font-size: 2rem; }
.value-card h3 { margin: 0 0 6px; font-size: 1.35rem; }
.value-card p { margin: 0; color: var(--color-muted); }

.cluster { max-width: 1240px; }
.benefit-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 16px; }
.benefit-card { padding: 24px; font-weight: 720; }

.presentation-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.presentation-card { display: grid; grid-template-columns: 42% 1fr; align-items: center; gap: 18px; min-height: 260px; padding: 26px; }
.presentation-card img { max-height: 190px; margin: auto; }
.presentation-card h3 { margin: 0 0 10px; font-size: 1.4rem; }
.presentation-card ul { margin: 0; padding-left: 18px; color: var(--color-muted); }

.initiatives { max-width: 1240px; }
.initiative-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.initiative-card { overflow: hidden; }
.initiative-card img { width: 100%; height: 220px; object-fit: cover; background: #efe6d6; }
.initiative-card__body { padding: 24px; }
.tag { display: inline-flex; margin-bottom: 12px; padding: 6px 10px; border-radius: 999px; background: rgba(111,109,34,.13); color: var(--color-olive); font-size: .78rem; font-weight: 800; text-transform: uppercase; }
.initiative-card h3 { margin: 0 0 10px; color: var(--color-burgundy); font-size: 1.4rem; }
dl { display: grid; grid-template-columns: 110px 1fr; gap: 4px 12px; margin: 18px 0; font-size: .92rem; }
dt { font-weight: 800; }
dd { margin: 0; color: var(--color-muted); }

.cta-section {
    display: grid;
    grid-template-columns: 1.2fr .8fr;
    gap: 24px;
    align-items: center;
    padding: clamp(56px, 8vw, 90px) clamp(20px, 6vw, 88px);
    background: linear-gradient(135deg, rgba(84,18,15,.96), rgba(115,27,24,.92)), url('../img/coffee-branches.svg') right bottom / 360px auto no-repeat;
    color: #fff;
}
.cta-section h2, .cta-section .section-kicker { color: #fff; }
.cta-section p { max-width: 760px; }
.site-footer { padding: 36px clamp(20px, 6vw, 88px); color: #f8efe5; background: var(--color-burgundy-dark); }
.site-footer p { max-width: 860px; margin-bottom: 0; }

@media (max-width: 980px) {
    .menu-toggle { display: inline-flex; border: 1px solid rgba(255,255,255,.45); border-radius: 999px; padding: 9px 14px; color: #fff; background: transparent; }
    .main-menu { position: absolute; top: 76px; right: 18px; display: none; flex-direction: column; width: min(280px, calc(100vw - 36px)); padding: 18px; border-radius: 18px; background: var(--color-burgundy-dark); }
    .main-menu.is-open { display: flex; }
    .hero__band { flex-direction: column; gap: 4px; }
    .section-dark,
    .split-layout,
    .section-grid,
    .two-column,
    .cta-section { grid-template-columns: 1fr; }
    .benefit-grid,
    .presentation-grid,
    .initiative-grid { grid-template-columns: repeat(2, 1fr); }
    .visual-card { min-height: auto; }
}

@media (max-width: 680px) {
    .topbar { padding: 12px 16px; }
    .brand span:last-child { display: none; }
    .hero { min-height: 780px; padding-top: 110px; }
    .hero h1 { font-size: clamp(3.1rem, 17vw, 5rem); }
    .btn { width: 100%; }
    .quote-panel { min-height: 420px; }
    .attribute-row { grid-template-columns: 32px 1fr; }
    .attribute-row span:last-child { grid-column: 2; }
    .benefit-grid,
    .presentation-grid,
    .initiative-grid { grid-template-columns: 1fr; }
    .presentation-card { grid-template-columns: 1fr; }
    dl { grid-template-columns: 1fr; }
}
