
/* =========================
   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: 22px;
  --shadow-1: 0 10px 30px rgba(0,0,0,.12);
  --shadow-2: 0 16px 50px rgba(0,0,0,.18);

  --container-max: 1500px;

  /* 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;
}

html { overflow-x: clip; }
body { overflow-x: clip; }

main{
  padding-block: var(--s6);
}
.home main {
  padding-top: 0;
}

/* =========================
   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: rgba(0,0,0,.55);
    border-bottom: 1px solid rgba(1,170,255,.22);

    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
  }
}



.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;
  border-top: 1px solid color-mix(in oklab, var(--brand-1) 10%, transparent);
}

.footer__inner{
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--s4);
  flex-wrap: wrap;
}

.footer__left{
  opacity: .75;
  font-size: .95rem;
}

.footer__nav{
  display: flex;
  gap: var(--s5);
}

.footer__nav a{
  text-decoration: none;
  font-weight: 500;
  opacity: .85;
}

.footer__nav a:hover{
  opacity: 1;
  text-decoration: underline;
}

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

.container{
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: clamp(1rem, 1vw, 2rem);
}

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



/* =========================
   Hero
   ========================= */


.hero {
  margin-bottom: var(--s2);
  margin-top: calc(var(--s4) * -1.3);
  padding: clamp(0rem, 7vw, 100rem) 0;
}

/* Make hero a stacking context */
.hero--image{
  position: relative;
  overflow: hidden;
}

/* Put background image on ::before instead of the element */
.hero--image::before{
  content:"";
  position:absolute;
  inset:0;
  background-image: url("/images/Hugin_narrow_blur.jpeg");
  background-size: cover;
  background-position: center;
  transform: scale(1.03); /* prevents blur edges */
  z-index: 0;
}

/* Put your dark/blue gradient on ::after */
.hero--image::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(
      110deg,
      color-mix(in oklab, black 68%, transparent) 0%,
      color-mix(in oklab, black 30%, transparent) 55%,
      transparent 100%
    );
  z-index: 1;
}

/* Ensure content sits above both */
.hero__overlay{ z-index: 2; }
.hero__content{ position: relative; z-index: 3; }

/* Mobile: blur only the background (::before), not content */
@media (max-width: 700px){
  .hero--image::before{
    /* -webkit-filter: blur(4px);
    filter: blur(4px); */
    background-position: 45% center;
  }

  .hero--image::after{
    background:
      linear-gradient(
        180deg,
        rgba(2, 0, 108, .65) 0%,
        rgba(0, 55, 164, .45) 35%,
        rgba(6, 56, 155, .15) 80%
      );
  }
}


.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{
    padding-top: clamp(6rem, 12vw, 10rem);
  padding-bottom: clamp(3rem, 6vw, 5rem);
}



.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(1.25rem, 1.5vw, 1.75rem);
  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);
}



/* =========================
    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: 0;
  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: 5px;
  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: 600px) {
  .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 (used)
   ========================= */

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

}

.page-hero__overlay {
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.9;
  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%);
}

/* Full-bleed about hero */
.page-hero--about {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

@supports (width: 100dvw) {
  .page-hero--about {
    width: 100dvw;
    margin-left: calc(50% - 50dvw);
    margin-right: calc(50% - 50dvw);
  }
}

.page-hero__content {
  position: relative;
  padding-block: clamp(4rem, 7vw, 7rem);
  padding-inline: clamp(1rem, 4vw, 2.5rem);
  margin-inline: auto;
  max-width: 60ch;
  text-align: center;
}

@media (max-width: 600px) {
  .page-hero__content { max-width: 48ch; }
}

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

.page-hero__lead {
  opacity: 0.92;
  font-size: 1rem; /* was .65rem (too small) */
  line-height: 1.6;
}

/* --- Feature panels (Sampling + Library) --- */
.feature-panel {
  padding: var(--s4) 0;
}

/* Right-aligned variant (desktop only) */
@media (min-width: 801px) {

  .feature-panel--right .feature-panel__content {
    justify-items: end;
  }

  .feature-panel--right .glass {
    text-align: left; /* keep text left-aligned for formal feel */
  }

  .feature-panel--right .feature-panel__scrim {
    background:
      radial-gradient(1000px 520px at 80% 25%, rgba(0,0,0,.55), transparent 60%),
      linear-gradient(
        270deg,
        rgba(0,0,0,.50) 0%,
        rgba(0,0,0,.25) 45%,
        transparent 75%
      );
  }
}


.feature-panel__frame {
  position: relative;
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--pico-background-color);
  box-shadow: 0 24px 60px rgba(0,0,0,.18);
}

.feature-panel__media {
  position: relative;
  height: clamp(320px, 46vw, 520px);
}

