/* =========================
   Theme tokens
   ========================= */
:root{
  /* Brand palette (same vibe, more color) */
  --brand-1: #01aaff; /* cyan/blue */
  --brand-2: #00d3c7; /* teal */
  --brand-3: hsl(231, 100%, 68%); /* violet accent */
  --brand-4: #ffb020; /* warm highlight */
  
  --radius: 5px;
  --shadow-1: 0 10px 30px rgba(0,0,0,.12);
  --shadow-2: 0 16px 50px rgba(0,0,0,.18);

  --container-max: 1120px;

  /* Fluid spacing */
  --s1: .25rem;
  --s2: .5rem;
  --s3: .75rem;
  --s4: 1rem;
  --s5: 1.5rem;
  --s6: 3rem;
  --s7: 5rem;
  --s8: 7rem;

  /* Background */
  --bg-1: radial-gradient(circle at 20% 15%, color-mix(in oklab, var(--brand-3) 22%, transparent) 0%, transparent 55%);
  --bg-2: radial-gradient(circle at 85% 75%, color-mix(in oklab, var(--brand-1) 30%, transparent) 0%, transparent 50%);
  --bg-3: radial-gradient(circle at 60% 10%, color-mix(in oklab, var(--brand-2) 18%, transparent) 0%, transparent 60%);
  --page-bg: var(--bg-1), var(--bg-2), var(--bg-3);

  /* Hint Pico primary (works with your existing pico css) */
  --primary: var(--brand-1);
    
  
}

@media (prefers-color-scheme: dark) {
  :root{
    --shadow-1: 0 10px 30px rgba(0,0,0,.35);
    --shadow-2: 0 16px 60px rgba(0,0,0,.45);

    --bg-1: radial-gradient(circle at 20% 15%, color-mix(in oklab, var(--brand-3) 18%, transparent) 0%, transparent 58%);
    --bg-2: radial-gradient(circle at 85% 75%, color-mix(in oklab, var(--brand-1) 22%, transparent) 0%, transparent 55%);
    --bg-3: radial-gradient(circle at 60% 10%, color-mix(in oklab, var(--brand-2) 14%, transparent) 0%, transparent 64%);
  }
}

html { scroll-behavior: smooth; }

body{
  background-image: var(--page-bg);
  background-attachment: fixed;
  background-size: cover;
}


/* =========================
   Header / nav
   ========================= */

.anchor-offset {
  scroll-margin-top: 90px;
}
.site-header{
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: blur(10px);
  background: color-mix(in oklab, #ffffff00 75%, transparent);
  border-bottom: 1px solid color-mix(in oklab, var(--brand-1) 12%, transparent);
}

@media (prefers-color-scheme: dark) {
  .site-header{
    background: color-mix(in oklab, black 55%, transparent);
    border-bottom: 1px solid color-mix(in oklab, var(--brand-1) 16%, transparent);
  }
}

.nav{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s4);
  padding-left: clamp(1rem, 2vw, 2rem);
  padding-right: clamp(1rem, 2vw, 2rem);
}

.nav__brand{
  display: inline-flex;
  align-items: center;
}

.logo{
  width: clamp(120px, 14vw, 170px);
  height: auto;
  display: block;
}

.nav__actions{
  display: inline-flex;
  align-items: center;
  gap: var(--s3);
}

.nav__contact button{
  border-radius: 999px;
}

.nav__link{
  font-weight: 600;
  text-decoration: none;
  padding: .4rem .6rem;
  border-radius: 999px;
  border: 1px solid transparent;
}

.nav__link:hover{
  border-color: color-mix(in oklab, var(--brand-1) 20%, transparent);
  background: color-mix(in oklab, var(--brand-1) 8%, transparent);
}


/* =========================
   Footer
   ========================= */
.footer{
  padding: var(--s6) 0 var(--s5);
  opacity: .9;
}


/* =========================
   Global
   ========================= */

.container{
  max-width: var(--container-max);
  margin-left: auto;
  margin-right: auto;

  padding-left: clamp(1rem, 2vw, 2rem);
  padding-right: clamp(1rem, 2vw, 2rem);
}



/* The title is full-bleed and independent of containers */
.page-header{
  text-align: left;
  margin-bottom: var(--s8);
   margin-top: var(--s5);
   padding-top: clamp(1rem, 2vh, 3rem);
}



/* =========================
   Hero
   ========================= */
.hero{
  position: relative;
  min-height: clamp(520px, 75vh, 860px);
  display: grid;
  align-items: end;
  overflow: hidden;

}

.hero--image{
  background-image:
    linear-gradient(
      110deg,
      color-mix(in oklab, black 68%, transparent) 0%,
      color-mix(in oklab, black 30%, transparent) 55%,
      transparent 100%
    ),
    url("/images/Hugin_narrow.jpeg");
  background-size: cover;
  background-position: center;
}


