*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --black:         #040306;
  --charcoal:      #080710;
  --charcoal-2:    #0d0c18;
  --charcoal-3:    #131220;
  --charcoal-4:    #1a1828;
  --charcoal-5:    #221f32;

  --purple:        #7b3fe4;
  --purple-mid:    #9d6aea;
  --purple-light:  #cdb8f8;
  --purple-pale:   #e4dcfd;

  --silver:        #dedad0;
  --silver-mid:    #b8b2cc;
  --silver-dim:    #807890;
  --silver-faint:  #4e4860;

  --white:         #f2eeff;
  --border:        rgba(210,200,245,0.08);
  --border-mid:    rgba(210,200,245,0.15);
  --border-hi:     rgba(210,200,245,0.26);

  --serif: 'Cormorant Garamond',Georgia,serif;
  --sans:  'Outfit',system-ui,sans-serif;
  --mono:  'Fira Code',monospace;

  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 14px;

  --ease: cubic-bezier(0.4,0,0.2,1);
  --t:  0.30s;
  --tf: 0.18s;

  --nav-h: 68px;
}

html{
  background:var(--black);
  color:var(--white);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.6;
  scroll-behavior:smooth;
  -webkit-font-smoothing:antialiased;
}

body{min-height:100vh;position:relative;}
/* overflow-x lives below header — overflow on body breaks position:sticky (Chrome/WebKit) */
.site-scroll-wrap{
  overflow-x:clip;
  width:100%;
}

/* ── BACKGROUND LAYERS ── */
body::before{
  content:'';position:fixed;inset:0;z-index:0;
  background:var(--charcoal);
}

body::after{
  content:'';position:fixed;inset:0;z-index:1;pointer-events:none;
  opacity:0.042;
  background-image:
    linear-gradient(45deg,var(--silver) 0.5px,transparent 0.5px),
    linear-gradient(-45deg,var(--silver) 0.5px,transparent 0.5px);
  background-size:48px 48px;
  background-position:0 0,24px 0;
}

.bloom{
  position:fixed;top:-200px;left:50%;transform:translateX(-50%);
  width:1000px;height:800px;border-radius:50%;pointer-events:none;z-index:2;
  background:radial-gradient(ellipse at center,
    rgba(123,63,228,0.28) 0%,
    rgba(123,63,228,0.13) 27%,
    rgba(123,63,228,0.04) 56%,
    transparent 74%
  );
}

.grain{
  position:fixed;inset:0;z-index:3;pointer-events:none;opacity:0.26;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='320' height='320'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.78' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='320' height='320' filter='url(%23g)' opacity='1'/%3E%3C/svg%3E");
  background-repeat:repeat;background-size:320px 320px;
}

main,footer{position:relative;z-index:10;}

/* ── STICKY HEADER (drawer is sibling of nav so fixed panel isn’t trapped by nav backdrop-filter) ── */
.site-header{
  position:sticky;top:0;z-index:250;
  box-sizing:border-box;
  height:var(--nav-h);
  display:flex;align-items:center;justify-content:flex-start;
  gap:0.75rem;flex-wrap:nowrap;
  padding:0 3rem;
  border-bottom:1px solid var(--border);
  background:rgba(8,7,16,0.85);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
}

nav.site-nav{
  flex:0 1 auto;
  display:flex;align-items:center;justify-content:flex-start;
  gap:0.75rem;
  min-width:0;height:100%;
}

.nav-logo{
  display:flex;align-items:center;text-decoration:none;flex-shrink:1;
  min-width:0;max-width:72%;
}
.nav-logo img{
  display:block;width:auto;max-width:100%;
  height:clamp(22px,5.2vw,34px);
  object-fit:contain;
  filter:brightness(1.08);
}

.nav-toggle{
  display:none;
  flex-shrink:0;
  align-items:center;justify-content:center;
  min-width:44px;min-height:44px;padding:0;margin:0;
  border:1px solid var(--border-mid);border-radius:var(--radius-md);
  background:rgba(123,63,228,0.1);
  color:var(--purple-light);
  cursor:pointer;
  transition:background var(--tf) var(--ease),border-color var(--tf) var(--ease),color var(--tf) var(--ease);
}
.nav-toggle:hover{background:rgba(123,63,228,0.2);border-color:var(--border-hi);color:var(--white);}
.nav-toggle-box{
  position:relative;width:22px;height:16px;display:flex;flex-direction:column;justify-content:space-between;
}
.nav-toggle-line{
  display:block;height:2px;width:100%;border-radius:1px;background:currentColor;
  transition:transform var(--t) var(--ease),opacity var(--tf) var(--ease);
  transform-origin:center;
}
.site-nav-open .nav-toggle-line:nth-child(1){transform:translateY(7px) rotate(45deg);}
.site-nav-open .nav-toggle-line:nth-child(2){opacity:0;}
.site-nav-open .nav-toggle-line:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

