/* assets/css/pages/contact.css */

.page-contact{
  --step-dur:260ms;
  --contact-border:rgba(255,255,255,0.10);
  --contact-border-strong:rgba(255,255,255,0.16);
  --contact-surface:rgba(20,26,38,0.76);
  --contact-field:rgba(5,8,14,0.78);
}

/* =========================================================
   PAGE / PRIMARY SPLIT LAYOUT
   ========================================================= */
.page-contact .contact-main{
  position:relative;
  padding:
    calc(var(--header-h, 76px) + 30px)
    0
    110px;
}

.page-contact .contact-main::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(
      circle at 12% 18%,
      rgba(166,255,181,0.055),
      transparent 34%
    ),
    radial-gradient(
      circle at 88% 14%,
      rgba(142,153,251,0.07),
      transparent 36%
    );
}

.page-contact .contact-main > .container{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:
    minmax(360px, 0.88fr)
    minmax(520px, 1.12fr);
  gap:28px;
  align-items:start;
  width:100%;
  max-width:1280px;
  margin:0 auto;
  padding:
    0
    clamp(20px, 3vw, 40px);
}

/* =========================================================
   IMAGE-LED CONTACT PANEL
   ========================================================= */
.page-contact .contact-hero{
  position:sticky;
  top:calc(var(--header-h, 76px) + 24px);
  isolation:isolate;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  min-height:720px;
  margin:0;
  padding:
    clamp(34px, 4.2vw, 56px);
  overflow:hidden;
  border:1px solid var(--contact-border);
  border-radius:32px;
  background:#10151e;
  box-shadow:
    0 30px 80px rgba(0,0,0,0.38),
    inset 0 1px 0 rgba(255,255,255,0.045);
}

.page-contact .contact-bg-image{
  position:absolute;
  inset:-5%;
  z-index:-3;
  background-image:
    url("/assets/img/photos/sustainability2.jpg");
  background-repeat:no-repeat;
  background-size:cover;
  background-position:52% 50%;
  filter:
    saturate(0.82)
    contrast(1.04)
    brightness(0.74);
  transform:scale(1.04);
  animation:
    contactImageDrift
    18s
    ease-in-out
    infinite
    alternate;
  will-change:transform, background-position;
}

.page-contact .contact-hero::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:-2;
  background:
    linear-gradient(
      180deg,
      rgba(7,10,16,0.18) 0%,
      rgba(7,10,16,0.42) 44%,
      rgba(7,10,16,0.94) 100%
    ),
    linear-gradient(
      100deg,
      rgba(8,12,18,0.42),
      rgba(8,12,18,0.08) 62%
    );
  pointer-events:none;
}

.page-contact .contact-hero::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  border-radius:inherit;
  pointer-events:none;
  box-shadow:
    inset 0 0 80px rgba(5,8,14,0.28),
    inset 0 1px 0 rgba(255,255,255,0.05);
}

@keyframes contactImageDrift{
  0%{
    transform:scale(1.04) translate3d(0, 0, 0);
    background-position:48% 50%;
  }

  100%{
    transform:scale(1.10) translate3d(-1.2%, -0.8%, 0);
    background-position:57% 48%;
  }
}

.page-contact .contact-hero-copy{
  max-width:35rem;
}

.page-contact .contact-eyebrow{
  margin:0 0 14px;
  font-size:0.76rem;
  line-height:1.2;
  letter-spacing:0.2em;
  text-transform:uppercase;
  color:rgba(255,255,255,0.64);
}

.page-contact .contact-hero h1{
  max-width:11ch;
  margin:0 0 22px;
  font-size:
    clamp(3rem, 4.5vw, 5rem);
  font-weight:400;
  line-height:0.98;
  letter-spacing:-0.045em;
  text-wrap:balance;
}

.page-contact .contact-lead{
  max-width:50ch;
  margin:0;
  color:rgba(255,255,255,0.78);
  font-size:clamp(1rem, 1.15vw, 1.08rem);
  line-height:1.75;
}

/* =========================================================
   CONTACT DETAILS INSIDE IMAGE PANEL
   ========================================================= */
.page-contact .contact-details{
  display:grid;
  grid-template-columns:
    repeat(2, minmax(0, 1fr));
  gap:12px;
  margin-top:36px;
  padding-top:24px;
  border-top:1px solid rgba(255,255,255,0.13);
}

.page-contact .contact-detail{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  min-width:0;
  min-height:118px;
  padding:17px 18px;
  border:1px solid rgba(255,255,255,0.10);
  border-radius:18px;
  background:
    linear-gradient(
      145deg,
      rgba(255,255,255,0.07),
      rgba(255,255,255,0.025)
    ),
    rgba(8,12,18,0.40);
  color:rgba(255,255,255,0.68);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.035);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
}