.hero__actions button{
    background: var(--brand-3);
}
.hero__overlay{
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 70% 30%, color-mix(in oklab, var(--brand-1) 30%, transparent) 0%, transparent 45%),
    radial-gradient(circle at 20% 70%, color-mix(in oklab, var(--brand-3) 22%, transparent) 0%, transparent 50%);
  mix-blend-mode: screen;
  opacity: .55;
}

@media (prefers-color-scheme: dark) {
  .hero__overlay{ opacity: .7; }
}

.hero__content{
  position: relative;
  padding: clamp(5rem, 10vw, 100rem) 0;
  max-width: 70ch;
    
  margin-left: clamp(1rem, 6vw, 8rem);
}



.hero__title{
  color: white;
  font-weight: 800;
  letter-spacing: .01em;
  font-size: clamp(2.1rem, 4.2vw, 3.6rem);
  line-height: 1.05;
  margin-bottom: var(--s4);
  text-wrap: balance;
}

.hero__lead{
  color: rgba(255,255,255,.88);
  font-size: clamp(1rem, 1.25vw, 1.15rem);
  line-height: 1.6;
  margin-bottom: var(--s5);
  max-width: 58ch;
}

.hero__actions button{
  border-radius: 999px;
  box-shadow: 0 12px 30px rgba(0,0,0,.25);
}

/* =========================
   Home features section
   ========================= */
.home-sections{
  padding: var(--s7) 0;
}

.feature{
  border-radius: var(--radius);
  box-shadow: var(--shadow-1);
  padding: var(--s5);
  border: 1px solid color-mix(in oklab, var(--brand-1) 12%, transparent);
  background: color-mix(in oklab, white 92%, transparent);
}

@media (prefers-color-scheme: dark) {
  .feature{
    background: color-mix(in oklab, black 55%, transparent);
    border: 1px solid color-mix(in oklab, var(--brand-1) 16%, transparent);
  }
}



/* =========================
    Contact page
========================= */



/* Team card – simple but better */
.team-card{
  background: color-mix(in oklab, white 10%, transparent);
}

@media (prefers-color-scheme: dark){
  .team-card{
    background: color-mix(in oklab, black 55%, transparent);

  }
}

.team-card__grid{
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  align-items: start;
}

@media (min-width: 700px){
  .team-card__grid{
    grid-template-columns: 160px 1fr;
    gap: 1.25rem;
  }
}

/* Center avatar on mobile, left-align on desktop */
.team-card__avatar{
  width: clamp(110px, 26vw, 150px);
  height: clamp(110px, 26vw, 150px);
  border-radius: 999px;
  overflow: hidden;
  margin-inline: auto;
  background: color-mix(in oklab, var(--brand-1, #01aaff) 8%, transparent);
}

@media (min-width: 700px){
  .team-card__avatar{
    margin-inline: 0;
  }
}

.team-card__avatar-img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.team-card__name{
  margin: 0;
  font-weight: 800;
  font-size: 1.15rem;
}

.team-card__role{
  margin: .25rem 0 0;
  opacity: .85;
  font-style: italic;
}

.team-card__desc{
  margin: .75rem 0 0;
  line-height: 1.55;
  opacity: .92;
  font-size: small;
}

.team-card__phone{
  margin: .75rem 0 0;
  font-weight: 600;
}

/* Email row */
.team-card__email{
  margin: .75rem 0 0;
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  flex-wrap: wrap;
}

/* IMPORTANT: hard-lock the svg icon size so it can't blow up */
.team-card__email-icon{
  width: 16px !important;
  height: 16px !important;
  max-width: 16px !important;
  max-height: 16px !important;
  display: inline-block !important;
  flex: 0 0 16px;
  opacity: .9;
}

@media (prefers-color-scheme: dark){
  .team-card__email-icon{
    filter: brightness(0) invert(1);
  }
}



/* =========================
   News page simple feed
   ========================= */


.news-subtitle {
  margin-top: .25rem;
  opacity: .85;
  max-width: 60ch;
}

.news-feed {
  display: grid;
  gap: var(--s4);
}

.news-feed a {
  display: block;
  text-decoration: none;
  color: inherit;
}
.news-row {
  text-decoration: none;
  color: inherit;
}

.news-row__card {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s4);
  padding: var(--s5);
  border-radius: var(--radius);
  box-shadow: var(--shadow-1);
  border: 0px solid color-mix(in oklab, var(--brand-1) 10%, transparent);
  background: color-mix(in oklab, white 10% , transparent);
  transition: transform 150ms ease, box-shadow 150ms ease;
}

@media (prefers-color-scheme: dark) {
  .news-row__card {
    background: color-mix(in oklab, black 55%, transparent);
    border: 1px solid color-mix(in oklab, var(--brand-1) 16%, transparent);
  }
}

.news-row:hover .news-row__card {
  transform: translateY(-2px);
  box-shadow: var(--shadow-2);
}

.news-row__date {
  font-size: .95rem;
  opacity: .8;
}

.news-row__title {
  margin: .35rem 0 .35rem;
  line-height: 1.15;
}

.news-row__excerpt {
  margin: 0;
  opacity: .9;
  max-width: 75ch;
}

.news-row__image {
  width: 100%;
  border-radius: calc(var(--radius) - 4px);
  overflow: hidden;
  border: 0px solid color-mix(in oklab, var(--brand-1) 10%, transparent);
}

.news-row__image img {
  width: 100%;
  height: auto;
  display: block;
  max-height: 220px;
  object-fit: cover;
}

/* Desktop: put image on right */
@media (min-width: 900px) {
  .news-row__card {
    grid-template-columns: 1fr 260px;
    align-items: center;
  }

  .news-row__image img {
    max-height: 160px;
    object-fit: contain; /* good for logos */
    background: color-mix(in oklab, white 0%, transparent);
  }

  @media (prefers-color-scheme: dark) {
    .news-row__image img {
      background: color-mix(in oklab, black 40%, transparent);
    }
  }
}




/* =========================
   About page
   ========================= */
.page-hero {
  position: relative;
  overflow: hidden;
  margin: var(--s6) auto var(--s6);
  min-height: clamp(260px, 36vh, 420px);
  display: grid;
  align-items: end;
  background-size: cover;
}

.page-hero__overlay {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 80% 20%, color-mix(in oklab, var(--brand-2) 25%, transparent) 0%, transparent 55%),
    radial-gradient(circle at 20% 80%, color-mix(in oklab, var(--brand-3) 18%, transparent) 0%, transparent 60%),
    linear-gradient(120deg,
      color-mix(in oklab, black 18%, transparent) 0%,
      transparent 55%
    );
  opacity: .9;
}