.feature-panel__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  filter: saturate(1.05) contrast(1.05);
}

/* For vertical sampling: keep crop intentional */
.feature-panel__frame--portrait .feature-panel__media img {
  object-position: 50% 25%;
}

.feature-panel__scrim {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(1000px 520px at 20% 25%, rgba(0,0,0,.55), transparent 60%),
    linear-gradient(90deg, rgba(0,0,0,.50) 0%, rgba(0,0,0,.25) 45%, transparent 75%);
}

.feature-panel__content {
  position: absolute;
  inset: 0;
  display: grid;
  align-content: center;
  justify-items: start;
  padding: clamp(16px, 4vw, 44px);
}




/* Glass card */
.glass {
  max-width: 520px;
  padding: clamp(16px, 2.2vw, 26px);
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.20);
  background: rgba(255,255,255,.10);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 18px 50px rgba(0,0,0,.25);
  color: rgba(255,255,255,.92);
}

.glass h2 {
  margin: 0 0 .6rem 0;
  letter-spacing: 0.2px;
  color: rgba(255,255,255,.92);
}

.glass p {
  margin: 0 0 1rem 0;
  color: rgba(255,255,255,.84);
  line-height: 1.55;
}

.glass .meta {
  display: flex;
  gap: .6rem;
  flex-wrap: wrap;
  font-size: 0.95rem;
  letter-spacing: 0.2px;
  color: rgba(255,255,255,.78);
}

/* =========================
   Feature panel – mobile stacked layout
   ========================= */

@media (max-width: 800px) {

  /* remove overlay positioning */
  .feature-panel__content {
    position: static;
    padding: 0;
  }

  /* remove scrim */
  .feature-panel__scrim {
    display: none;
  }

  /* let frame behave like normal block */
  .feature-panel__frame {
    display: block;
    overflow: visible;
    box-shadow: 0 18px 40px rgba(0,0,0,.12);
  }

  /* image keeps top rounded corners only */
  .feature-panel__media {
    height: auto;
  }

  .feature-panel__media img {
    height: auto;
    aspect-ratio: 16 / 10;
    border-radius: 22px 22px 0 0;
  }

  /* glass becomes normal content card */
  .glass {
    max-width: 100%;
    border-radius: 0 0 22px 22px;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    background: var(--pico-background-color);
    color: var(--pico-color);
    border: none;
    box-shadow: none;
    padding: var(--s5);
  }

  .glass h2,
  .glass p,
  .glass .meta {
    color: inherit;
  }
}





/* --- CTA float (Get in touch) --- */
.about-cta-float {
  position: relative;
  overflow: hidden;
  margin-block: var(--s6);
  min-height: clamp(260px, 44vh, 480px);
  border-radius: var(--radius);
  box-shadow: var(--shadow-1);
}

.about-cta-float__bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.about-cta-float__scrim {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 80% 80%, color-mix(in oklab, black 55%, transparent), transparent 60%);
}

.about-cta-float__inner {
  position: relative;
  height: 100%;
  display: grid;
  align-items: end;
  justify-items: end;
  padding: clamp(1rem, 3vw, 2rem);
}

.about-cta-float__card {
  max-width: 52ch;
  padding: clamp(1.25rem, 3vw, 2rem);
  border-radius: var(--radius);
  box-shadow: var(--shadow-2);
  background: color-mix(in oklab, white 88%, transparent);
  border: 1px solid color-mix(in oklab, white 35%, transparent);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  display: grid;
  gap: var(--s4);
}
/* CTA button */
.about-cta-btn {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  padding: 0.9rem 1.1rem;
  border-radius: 999px;
  background: var(--brand-3);
  color: white;
  text-decoration: none;
  font-weight: 600;
  border: 0;
  cursor: pointer;
}
@media (prefers-color-scheme: dark) {
  .about-cta-float__card {
    background: color-mix(in oklab, black 60%, transparent);
    border: 1px solid color-mix(in oklab, white 12%, transparent);
    color: white;
  }
}

/* =========================
   CTA – Mobile simplified
   ========================= */

@media (max-width: 700px) {

  /* Remove background image + scrim */
  .about-cta-float {
    min-height: auto;
    box-shadow: none;
    background: none;
  }

  .about-cta-float__bg,
  .about-cta-float__scrim {
    display: none;
  }

  /* Make inner behave like normal block */
  .about-cta-float__inner {
    height: auto;
    padding: 0;
  }

  /* Turn card into clean standalone box */
  .about-cta-float__card {
    max-width: 100%;
    border-radius: var(--radius);
    box-shadow: var(--shadow-1);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;

    background: var(--pico-background-color);
    border: 1px solid color-mix(in oklab, var(--brand-1) 12%, transparent);
  }
}


