/* ============================================================
   whoisbelinskii.com  —  dark / cinematic / electric-blue skin
   You normally don't need to touch this file. To change the
   accent color, edit --neon below.  (Content lives in index.html)
   ============================================================ */

:root{
  --bg:        #5a8fd6;       /* sky blue base (behind clouds) */
  --panel:     #ffffff;       /* box background (white MySpace panels) */
  --panel-2:   #f4f7fc;       /* slightly tinted inset      */
  --ink:       #1a2230;       /* body text (dark on white)  */
  --ink-dim:   #5b6b85;       /* secondary text             */
  --neon:      #2b5fb0;       /* ← EDIT to change accent color (MySpace navy-blue) */
  --neon-soft: rgba(43,95,176,.12);
  --hair:      rgba(40,70,120,.22);
  --serif: "Anton", Impact, sans-serif;
  --mono:  "Space Mono", "Courier New", monospace;
  --body:  "DM Sans", system-ui, sans-serif;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  /* ===== MySpace blue-sky base color (clouds drift on the layer below) ===== */
  background-color:#5a8fd6;                 /* ← EDIT sky color (e.g. #5a8fd6 classic MySpace blue) */
  color:var(--ink);
  font-family:var(--body);
  font-size:15px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
/* drifting cartoon clouds — a fixed full-screen layer behind all content */
body::before{
  content:"";
  position:fixed; top:0; left:0; right:0; bottom:0; z-index:-1; pointer-events:none;
  /* every cloud sits fully inside the 360x300 tile (with edge clearance) so nothing
     gets clipped when the pattern repeats — no flat-cut sides */
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='360' height='300' viewBox='0 0 360 300'%3E%3Cg fill='%23ffffff' stroke='%23222' stroke-width='3' stroke-linejoin='round'%3E%3Cpath d='M40 55c-13 0-21 8-21 19 0 11 9 19 23 19h62c13 0 23-8 23-19 0-10-9-18-20-18-3-11-13-19-26-19-12 0-23 8-25 18h-5c-5 0-9-3-11-7-1 4 0 7 3 7z'/%3E%3Cpath d='M230 45c-13 0-21 8-21 19 0 11 9 19 23 19h62c13 0 23-8 23-19 0-10-9-18-20-18-3-11-13-19-26-19-12 0-23 8-25 18h-5c-5 0-9-3-11-7-1 4 0 7 3 7z'/%3E%3Cpath d='M150 135c-13 0-21 8-21 19 0 11 9 19 23 19h62c13 0 23-8 23-19 0-10-9-18-20-18-3-11-13-19-26-19-12 0-23 8-25 18h-5c-5 0-9-3-11-7-1 4 0 7 3 7z'/%3E%3Cpath d='M35 215c-13 0-21 8-21 19 0 11 9 19 23 19h62c13 0 23-8 23-19 0-10-9-18-20-18-3-11-13-19-26-19-12 0-23 8-25 18h-5c-5 0-9-3-11-7-1 4 0 7 3 7z'/%3E%3Cpath d='M240 225c-13 0-21 8-21 19 0 11 9 19 23 19h62c13 0 23-8 23-19 0-10-9-18-20-18-3-11-13-19-26-19-12 0-23 8-25 18h-5c-5 0-9-3-11-7-1 4 0 7 3 7z'/%3E%3C/g%3E%3C/svg%3E");
  background-repeat:repeat;
  background-size:360px 300px;
  /* make the layer wider than the screen so it can slide one tile (360px) and loop seamlessly */
  width:calc(100% + 360px);
  animation:cloud-drift 60s linear infinite;   /* ← EDIT 60s: bigger = slower clouds */
}
@keyframes cloud-drift{
  from{ transform:translateX(0); }
  to{ transform:translateX(-360px); }   /* one full tile-width = seamless loop */
}
/* film grain disabled so the bright cloud sky stays crisp (was muting the blue) */
a{ color:var(--neon); text-decoration:none; }
a:hover{ text-decoration:underline; }

/* ===== MySpace top nav strip ===== */
.msnav{
  position:sticky; top:0; z-index:50;
  display:flex; align-items:center; justify-content:center; gap:18px;
  padding:7px 18px;
  min-height:54px;   /* room for the Whois logo */
  background:linear-gradient(180deg, #3f7cc4, #2b5fb0);
  border-bottom:1px solid #1f4a8c;
  box-shadow:0 2px 8px rgba(20,50,100,.35);
  font-family:var(--mono);
  font-size:11px; letter-spacing:.5px;
}
.msnav__brand-link{
  position:absolute; left:18px; top:50%; transform:translateY(-50%);
  display:flex; align-items:center;
  background:rgba(255,255,255,.92); border-radius:22px;
  padding:5px 14px 5px 10px; box-shadow:0 1px 4px rgba(20,50,100,.35);
}
.msnav__brand-link:hover{ background:#fff; }
.msnav__brand-logo{
  height:28px; width:auto; display:block;   /* ← EDIT to resize the Whois wordmark */
}
/* the row of nav links */
.msnav__links{ display:flex; align-items:center; gap:18px; }
/* hamburger toggle — hidden on desktop, shown on phone */
.msnav__toggle{
  display:none; position:absolute; right:16px; top:50%; transform:translateY(-50%);
  width:40px; height:36px; padding:8px 9px; cursor:pointer; z-index:2;
  background:rgba(255,255,255,.92); border:1px solid rgba(255,255,255,.6); border-radius:8px;
  box-shadow:0 1px 4px rgba(20,50,100,.35);
  flex-direction:column; justify-content:space-between;
}
.msnav__toggle span{ display:block; height:2px; width:100%; background:#2b5fb0; border-radius:2px; transition:transform .2s ease, opacity .2s ease; }
/* turn the hamburger into an X when open */
.msnav.is-open .msnav__toggle span:nth-child(1){ transform:translateY(8px) rotate(45deg); }
.msnav.is-open .msnav__toggle span:nth-child(2){ opacity:0; }
.msnav.is-open .msnav__toggle span:nth-child(3){ transform:translateY(-8px) rotate(-45deg); }
.msnav__brand{ color:#ffffff; text-transform:lowercase; font-weight:700; }
.msnav__brand span{ color:#cfe0f5; }
.msnav a{ color:#eaf2ff; text-transform:lowercase; }
.msnav a:hover{ color:#fff; text-decoration:none; text-shadow:0 0 8px rgba(255,255,255,.6); }
.msnav__status{ color:#cfe0f5; display:flex; align-items:center; gap:6px; }
.msnav__logo{
  margin-left:auto;            /* push to far right */
  height:46px; width:auto;     /* ← EDIT to resize the Whois logo in the nav */
  filter:drop-shadow(0 1px 3px rgba(0,0,0,.45));  /* subtle shadow so it reads on any bg */
}
.msnav__status i{
  width:7px; height:7px; border-radius:50%; background:#2bd66f;
  box-shadow:0 0 8px #2bd66f; animation:pulse 2s infinite;
}
@keyframes pulse{ 0%,100%{opacity:1} 50%{opacity:.35} }

.page{ max-width:920px; margin:0 auto; padding:16px 14px 60px; }

/* ===== HERO ===== */
.hero{
  position:relative; height:clamp(260px,42vw,440px);
  margin:14px 0 16px; overflow:hidden;
  border:1px solid var(--hair); border-radius:6px;
}
.hero__bg{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; filter:saturate(1.05) contrast(1.05);
}
/* logo-style hero (square art on black): show it whole, offset up so the
   BELINSKII name sits in the open space below the chain, not on the text */
.hero--logo .hero__bg{
  object-fit:contain;
  object-position:center 6%;    /* logo near the top, full square visible */
  padding:14px 0 0;
  transform:scale(.86);         /* breathing room so nothing clips at edges */
  transform-origin:center top;
}
.hero--logo{ background:#000; height:clamp(340px,46vw,520px); }
.hero--logo .hero__veil{
  background:linear-gradient(180deg, rgba(5,6,8,0) 45%, rgba(5,6,8,.6) 72%, rgba(5,6,8,.98) 100%);
}
/* center the name along the bottom, clear of the logo above */
.hero--logo .hero__name{ left:0; right:0; bottom:clamp(14px,3vw,28px); text-align:center; }
.hero__veil{
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(5,6,8,.15) 0%, rgba(5,6,8,.55) 55%, rgba(5,6,8,.96) 100%);
}
.hero__name{ position:absolute; left:clamp(18px,5vw,46px); bottom:clamp(18px,4vw,40px); }
.hero__kicker{
  margin:0 0 2px; font-family:var(--mono); font-size:12px; letter-spacing:5px;
  color:var(--neon); text-transform:lowercase;
}
.hero__title{
  margin:0; font-family:var(--serif);
  font-size:clamp(56px,12vw,140px); line-height:.86; letter-spacing:2px;
  color:#fff;
  text-shadow:0 0 18px rgba(30,111,255,.65), 0 0 46px rgba(30,111,255,.35);
  animation:rise .9s cubic-bezier(.2,.8,.2,1) both;
}
.hero__tag{
  margin:10px 0 0; font-size:13px; letter-spacing:1.5px; color:var(--ink-dim);
  text-transform:uppercase;
}
.blink{ color:var(--neon); animation:blink 1.4s steps(1) infinite; }
@keyframes blink{ 50%{opacity:.25} }
@keyframes rise{ from{ opacity:0; transform:translateY(22px) } to{ opacity:1; transform:none } }

/* ===== two-column layout ===== */
.cols{ display:grid; grid-template-columns:248px 1fr; gap:16px; align-items:start; }

/* ===== boxes (the MySpace panels) ===== */
.box{
  background:linear-gradient(180deg, var(--panel-2), var(--panel));
  border:1px solid var(--hair); border-radius:6px; overflow:hidden;
  margin-bottom:16px;
  animation:fade .6s ease both;
}
.col--right .box:nth-child(1){ animation-delay:.05s }
.col--right .box:nth-child(2){ animation-delay:.12s }
.col--right .box:nth-child(3){ animation-delay:.19s }
.col--right .box:nth-child(4){ animation-delay:.26s }
@keyframes fade{ from{opacity:0; transform:translateY(10px)} to{opacity:1; transform:none} }

.box__title{
  margin:0; padding:8px 12px;
  font-family:var(--mono); font-size:12px; letter-spacing:.5px; text-transform:lowercase;
  color:#ffffff;
  background:linear-gradient(180deg, var(--neon), #1f4a8c);
  box-shadow:inset 0 -1px 0 rgba(0,0,0,.3);
}
.box__body{ padding:14px; }

/* profile card */
.box--profile .box__body,
.profile{ padding:12px; text-align:center; }
.profile__pic{
  width:100%; aspect-ratio:1; object-fit:cover; border-radius:4px;
  border:1px solid var(--neon); box-shadow:0 0 22px var(--neon-soft);
}
.profile__name{
  margin:10px 0 0; font-family:var(--serif); font-size:24px; letter-spacing:1px; color:var(--ink);
}
.profile__mood{ margin:2px 0 8px; font-size:13px; color:var(--ink-dim); font-style:italic; }
.profile__status{
  margin:0 0 8px; display:flex; align-items:center; justify-content:center; gap:6px;
  font-family:var(--mono); font-size:11px; color:var(--ink-dim); text-transform:lowercase;
}
.profile__status i{
  width:7px; height:7px; border-radius:50%; background:#2bd66f;
  box-shadow:0 0 8px #2bd66f; animation:pulse 2s infinite;
}
.viewmy{ margin:0; font-family:var(--mono); font-size:11px; color:var(--ink-dim); }

/* contact list */
.contact{ list-style:none; margin:0; padding:0; }
.contact li{ border-bottom:1px dashed var(--hair); }
.contact li:last-child{ border-bottom:0; }
.contact a{
  display:block; padding:7px 4px; color:var(--neon); font-size:13px;
  transition:padding-left .15s ease, color .15s ease;
}
.contact a::before{ content:"› "; color:var(--neon); }
.contact a:hover{ padding-left:8px; color:#0c2a55; text-decoration:none; background:var(--neon-soft); }

/* general-info table */
.info{ width:100%; border-collapse:collapse; font-size:13px; }
.info th{
  text-align:left; vertical-align:top; padding:5px 10px 5px 0; white-space:nowrap;
  color:var(--neon); font-weight:500; font-family:var(--mono); font-size:11px; text-transform:lowercase;
}
.info td{ padding:5px 0; color:var(--ink); }
.info tr + tr th, .info tr + tr td{ border-top:1px solid var(--hair); }

/* url */
.box--url .url{ font-family:var(--mono); font-size:13px; word-break:break-all; }

/* story blurb */
.blurb p{ margin:0 0 12px; }
.blurb p:last-child{ margin-bottom:0; }
.blurb strong{ color:var(--neon); }

/* ===== custom audio player ===== */
.player{
  display:flex; align-items:center; gap:14px;
  padding:14px; border-radius:5px;
  background:radial-gradient(120% 140% at 0% 0%, rgba(43,95,176,.08), transparent 60%), var(--panel-2);
  border:1px solid var(--neon-soft);
}
.player__btn{
  flex:0 0 auto; width:52px; height:52px; border-radius:50%;
  border:1px solid var(--neon); background:#ffffff; color:var(--neon);
  font-size:16px; cursor:pointer;
  box-shadow:0 0 0 0 rgba(30,111,255,.5);
  transition:transform .12s ease, box-shadow .25s ease, background .2s ease;
}
.player__btn:hover{ background:var(--neon); color:#ffffff; box-shadow:0 0 22px var(--neon); transform:scale(1.05); }
.is-playing .player__btn{ box-shadow:0 0 26px var(--neon); }
.player__main{ flex:1; min-width:0; }
.player__meta{ display:flex; gap:6px; align-items:baseline; margin-bottom:8px; }
.player__song{ font-weight:700; color:var(--ink); }
.player__artist{ color:var(--ink-dim); font-size:13px; }
.player__seek{
  -webkit-appearance:none; appearance:none; width:100%; height:5px; border-radius:3px;
  --fill:0%;
  background:linear-gradient(90deg, var(--neon) var(--fill), #cdd8ea var(--fill));
  cursor:pointer;
}
.player__seek::-webkit-slider-thumb{
  -webkit-appearance:none; width:14px; height:14px; border-radius:50%;
  background:#fff; border:2px solid var(--neon); box-shadow:0 0 10px var(--neon); cursor:pointer;
}
.player__seek::-moz-range-thumb{
  width:14px; height:14px; border-radius:50%; background:#fff;
  border:2px solid var(--neon); box-shadow:0 0 10px var(--neon); cursor:pointer;
}
.player__time{ margin-top:6px; font-family:var(--mono); font-size:11px; color:var(--ink-dim); }
.player__note{ margin:10px 0 0; font-size:12px; color:var(--ink-dim); }
.player__note code{ color:var(--neon); background:rgba(30,111,255,.1); padding:1px 5px; border-radius:3px; }

/* playlist */
.playlist{ list-style:none; margin:12px 0 0; padding:0; counter-reset:none; }
.playlist__item{
  display:flex; align-items:center; gap:12px;
  padding:9px 12px; border:1px solid var(--hair); border-radius:5px;
  margin-bottom:6px; cursor:pointer; color:var(--ink);
  background:var(--panel-2); transition:background .15s ease, border-color .15s ease, transform .12s ease;
}
.playlist__item:hover{ background:var(--neon-soft); border-color:var(--neon); transform:translateX(2px); }
.playlist__no{
  flex:0 0 auto; width:22px; text-align:center;
  font-family:var(--mono); font-size:12px; color:var(--ink-dim);
}
.playlist__t{ flex:1; font-weight:500; }
.tag-unrel{
  font-style:normal; font-family:var(--mono); font-size:9px; letter-spacing:.5px;
  text-transform:uppercase; color:var(--neon);
  border:1px solid var(--neon); border-radius:20px; padding:1px 7px;
  margin-left:6px; vertical-align:middle; white-space:nowrap;
}
.playlist__cr{ font-size:12px; color:var(--ink-dim); }
.playlist__item.is-active{
  background:linear-gradient(90deg, var(--neon-soft), transparent);
  border-color:var(--neon);
}
.playlist__item.is-active .playlist__no{ color:var(--neon); }
.playlist__item.is-active .playlist__t{ color:var(--neon); font-weight:700; }
/* show an equalizer-ish dot on the active+playing row's number */
.is-playing .playlist__item.is-active .playlist__no::before{
  content:"♪"; color:var(--neon); text-shadow:0 0 8px var(--neon);
}
.is-playing .playlist__item.is-active .playlist__no{ font-size:0; }
.is-playing .playlist__item.is-active .playlist__no::before{ font-size:13px; }

/* ===== "Stream it:" per-song links (shown in the player for released tracks) ===== */
.player__links{ display:flex; flex-wrap:wrap; align-items:center; gap:8px; margin-top:10px; }
.player__links-label{
  font-family:var(--mono); font-size:10px; letter-spacing:.5px;
  text-transform:uppercase; color:var(--ink-dim);
}
.player__link{
  font-family:var(--mono); font-size:10px; letter-spacing:.5px; text-transform:uppercase;
  color:var(--neon); background:#ffffff;
  border:1px solid var(--neon-soft); border-radius:20px; padding:3px 10px;
  transition:color .15s ease, background .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.player__link:hover{
  color:#ffffff; background:var(--neon); border-color:var(--neon);
  box-shadow:0 0 12px var(--neon); text-decoration:none;
}

/* ===== gallery ===== */
.gallery{ display:grid; grid-template-columns:repeat(4,1fr); gap:8px; }
.gallery__item{ position:relative; overflow:hidden; border-radius:4px; border:1px solid var(--hair); }
.gallery__item img{
  display:block; width:100%; aspect-ratio:1; object-fit:cover;
  filter:grayscale(.25) brightness(.92);
  transition:transform .35s ease, filter .35s ease;
}
.gallery__item:hover img{ transform:scale(1.08); filter:none; }
.gallery__item::after{
  content:""; position:absolute; inset:0; box-shadow:inset 0 0 0 0 var(--neon);
  transition:box-shadow .25s ease;
}
.gallery__item:hover::after{ box-shadow:inset 0 0 0 2px var(--neon); }

/* ===== links / follow buttons ===== */
.links{ display:flex; flex-wrap:wrap; gap:9px; }
.links__btn{
  padding:9px 16px; border-radius:30px; font-family:var(--mono); font-size:12px;
  color:var(--neon); background:#ffffff; border:1px solid var(--neon-soft);
  transition:all .18s ease;
}
.links__btn:hover{
  color:#ffffff; background:var(--neon); border-color:var(--neon);
  box-shadow:0 0 18px var(--neon); text-decoration:none; transform:translateY(-2px);
}

/* ===== footer ===== */
.foot{
  margin-top:26px; padding:14px 18px; border-radius:6px;
  background:rgba(255,255,255,.85); border:1px solid var(--hair);
  text-align:center; font-family:var(--mono); font-size:11px; color:var(--ink-dim);
}

/* ===== music deep-dive page (music.html) ===== */
.msnav a.is-current{ color:#fff; font-weight:700; text-shadow:0 0 8px rgba(255,255,255,.6); }

.backlink{
  display:inline-block; margin:4px 0 14px;
  font-family:var(--mono); font-size:12px; color:#fff;
  background:rgba(43,95,176,.55); padding:6px 12px; border-radius:20px;
  border:1px solid rgba(255,255,255,.5);
}
.backlink:hover{ background:var(--neon); text-decoration:none; }

.musichero{
  background:rgba(255,255,255,.92); border:1px solid var(--hair); border-radius:6px;
  padding:22px 20px; margin-bottom:16px; text-align:center;
}
.musichero__title{
  margin:0; font-family:var(--serif); font-size:clamp(40px,9vw,76px);
  letter-spacing:1px; color:var(--ink); line-height:.95;
}
.musichero__sub{ margin:8px 0 0; font-family:var(--mono); font-size:12px; color:var(--ink-dim); }

/* big now-playing player */
.bigplayer{ display:flex; gap:18px; align-items:center; }
.bigplayer__art{
  flex:0 0 auto; width:120px; height:120px; border-radius:8px;
  display:flex; align-items:center; justify-content:center;
  background:radial-gradient(circle at 30% 30%, #2b5fb0, #0d2a55);
  border:1px solid var(--neon); box-shadow:0 0 22px var(--neon-soft);
  overflow:hidden;
}
.bigplayer__art img{ width:100%; height:100%; object-fit:cover; }   /* drop real cover art later */
.bigplayer__disc{ font-size:48px; color:#fff; opacity:.85; }
.is-playing .bigplayer__disc{ animation:spin 3s linear infinite; }
@keyframes spin{ to{ transform:rotate(360deg) } }
.bigplayer__main{ flex:1; min-width:0; }
.bigplayer__controls{ display:flex; align-items:center; gap:14px; margin-top:4px; }
.bigplayer__bar{ flex:1; min-width:0; }

@media (max-width:640px){
  .bigplayer{ flex-direction:column; text-align:center; }
  .bigplayer__art{ width:160px; height:160px; }
  .bigplayer__controls{ width:100%; }
}

/* ===== photos deep-dive page (photos.html) ===== */
.photogrid{ display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }
.photo{
  position:relative; overflow:hidden; border-radius:6px;
  border:1px solid var(--hair); cursor:pointer; aspect-ratio:1;
  background:var(--panel-2);
}
.photo img{
  display:block; width:100%; height:100%; object-fit:cover;
  transition:transform .35s ease, filter .35s ease; filter:brightness(.96);
}
.photo:hover img{ transform:scale(1.06); filter:none; }
.photo::after{
  content:""; position:absolute; inset:0; box-shadow:inset 0 0 0 0 var(--neon);
  transition:box-shadow .25s ease; pointer-events:none;
}
.photo:hover::after{ box-shadow:inset 0 0 0 3px var(--neon); }

/* lightbox (fullscreen photo viewer) */
body.lb-open{ overflow:hidden; }   /* stop background scroll while open */
.lightbox[hidden]{ display:none; }  /* keep it hidden until a photo is clicked */
.lightbox{
  position:fixed; inset:0; z-index:1000;
  display:flex; align-items:center; justify-content:center;
  background:rgba(6,14,30,.92); backdrop-filter:blur(4px);
}
.lightbox__img{
  max-width:90vw; max-height:85vh; border-radius:8px;
  border:2px solid var(--neon); box-shadow:0 0 40px rgba(43,95,176,.6);
}
.lightbox__close, .lightbox__nav{
  position:absolute; background:rgba(255,255,255,.12); color:#fff;
  border:1px solid rgba(255,255,255,.4); cursor:pointer;
  font-family:var(--mono); line-height:1; border-radius:50%;
  transition:background .15s ease, transform .15s ease;
}
.lightbox__close{ top:18px; right:18px; width:44px; height:44px; font-size:26px; }
.lightbox__nav{ top:50%; transform:translateY(-50%); width:52px; height:52px; font-size:32px; }
.lightbox__nav--prev{ left:14px; }
.lightbox__nav--next{ right:14px; }
.lightbox__close:hover, .lightbox__nav:hover{ background:var(--neon); }
.lightbox__nav:hover{ transform:translateY(-50%) scale(1.08); }

@media (max-width:640px){
  .photogrid{ grid-template-columns:repeat(2,1fr); }
  .lightbox__nav{ width:42px; height:42px; font-size:26px; }
}

/* ===== responsive: stack columns on small screens ===== */
@media (max-width:640px){
  /* dissolve the two columns so every box becomes a single stacked flow,
     then set a custom phone order (desktop layout is untouched). */
  .cols{ display:flex; flex-direction:column; }
  .col--left, .col--right{ display:contents; }

  /* phone order: profile → bio → music → general info → pics → follow → contacting → url */
  .box--profile { order:1; }
  #story        { order:2; }   /* who is belinskii / bio */
  #music        { order:3; }
  #general-info { order:4; }
  #pics         { order:5; }
  #links        { order:6; }   /* find me / follow me */
  #contacting   { order:7; }
  .box--url     { order:8; }

  .gallery{ grid-template-columns:repeat(2,1fr); }

  /* ---- phone nav: logo centered, hamburger right, links in a dropdown ---- */
  /* 3-column grid: [left spacer] [centered logo] [hamburger] — all within viewport */
  .msnav{
    display:grid; grid-template-columns:40px minmax(0,1fr) 40px; align-items:center;
    gap:0; padding:8px 12px; min-height:50px; width:100%; box-sizing:border-box;
  }
  .msnav__brand-link{
    position:static; transform:none;
    grid-column:2; justify-self:center;     /* logo centered in the middle column */
    max-width:100%;
  }
  .msnav__toggle{
    display:flex; position:static; transform:none;
    grid-column:3; justify-self:end;        /* hamburger in the right column */
  }

  /* links hidden by default; shown as a dropdown panel when menu is open */
  .msnav__links{
    display:none; position:absolute; top:100%; left:0; right:0;
    flex-direction:column; align-items:stretch; gap:0;
    background:#2b5fb0; border-bottom:1px solid #1f4a8c;
    box-shadow:0 8px 16px rgba(20,50,100,.35);
  }
  .msnav.is-open .msnav__links{ display:flex; }
  .msnav__links a{
    padding:14px 18px; border-top:1px solid rgba(255,255,255,.12);
    font-size:14px; text-align:center;
  }
  .msnav__status{ display:none; }
}

@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; scroll-behavior:auto; }
}
