/* ===========================================================
   RARITY FLIGHT STUDIOS
   "afternoon" poster aesthetic: cream ground, bold lowercase
   cobalt type, duotone blue sky panels w/ white text. No yellow.
   =========================================================== */

:root{
  --paper:#f3eee2;        /* warm cream ground */
  --paper-2:#fbf8ef;
  --blue:#1d54c8;         /* cobalt */
  --blue-deep:#143ea0;
  --blue-soft:#5d8ee6;
  --text:#1b2c57;         /* dark blue ink */
  --white:#fbf8ef;
  --line:#1d54c826;
  --radius:14px;
  --maxw:1180px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Space Grotesk",system-ui,sans-serif;
  color:var(--text);background:var(--paper);
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
/* thin poster frame around the whole page */
body::before{
  content:"";position:fixed;inset:10px;z-index:8000;pointer-events:none;
  border:1.5px solid var(--blue);border-radius:6px;
}
/* paper grain */
body::after{
  content:"";position:fixed;inset:0;z-index:9000;pointer-events:none;
  opacity:.07;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.ico{width:1em;height:1em;display:inline-block;vertical-align:-0.12em;flex:0 0 auto}

/* ---------- BLUE TEXT FILLED WITH BLURRED SKY ---------- */
.section-head h2,
.cta__card h2,
.stat strong,
.quote blockquote,
.kicker,
.card__num,
.nav .brand__name,
.nav__cta{
  background-image:url("sky.svg");
  background-size:cover;
  background-position:center;
  background-attachment:fixed;
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
}
.kicker .ico{-webkit-text-fill-color:initial}
.nav .brand__name em{-webkit-text-fill-color:var(--text)} /* keep "flight" dark */
@supports not ((-webkit-background-clip:text) or (background-clip:text)){
  .section-head h2,.cta__card h2,.stat strong,.quote blockquote,.kicker,.card__num,.nav .brand__name,.nav__cta{color:var(--blue)}
}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:1rem;
  padding:.95rem 1.6rem;border-radius:100px;border:2px solid var(--blue);
  transition:transform .15s ease, box-shadow .15s ease, background .2s, color .2s;cursor:pointer;line-height:1;
}
.btn--solid{background:var(--blue);color:var(--white)}
.btn--solid:hover{transform:translateY(-2px);background:var(--blue-deep);border-color:var(--blue-deep);box-shadow:0 10px 22px -8px var(--blue-deep)}
.btn--ghost{background:rgba(255,255,255,.1);color:var(--white);border-color:rgba(255,255,255,.75);backdrop-filter:blur(4px)}
.btn--ghost:hover{background:var(--white);color:var(--blue);border-color:var(--white)}
.btn--full{width:100%;justify-content:center;padding:1.1rem;font-size:1.1rem}

/* ---------- NAV ---------- */
.nav{
  position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:center;
  gap:clamp(1.2rem,4vw,2.6rem);padding:1.15rem clamp(1.4rem,4vw,2.5rem) .75rem;
  background:rgba(243,238,226,.9);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:.5rem;color:var(--blue)}
.brand__mark{display:flex;color:var(--blue)}
.brand__name{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:1.12rem;letter-spacing:-.02em;color:var(--blue)}
.brand__name em{font-style:normal;margin:0 .12em;color:var(--text)}
.nav__links{display:flex;align-items:center;gap:1.6rem}
.nav__links a{font-weight:500;font-size:.98rem;color:var(--text)}
.nav__links a:not(.nav__cta):hover{color:var(--blue)}
.nav__cta{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;color:var(--blue);border:2px solid var(--blue);border-radius:100px;padding:.55rem 1.1rem}
.nav__cta:hover{background:var(--blue);color:var(--white)}
.nav__menu{display:none;font-size:1.6rem;background:none;border:none;cursor:pointer;color:var(--blue)}

/* ---------- CHIP / KICKER ---------- */
.chip{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:"Bricolage Grotesque",sans-serif;font-weight:700;text-transform:lowercase;
  font-size:.92rem;background:var(--white);color:var(--blue);padding:.5rem 1rem;border-radius:8px;
}
.chip .ico{font-size:1.05rem}
.kicker{
  display:inline-flex;align-items:center;gap:.45rem;
  font-family:"Bricolage Grotesque",sans-serif;font-weight:700;text-transform:lowercase;
  letter-spacing:.04em;font-size:.95rem;color:var(--blue);margin-bottom:1rem;
}
.kicker--center{justify-content:center}
.kicker--light{color:#cfe0ff}

/* ---------- BLURRED VINTAGE-PHOTO SKY BACKGROUND ---------- */
:root{--sky-tint:linear-gradient(180deg,rgba(30,60,120,.30),rgba(16,44,104,.50))}
.sky-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
/* soft, faded, desaturated photo (blurred) */
.sky-bg::before{
  content:"";position:absolute;inset:-24px;
  background:var(--sky-tint), url("sky.svg") center/cover no-repeat;
  filter:blur(4px) saturate(.74) contrast(1.06) sepia(.14) brightness(1.02);
  transform:scale(1.07);
}
/* sharp film/paper grain on top of the blur — this is what reads as "old photo" */
.sky-bg::after{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.55;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='170' height='170'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.62' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:170px 170px;
}

/* unique faded photo per block */
.sky-a::before{background:var(--sky-tint), url("sky.svg") center/cover no-repeat}
.sky-b::before{background:var(--sky-tint), url("sky2.svg") center 64%/cover no-repeat}
.sky-c::before{background:var(--sky-tint), url("sky3.svg") center/cover no-repeat}

/* feather edges so the sky dissolves into adjacent cream blocks */
.fade-b{-webkit-mask-image:linear-gradient(180deg,#000 0,#000 calc(100% - 78px),transparent 100%);mask-image:linear-gradient(180deg,#000 0,#000 calc(100% - 78px),transparent 100%)}
/* gentler, longer fade for the hero */
.fade-hero{-webkit-mask-image:linear-gradient(180deg,#000 0,#000 62%,transparent 100%);mask-image:linear-gradient(180deg,#000 0,#000 62%,transparent 100%)}
.fade-t{-webkit-mask-image:linear-gradient(180deg,transparent 0,#000 78px,#000 100%);mask-image:linear-gradient(180deg,transparent 0,#000 78px,#000 100%)}
.fade-tb{-webkit-mask-image:linear-gradient(180deg,transparent 0,#000 26%,#000 74%,transparent 100%);mask-image:linear-gradient(180deg,transparent 0,#000 26%,#000 74%,transparent 100%)}

/* ---------- HERO ---------- */
.hero{position:relative;overflow:hidden;padding:clamp(3.5rem,8vw,6rem) clamp(1.4rem,4vw,2.5rem) clamp(4rem,8vw,6rem)}
.hero__inner{max-width:1180px;margin:0 auto;position:relative;z-index:5}
.hero__title{
  font-family:"Bricolage Grotesque",sans-serif;font-weight:800;text-transform:lowercase;color:var(--white);
  font-size:clamp(3.4rem,13vw,9rem);line-height:.88;letter-spacing:-.04em;margin:1.1rem 0 0;
  text-shadow:0 6px 30px rgba(9,30,75,.45);
}
.hero__title .dot{color:var(--white)}
.hero__sub{max-width:600px;margin:1.4rem 0 0;font-size:clamp(1.05rem,2.2vw,1.28rem);line-height:1.55;color:var(--white);text-shadow:0 1px 10px rgba(9,30,75,.4)}
.hero__sub strong{color:#dbe7ff}
.hero__actions{display:flex;gap:.9rem;flex-wrap:wrap;margin-top:1.8rem}
.hero__actions .btn--solid{background:var(--white);color:var(--blue);border-color:var(--white)}
.hero__actions .btn--solid:hover{background:var(--paper);border-color:var(--paper);box-shadow:0 12px 26px -10px rgba(9,30,75,.55)}
.hero__meta{margin-top:2.6rem}

/* ---------- SKY PANEL ---------- */
.panel{
  position:relative;overflow:hidden;margin-top:clamp(2rem,5vw,3rem);
  border-radius:20px;border:1.5px solid var(--blue);
  min-height:clamp(360px,46vw,520px);padding:clamp(1.3rem,3.5vw,2.2rem);
  display:flex;flex-direction:column;justify-content:space-between;
  box-shadow:0 30px 60px -34px rgba(20,62,160,.6);
}
.panel::before{content:"";position:absolute;inset:12px;border:1.5px solid rgba(255,255,255,.55);border-radius:12px;z-index:3;pointer-events:none}
.panel__sky{position:absolute;inset:-20px;z-index:0;background:url("sky.svg") center/cover no-repeat,linear-gradient(180deg,var(--blue-deep),var(--blue-soft));filter:blur(1px);transform:scale(1.04)}
.panel__tag{
  position:relative;z-index:4;align-self:flex-start;display:inline-flex;align-items:center;gap:.55rem;
  font-family:"Bricolage Grotesque",sans-serif;font-weight:700;text-transform:lowercase;
  background:var(--blue);color:var(--white);padding:.55rem 1rem;border-radius:8px;font-size:clamp(1rem,2.4vw,1.5rem);
}
.panel__meta{position:relative;z-index:4;display:grid;grid-template-columns:repeat(4,auto);gap:clamp(1rem,4vw,3rem)}
.panel__meta div{display:flex;flex-direction:column}
.panel__meta span{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;text-transform:lowercase;color:#cfe0ff;font-size:.82rem;letter-spacing:.02em}
.panel__meta strong{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;color:#fff;font-size:clamp(.95rem,2vw,1.15rem)}

/* sky doodads */
.flare{position:absolute;top:8%;right:7%;width:clamp(46px,7vw,74px);color:#fff;z-index:2;opacity:.95}
.bird-hero{position:absolute;top:34%;right:24%;width:clamp(48px,8vw,90px);color:#0e1f44;z-index:2;animation:soar 9s ease-in-out infinite}
.spiral-mark{position:absolute;left:6%;bottom:24%;width:clamp(34px,5vw,48px);color:#fff;opacity:.85;z-index:2}
.sky-bird{position:absolute;color:#0e1f44;opacity:.85;aspect-ratio:3/1;height:auto;z-index:2}
.sb1{top:22%;left:30%;width:54px;animation:soar 11s ease-in-out infinite .4s}
@keyframes soar{0%,100%{transform:translate(0,0) rotate(-2deg)}50%{transform:translate(-12px,-14px) rotate(2deg)}}

/* ---------- SECTION HEAD ---------- */
.section-head{max-width:var(--maxw);margin:0 auto clamp(2rem,5vw,3.2rem)}
.section-head--center{text-align:center}
.section-head h2{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;text-transform:lowercase;color:var(--blue);font-size:clamp(2.1rem,6.5vw,4.4rem);line-height:.95;letter-spacing:-.03em}
.lede{max-width:620px;margin-top:1.2rem;font-size:1.12rem;line-height:1.55;color:var(--text)}
.section-head--center .lede{margin-left:auto;margin-right:auto}

/* ---------- SERVICES ---------- */
.services{padding:clamp(3rem,7vw,5.5rem) clamp(1.4rem,4vw,2.5rem)}
.cards{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.card{background:var(--paper-2);border:1.5px solid var(--blue);border-radius:var(--radius);padding:1.7rem 1.5rem 1.9rem;transition:transform .2s ease, box-shadow .2s ease}
.card:hover{transform:translateY(-5px);box-shadow:0 18px 34px -20px rgba(20,62,160,.55)}
.card__num{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:.95rem;color:var(--blue)}
.card h3{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:1.45rem;letter-spacing:-.02em;margin:.6rem 0 .55rem;color:var(--text)}
.card p{color:var(--text);opacity:.82;line-height:1.55;font-size:1rem}

/* ---------- PROMISE (blue block) ---------- */
.promise{position:relative;overflow:hidden;color:var(--white);text-align:center;padding:clamp(4rem,9vw,7rem) clamp(1.4rem,4vw,2.5rem)}
.promise__inner{position:relative;z-index:2;max-width:900px;margin:0 auto}
.promise h2{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;text-transform:lowercase;font-size:clamp(2.2rem,6.5vw,4.6rem);line-height:.95;letter-spacing:-.03em;text-shadow:0 5px 26px rgba(9,30,75,.45)}
.promise p{margin-top:1.4rem;font-size:1.2rem;line-height:1.6;opacity:.95;max-width:680px;margin-left:auto;margin-right:auto;text-shadow:0 1px 10px rgba(9,30,75,.4)}
.spark-deco{position:absolute;color:rgba(255,255,255,.85);z-index:1}
.sd1{width:40px;top:18%;left:10%;animation:twinkle 4s ease-in-out infinite}
.sd2{width:54px;bottom:16%;right:11%;animation:twinkle 5s ease-in-out infinite 1s}
@keyframes twinkle{0%,100%{transform:scale(1) rotate(0);opacity:.5}50%{transform:scale(1.25) rotate(20deg);opacity:1}}

/* ---------- PROCESS ---------- */
.process{padding:clamp(3.5rem,8vw,6rem) clamp(1.4rem,4vw,2.5rem)}
.steps{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.step{background:var(--paper-2);border:1.5px solid var(--blue);border-radius:var(--radius);padding:1.9rem 1.6rem 2rem}
.step:nth-child(2){transform:translateY(26px)}
.step__no{display:inline-block;font-family:"Bricolage Grotesque",sans-serif;font-weight:700;background:var(--blue);color:var(--white);padding:.4rem 1rem;border-radius:100px;font-size:.85rem;letter-spacing:.03em;margin-bottom:1rem}
.step h3{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:1.5rem;letter-spacing:-.02em;line-height:1.05;margin-bottom:.65rem;color:var(--text)}
.step p{color:var(--text);opacity:.82;line-height:1.6}
.process__cta{text-align:center;margin-top:clamp(2.5rem,6vw,3.6rem)}

/* ---------- RESULTS ---------- */
.results{padding:clamp(3rem,7vw,5.5rem) clamp(1.4rem,4vw,2.5rem)}
.results__grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.stat{border:1.5px solid var(--blue);border-radius:var(--radius);padding:1.8rem 1.4rem;text-align:center;background:var(--paper-2)}
.stat strong{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:clamp(2.2rem,5vw,3.2rem);color:var(--blue);line-height:1;display:block}
.stat span{display:block;margin-top:.55rem;color:var(--text);opacity:.8;font-size:.95rem;line-height:1.4}
.quote{max-width:840px;margin:clamp(2.5rem,6vw,4rem) auto 0;text-align:center}
.quote blockquote{font-family:"Bricolage Grotesque",sans-serif;font-weight:600;font-size:clamp(1.4rem,3.5vw,2.2rem);line-height:1.25;color:var(--blue);letter-spacing:-.02em}
.quote figcaption{margin-top:1.1rem;font-family:"Bricolage Grotesque",sans-serif;font-weight:700;color:var(--text)}

/* ---------- CTA (sky panel) ---------- */
/* CTA + footer share one continuous sky */
.bottom{position:relative;overflow:hidden}
.bottom>.sky-bg{z-index:0}
.cta{position:relative;z-index:1;overflow:hidden;padding:clamp(4.5rem,9vw,7.5rem) clamp(1.4rem,4vw,2.5rem)}
.cta>*:not(.sky-bg){position:relative;z-index:3}
.cta-flare{position:absolute;top:9%;right:10%;width:clamp(50px,7vw,80px);color:#fff;z-index:1;opacity:.95}
.cta .sky-bird{z-index:1}
.cb1{top:16%;left:11%;width:64px;animation:soar 8s ease-in-out infinite}
.cb2{bottom:14%;right:13%;top:auto;width:48px;animation:soar 10s ease-in-out infinite .5s}
.cta__card{max-width:680px;margin:0 auto;background:var(--paper-2);border:1.5px solid var(--blue);border-radius:20px;padding:clamp(2rem,5vw,3.2rem);box-shadow:0 30px 60px -28px rgba(20,62,160,.7);text-align:center}
.cta__card h2{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;text-transform:lowercase;font-size:clamp(2.2rem,6vw,3.4rem);line-height:.98;letter-spacing:-.03em;color:var(--blue)}
.cta__lead{color:var(--text);opacity:.85;margin:1rem auto 1.8rem;max-width:480px;line-height:1.55}

/* ---------- CONTACT CARD ---------- */
.contact{text-align:left;margin:0 0 1.6rem;border-top:1px solid var(--line)}
.contact__row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.95rem .2rem;border-bottom:1px solid var(--line)}
.contact__label{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;text-transform:lowercase;letter-spacing:.02em;color:var(--blue);font-size:.9rem}
.contact__value{font-size:1rem;color:var(--text);font-weight:500}
a.contact__row{transition:color .15s ease}
a.contact__row:hover .contact__value{color:var(--blue)}

/* ---------- FOOTER ---------- */
.footer{position:relative;z-index:1;color:var(--white);padding:clamp(2.8rem,6vw,4rem) clamp(1.4rem,4vw,2.5rem) 2.4rem}
.footer>*{position:relative;z-index:2}
.footer__top{display:flex;align-items:baseline;gap:1rem;flex-wrap:wrap;padding-bottom:1.6rem;border-bottom:1px solid rgba(255,255,255,.2)}
.brand__name--big{font-size:clamp(1.5rem,4vw,2.2rem);color:var(--white)}
.brand__name--big em{color:#bcd2ff}
.footer__top p{font-family:"Bricolage Grotesque",sans-serif;font-weight:600;opacity:.8;text-transform:lowercase}
.footer__meta{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:1.6rem}
.footer__meta span{display:block;font-family:"Bricolage Grotesque",sans-serif;font-weight:700;text-transform:lowercase;color:#bcd2ff;font-size:.82rem;margin-bottom:.6rem}
.footer__meta a{display:block;opacity:.85;margin-bottom:.4rem;font-size:.95rem}
.footer__meta a:hover{opacity:1}
.footer__meta .fmail{display:block;opacity:.85;margin-bottom:.4rem;font-size:.95rem;cursor:default}
.footer__legal{margin-top:1.8rem;opacity:.6;font-size:.85rem;font-family:"Bricolage Grotesque",sans-serif}

/* ---------- RESPONSIVE ---------- */
@media(max-width:900px){
  .cards{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:1fr}
  .step:nth-child(2){transform:none}
  .results__grid{grid-template-columns:repeat(2,1fr)}
  .panel__meta{grid-template-columns:repeat(2,1fr);gap:1rem}
}
@media(max-width:760px){
  .nav{justify-content:space-between}
  .nav__links{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background:var(--paper-2);border-bottom:1px solid var(--line);padding:.5rem 0}
  .nav__links.open{display:flex}
  .nav__links a{padding:.9rem clamp(1.4rem,4vw,2.5rem)}
  .nav__cta{margin:.5rem clamp(1.4rem,4vw,2.5rem);text-align:center}
  .nav__menu{display:block}
  .bird-hero{right:8%}
}
@media(max-width:560px){
  .cards{grid-template-columns:1fr}
  .results__grid{grid-template-columns:1fr}
  .form__row{flex-direction:column;gap:.8rem}
  .footer__meta{grid-template-columns:1fr}
  body::before{inset:6px}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;scroll-behavior:auto}}
