$bg: #eef2f7; $surface: #ffffff; $surface-soft: #f8fafc; $text: #182131; $muted: #5f6c83; $line: #d7deea; $line-strong: #c7d1e1; $accent: #2349b6; $accent-soft: #eef3ff; $shadow: 0 22px 54px rgba(16, 24, 40, 0.08); $print-text: #111111; *, *::before, *::after { box-sizing: border-box; } html { font-size: 16px; } body { margin: 0; font-family: Inter, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif; color: $text; background: radial-gradient(circle at top left, rgba(35, 73, 182, 0.06), transparent 24rem), $bg; line-height: 1.6; text-rendering: optimizeLegibility; } a { color: $accent; text-decoration: none; text-underline-offset: 0.16em; &:hover { text-decoration: underline; } } p, li, dd { max-width: 75ch; } .resume { width: min(1080px, calc(100% - 2rem)); margin: 2rem auto; padding: 2.35rem; background: $surface; border: 1px solid $line; border-radius: 18px; box-shadow: $shadow; } .resume--compact { width: min(980px, calc(100% - 2rem)); padding: 2rem 2.1rem; } .resume--two-page { width: min(1020px, calc(100% - 2rem)); padding: 2.1rem 2.15rem; } .hero { display: grid; grid-template-columns: minmax(0, 1.9fr) minmax(280px, 1fr); gap: 1.75rem; align-items: start; padding-bottom: 1.8rem; border-bottom: 1px solid $line-strong; } .hero__identity h1 { margin: 0.35rem 0 0.9rem; font-size: clamp(2.15rem, 4vw, 3.15rem); line-height: 1.02; letter-spacing: -0.02em; } .eyebrow { margin: 0; color: $accent; font-size: 0.84rem; font-weight: 700; line-height: 1.45; letter-spacing: 0.08em; text-transform: uppercase; } .headline { margin: 0; max-width: 58ch; color: $muted; font-size: 1.05rem; line-height: 1.68; } .hero__meta { display: grid; gap: 0.55rem; margin: 0; padding: 1.1rem 1.15rem; list-style: none; background: linear-gradient(180deg, $surface-soft, $accent-soft); border: 1px solid #d5def5; border-radius: 14px; } .hero__meta li { max-width: none; color: $text; font-size: 0.95rem; } .section { padding-top: 1.7rem; } .section h2 { margin: 0 0 0.95rem; color: #23304a; font-size: 0.88rem; font-weight: 800; letter-spacing: 0.11em; text-transform: uppercase; } .section--grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1.2rem; } .panel, .callout { padding: 1.15rem 1.2rem; border: 1px solid $line; border-radius: 14px; background: $surface-soft; } .panel h2, .callout h2 { margin-top: 0; } .tag-list, .plain-list { margin: 0; padding-left: 1.1rem; } .plain-list li + li { margin-top: 0.35rem; } .tag-list { display: flex; flex-wrap: wrap; gap: 0.58rem; padding-left: 0; list-style: none; } .tag-list li { max-width: none; padding: 0.42rem 0.76rem; border: 1px solid #cfdaef; border-radius: 999px; background: $accent-soft; color: #243657; font-size: 0.91rem; font-weight: 600; line-height: 1.2; } .stack-list { margin: 0; } .stack-list div + div { margin-top: 0.8rem; padding-top: 0.8rem; border-top: 1px solid #e8edf5; } .stack-list dt { color: #243657; font-weight: 700; } .stack-list dd { margin: 0.14rem 0 0; color: $muted; } .entry { padding: 1.05rem 0; border-top: 1px solid $line; } .entry:first-of-type { border-top: 0; padding-top: 0.1rem; } .entry h3 { margin: 0; font-size: 1.08rem; line-height: 1.3; } .entry p, .entry ul { margin: 0.5rem 0 0; } .entry ul { padding-left: 1.2rem; } .entry li + li { margin-top: 0.45rem; } .entry__head { display: flex; justify-content: space-between; gap: 1rem; align-items: baseline; } .entry__org { margin-top: 0.2rem; color: $muted; font-weight: 600; } .entry__meta { color: $muted; font-size: 0.94rem; white-space: nowrap; } .callout ul { margin: 0; padding-left: 1.15rem; } .callout li + li { margin-top: 0.45rem; } .footer-meta { border-top: 1px solid $line; margin-top: 1rem; } .footer-meta p { margin: 0; max-width: none; color: $muted; font-size: 0.95rem; } .resume--compact { .hero { gap: 1.3rem; padding-bottom: 1.45rem; } .section { padding-top: 1.35rem; } .headline { max-width: 50ch; font-size: 1rem; } .panel, .callout { padding: 1rem 1.05rem; } .entry { padding: 0.9rem 0; } .entry li + li { margin-top: 0.32rem; } .footer-meta { margin-top: 0.8rem; } } .resume--two-page { .section { padding-top: 1.45rem; } .panel, .callout { padding: 1rem 1.05rem; } .entry { padding: 0.88rem 0; } .entry li + li { margin-top: 0.34rem; } } @media (max-width: 900px) { .resume, .resume--compact, .resume--two-page { width: min(100%, calc(100% - 1rem)); margin: 0.5rem auto; padding: 1.35rem; border-radius: 14px; } .hero, .section--grid, .entry__head { grid-template-columns: 1fr; display: grid; } .hero { gap: 1rem; } .entry__head { gap: 0.3rem; } .entry__meta { white-space: normal; } } @media (max-width: 560px) { html { font-size: 15px; } .hero__identity h1 { font-size: 2rem; } .headline { font-size: 0.98rem; } .hero__meta { padding: 0.9rem 1rem; } } @media print { body { background: #ffffff; color: $print-text; font-size: 10.7pt; line-height: 1.45; } a { color: $print-text; text-decoration: none; } .resume, .resume--compact, .resume--two-page { width: 100%; margin: 0; padding: 0; border: 0; border-radius: 0; box-shadow: none; } .hero { gap: 0.8rem; padding-bottom: 0.8rem; } .hero__identity h1 { margin-bottom: 0.45rem; font-size: 22pt; } .headline, .entry__org, .entry__meta, .stack-list dd { color: $print-text; } .hero__meta, .panel, .callout { background: transparent; border: 1px solid #bdbdbd; } .section { padding-top: 0.9rem; } .section, .panel, .entry, .callout, .hero { break-inside: avoid; page-break-inside: avoid; } .tag-list li { background: transparent; border-color: #999999; color: $print-text; } }