/* =========================================================
   GRACYL — CONTACT
   ========================================================= */

body[data-page="contact"]{
  overflow-x:hidden;
}

.contact-page,
.contact-page *{
  box-sizing:border-box;
}

.contact-page{
  position:relative;
  overflow:hidden;
}

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

/* Reveal */

.reveal{
  opacity:0;
  transform:translateY(24px);
  transition:
    opacity .7s ease,
    transform .7s cubic-bezier(.22,.61,.36,1);
}

.reveal.reveal-visible{
  opacity:1;
  transform:none;
}

/* Kicker */

.contact-kicker{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  margin:0 0 12px;
  color:color-mix(in oklab, var(--muted, #5B6A7E), #000 12%);
  font-size:.8rem;
  font-weight:750;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.contact-kicker__dot{
  width:9px;
  height:9px;
  border-radius:999px;
  background:
    radial-gradient(circle at 30% 30%, #fff, rgba(255,255,255,.15) 38%, transparent 62%),
    linear-gradient(135deg, #12B3FF, #7C8CFF, #FF168B);
  box-shadow:0 8px 22px rgba(18,179,255,.20);
  flex:0 0 auto;
}

/* Hero background */

.contact-hero{
  position:relative;
  overflow:visible;
  padding:clamp(86px, 10vw, 136px) 0 clamp(34px, 5vw, 66px);
}

.contact-hero::before{
  content:"";
  position:absolute;
  top:-260px;
  left:calc(50% - 50vw);
  width:100vw;
  height:1500px;
  pointer-events:none;
  z-index:0;
  background:
    radial-gradient(70% 56% at 50% 0%, rgba(70,220,255,.30), transparent 68%),
    radial-gradient(42% 32% at 22% 42%, rgba(255,22,139,.15), transparent 70%),
    radial-gradient(45% 34% at 82% 30%, rgba(124,140,255,.17), transparent 72%);
  filter:blur(80px) saturate(150%);
  animation:contactPaint 26s ease-in-out infinite;
}

@keyframes contactPaint{
  0%, 100%{
    transform:scale(1);
    opacity:.95;
  }

  50%{
    transform:scale(1.035) translateY(14px);
    opacity:1;
  }
}

/* Hero */

.contact-hero__wrap{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(260px, 380px);
  gap:clamp(28px, 5vw, 70px);
  align-items:center;
  max-width:1120px;
}

.contact-hero__content{
  min-width:0;
}

.contact-hero h1{
  margin:0 0 clamp(18px, 3vw, 30px);
  max-width:840px;
  font-size:clamp(42px, 6.4vw, 76px);
  line-height:.98;
  letter-spacing:-.07em;
  color:var(--ink, #0F172A);
  text-wrap:balance;
}

.contact-hero p:not(.contact-kicker){
  margin:0;
  max-width:760px;
  color:var(--muted, #5B6A7E);
  font-size:clamp(1.05rem, 1.45vw, 1.2rem);
  line-height:1.72;
}

.contact-hero__visual{
  position:relative;
  margin:0;
  min-width:0;
}

.contact-hero__visual::before{
  content:"";
  position:absolute;
  left:50%;
  bottom:4%;
  width:74%;
  height:66px;
  transform:translateX(-50%);
  pointer-events:none;
  z-index:0;
  background:radial-gradient(60% 100% at 50% 40%, rgba(15,23,42,.16), transparent 70%);
  filter:blur(22px);
  opacity:.62;
}

.contact-hero__visual img{
  position:relative;
  z-index:1;
  width:100%;
  height:auto;
  max-height:360px;
  object-fit:contain;
  filter:drop-shadow(0 30px 64px rgba(15,23,42,.13));
}

/* Contact options */

.contact-options-section{
  padding:0 0 clamp(42px, 6vw, 80px);
}

.contact-options-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:18px;
  max-width:1120px;
  margin:0 auto;
}

.contact-option-card{
  min-width:0;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  padding:clamp(24px, 3vw, 32px);
  border-radius:30px;
  background:linear-gradient(180deg, rgba(255,255,255,.90), rgba(255,255,255,.70));
  border:1px solid rgba(15,23,42,.08);
  box-shadow:0 18px 48px rgba(15,23,42,.08), inset 0 1px 0 rgba(255,255,255,.78);
  transition:transform .24s ease, box-shadow .24s ease;
}

.contact-option-card:hover{
  transform:translateY(-4px);
  box-shadow:0 26px 68px rgba(15,23,42,.12), inset 0 1px 0 rgba(255,255,255,.84);
}

.contact-option-card--highlight{
  background:
    radial-gradient(80% 90% at 20% 0%, rgba(18,179,255,.14), transparent 70%),
    radial-gradient(80% 90% at 100% 100%, rgba(255,22,139,.14), transparent 70%),
    linear-gradient(180deg, rgba(255,255,255,.94), rgba(255,255,255,.76));
}

.contact-option-card__label{
  display:block;
  margin:0 0 18px;
  color:var(--brand, #FF168B);
  font-size:.78rem;
  font-weight:850;
  letter-spacing:.10em;
  text-transform:uppercase;
}

.contact-option-card__link{
  display:inline-flex;
  color:var(--ink, #0F172A);
  font-size:clamp(1.08rem, 1.8vw, 1.35rem);
  font-weight:850;
  letter-spacing:-.035em;
  text-decoration:none;
}

.contact-option-card__link:hover{
  color:var(--brand, #FF168B);
}

.contact-option-card__button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:auto;
  max-width:100%;
  min-height:50px;
  margin:0 0 24px;
  padding:0 28px;
  border-radius:999px;
  color:#fff;
  background:linear-gradient(135deg, #12B3FF, #7C8CFF, #FF168B);
  box-shadow:0 16px 34px rgba(255,22,139,.22);
  font-size:clamp(.96rem, 1.2vw, 1.06rem);
  font-weight:850;
  line-height:1;
  text-decoration:none;
  white-space:nowrap;
  transition:transform .2s ease, box-shadow .2s ease, filter .2s ease;
}

.contact-option-card__button:hover{
  transform:translateY(-2px);
  box-shadow:0 22px 46px rgba(255,22,139,.28);
  filter:saturate(1.08);
}

.contact-option-card p{
  margin:0;
  color:var(--muted, #5B6A7E);
  line-height:1.62;
  font-size:.98rem;
}

/* Form section */

.contact-form-section{
  padding:0 0 clamp(54px, 7vw, 96px);
}

.contact-form-card{
  max-width:1100px;
  margin:0 auto;
  padding:clamp(28px, 4.8vw, 58px);
  border-radius:38px;
  background:
    radial-gradient(72% 80% at 0% 10%, rgba(18,179,255,.10), transparent 64%),
    radial-gradient(60% 76% at 100% 100%, rgba(255,22,139,.10), transparent 68%),
    linear-gradient(180deg, rgba(255,255,255,.95), rgba(255,255,255,.78));
  border:1px solid rgba(15,23,42,.08);
  box-shadow:0 30px 92px rgba(15,23,42,.12);
  backdrop-filter:blur(12px) saturate(150%);
  -webkit-backdrop-filter:blur(12px) saturate(150%);
}

.contact-form-head{
  text-align:center;
  max-width:760px;
  margin:0 auto 30px;
}

.contact-form-head h2{
  margin:0 0 14px;
  color:var(--ink, #0F172A);
  font-size:clamp(34px, 4.8vw, 58px);
  line-height:1.02;
  letter-spacing:-.06em;
  text-wrap:balance;
}

.contact-form-head p{
  margin:0 auto;
  color:var(--muted, #5B6A7E);
  line-height:1.72;
  font-size:1.03rem;
}

/* Alerts */

.contact-alert{
  margin:0 0 22px;
  padding:15px 18px;
  border-radius:18px;
  font-weight:700;
  line-height:1.5;
}

.contact-alert--success{
  color:#166534;
  background:rgba(34,197,94,.14);
  border:1px solid rgba(34,197,94,.22);
}

.contact-alert--error{
  color:#991B1B;
  background:rgba(239,68,68,.12);
  border:1px solid rgba(239,68,68,.22);
}

/* Form */

/* Apple / iCloud toast — Liquid Glass Gracyl */

.apple-toast{
  --toast-color:#12b76a;

  position:fixed!important;
  top:24px!important;
  left:50%!important;
  z-index:2147483647!important;

  display:flex!important;
  align-items:flex-start;
  gap:14px;

  width:min(560px, calc(100% - 32px));
  padding:20px 54px 18px 18px;
  border-radius:28px;
  overflow:hidden;

  background:
    radial-gradient(120% 140% at 0% -20%,
      rgba(255,155,230,.16) 0%,
      rgba(255,255,255,0) 35%),
    linear-gradient(180deg,
      rgba(255,255,255,.68) 0%,
      rgba(255,255,255,.48) 100%);

  backdrop-filter:saturate(160%) blur(18px);
  -webkit-backdrop-filter:saturate(160%) blur(18px);

  border:1px solid rgba(255,255,255,.68);

  box-shadow:
    0 6px 22px rgba(18,24,40,.14),
    0 1px 0 rgba(255,255,255,.45) inset;

  color:#1F2A44;

  opacity:0;
  transform:translateX(-50%) translateY(-14px);
  animation:animation:appleToastIn .38s cubic-bezier(.22,.61,.36,1) forwards;
}

.apple-toast--success{
  --toast-color:#12b76a;
}

.apple-toast--error{
  --toast-color:#ff3b30;
}

.apple-toast::before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:4px;
  background:rgba(255,255,255,.42);
}

.apple-toast::after{
  content:"";
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:4px;
  background:var(--toast-color);
  transform-origin:left center;
  animation:appleToastProgress 3s linear forwards;
}

.apple-toast__icon,
.apple-toast > div:not(.apple-toast__icon),
.apple-toast__close{
  position:relative;
  z-index:1;
}

.apple-toast__icon{
  flex:0 0 36px;
  width:36px;
  height:36px;
  border-radius:999px;

  display:grid;
  place-items:center;

  color:#fff;
  font-size:18px;
  font-weight:900;

  background:var(--toast-color);

  box-shadow:
    0 10px 22px rgba(16,24,40,.14),
    inset 0 1px 0 rgba(255,255,255,.45);
}

.apple-toast strong{
  display:block;
  margin:1px 0 4px;
  color:#1F2A44;
  font-size:.98rem;
  font-weight:850;
  letter-spacing:-.02em;
}

.apple-toast span{
  display:block;
  color:#5C6475;
  font-size:.92rem;
  line-height:1.45;
}

.apple-toast__close{
  position:absolute;
  top:12px;
  right:12px;

  width:30px;
  height:30px;

  display:grid;
  place-items:center;

  border:1px solid rgba(255,255,255,.72);
  border-radius:999px;

  background:rgba(255,255,255,.46);
  backdrop-filter:blur(10px) saturate(150%);
  -webkit-backdrop-filter:blur(10px) saturate(150%);

  color:#1F2A44;
  font-size:20px;
  line-height:1;
  cursor:pointer;

  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.70),
    0 6px 14px rgba(16,24,40,.08);

  transition:
    transform .18s ease,
    background .18s ease,
    box-shadow .18s ease;
}

.apple-toast__close:hover{
  transform:translateY(-1px);
  background:rgba(255,255,255,.74);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.88),
    0 10px 20px rgba(16,24,40,.12);
}

.apple-toast.is-hidden{
  animation:appleToastClose .24s ease forwards!important;
  pointer-events:none;
}

.apple-toast.is-hidden::after{
  animation-play-state:paused;
}

@keyframes appleToastIn{
  to{
    opacity:1;
    transform:translateX(-50%) translateY(0);
  }
}

@keyframes appleToastAutoClose{
  to{
    opacity:0;
    transform:translateX(-50%) translateY(-14px) scale(.98);
    pointer-events:none;
  }
}

@keyframes appleToastClose{
  to{
    opacity:0;
    transform:translateX(-50%) translateY(-14px) scale(.98);
  }
}

@keyframes appleToastProgress{
  from{
    transform:scaleX(1);
  }

  to{
    transform:scaleX(0);
  }
}

@media (max-width:430px){
  .apple-toast{
    top:14px!important;
    width:calc(100% - 24px);
    padding:18px 46px 16px 16px;
    border-radius:24px;
  }

  .apple-toast__close{
    top:10px;
    right:10px;
  }
}

@media (prefers-reduced-motion:reduce){
  .apple-toast{
    animation:appleToastIn .01s ease forwards;
  }

  .apple-toast::after{
    animation:none;
    transform:scaleX(1);
  }
}

/* Details — full width band */

.contact-details-section{
  position:relative;
  width:100vw;
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
  overflow:hidden;
  padding:0;
}

.contact-details-bg{
  position:relative;
  width:100%;
  padding:clamp(76px, 9vw, 126px) 0;
  background:
    radial-gradient(55% 85% at 12% 20%, rgba(18,179,255,.18), transparent 68%),
    radial-gradient(58% 85% at 86% 80%, rgba(255,22,139,.14), transparent 70%),
    linear-gradient(180deg, rgba(255,255,255,.76), rgba(255,255,255,.54));
  overflow:hidden;
}

.contact-details-bg::before{
  content:"";
  position:absolute;
  inset:auto -10vw -35% -10vw;
  height:58%;
  pointer-events:none;
  background:
    radial-gradient(52% 70% at 15% 40%, rgba(70,220,255,.16), transparent 70%),
    radial-gradient(50% 75% at 82% 35%, rgba(255,22,139,.13), transparent 72%);
  filter:blur(46px) saturate(140%);
}

.contact-details-main{
  position:relative;
  z-index:1;
  text-align:center;
  max-width:860px;
  margin:0 auto clamp(28px, 4vw, 46px);
}

.contact-details-main h2{
  margin:0 0 14px;
  color:var(--ink, #0F172A);
  font-size:clamp(34px, 4.8vw, 58px);
  line-height:1.04;
  letter-spacing:-.06em;
  text-wrap:balance;
}

.contact-details-main p{
  margin:0 auto;
  color:var(--muted, #5B6A7E);
  line-height:1.72;
  font-size:1.03rem;
}

.contact-details-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:18px;
  max-width:1120px;
  margin:0 auto;
}

.contact-mini-panel{
  padding:22px;
  border-radius:26px;
  background:linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.70));
  border:1px solid rgba(255,255,255,.72);
  box-shadow:
    0 18px 44px rgba(15,23,42,.08),
    inset 0 1px 0 rgba(255,255,255,.82);
  backdrop-filter:blur(16px) saturate(150%);
  -webkit-backdrop-filter:blur(16px) saturate(150%);
}

.contact-mini-panel h3{
  margin:0 0 8px;
  color:var(--ink, #0F172A);
  font-size:1.08rem;
  letter-spacing:-.02em;
}

.contact-mini-panel p{
  margin:0;
  color:var(--muted, #5B6A7E);
  line-height:1.58;
  font-size:.96rem;
}

.contact-details-footer{
  position:relative;
  z-index:1;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:22px;
  flex-wrap:wrap;
  max-width:1120px;
  margin:clamp(26px, 4vw, 44px) auto 0;
  padding-top:24px;
  border-top:1px solid rgba(15,23,42,.08);
}

.contact-details-footer span{
  color:var(--muted, #5B6A7E);
  line-height:1.58;
  max-width:760px;
}

.contact-details-footer .link{
  font-weight:850;
}

/* Phone */

.contact-phone-list{
  display:flex;
  flex-direction:column;
  gap:14px;
  margin-top:6px;
}

.contact-phone-item{
  display:flex;
  flex-direction:column;
  gap:4px;
}

.contact-phone-item__type{
  color:var(--muted, #5B6A7E);
  font-size:.76rem;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}

/* Responsive */

@media (max-width:900px){
  .contact-hero__wrap{
    grid-template-columns:1fr;
    text-align:center;
  }

  .contact-hero p:not(.contact-kicker){
    margin-left:auto;
    margin-right:auto;
  }

  .contact-kicker{
    justify-content:center;
  }

  .contact-hero__visual{
    max-width:380px;
    margin:0 auto;
  }

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

  .contact-option-card{
    align-items:center;
    text-align:center;
  }

  .contact-details-footer{
    justify-content:center;
    text-align:center;
  }
}

@media (max-width:700px){
  .contact-hero{
    padding:82px 0 42px;
  }

  .contact-form-card{
    border-radius:28px;
  }

  .contact-details-bg{
    padding:58px 0;
  }

  .form-row{
    grid-template-columns:1fr;
  }

.contact-form-footer{
  align-items:stretch;
}

.contact-form-footer .btn{
  width:100%;
}

  .textarea{
    min-height:210px;
  }
}

@media (max-width:430px){
  .contact-hero__wrap,
  .contact-form-head,
  .contact-details-main,
  .contact-option-card{
    text-align:left;
	margin-top: 25px;
  }

  .contact-kicker{
    justify-content:flex-start;
  }

  .contact-option-card{
    align-items:flex-start;
  }

  .contact-option-card__button{
    width:100%;
    min-height:50px;
    margin-bottom:20px;
  }

  .contact-hero h1{
    font-size:clamp(38px, 11vw, 56px);
  }

  .contact-form-card{
    padding:22px;
  }

  .contact-details-footer{
    align-items:flex-start;
    justify-content:flex-start;
    text-align:left;
  }
}

@media (prefers-reduced-motion:reduce){
  .reveal,
  .input,
  .textarea,
  .contact-option-card,
  .contact-option-card__button{
    transition:none;
  }

  .contact-hero::before{
    animation:none;
  }
}

.apple-toast__close{
	
	display: none !important;
	
}