.page-contact a.contact-detail{
  text-decoration:none;
  transition:
    transform 180ms ease,
    border-color 180ms ease,
    background-color 180ms ease,
    box-shadow 220ms ease;
}

@media (hover:hover) and (pointer:fine){
  .page-contact a.contact-detail:hover{
    transform:translateY(-2px);
    border-color:rgba(166,255,181,0.24);
    box-shadow:
      0 16px 34px rgba(0,0,0,0.22),
      inset 0 1px 0 rgba(255,255,255,0.045);
  }
}

.page-contact .contact-detail-label{
  margin-bottom:10px;
  color:rgba(255,255,255,0.50);
  font-size:0.68rem;
  line-height:1.2;
  letter-spacing:0.17em;
  text-transform:uppercase;
}

.page-contact .contact-detail strong{
  margin-bottom:4px;
  color:rgba(255,255,255,0.96);
  font-size:0.95rem;
  font-weight:600;
  overflow-wrap:anywhere;
}

.page-contact .contact-detail > span:last-child,
.page-contact .contact-detail address{
  font-size:0.86rem;
  line-height:1.55;
}

.page-contact .contact-detail address{
  display:grid;
  margin:0;
  font-style:normal;
}

.page-contact .contact-detail address strong{
  display:block;
}

/* =========================================================
   FORM COLUMN / MODE ORDERING
   ========================================================= */
.page-contact .contact-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:18px;
  align-items:start;
  min-width:0;
}

body.is-general .contact-panel--classic{
  order:1;
}

body.is-general .contact-panel--wizard{
  order:2;
}

body:is(.is-edu, .is-sponsorship) .contact-panel--wizard{
  order:1;
}

body:is(.is-edu, .is-sponsorship) .contact-panel--classic{
  order:2;
}

body:is(.is-corporate, .is-buyers-guide) .contact-panel--wizard{
  display:none;
}

/* =========================================================
   FORM PANELS
   ========================================================= */
.page-contact .contact-panel{
  position:relative;
  min-width:0;
  padding:
    clamp(28px, 3.2vw, 42px);
  overflow:hidden;
  border:1px solid var(--contact-border);
  border-radius:30px;
  background:
    radial-gradient(
      circle at 0 0,
      rgba(166,255,181,0.065),
      transparent 42%
    ),
    radial-gradient(
      circle at 100% 0,
      rgba(142,153,251,0.075),
      transparent 44%
    ),
    linear-gradient(
      145deg,
      rgba(255,255,255,0.052),
      rgba(255,255,255,0.018)
    ),
    var(--contact-surface);
  box-shadow:
    0 28px 72px rgba(0,0,0,0.32),
    inset 0 1px 0 rgba(255,255,255,0.035);
  backdrop-filter:blur(22px) saturate(1.08);
  -webkit-backdrop-filter:blur(22px) saturate(1.08);
}

.page-contact .contact-panel::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(
      115deg,
      rgba(255,255,255,0.025),
      transparent 42%
    );
}

.page-contact .contact-panel > *{
  position:relative;
  z-index:1;
}

.page-contact .panel-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:24px;
  margin-bottom:30px;
}

.page-contact .panel-head--simple{
  justify-content:flex-start;
}

.page-contact .panel-copy{
  max-width:36rem;
}

.page-contact .panel-kicker{
  margin:0 0 11px;
  color:rgba(255,255,255,0.48);
  font-size:0.72rem;
  line-height:1.2;
  letter-spacing:0.18em;
  text-transform:uppercase;
}

.page-contact .panel-title{
  margin:0;
  color:rgba(255,255,255,0.97);
  font-size:clamp(1.45rem, 2.2vw, 1.85rem);
  font-weight:500;
  line-height:1.18;
  letter-spacing:-0.025em;
}

.page-contact .panel-sub{
  max-width:50ch;
  margin:12px 0 0;
  color:rgba(255,255,255,0.65);
  font-size:0.96rem;
  line-height:1.65;
}

.page-contact .micro{
  max-width:58ch;
  margin:22px 0 0;
  color:rgba(255,255,255,0.55);
  font-size:0.89rem;
  line-height:1.6;
}

/* =========================================================
   GENERAL-PAGE EDUCATION ACCORDION
   ========================================================= */
.education-toggle{
  display:none;
  width:100%;
  padding:0;
  border:0;
  background:transparent;
  color:inherit;
  text-align:left;
  cursor:pointer;
}

body.is-general .contact-panel--wizard{
  min-height:0;
  padding:0;
}

body.is-general .education-toggle{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  padding:23px 26px;
}

body.is-general .education-questionnaire-body[hidden]{
  display:none;
}