.nav-drawer{
  flex:1;
  display:flex;align-items:center;justify-content:flex-end;min-width:0;
}

.nav-links{display:flex;align-items:center;gap:2.25rem;list-style:none;margin:0;padding:0;}
.nav-links a{
  color:var(--silver-mid);text-decoration:none;
  font-size:0.77rem;font-weight:500;letter-spacing:0.15em;text-transform:uppercase;
  transition:color var(--tf) var(--ease);
}
.nav-links a:hover{color:var(--white);}

.nav-ventures{
  color:var(--purple-light) !important;
  border:1px solid rgba(205,184,248,0.22);
  padding:0.32rem 0.8rem;
  border-radius:var(--radius-sm);
  transition:color var(--tf) var(--ease),border-color var(--tf) var(--ease),background var(--tf) var(--ease) !important;
}
.nav-ventures:hover{
  color:var(--white) !important;
  border-color:rgba(205,184,248,0.45) !important;
  background:rgba(123,63,228,0.14) !important;
}

@media (max-width:768px){
  :root{--nav-h:56px;}
  /* Fixed bar: iOS/WebKit often breaks position:sticky on headers that use backdrop-filter
     or contain transformed children (the off-canvas drawer). */
  html{scroll-padding-top:var(--nav-h);}
  .site-header{
    position:fixed;
    left:0;right:0;top:0;width:100%;max-width:100%;
    -webkit-backdrop-filter:none;
    backdrop-filter:none;
    background:rgba(8,7,16,0.97);
    padding:0 max(1.25rem, env(safe-area-inset-right, 0px)) 0 max(1.25rem, env(safe-area-inset-left, 0px));
  }
  .site-scroll-wrap{margin-top:var(--nav-h);}
  nav.site-nav{flex:1;justify-content:space-between;}
  .nav-logo{max-width:calc(100% - 56px);}
  .nav-logo img{height:clamp(20px,7vw,28px);max-height:28px;}
  .nav-toggle{display:inline-flex;}
  .nav-drawer{
    position:fixed;z-index:260;
    top:var(--nav-h);left:0;right:0;bottom:0;
    flex:none;justify-content:stretch;align-items:stretch;
    padding:0.75rem max(1.25rem, env(safe-area-inset-right, 0px)) max(2rem, env(safe-area-inset-bottom, 0px)) max(1.25rem, env(safe-area-inset-left, 0px));
    background:rgba(8,7,16,0.97);
    backdrop-filter:blur(16px);
    -webkit-backdrop-filter:blur(16px);
    border-bottom:1px solid var(--border);
    box-shadow:0 24px 48px rgba(0,0,0,0.55);
    overflow-y:auto;
    overscroll-behavior:contain;
    -webkit-overflow-scrolling:touch;
    visibility:hidden;opacity:0;
    transform:translateX(100%);
    pointer-events:none;
    transition:
      transform var(--t) var(--ease),
      opacity var(--t) var(--ease),
      visibility 0s linear var(--t);
  }
  body.site-nav-open .nav-drawer{
    visibility:visible;opacity:1;transform:translateX(0);pointer-events:auto;
    transition-delay:0s,0s,0s;
  }
  .nav-links{
    flex-direction:column;align-items:stretch;gap:0;
    width:100%;max-width:420px;margin-left:auto;
  }
  .nav-links li{
    border-bottom:1px solid var(--border);
  }
  .nav-links a{
    display:block;padding:1rem 0;font-size:0.82rem;letter-spacing:0.12em;
  }
  .nav-links a.nav-ventures{
    margin-top:0.35rem;padding:0.65rem 0.85rem;
    border:1px solid rgba(205,184,248,0.25);
    border-radius:var(--radius-md);
    text-align:center;
  }
  .nav-links li:last-child{border-bottom:none;padding-top:0.25rem;}
  body.site-nav-open{overflow:hidden;}
}

@media (max-width:400px){
  :root{--nav-h:52px;}
  .nav-logo img{height:clamp(18px,9vw,24px);}
}

/* ── HERO ── */
.hero{
  padding:6.5rem 3rem 5.5rem;
  max-width:1100px;margin:0 auto;text-align:center;
}

