:root { color-scheme: light; --bg: #f4efe6; --bg-alt: #efe5d5; --card: rgba(255,255,255,0.68); --card-strong: #fffaf1; --text: #111111; --muted: rgba(17,17,17,0.66); --line: rgba(17,17,17,0.12); --accent: #111111; --shadow: 0 28px 80px rgba(17,17,17,0.08); }
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: "Inter Tight", system-ui, sans-serif; color: var(--text); background: radial-gradient(circle at top left, rgba(217,196,154,0.5), transparent 35%), radial-gradient(circle at top right, rgba(255,255,255,0.8), transparent 30%), linear-gradient(180deg, #f8f2e8 0%, var(--bg) 35%, #f0e7d9 100%); }
a { color: inherit; text-decoration: none; }
.page-shell { width: min(1180px, calc(100% - 32px)); margin: 0 auto; padding: 20px 0 32px; }
.topbar { position: sticky; top: 16px; z-index: 20; display: flex; justify-content: space-between; align-items: center; gap: 20px; padding: 16px 18px; border: 1px solid var(--line); border-radius: 22px; background: rgba(255,250,241,0.78); backdrop-filter: blur(18px); box-shadow: var(--shadow); }
.brand { display: flex; align-items: center; gap: 12px; }
.brand-mark { display: grid; place-items: center; width: 42px; height: 42px; border-radius: 14px; background: var(--accent); color: white; font-weight: 800; }
.brand strong { display: block; font-size: 1rem; letter-spacing: 0.02em; }
.brand small { display: block; color: var(--muted); margin-top: 2px; }
.nav { display: flex; gap: 18px; flex-wrap: wrap; color: var(--muted); }
.hero, .section, .intro-strip, .delivery, .cta { border: 1px solid var(--line); border-radius: 32px; background: var(--card); box-shadow: var(--shadow); }
.hero { margin-top: 18px; padding: 36px; display: grid; grid-template-columns: 1.3fr 0.9fr; gap: 28px; overflow: hidden; position: relative; }
.hero::after { content: ""; position: absolute; right: -80px; top: -70px; width: 260px; height: 260px; border-radius: 50%; background: radial-gradient(circle, rgba(17,17,17,0.12), transparent 70%); filter: blur(10px); }
.eyebrow, .section-kicker, .panel-label { text-transform: uppercase; letter-spacing: 0.16em; font-size: 0.75rem; color: var(--muted); }
.hero h1 { margin: 14px 0 18px; font-family: "Fraunces", serif; font-size: clamp(3rem, 6vw, 5.5rem); line-height: 0.94; letter-spacing: -0.04em; max-width: 10ch; }
.hero-text, .intro-strip p, .delivery-copy p, .system-card p, .stage-card p { color: var(--muted); line-height: 1.7; font-size: 1.02rem; }
.hero-actions { display: flex; gap: 12px; flex-wrap: wrap; margin: 28px 0 18px; }
.button { display: inline-flex; align-items: center; justify-content: center; padding: 14px 18px; border-radius: 999px; border: 1px solid var(--line); font-weight: 700; transition: transform 0.18s ease, background 0.18s ease, color 0.18s ease; }
.button.primary { background: var(--accent); color: white; }
.button.secondary { background: transparent; }
.hero-badges { display: flex; gap: 10px; flex-wrap: wrap; }
.hero-badges span { padding: 10px 14px; border-radius: 999px; background: rgba(17,17,17,0.06); border: 1px solid var(--line); font-size: 0.95rem; }
.hero-panel { display: grid; gap: 16px; align-content: start; }
.panel-card { padding: 22px; border-radius: 24px; background: var(--card-strong); border: 1px solid var(--line); }
.panel-card h2, .section h2 { font-family: "Fraunces", serif; line-height: 1; letter-spacing: -0.03em; margin: 10px 0 14px; }
.panel-card h2 { font-size: clamp(2rem, 3vw, 3rem); }
.panel-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.panel-grid article { background: rgba(255,250,241,0.85); border: 1px solid var(--line); border-radius: 20px; padding: 16px; }
.panel-grid strong { font-size: 1.4rem; margin-bottom: 10px; }
.panel-grid span { display: block; color: var(--muted); line-height: 1.5; }
.intro-strip, .cta, .delivery { margin-top: 18px; padding: 24px 28px; display: flex; justify-content: space-between; gap: 24px; align-items: center; }
.intro-strip h2, .delivery h2, .cta h2, .section-head h2 { margin: 8px 0 0; max-width: 18ch; font-family: "Fraunces", serif; font-size: clamp(2rem, 4vw, 3.6rem); line-height: 0.98; }
.intro-strip p { max-width: 42ch; margin: 0; }
.section { margin-top: 18px; padding: 28px; }
.section-head { display: flex; justify-content: space-between; gap: 24px; align-items: end; margin-bottom: 20px; }
.stage-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
.stage-card, .system-card { padding: 20px; border-radius: 24px; background: rgba(255,250,241,0.82); border: 1px solid var(--line); }
.stage-card h3, .system-card h3 { margin: 14px 0 12px; font-size: 1.25rem; }
.stage-no { display: inline-grid; place-items: center; width: 42px; height: 42px; border-radius: 50%; background: var(--accent); color: white; font-weight: 800; }
.stage-card p { margin: 0 0 10px; }
.systems-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.system-card.wide { grid-column: 1 / -1; }
.delivery-copy { max-width: 44ch; }
.delivery-points { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; width: min(100%, 620px); }
.delivery-points div { padding: 18px; border-radius: 20px; background: rgba(255,250,241,0.86); border: 1px solid var(--line); }
.delivery-points strong { display: inline-flex; align-items: center; justify-content: center; margin-bottom: 8px; font-size: 1rem; }
.delivery-points span { color: var(--muted); line-height: 1.6; }
.cta { align-items: center; }
.footer { display: flex; justify-content: space-between; gap: 16px; padding: 20px 4px 0; color: var(--muted); }
@media (max-width: 980px) { .hero, .intro-strip, .delivery, .cta, .section-head { grid-template-columns: 1fr; flex-direction: column; align-items: start; } .stage-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } .systems-grid, .delivery-points { grid-template-columns: 1fr; } .delivery-points { width: 100%; } }
@media (max-width: 720px) { .page-shell { width: min(100% - 20px, 1180px); padding-top: 10px; } .topbar { top: 10px; padding: 14px; border-radius: 20px; flex-direction: column; align-items: start; } .hero, .section, .intro-strip, .delivery, .cta { padding: 20px; border-radius: 24px; } .hero h1 { max-width: 12ch; } .stage-grid { grid-template-columns: 1fr; } .panel-grid { grid-template-columns: 1fr; } }