body.is-general .contact-panel--wizard.is-open{
  padding:
    0
    clamp(24px, 3vw, 34px)
    clamp(26px, 3vw, 34px);
}

body.is-general
.contact-panel--wizard.is-open
.education-toggle{
  width:calc(100% + clamp(48px, 6vw, 68px));
  margin-left:calc(clamp(24px, 3vw, 34px) * -1);
  margin-bottom:28px;
  padding:
    23px
    clamp(24px, 3vw, 34px);
  border-bottom:1px solid rgba(255,255,255,0.09);
}

.education-toggle-copy{
  display:grid;
  gap:5px;
}

.education-toggle-kicker{
  color:rgba(255,255,255,0.46);
  font-size:0.68rem;
  line-height:1.2;
  letter-spacing:0.17em;
  text-transform:uppercase;
}

.education-toggle strong{
  color:rgba(255,255,255,0.94);
  font-size:1.02rem;
  line-height:1.3;
}

.education-toggle-copy > span:last-child{
  max-width:56ch;
  color:rgba(255,255,255,0.58);
  font-size:0.89rem;
  line-height:1.5;
}

.education-toggle-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex:0 0 40px;
  width:40px;
  height:40px;
  border:1px solid rgba(255,255,255,0.12);
  border-radius:999px;
  background:rgba(255,255,255,0.045);
  color:rgba(255,255,255,0.78);
  font-size:1.18rem;
}

/* =========================================================
   PROGRESS
   ========================================================= */
.page-contact .progress{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:210px;
  padding-top:5px;
}

.page-contact .bar{
  flex:1;
  height:7px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,0.12);
  border-radius:999px;
  background:rgba(255,255,255,0.075);
}

.page-contact .bar > span{
  display:block;
  width:0;
  height:100%;
  border-radius:inherit;
  background:var(--brand-grad);
  transition:width 350ms ease;
}

.page-contact .stepcount{
  color:rgba(255,255,255,0.55);
  font-size:0.86rem;
  white-space:nowrap;
}

/* =========================================================
   WIZARD
   ========================================================= */
.page-contact .steps-viewport{
  min-height:320px;
}

.page-contact .q{
  display:none;
}

.page-contact .q.is-active{
  display:block;
  animation:
    stepIn
    var(--step-dur)
    cubic-bezier(.2,.85,.2,1)
    both;
}

@keyframes stepIn{
  from{
    opacity:0;
    transform:translateY(10px);
    filter:blur(5px);
  }

  to{
    opacity:1;
    transform:none;
    filter:none;
  }
}

.page-contact .q-title{
  margin-bottom:16px;
  color:rgba(255,255,255,0.94);
  font-size:1.08rem;
  font-weight:700;
  line-height:1.45;
  letter-spacing:-0.01em;
}

.page-contact .hint{
  margin:-2px 0 10px;
  color:rgba(255,255,255,0.48);
}

/* =========================================================
   FORM FIELDS
   ========================================================= */
.page-contact .field{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:15px;
}

.page-contact .field.two > *{
  flex:1 1 220px;
}

.page-contact input,
.page-contact textarea{
  font:inherit;
  line-height:1.4;
}

.page-contact input[type="text"],
.page-contact input[type="email"],
.page-contact input[type="tel"],
.page-contact textarea{
  width:100%;
  padding:15px 16px;
  border:1px solid rgba(148,163,184,0.28);
  border-radius:14px;
  outline:2px solid transparent;
  outline-offset:2px;
  background:var(--contact-field);
  color:var(--fg);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.018);
  transition:
    border-color 180ms ease,
    background-color 180ms ease,
    box-shadow 200ms ease,
    transform 180ms ease;
}

.page-contact input::placeholder,
.page-contact textarea::placeholder{
  color:rgba(255,255,255,0.34);
}

.page-contact textarea{
  min-height:170px;
  resize:vertical;
}

.page-contact input:focus,
.page-contact textarea:focus{
  transform:translateY(-1px);
  border-color:rgba(166,255,181,0.72);
  background:rgba(7,12,19,0.94);
  box-shadow:
    0 0 0 3px rgba(166,255,181,0.085);
}

/* =========================================================
   CHIPS
   ========================================================= */
.page-contact .chips{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:13px;
}

.page-contact .q:first-child .chips{
  margin-top:18px;
}

.page-contact .chip{
  position:relative;
  display:inline-flex;
  align-items:center;
  gap:0.5rem;
  padding:0.65rem 0.95rem;
  border:1px solid rgba(255,255,255,0.11);
  border-radius:999px;
  background:rgba(255,255,255,0.045);
  cursor:pointer;
  user-select:none;
  transition:
    transform 120ms ease,
    background-color 180ms ease,
    border-color 180ms ease,
    box-shadow 200ms ease;
}