.hero-roles{
  display:flex;align-items:center;justify-content:center;
  gap:0.65rem;margin-bottom:2.5rem;flex-wrap:wrap;
}
.hero-role{
  font-family:var(--mono);font-size:0.68rem;font-weight:400;
  letter-spacing:0.26em;text-transform:uppercase;color:var(--purple-light);
}
.hero-sep{width:3px;height:3px;border-radius:50%;background:var(--purple-mid);opacity:0.7;flex-shrink:0;}
.hero-line{display:block;width:60px;height:1px;background:linear-gradient(90deg,transparent,var(--purple-mid),transparent);}

/* Narrow view: role row + gradient lines wrap badly; headline + portals still carry the story. */
@media (max-width:768px){
  .hero-roles{display:none;}
}

.hero h1{
  font-family:var(--serif);font-size:clamp(3.4rem,7.5vw,6.5rem);
  font-weight:700;line-height:1.0;letter-spacing:-0.01em;
  color:var(--white);margin-bottom:0.3rem;
}
.hero h1 em{font-style:italic;font-weight:300;color:var(--purple-light);}

.hero-tagline{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(1.05rem,2vw,1.25rem);
  color:var(--silver);margin-bottom:2.75rem;letter-spacing:0.02em;
}

.hero-body{
  max-width:580px;margin:0 auto 3.75rem;
  font-size:0.93rem;font-weight:300;color:var(--silver);line-height:1.9;
}
.hero-body strong{color:var(--white);font-weight:500;}

/* CHOOSE PROMPT — matches eyebrow treatment */
.choose-prompt{
  display:inline-flex;align-items:center;gap:0.85rem;
  font-family:var(--mono);font-size:0.68rem;font-weight:400;
  letter-spacing:0.22em;text-transform:uppercase;
  color:var(--purple-light);opacity:0.88;
}
.choose-prompt::before,.choose-prompt::after{
  content:'';display:block;height:1px;width:52px;
  background:linear-gradient(90deg,transparent,var(--purple-mid));
}
.choose-prompt::after{background:linear-gradient(90deg,var(--purple-mid),transparent);}

/* ── PORTALS ── */
.portals-section{
  max-width:1100px;margin:0 auto;
  padding:0 3rem 5rem;
}

.portals-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  grid-auto-rows:1fr;
  gap:1.35rem;
}

.portal{
  background:var(--charcoal-2);
  border:1px solid var(--border-mid);
  border-radius:var(--radius-lg);
  padding:2.25rem 2rem 2.5rem;
  text-decoration:none;color:var(--white);
  display:flex;flex-direction:column;
  position:relative;overflow:hidden;
  min-height:320px;
  transition:
    background var(--t) var(--ease),
    border-color var(--t) var(--ease),
    transform var(--t) var(--ease),
    box-shadow var(--t) var(--ease);
}

.portal::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  border-radius:var(--radius-lg) var(--radius-lg) 0 0;
}
.portal::after{
  content:'';position:absolute;inset:0;border-radius:var(--radius-lg);
  opacity:0;transition:opacity var(--t) var(--ease);pointer-events:none;
}

.portal:hover{
  background:var(--charcoal-3);
  border-color:var(--border-hi);
  transform:translateY(-5px);
  box-shadow:0 18px 44px rgba(0,0,0,0.55),0 0 0 1px var(--border-hi);
}
.portal:hover::after{opacity:1;}