/* About hero full width (full-bleed) */
.page-hero--about{
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  border-radius: 0;          /* remove any rounding */
}

/* optional: if you want it flush with edges */
.page-hero--about{
  border-left: 0;
  border-right: 0;
}


@media (prefers-color-scheme: dark) {
  .page-hero--about {
    background: color-mix(in oklab, black 55%, transparent);
    border: 0px solid color-mix(in oklab, var(--brand-1) 16%, transparent);
  }
}

.page-hero__content {
  position: relative;
  padding: clamp(5rem, 10vw, 100rem) 0;
  max-width: 70ch;
    
  margin-left: clamp(1rem, 6vw, 8rem);
}



.page-hero__title {
  font-size: clamp(2rem, 5vw, 3rem);
  line-height: 1.08;
  margin-bottom: var(--s4);
  text-wrap: balance;
}

.page-hero__lead {
  opacity: .92;
  font-size: 1.05rem;
  line-height: 1.6;

}

/* Two-column layout that stacks on mobile */
.about-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s5);
  margin-bottom: var(--s6);
}

@media (min-width: 900px) {
  .about-grid {
    grid-template-columns: 1.3fr 0.7fr;
    align-items: start;
  }
}

.about-card {
  border-radius: var(--radius);
  box-shadow: var(--shadow-1);
  padding: var(--s5);
  border: 1px solid color-mix(in oklab, var(--brand-1) 10%, transparent);
  background: color-mix(in oklab, white 92%, transparent);
}

@media (prefers-color-scheme: dark) {
  .about-card {
    background: color-mix(in oklab, black 55%, transparent);
    border: 0px solid color-mix(in oklab, var(--brand-1) 16%, transparent);
  }
}

.about-card--cta {
  border: 0px solid color-mix(in oklab, var(--brand-2) 20%, transparent);
}

.about-cta-btn {
  border-radius: 999px;
  width: 100%;
  background: var(--brand-3)
}

.about-bullets {
  margin-top: var(--s4);
  display: grid;
  gap: var(--s4);
}

.about-bullet {
  display: grid;
  grid-template-columns: 14px 1fr;
  gap: var(--s3);
  align-items: start;
}

.dot {
  width: 10px;
  height: 10px;
  margin-top: .35rem;
  border-radius: 999px;
  display: inline-block;
  box-shadow: 0 0 0 6px color-mix(in oklab, var(--brand-1) 10%, transparent);
}

.dot--a { background: var(--brand-1); }
.dot--b { background: var(--brand-2); }
.dot--c { background: var(--brand-3); }

.about-image img {
  width: 100%;
  height: auto;
  border-radius: var(--radius);
  box-shadow: var(--shadow-1);
  display: block;
}
