/* Max Bauwens - Page contact master v1.0 */
:root {
  --orange: #DF4B27;
  --warm: #F8F6F2;
  --black: #000000;
  --anthracite: #242424;
  --muted: #706C67;
  --line: #D8D2CB;
  --surface: rgba(255,255,255,.55);
  --profile-photo-size: clamp(104px, 30vw, 168px);
  --profile-photo-position-x: 50%;
  --profile-photo-position-y: 50%;
  --page-max: 720px;
  --radius: 15px;
  --shadow: 0 8px 28px rgba(0,0,0,.035);
  --font-text: "Manrope", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
  --font-title: "Poppins", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
  --font-slogan: "GFS Didot", "Iowan Old Style", Baskerville, Georgia, serif;
}
* { box-sizing: border-box; }
html { color-scheme: light; background: var(--warm); scroll-behavior: smooth; }
body { margin: 0; min-width: 280px; background: var(--warm); color: var(--anthracite); font-family: var(--font-text); font-size: 16px; line-height: 1.5; text-rendering: optimizeLegibility; }
a { color: inherit; text-decoration: none; }
a:focus-visible { outline: 3px solid rgba(223,75,39,.42); outline-offset: 3px; }
img, svg { display: block; max-width: 100%; }
.page { width: min(100%, var(--page-max)); margin: 0 auto; min-height: 100vh; padding: clamp(28px,5vw,54px) clamp(20px,5vw,48px) 26px; overflow: hidden; }
.identity { text-align: center; }
.logo { width: min(100%, 410px); height: auto; margin: 0 auto; }
.profile-photo { position: relative; width: var(--profile-photo-size); aspect-ratio: 1; margin: clamp(22px,4vw,32px) auto 0; border-radius: 50%; overflow: hidden; border: 1px solid #CEC7BF; background: #E9E4DE; box-shadow: 0 8px 24px rgba(0,0,0,.08); }
.profile-photo picture, .profile-photo img { position: absolute; inset: 0; width: 100%; height: 100%; }
.profile-photo img { object-fit: cover; object-position: var(--profile-photo-position-x) var(--profile-photo-position-y); color: transparent; }
.profile-fallback { position: absolute; inset: 0; display: grid; place-items: center; color: #605C57; font: 700 1.5rem var(--font-title); }
.accent { height: 3px; width: 54px; background: var(--orange); border-radius: 999px; margin: clamp(20px,4vw,30px) auto 20px; }
.descriptor { margin: 0; color: var(--black); font-family: var(--font-title); font-size: clamp(.88rem,2.7vw,1.05rem); line-height: 1.55; font-weight: 700; }
.descriptor .dot { color: var(--orange); padding: 0 .32rem; }
.location { width: fit-content; max-width: 100%; margin: 18px auto 0; padding: 9px 17px; border: 1px solid #DED8D1; border-radius: 999px; background: rgba(255,255,255,.4); color: var(--muted); font-size: clamp(.76rem,2.4vw,.9rem); font-weight: 520; line-height: 1.45; }
.location .loc-dot { display: inline-block; padding: 0 .42rem; color: inherit; font-weight: 900; transform: translateY(-.03em); }
.section { margin-top: clamp(30px,6vw,44px); }
.section-title { margin: 0 0 15px; color: var(--orange); font-family: var(--font-title); font-size: .82rem; font-weight: 700; line-height: 1.2; letter-spacing: .13em; text-transform: uppercase; }
.actions { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 12px; }
.action { min-height: 76px; padding: 13px 12px; border: 1px solid #D2CCC5; border-radius: var(--radius); background: var(--surface); display: flex; align-items: center; gap: 10px; box-shadow: var(--shadow); transition: transform .16s ease, border-color .16s ease, background-color .16s ease; }
.action:hover { transform: translateY(-1px); border-color: #BDB5AC; }
.action.primary { color: #FFFFFF; background: var(--black); border-color: var(--black); }
.action svg { width: 22px; height: 22px; flex: 0 0 auto; color: var(--black); }
.action.primary svg { color: #FFFFFF; }
.action span { min-width: 0; display: grid; gap: 2px; }
.action strong { font-size: clamp(.82rem,2.8vw,1rem); line-height: 1.18; font-weight: 760; }
.action small { overflow-wrap: anywhere; color: var(--muted); font-size: clamp(.61rem,1.9vw,.73rem); line-height: 1.28; }
.action.primary small { color: rgba(255,255,255,.83); }
.socials { display: flex; gap: 11px; flex-wrap: wrap; }
.social { min-height: 48px; padding: 0 16px; border: 1px solid #D3CDC6; border-radius: 13px; display: flex; align-items: center; gap: 9px; background: rgba(255,255,255,.48); font-size: .9rem; font-weight: 700; }
.social svg { width: 20px; height: 20px; color: var(--black); }
.portfolio-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 10px; }
.portfolio-item { min-height: 52px; padding: 0 14px; border: 1px solid #D6D0C9; border-radius: 13px; display: flex; align-items: center; gap: 8px; background: transparent; color: var(--anthracite); font-size: .9rem; font-weight: 720; cursor: default; }
.portfolio-item .arrow { width: 18px; height: 18px; margin-left: auto; color: #77736E; opacity: .62; }
.portfolio-note { margin: 11px 0 0; color: var(--muted); font-size: .73rem; line-height: 1.45; }
.slogan-wrap { margin-top: clamp(30px,6vw,44px); padding: 20px 8px 14px; border-bottom: 1px solid var(--line); text-align: center; }
.slogan { margin: 0; color: #4A4743; font-family: var(--font-slogan); font-size: clamp(1.05rem,3.4vw,1.35rem); font-style: italic; line-height: 1.28; letter-spacing: .005em; }
.footer { margin-top: 18px; display: flex; align-items: center; justify-content: space-between; gap: 16px; color: #77736E; font-size: .76rem; }
.footer img { width: 36px; height: 36px; }
@media (max-width: 420px) {
  .action small { font-size: .61rem; }
}
@media (max-width: 350px) {
  .page { padding-inline: 16px; }
  .actions { grid-template-columns: 1fr; gap: 9px; }
  .action { min-height: 64px; padding: 11px 14px; gap: 11px; }
  .action svg { width: 22px; height: 22px; }
  .action small { font-size: .7rem; }
  .descriptor .dot { padding-inline: .2rem; }
  .location { padding-inline: 11px; }
  .location .loc-dot { padding-inline: .25rem; }
}
@media (min-width: 800px) {
  .page { padding-top: 58px; padding-bottom: 42px; }
  .section-title { font-size: .88rem; }
}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { scroll-behavior: auto !important; transition: none !important; }
}
@media print {
  body { background: #FFFFFF; }
  .page { max-width: 720px; padding: 20px; }
  .action, .social { box-shadow: none; }
}