.portal-dev::before   {background:linear-gradient(90deg,#3db8a4,#2a8a7a);}
.portal-music::before {background:linear-gradient(90deg,var(--purple-light),var(--purple-mid));}
.portal-author::before{background:linear-gradient(90deg,#d4b87a,#a08848);}
.portal-emcee::before {background:linear-gradient(90deg,#b080f0,var(--purple));}

.portal-dev::after   {background:radial-gradient(ellipse at top left,rgba(61,184,164,0.07),transparent 70%);}
.portal-music::after {background:radial-gradient(ellipse at top left,rgba(157,106,234,0.08),transparent 70%);}
.portal-author::after{background:radial-gradient(ellipse at top left,rgba(212,184,122,0.07),transparent 70%);}
.portal-emcee::after {background:radial-gradient(ellipse at top left,rgba(123,63,228,0.09),transparent 70%);}

.portal-number{
  font-family:var(--mono);font-size:0.6rem;letter-spacing:0.18em;
  color:var(--silver-faint);margin-bottom:1.4rem;
  display:flex;align-items:center;gap:0.6rem;position:relative;z-index:1;
}
.portal-number::after{content:'';flex:1;height:1px;background:var(--border);}

.portal-icon-wrap{
  width:46px;height:46px;border-radius:var(--radius-md);
  border:1px solid var(--border-mid);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:1.25rem;
  transition:border-color var(--t) var(--ease),background var(--t) var(--ease);
  position:relative;z-index:1;flex-shrink:0;
}

.portal-dev .portal-icon-wrap   {color:#3db8a4;background:rgba(61,184,164,0.09);}
.portal-music .portal-icon-wrap {color:var(--purple-light);background:rgba(157,106,234,0.11);}
.portal-author .portal-icon-wrap{color:#d4b87a;background:rgba(212,184,122,0.09);}
.portal-emcee .portal-icon-wrap {color:#c09af0;background:rgba(123,63,228,0.11);}
.portal:hover .portal-icon-wrap{border-color:var(--border-hi);}

.portal-tag{
  font-family:var(--mono);font-size:0.64rem;letter-spacing:0.2em;
  text-transform:uppercase;margin-bottom:0.5rem;
  font-weight:400;position:relative;z-index:1;
}

.portal-dev .portal-tag   {color:#3db8a4;}
.portal-music .portal-tag {color:var(--purple-light);}
.portal-author .portal-tag{color:#d4b87a;}
.portal-emcee .portal-tag {color:#c09af0;}

.portal h2{
  font-family:var(--serif);font-size:1.75rem;font-weight:600;
  line-height:1.1;margin-bottom:0.85rem;
  color:var(--white);position:relative;z-index:1;
}

.portal p{
  font-size:0.86rem;font-weight:300;color:var(--silver-mid);
  line-height:1.85;flex:1;margin-bottom:1.5rem;position:relative;z-index:1;
}

.portal-cta{
  display:inline-flex;align-items:center;gap:0.42rem;
  font-size:0.72rem;font-weight:500;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--silver-mid);text-decoration:none;
  padding-bottom:2px;border-bottom:1px solid var(--border-mid);
  transition:color var(--tf) var(--ease),border-color var(--tf) var(--ease);
  position:relative;z-index:1;width:fit-content;
}
.portal:hover .portal-cta{color:var(--white);border-color:var(--border-hi);}

.portal-cta-arrow{transition:transform var(--tf) var(--ease);display:inline-block;font-size:0.84rem;}
.portal:hover .portal-cta-arrow{transform:translate(2px,-2px);}

/* ── FIND ME ── */
.social-section{
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  padding:3.5rem 3rem;
  background:linear-gradient(180deg,transparent 0%,rgba(123,63,228,0.05) 50%,transparent 100%);
}
.social-inner{
  max-width:1100px;margin:0 auto;
  display:flex;flex-direction:column;align-items:center;gap:2.25rem;
}

/* matches eyebrow style */
.social-heading{
  font-family:var(--mono);font-size:0.68rem;font-weight:400;
  letter-spacing:0.22em;text-transform:uppercase;
  color:var(--purple-light);opacity:0.88;
  display:flex;align-items:center;gap:0.85rem;
}
.social-heading::before,.social-heading::after{
  content:'';display:block;height:1px;width:60px;
  background:linear-gradient(90deg,transparent,var(--purple-mid));
}
.social-heading::after{background:linear-gradient(90deg,var(--purple-mid),transparent);}

.social-buttons{
  display:flex;align-items:stretch;justify-content:center;
  gap:1rem;flex-wrap:wrap;width:100%;max-width:min(100%,920px);
  row-gap:0.75rem;
}

.social-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:0.65rem;
  padding:0.75rem 1.75rem;border-radius:var(--radius-md);
  text-decoration:none;font-size:0.82rem;font-weight:500;letter-spacing:0.05em;
  transition:transform var(--t) var(--ease),box-shadow var(--t) var(--ease),
             border-color var(--t) var(--ease),color var(--t) var(--ease),background var(--t) var(--ease);
  position:relative;overflow:hidden;white-space:nowrap;
  flex:0 1 auto;
  min-width:min(100%,10.5rem);
}
.social-btn-note{
  font-weight:400;letter-spacing:0.03em;opacity:0.88;font-size:0.9em;
}
.social-btn::before{
  content:'';position:absolute;inset:0;opacity:0;
  transition:opacity var(--t) var(--ease);
}
.social-btn:hover{transform:translateY(-3px);}
.social-btn:hover::before{opacity:1;}

.social-btn-linkedin{
  background:rgba(10,102,194,0.14);border:1px solid rgba(10,102,194,0.32);color:#8ec4ff;
}
.social-btn-linkedin::before{background:linear-gradient(135deg,rgba(10,102,194,0.22),rgba(10,102,194,0.08));}
.social-btn-linkedin:hover{
  border-color:rgba(10,102,194,0.6);color:#c0dcff;
  box-shadow:0 10px 30px rgba(10,102,194,0.26),0 0 0 1px rgba(10,102,194,0.28);
}

/* Class name avoids "facebook" substring — many desktop ad blockers hide that in class/id. */
.social-btn-fmusic{
  background:rgba(66,103,178,0.12);border:1px solid rgba(66,103,178,0.28);color:#9ab4f0;
}
.social-btn-fmusic::before{background:linear-gradient(135deg,rgba(66,103,178,0.2),rgba(66,103,178,0.06));}
.social-btn-fmusic:hover{
  border-color:rgba(66,103,178,0.55);color:#bdd0ff;
  box-shadow:0 10px 30px rgba(66,103,178,0.22),0 0 0 1px rgba(66,103,178,0.26);
}

.social-btn-amazon{
  background:rgba(255,153,0,0.10);border:1px solid rgba(255,153,0,0.25);color:#f0c070;
}
.social-btn-amazon::before{background:linear-gradient(135deg,rgba(255,153,0,0.18),rgba(255,153,0,0.05));}
.social-btn-amazon:hover{
  border-color:rgba(255,153,0,0.5);color:#ffd890;
  box-shadow:0 10px 30px rgba(255,153,0,0.18),0 0 0 1px rgba(255,153,0,0.22);
}

.social-icon{width:17px;height:17px;flex-shrink:0;position:relative;z-index:1;}
.social-btn span{position:relative;z-index:1;}

/* ── ABOUT ── */
.about-section{
  max-width:1100px;margin:0 auto;
  padding:5.5rem 3rem;
  display:grid;grid-template-columns:360px 1fr;gap:5rem;align-items:start;
}

.about-photo-col{position:relative;}

.about-photo-frame{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  aspect-ratio:3/4;border:1px solid var(--border-mid);
}
.about-photo-frame::before{
  content:'';position:absolute;inset:0;z-index:2;
  background:linear-gradient(to bottom,transparent 50%,rgba(8,7,16,0.48) 74%,rgba(8,7,16,0.90) 100%);
}
.about-photo-frame img{
  width:100%;height:100%;object-fit:cover;object-position:center top;display:block;
  filter:grayscale(12%) contrast(1.06);
  transition:filter var(--t) var(--ease);
}
.about-photo-frame:hover img{filter:grayscale(0%) contrast(1.02);}

.about-photo-caption{position:absolute;bottom:1.5rem;left:1.5rem;right:1.5rem;z-index:4;}
.about-photo-name{font-family:var(--serif);font-size:1.5rem;font-weight:600;color:var(--white);line-height:1.1;margin-bottom:0.28rem;}
.about-photo-sub{font-size:0.71rem;font-weight:400;color:var(--silver-mid);letter-spacing:0.1em;}

.about-photo-col::before{
  content:'';position:absolute;left:-1.5rem;top:3rem;bottom:3rem;width:2px;
  background:linear-gradient(180deg,transparent,var(--purple),transparent);border-radius:2px;
}

.about-content{padding-top:0.25rem;}

/* EYEBROW — canonical reference style */
.about-eyebrow{
  font-family:var(--mono);font-size:0.68rem;font-weight:400;
  letter-spacing:0.22em;text-transform:uppercase;
  color:var(--purple-light);opacity:0.88;
  margin-bottom:1.25rem;
  display:flex;align-items:center;gap:0.85rem;
}
.about-eyebrow::after{
  content:'';display:block;height:1px;width:40px;
  background:var(--purple-mid);opacity:0.6;
}

.about-content h2{
  font-family:var(--serif);font-size:clamp(2.1rem,3vw,2.9rem);font-weight:600;
  line-height:1.1;color:var(--white);margin-bottom:0.4rem;
}
.about-content h2 em{font-style:italic;font-weight:300;color:var(--purple-light);}

.about-lead{
  font-family:var(--serif);font-style:italic;font-size:1.08rem;font-weight:300;
  color:var(--silver);margin-bottom:2rem;line-height:1.7;
}

.about-content p{
  font-size:0.89rem;font-weight:300;color:var(--silver-mid);
  line-height:1.9;margin-bottom:1.1rem;
}
.about-content p:last-of-type{margin-bottom:0;}
.about-content p strong{color:var(--white);font-weight:500;}
.about-content p a{
  color:var(--purple-light);text-decoration:none;
  border-bottom:1px solid rgba(205,184,248,0.32);
  transition:color var(--tf) var(--ease),border-color var(--tf) var(--ease);
}
.about-content p a:hover{color:var(--white);border-color:rgba(240,236,252,0.6);}

/* ── FOOTER ── */
footer{
  border-top:1px solid var(--border);
  padding:1.6rem 3rem;
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:1rem;
}

.footer-copy{
  font-family:var(--mono);font-size:0.72rem;font-weight:300;letter-spacing:0.05em;
  color:var(--purple-light);opacity:0.82;
  display:flex;align-items:center;gap:0.5rem;flex-wrap:wrap;
}
.footer-copy a{
  color:var(--purple-light);text-decoration:none;
  border-bottom:1px solid rgba(205,184,248,0.28);
  transition:color var(--tf) var(--ease),border-color var(--tf) var(--ease),opacity var(--tf) var(--ease);
}
.footer-copy a:hover{color:var(--white);border-color:rgba(240,236,252,0.5);opacity:1;}
.footer-sep{opacity:0.38;}

.footer-links{display:flex;gap:1.75rem;list-style:none;}
.footer-links a{
  color:var(--silver-dim);text-decoration:none;
  font-size:0.72rem;letter-spacing:0.1em;text-transform:uppercase;
  transition:color var(--tf) var(--ease);
}
.footer-links a:hover{color:var(--silver);}

/* ── CONTACT ── */
.contact-section{
  border-top:1px solid var(--border);
  padding:5.5rem 3rem;
  background:linear-gradient(180deg,rgba(123,63,228,0.04) 0%,transparent 60%);
}
.contact-inner{
  max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:320px 1fr;gap:5rem;align-items:start;
}
.contact-eyebrow{
  font-family:var(--mono);font-size:0.68rem;font-weight:400;
  letter-spacing:0.22em;text-transform:uppercase;
  color:var(--purple-light);opacity:0.88;
  margin-bottom:1.25rem;
  display:flex;align-items:center;gap:0.85rem;
}
.contact-eyebrow::after{
  content:'';display:block;height:1px;width:40px;
  background:var(--purple-mid);opacity:0.6;
}
.contact-info-col h2{
  font-family:var(--serif);font-size:clamp(2rem,3vw,2.8rem);font-weight:600;
  line-height:1.1;color:var(--white);margin-bottom:0.4rem;
}
.contact-info-col h2 em{font-style:italic;font-weight:300;color:var(--purple-light);}
.contact-lead{
  font-family:var(--serif);font-style:italic;font-size:1.05rem;font-weight:300;
  color:var(--silver);margin-bottom:2.25rem;line-height:1.7;
}
.contact-details{display:flex;flex-direction:column;gap:1rem;}
.contact-detail{display:flex;align-items:flex-start;gap:0.85rem;}
.contact-detail-icon{
  width:36px;height:36px;border-radius:var(--radius-md);
  border:1px solid var(--border-mid);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;color:var(--purple-light);
  background:rgba(123,63,228,0.09);
}
.contact-detail-label{
  font-family:var(--mono);font-size:0.6rem;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--silver-faint);margin-bottom:0.2rem;
}
.contact-detail-value{font-size:0.88rem;font-weight:400;color:var(--silver);}
.contact-detail-value a{
  color:var(--silver);text-decoration:none;
  border-bottom:1px solid var(--border-mid);
  transition:color var(--tf) var(--ease),border-color var(--tf) var(--ease);
}
.contact-detail-value a:hover{color:var(--purple-light);border-color:rgba(205,184,248,0.4);}

.contact-form{display:flex;flex-direction:column;gap:1rem;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.form-field{display:flex;flex-direction:column;gap:0.4rem;}
.form-label{
  font-family:var(--mono);font-size:0.6rem;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--silver-dim);
}
.form-input,.form-select,.form-textarea{
  background:var(--charcoal-2);
  border:1px solid var(--border-mid);
  border-radius:var(--radius-md);
  padding:0.75rem 1rem;
  font-family:var(--sans);font-size:0.85rem;font-weight:300;
  color:var(--white);outline:none;
  transition:border-color var(--tf) var(--ease),background var(--tf) var(--ease),box-shadow var(--tf) var(--ease);
  width:100%;-webkit-appearance:none;appearance:none;
}
.form-input::placeholder,.form-textarea::placeholder{color:var(--silver-faint);}
.form-input:focus,.form-select:focus,.form-textarea:focus{
  border-color:rgba(123,63,228,0.55);
  background:var(--charcoal-3);
  box-shadow:0 0 0 3px rgba(123,63,228,0.12);
}
.form-select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%237a7290' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 1rem center;
  padding-right:2.5rem;cursor:pointer;
}
.form-select option{background:var(--charcoal-3);color:var(--white);}
.form-textarea{resize:vertical;min-height:130px;line-height:1.7;}
.sms-notice{
  font-size:0.74rem;font-weight:300;color:var(--silver-faint);
  line-height:1.65;padding:0.75rem 1rem;
  border:1px solid var(--border);border-radius:var(--radius-md);
  background:rgba(123,63,228,0.04);
  display:none;
}
.sms-notice.visible{display:block;}
.sms-notice strong{color:var(--silver-dim);font-weight:500;}
.form-submit{
  display:inline-flex;align-items:center;justify-content:center;gap:0.6rem;
  padding:0.9rem 2.25rem;
  background:var(--purple);
  border:1px solid rgba(123,63,228,0.6);
  border-radius:var(--radius-md);
  font-family:var(--sans);font-size:0.82rem;font-weight:500;
  letter-spacing:0.1em;text-transform:uppercase;
  color:var(--white);cursor:pointer;
  transition:background var(--t) var(--ease),box-shadow var(--t) var(--ease),transform var(--t) var(--ease);
  align-self:flex-start;
}
.form-submit:hover{
  background:#6a2fd4;
  border-color:rgba(123,63,228,0.9);
  box-shadow:0 8px 28px rgba(123,63,228,0.35);
  transform:translateY(-2px);
}
.form-submit:active{transform:translateY(0);}

/* ── ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

.hero-roles   {animation:fadeIn  0.6s var(--ease) 0.10s both;}
.hero h1      {animation:fadeUp  0.8s var(--ease) 0.20s both;}
.hero-tagline {animation:fadeUp  0.6s var(--ease) 0.35s both;}
.hero-body    {animation:fadeUp  0.6s var(--ease) 0.50s both;}
.choose-prompt{animation:fadeUp  0.5s var(--ease) 0.65s both;}

.portal                  {animation:fadeUp 0.55s var(--ease) both;}
.portal:nth-child(1)     {animation-delay:0.72s;}
.portal:nth-child(2)     {animation-delay:0.82s;}
.portal:nth-child(3)     {animation-delay:0.92s;}
.portal:nth-child(4)     {animation-delay:1.02s;}

.social-section          {animation:fadeIn 0.8s var(--ease) 1.10s both;}
.about-section           {animation:fadeUp 0.8s var(--ease) 0.20s both;}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .site-header{padding:0 2rem;}
  .hero{padding:5.5rem 2rem 4.5rem;}
  .portals-section{padding:0 2rem 4.5rem;}
  .social-section{padding:3rem 2rem;}
  .about-section{grid-template-columns:290px 1fr;gap:3.5rem;padding:4.5rem 2rem;}
  .contact-section{padding:4.5rem 2rem;}
  .contact-inner{grid-template-columns:280px 1fr;gap:3.5rem;}
  footer{padding:1.4rem 2rem;}
}

@media(max-width:680px){
  .portals-grid{grid-template-columns:1fr;grid-auto-rows:auto;}
  .portal{min-height:260px;}
  .about-section{grid-template-columns:1fr;gap:3rem;padding:4rem 1.5rem;}
  .about-photo-col{max-width:320px;margin:0 auto;}
  .about-photo-col::before{display:none;}
  .contact-section{padding:4rem 1.5rem;}
  .contact-inner{grid-template-columns:1fr;gap:3rem;}
  .form-row{grid-template-columns:1fr;}
  .site-header{padding:0 1.5rem;}
  .hero{padding:5rem 1.5rem 3.5rem;}
  .portals-section{padding:0 1.5rem 3.5rem;}
  .social-section{padding:3rem 1.5rem;}
  footer{padding:1.25rem 1.5rem;}
}

@media(max-width:580px){
  .social-buttons{
    flex-direction:column;align-items:stretch;gap:0.75rem;max-width:100%;
  }
  .social-btn{
    min-width:0;width:100%;white-space:normal;text-align:center;
    padding:0.7rem 1.1rem;font-size:0.78rem;
  }
  footer{flex-direction:column;align-items:flex-start;gap:0.75rem;}
  .footer-links{gap:1.25rem;}
}

/* ── Skip link (accessibility) ── */
.skip-link{
  position:absolute;left:-9999px;top:0;z-index:1000;
  padding:0.65rem 1.25rem;
  background:var(--purple);color:var(--white);font-size:0.82rem;font-weight:600;
  text-decoration:none;border-radius:0 0 var(--radius-md) var(--radius-md);
  transition:transform var(--tf) var(--ease);
}
.skip-link:focus{
  left:1rem;top:1rem;outline:2px solid var(--white);outline-offset:3px;
}

/* Focus visibility */
a:focus-visible,.portal:focus-visible,.social-btn:focus-visible,
.form-submit:focus-visible,.form-input:focus-visible,.form-select:focus-visible,.form-textarea:focus-visible,
button:focus-visible,.nav-toggle:focus-visible{
  outline:2px solid var(--purple-light);outline-offset:3px;
}

/* Honeypot — hidden from view, not display:none so bots still fill */
.form-honeypot-wrap{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

/* Contact success notice */
.contact-flash{
  display:none;margin-bottom:1.25rem;padding:1.15rem 1.25rem;border-radius:var(--radius-md);
  border:1px solid rgba(61,184,164,0.45);background:rgba(61,184,164,0.12);
  color:var(--silver);font-size:0.88rem;line-height:1.65;
}
.contact-flash.visible{display:block;}
.contact-flash-title{display:block;color:var(--white);font-weight:600;font-size:0.95rem;margin-bottom:0.5rem;}
.contact-flash-text{margin:0;color:var(--silver-mid);font-weight:300;}

.contact-flash-error{
  border-color:rgba(232,96,96,0.45);
  background:rgba(232,96,96,0.1);
}
.contact-flash-error .contact-flash-text{color:var(--silver);}

/* Back to top — above fixed header (250) / drawer (260); must stay clickable */
.back-to-top{
  position:fixed;right:1.25rem;bottom:1.25rem;z-index:400;
  width:48px;height:48px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:var(--charcoal-3);
  border:1px solid var(--border-mid);
  color:var(--purple-light);
  cursor:pointer;
  box-shadow:0 8px 28px rgba(0,0,0,0.45);
  opacity:0;visibility:hidden;pointer-events:none;
  transform:translateY(12px);
  transition:
    opacity var(--t) var(--ease),
    transform var(--t) var(--ease),
    visibility 0s linear var(--t),
    background var(--tf) var(--ease),
    border-color var(--tf) var(--ease),
    color var(--tf) var(--ease);
}
.back-to-top.is-visible{
  opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0);
  transition-delay:0s,0s,0s;
}
.back-to-top:hover{
  background:var(--charcoal-4);
  border-color:var(--border-hi);
  color:var(--white);
}
.back-to-top:focus-visible{outline:2px solid var(--purple-light);outline-offset:3px;}

@media(min-width:681px){
  .back-to-top{right:2rem;bottom:2rem;}
}

/* Legal article pages */
.legal-page{min-height:100vh;display:flex;flex-direction:column;}
.legal-main{
  flex:1;max-width:720px;margin:0 auto;padding:4.5rem 3rem 6rem;width:100%;
}
.legal-main h1{
  font-family:var(--serif);font-size:clamp(2rem,4vw,2.85rem);font-weight:600;
  line-height:1.1;color:var(--white);margin-bottom:0.5rem;
}
.legal-meta{
  font-family:var(--mono);font-size:0.68rem;letter-spacing:0.12em;text-transform:uppercase;
  color:var(--silver-faint);margin-bottom:2.25rem;
}
.legal-main h2{
  font-family:var(--serif);font-size:1.35rem;font-weight:600;color:var(--white);
  margin:2.25rem 0 0.75rem;line-height:1.2;
}
.legal-main p,.legal-main li{
  font-size:0.92rem;font-weight:300;color:var(--silver-mid);line-height:1.85;
  margin-bottom:1rem;
}
.legal-main ul{margin:0 0 1rem 1.15rem;}
.legal-main li{margin-bottom:0.4rem;}
.legal-main a{
  color:var(--purple-light);text-decoration:none;
  border-bottom:1px solid rgba(205,184,248,0.32);
  transition:color var(--tf) var(--ease),border-color var(--tf) var(--ease);
}
.legal-main a:hover{color:var(--white);border-color:rgba(240,236,252,0.55);}

/* HTTP error page (/errors/error.php) */
.error-page-inner .error-page-code{
  font-family:var(--mono);font-size:clamp(3rem,12vw,5rem);font-weight:300;line-height:1;
  letter-spacing:0.06em;color:var(--purple);opacity:0.55;margin-bottom:0.35rem;
}
.error-page-inner h1{margin-bottom:0.35rem;}
.error-page-inner .legal-meta{margin-bottom:1.5rem;}

@media(max-width:680px){
  .legal-main{padding:4rem 1.5rem 5rem;}
}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto;}
  .hero-roles,.hero h1,.hero-tagline,.hero-body,.choose-prompt,
  .portal,.social-section,.about-section{
    animation:none !important;
  }
  .portal:hover{transform:none;}
  .social-btn:hover{transform:none;}
  .form-submit:hover{transform:none;}
  .back-to-top{transition:none;}
}
@media (prefers-reduced-motion:reduce) and (max-width:768px){
  .nav-drawer{transition:none;}
  .nav-toggle-line{transition:none;}
}