.page-contact .chip:focus-within{
  outline:2px solid rgba(166,255,181,0.62);
  outline-offset:2px;
}

.page-contact .chip input{
  appearance:none;
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  margin:0;
  opacity:0;
  cursor:pointer;
}

.page-contact .chip[data-checked="true"]{
  border-color:rgba(166,255,181,0.38);
  background:
    linear-gradient(
      135deg,
      rgba(166,255,181,0.11),
      rgba(142,153,251,0.10)
    );
  box-shadow:
    0 0 0 3px rgba(166,255,181,0.075);
}

.page-contact .chip:active{
  transform:scale(0.985);
}

/* =========================================================
   BUTTONS / ACTIONS
   ========================================================= */
.page-contact .actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:12px;
  margin-top:24px;
}

.page-contact .actions-classic{
  justify-content:flex-end;
  margin-top:20px;
}

.page-contact .actions-classic .btn{
  min-height:46px;
}

.page-contact .actions-classic .btn.primary{
  min-width:126px;
  font-weight:700;
}

.page-contact .btn.alt{
  background:rgba(255,255,255,0.025);
}

.page-contact .btn[disabled]{
  opacity:0.48;
  cursor:not-allowed;
}

#copyEmail{
  transition:
    transform 180ms ease,
    border-color 180ms ease,
    background-color 180ms ease,
    color 180ms ease;
}

/* =========================================================
   UTILITIES / REVEAL
   ========================================================= */
.page-contact .honeypot{
  position:absolute;
  left:-9999px;
  opacity:0;
}

.page-contact .reveal{
  opacity:0;
  transform:translateY(14px);
  filter:blur(4px);
  transition:
    opacity 800ms cubic-bezier(.2,0,.2,1),
    transform 800ms cubic-bezier(.2,0,.2,1),
    filter 800ms cubic-bezier(.2,0,.2,1);
}

.page-contact .reveal.show{
  opacity:1;
  transform:none;
  filter:none;
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1100px){
  .page-contact .contact-main > .container{
    grid-template-columns:
      minmax(320px, 0.82fr)
      minmax(470px, 1.18fr);
    gap:22px;
  }

  .page-contact .contact-hero{
    min-height:680px;
    padding:36px;
  }

  .page-contact .contact-details{
    grid-template-columns:1fr;
  }

  .page-contact .contact-detail{
    min-height:0;
  }
}

@media (max-width:980px){
  .page-contact .contact-main{
    padding:
      calc(var(--header-h, 72px) + 20px)
      0
      90px;
  }

  .page-contact .contact-main > .container{
    grid-template-columns:1fr;
    max-width:760px;
  }

  .page-contact .contact-hero{
    position:relative;
    top:auto;
    min-height:570px;
  }

  .page-contact .contact-details{
    grid-template-columns:
      repeat(2, minmax(0, 1fr));
  }

  .page-contact .contact-panel{
    padding:
      clamp(26px, 5vw, 38px);
  }
}

@media (max-width:700px){
  .page-contact .contact-main > .container{
    padding:0 14px;
  }

  .page-contact .contact-hero{
    min-height:530px;
    padding:28px 24px;
    border-radius:25px;
  }

  .page-contact .contact-hero h1{
    max-width:12ch;
    font-size:clamp(2.65rem, 13vw, 4rem);
  }

  .page-contact .contact-details{
    grid-template-columns:1fr;
    margin-top:28px;
  }

  .page-contact .contact-detail{
    min-height:0;
    padding:15px 16px;
  }

  .page-contact .contact-panel{
    padding:24px;
    border-radius:24px;
  }

  .page-contact .panel-head{
    flex-direction:column;
    gap:18px;
    margin-bottom:24px;
  }

  .page-contact .progress{
    width:100%;
    min-width:0;
  }

  .page-contact .steps-viewport{
    min-height:285px;
  }

  .page-contact .actions-classic{
    justify-content:stretch;
  }

  .page-contact .actions-classic > *{
    flex:1 1 auto;
  }
}

@media (max-width:480px){
  .page-contact .contact-hero{
    min-height:560px;
  }

  .page-contact .actions{
    align-items:stretch;
  }

  .page-contact .actions .btn{
    flex:1 1 100%;
    width:100%;
  }
}

/* =========================================================
   REDUCED MOTION
   ========================================================= */
@media (prefers-reduced-motion:reduce){
  .page-contact .contact-bg-image{
    animation:none;
    transform:scale(1.04);
  }

  .page-contact .reveal{
    opacity:1;
    transform:none;
    filter:none;
    transition:none;
  }

  .page-contact .q.is-active{
    animation:none;
  }
}

