/* ============================================================
   TIDAL FILMS LLC — Cinematic Production
   Dark editorial theme · Orange County, CA
   ============================================================ */

/* ---------- TOKENS ---------- */
:root{
  --ink:        #0a0c0d;
  --ink-soft:   #0f1213;
  --ink-card:   #14181a;
  --ink-card-2: #181d1f;
  --bone:       #f4f0e7;
  --mist:       #98a0a0;
  --mist-dim:   #5f6868;
  --tide:       #46c4bc;
  --tide-deep:  #1f8d86;
  --sand:       #e3a866;
  --line:       rgba(244,240,231,.09);
  --line-2:     rgba(244,240,231,.16);
  --shadow:     0 30px 70px -25px rgba(0,0,0,.85);

  --serif: "Fraunces", Georgia, serif;
  --sans:  "Hanken Grotesk", system-ui, sans-serif;

  --wrap: 1240px;
  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
}

/* ---------- RESET ---------- */
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  background:var(--ink);
  color:var(--bone);
  font-family:var(--sans);
  font-weight:400;
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img,video,svg{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit;}
ul{list-style:none;}
::selection{background:var(--tide);color:var(--ink);}

section[id], main{scroll-margin-top:86px;}

/* ---------- GRAIN OVERLAY ---------- */
.grain{
  position:fixed;inset:0;z-index:9000;pointer-events:none;
  opacity:.4;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- SCROLL PROGRESS ---------- */
.scroll-progress{
  position:fixed;top:0;left:0;right:0;height:2px;z-index:9100;
  background:rgba(255,255,255,.04);
}
.scroll-progress span{
  display:block;height:100%;width:0%;
  background:linear-gradient(90deg,var(--tide),var(--sand));
  transition:width .1s linear;
}

/* ---------- CUSTOM CURSOR ---------- */
.cursor-dot,.cursor-ring{
  position:fixed;top:0;left:0;z-index:9200;pointer-events:none;
  border-radius:50%;mix-blend-mode:difference;
}
.cursor-dot{
  width:6px;height:6px;background:var(--bone);
  transform:translate(-50%,-50%);
}
.cursor-ring{
  width:38px;height:38px;border:1px solid rgba(244,240,231,.55);
  transform:translate(-50%,-50%);
  transition:width .3s var(--ease),height .3s var(--ease),
             background .3s var(--ease),border-color .3s var(--ease),opacity .3s;
}
.cursor-ring.is-hover{
  width:62px;height:62px;background:rgba(244,240,231,.12);border-color:transparent;
}
.cursor-ring.is-view::after{
  content:"VIEW";font:600 9px/1 var(--sans);letter-spacing:.12em;
  color:var(--bone);position:absolute;inset:0;display:grid;place-items:center;
}
body.cursor-on{cursor:none;}
body.cursor-on a,body.cursor-on button{cursor:none;}
@media (hover:none),(pointer:coarse){
  .cursor-dot,.cursor-ring{display:none;}
  body.cursor-on{cursor:auto;}
}

/* ---------- PRELOADER ---------- */
.preloader{
  position:fixed;inset:0;z-index:9999;background:var(--ink);
  display:grid;place-items:center;
  transition:opacity .6s var(--ease),visibility .6s;
}
.preloader.done{opacity:0;visibility:hidden;}
.preloader-mark{display:flex;align-items:center;gap:.6rem;}
.pl-word{
  font:600 clamp(1.6rem,5vw,2.6rem)/1 var(--serif);letter-spacing:.04em;
  opacity:0;transform:translateY(110%);
  animation:plWord .7s var(--ease-out) forwards;
}
.pl-word--2{animation-delay:.12s;}
.pl-line{
  width:0;height:1px;background:var(--tide);
  animation:plLine .6s .35s var(--ease) forwards;
}
@keyframes plWord{to{opacity:1;transform:translateY(0);}}
@keyframes plLine{to{width:54px;}}

/* ---------- HEADER ---------- */
.header{
  position:fixed;top:0;left:0;right:0;z-index:8000;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.4rem clamp(1.2rem,4vw,3rem);
  transition:padding .4s var(--ease),background .4s var(--ease),
             backdrop-filter .4s var(--ease),border-color .4s var(--ease);
  border-bottom:1px solid transparent;
}
.header.scrolled{
  padding:.85rem clamp(1.2rem,4vw,3rem);
  background:rgba(10,12,13,.82);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:.6rem;}
.brand-mark{
  width:30px;height:30px;fill:none;stroke:var(--tide);
  stroke-width:2;stroke-linecap:round;
  transition:transform .5s var(--ease);
}
.brand:hover .brand-mark{transform:translateX(3px);}
.brand-text{
  font:600 1.18rem/1 var(--serif);letter-spacing:.01em;
}
.brand-text em{
  font-style:normal;font-family:var(--sans);font-weight:500;
  font-size:.5rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--tide);margin-left:.25rem;vertical-align:.35em;
}
.nav{display:flex;align-items:center;gap:.35rem;}
.nav-link{
  position:relative;padding:.5rem .85rem;
  font-size:.82rem;font-weight:500;letter-spacing:.02em;color:var(--mist);
  transition:color .3s var(--ease);
}
.nav-link::after{
  content:"";position:absolute;left:.85rem;right:.85rem;bottom:.28rem;
  height:1px;background:var(--tide);transform:scaleX(0);transform-origin:left;
  transition:transform .35s var(--ease);
}
.nav-link:hover{color:var(--bone);}
.nav-link:hover::after,.nav-link.active::after{transform:scaleX(1);}
.nav-link.active{color:var(--bone);}
.nav-link--cta{
  margin-left:.5rem;color:var(--ink);background:var(--bone);
  border-radius:100px;padding:.6rem 1.2rem;font-weight:600;
  transition:background .3s var(--ease),color .3s var(--ease),transform .3s var(--ease);
}
.nav-link--cta::after{display:none;}
.nav-link--cta:hover{background:var(--tide);color:var(--ink);transform:translateY(-2px);}

/* burger */
.menu-toggle{
  display:none;width:42px;height:42px;border-radius:50%;
  border:1px solid var(--line-2);position:relative;
}
.menu-toggle span{
  position:absolute;left:50%;width:16px;height:1.5px;background:var(--bone);
  transform:translateX(-50%);transition:.35s var(--ease);
}
.menu-toggle span:first-child{top:17px;}
.menu-toggle span:last-child{bottom:17px;}
.menu-toggle.open span:first-child{top:50%;transform:translate(-50%,-50%) rotate(45deg);}
.menu-toggle.open span:last-child{bottom:auto;top:50%;transform:translate(-50%,-50%) rotate(-45deg);}

/* ---------- MOBILE MENU ---------- */
.mobile-menu{
  position:fixed;inset:0;z-index:7900;background:var(--ink-soft);
  display:flex;flex-direction:column;justify-content:center;
  padding:6rem 2rem 2rem;
  clip-path:circle(0% at 100% 0%);
  transition:clip-path .65s var(--ease);
}
.mobile-menu.open{clip-path:circle(150% at 100% 0%);}
.mobile-menu nav{display:flex;flex-direction:column;}
.m-link{
  display:flex;align-items:baseline;gap:1rem;
  padding:.9rem 0;border-bottom:1px solid var(--line);
  font:500 clamp(1.7rem,8vw,2.6rem)/1.1 var(--serif);
  opacity:0;transform:translateY(20px);
}
.mobile-menu.open .m-link{
  opacity:1;transform:translateY(0);
  transition:opacity .5s var(--ease),transform .5s var(--ease);
}
.mobile-menu.open .m-link:nth-child(1){transition-delay:.18s;}
.mobile-menu.open .m-link:nth-child(2){transition-delay:.24s;}
.mobile-menu.open .m-link:nth-child(3){transition-delay:.30s;}
.mobile-menu.open .m-link:nth-child(4){transition-delay:.36s;}
.mobile-menu.open .m-link:nth-child(5){transition-delay:.42s;}
.mobile-menu.open .m-link:nth-child(6){transition-delay:.48s;}
.mobile-menu.open .m-link:nth-child(7){transition-delay:.54s;}
.m-link span{font:600 .7rem/1 var(--sans);color:var(--tide);letter-spacing:.1em;}
.m-link--cta{color:var(--tide);}
.m-foot{
  display:flex;flex-direction:column;gap:.4rem;margin-top:2.2rem;
  font-size:.9rem;color:var(--mist);
}

/* ---------- BUTTONS ---------- */
.btn{
  position:relative;display:inline-flex;align-items:center;justify-content:center;
  padding:1rem 2rem;border-radius:100px;
  font-size:.86rem;font-weight:600;letter-spacing:.03em;
  overflow:hidden;transition:transform .3s var(--ease),color .35s var(--ease);
  will-change:transform;
}
.btn span{position:relative;z-index:2;}
.btn::before{
  content:"";position:absolute;inset:0;z-index:1;
  transition:transform .45s var(--ease);
}
.btn--solid{background:var(--bone);color:var(--ink);}
.btn--solid::before{background:var(--tide);transform:translateY(101%);}
.btn--solid:hover::before{transform:translateY(0);}
.btn--solid:hover{color:var(--ink);}
.btn--ghost{border:1px solid var(--line-2);color:var(--bone);}
.btn--ghost::before{background:var(--bone);transform:translateY(101%);}
.btn--ghost:hover::before{transform:translateY(0);}
.btn--ghost:hover{color:var(--ink);}
.btn--full{width:100%;margin-top:.4rem;}

/* ---------- LAYOUT HELPERS ---------- */
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 clamp(1.2rem,4vw,2.4rem);}
.section{padding:clamp(5rem,10vw,9rem) 0;position:relative;}
.eyebrow{
  display:inline-flex;align-items:center;gap:.55rem;
  font-size:.72rem;font-weight:600;letter-spacing:.18em;
  text-transform:uppercase;color:var(--mist);margin-bottom:1.3rem;
}
.eyebrow--c{margin-left:auto;margin-right:auto;}
.eyebrow .dot{
  width:6px;height:6px;border-radius:50%;background:var(--tide);
  box-shadow:0 0 12px var(--tide);
  animation:pulse 2.6s var(--ease) infinite;
}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1;}50%{transform:scale(1.5);opacity:.5;}}

.sec-title{
  font:500 clamp(2.1rem,5.4vw,4rem)/1.06 var(--serif);
  letter-spacing:-.015em;
}
.sec-title em{
  font-style:italic;color:var(--tide);
  font-variation-settings:"opsz" 120;
}
.sec-lead{
  color:var(--mist);font-size:1.04rem;max-width:46ch;margin-top:1.2rem;
}
.sec-lead em{font-style:italic;color:var(--bone);}
.sec-head{margin-bottom:3.4rem;}
.sec-head--center{text-align:center;}
.sec-head--center .sec-lead{margin-left:auto;margin-right:auto;}
.sec-head--row{
  display:flex;justify-content:space-between;align-items:flex-end;
  gap:2.5rem;flex-wrap:wrap;
}
.sec-head--row .sec-lead{margin-top:0;}

/* ---------- REVEAL SYSTEM ---------- */
[data-reveal]{
  opacity:0;transform:translateY(34px);
  transition:opacity .9s var(--ease-out),transform .9s var(--ease-out);
}
[data-reveal].is-visible{opacity:1;transform:translateY(0);}
[data-reveal].is-visible{transition-delay:var(--rd,0s);}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;min-height:100svh;
  display:flex;flex-direction:column;justify-content:center;
  padding:8rem clamp(1.2rem,4vw,3rem) 5rem;
  overflow:hidden;
}
.hero-media{position:absolute;inset:0;z-index:0;}
.hero-video{
  position:absolute;inset:0;
  width:100%;height:100%;object-fit:cover;
  filter:saturate(.85) contrast(1.05) brightness(.62);
  transform:scale(1.06);
  opacity:0;transition:opacity 1.2s ease;
  will-change:opacity;
}
.hero-video.is-active{opacity:1;}
.hero-veil{
  position:absolute;inset:0;
  background:
    radial-gradient(120% 80% at 70% 20%,transparent,rgba(10,12,13,.5)),
    linear-gradient(180deg,rgba(10,12,13,.55) 0%,rgba(10,12,13,.2) 40%,var(--ink) 100%);
}
.hero-inner{position:relative;z-index:2;max-width:var(--wrap);margin:0 auto;width:100%;}
.hero-eyebrow{
  opacity:0;animation:fadeUp .8s .2s var(--ease-out) forwards;
}
.hero-title{
  font:500 clamp(2.9rem,9.4vw,7.2rem)/.98 var(--serif);
  letter-spacing:-.025em;margin-bottom:1.6rem;
}
.hero-title .line{display:block;overflow:hidden;}
.hero-title .w{
  display:block;transform:translateY(108%);
  animation:heroWord 1s var(--ease-out) forwards;
}
.hero-title .line:nth-child(1) .w{animation-delay:.35s;}
.hero-title .line:nth-child(2) .w{animation-delay:.46s;}
.hero-title .line:nth-child(3) .w{animation-delay:.57s;}
.hero-title em{font-style:italic;color:var(--tide);font-variation-settings:"opsz" 144;}
@keyframes heroWord{to{transform:translateY(0);}}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}
.hero-sub{
  max-width:50ch;font-size:1.1rem;color:var(--mist);
  opacity:0;animation:fadeUp .9s .8s var(--ease-out) forwards;
}
.hero-actions{
  display:flex;gap:.9rem;margin-top:2.2rem;flex-wrap:wrap;
  opacity:0;animation:fadeUp .9s .95s var(--ease-out) forwards;
}
.hero-scroll{
  position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);
  z-index:2;display:flex;flex-direction:column;align-items:center;gap:.6rem;
  font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--mist);
  opacity:0;animation:fadeUp 1s 1.3s var(--ease-out) forwards;
}
.hero-scroll-line{
  width:1px;height:46px;background:var(--line-2);position:relative;overflow:hidden;
}
.hero-scroll-line::after{
  content:"";position:absolute;top:-50%;left:0;width:100%;height:50%;
  background:var(--tide);animation:scrollDrop 2s var(--ease) infinite;
}
@keyframes scrollDrop{0%{top:-50%;}60%,100%{top:100%;}}

/* ---------- MARQUEE ---------- */
.marquee{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:1.5rem 0;overflow:hidden;background:var(--ink-soft);
}
.marquee-track{
  display:flex;align-items:center;gap:2.4rem;width:max-content;
  animation:scroll 38s linear infinite;
}
.marquee-track span{
  font:500 clamp(1.5rem,3.6vw,2.6rem)/1 var(--serif);
  letter-spacing:.01em;white-space:nowrap;
}
.marquee-track i{color:var(--tide);font-style:normal;font-size:1rem;}
@keyframes scroll{to{transform:translateX(-50%);}}

/* ============================================================
   SERVICES
   ============================================================ */
.svc-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem;
}
.svc-card{
  position:relative;display:flex;flex-direction:column;
  padding:2.2rem 1.7rem 1.9rem;border-radius:14px;
  background:var(--ink-card);border:1px solid var(--line);
  overflow:hidden;
  transition:transform .5s var(--ease),border-color .5s var(--ease),background .5s var(--ease);
}
.svc-card::before{
  content:"";position:absolute;inset:0;border-radius:14px;
  background:radial-gradient(80% 60% at 50% 0%,rgba(70,196,188,.16),transparent);
  opacity:0;transition:opacity .5s var(--ease);
}
.svc-card:hover{transform:translateY(-8px);border-color:var(--line-2);background:var(--ink-card-2);}
.svc-card:hover::before{opacity:1;}
.svc-num{
  font:600 .72rem/1 var(--sans);letter-spacing:.14em;color:var(--mist-dim);
  position:relative;
}
.svc-icon{
  width:52px;height:52px;border-radius:12px;margin:1.6rem 0 1.3rem;
  display:grid;place-items:center;
  background:rgba(70,196,188,.1);border:1px solid rgba(70,196,188,.2);
  position:relative;transition:transform .5s var(--ease);
}
.svc-card:hover .svc-icon{transform:translateY(-3px) rotate(-4deg);}
.svc-icon svg{
  width:24px;height:24px;fill:none;stroke:var(--tide);
  stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;
}
.svc-card h3{
  font:500 1.32rem/1.2 var(--serif);margin-bottom:.6rem;position:relative;
}
.svc-card p{font-size:.92rem;color:var(--mist);flex:1;position:relative;}
.svc-go{
  display:inline-flex;align-items:center;gap:.4rem;margin-top:1.4rem;
  font-size:.78rem;font-weight:600;letter-spacing:.04em;color:var(--tide);
  position:relative;
}
.svc-go i{transition:transform .35s var(--ease);font-style:normal;}
.svc-card:hover .svc-go i{transform:translateX(5px);}

/* ============================================================
   SELECTED WORK / GALLERY
   ============================================================ */
.filters{
  display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:2rem;
}
.filter{
  padding:.6rem 1.25rem;border-radius:100px;
  border:1px solid var(--line-2);
  font-size:.78rem;font-weight:600;letter-spacing:.03em;color:var(--mist);
  transition:.35s var(--ease);
}
.filter:hover{color:var(--bone);border-color:var(--bone);}
.filter.is-active{background:var(--bone);color:var(--ink);border-color:var(--bone);}

.gallery{
  display:grid;grid-template-columns:repeat(4,1fr);
  grid-auto-rows:230px;gap:1rem;
}
.g-item{
  position:relative;overflow:hidden;border-radius:12px;
  border:1px solid var(--line);
  transition:opacity .5s var(--ease),transform .5s var(--ease),filter .5s var(--ease);
}
.g-item.g-tall{grid-row:span 2;}
.g-item img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .9s var(--ease);
}
.g-item:hover img{transform:scale(1.08);}
.g-item figcaption{
  position:absolute;left:0;right:0;bottom:0;
  padding:2.2rem 1.2rem 1.1rem;
  background:linear-gradient(transparent,rgba(10,12,13,.92));
  transform:translateY(8px);opacity:0;
  transition:.45s var(--ease);
}
.g-item:hover figcaption{transform:translateY(0);opacity:1;}
.g-item figcaption span{
  font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--tide);
}
.g-item figcaption b{
  display:block;font:500 1.05rem/1.2 var(--serif);margin-top:.2rem;
}
.g-item.is-hidden{
  opacity:0;transform:scale(.92);pointer-events:none;
  width:0;height:0;padding:0;margin:0;border:0;
  grid-row:auto !important;
  position:absolute;
}

/* ---------- STATS ---------- */
.stats{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--ink-soft);
}
.stats-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
}
.stat{
  padding:3rem 1.5rem;text-align:center;
  border-right:1px solid var(--line);
}
.stat:last-child{border-right:0;}
.stat-num{
  display:block;
  font:500 clamp(2.6rem,5vw,3.8rem)/1 var(--serif);
  color:var(--bone);
}
.stat-label{
  display:block;margin-top:.5rem;
  font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--mist);
}

/* ============================================================
   FEATURE (WEDDINGS)
   ============================================================ */
.feature-grid{
  display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(2rem,5vw,4.5rem);
  align-items:center;
}
.feature-media{position:relative;}
.fm-stack{position:relative;padding:2rem 2rem 0 0;}
.fm-1{
  width:100%;border-radius:14px;aspect-ratio:4/5;object-fit:cover;
  border:1px solid var(--line);
}
.fm-2{
  position:absolute;right:0;bottom:-2.5rem;width:48%;
  border-radius:12px;aspect-ratio:1;object-fit:cover;
  border:4px solid var(--ink);box-shadow:var(--shadow);
}
.fm-badge{
  position:absolute;top:0;left:0;
  background:var(--tide);color:var(--ink);
  font:600 .68rem/1 var(--sans);letter-spacing:.1em;text-transform:uppercase;
  padding:.6rem .9rem;border-radius:8px;
}
.feature-copy .price-row{margin-top:2.2rem;}

/* ---------- PRICE CARDS ---------- */
.price-row{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;
}
.price-card{
  position:relative;display:flex;flex-direction:column;
  padding:1.9rem 1.5rem;border-radius:14px;
  background:var(--ink-card);border:1px solid var(--line);
  transition:transform .5s var(--ease),border-color .5s var(--ease),background .5s var(--ease);
}
.price-card:hover{transform:translateY(-6px);border-color:var(--line-2);}
.price-card--featured{
  background:var(--ink-card-2);
  border-color:rgba(70,196,188,.4);
  box-shadow:0 0 0 1px rgba(70,196,188,.12),0 30px 60px -30px rgba(0,0,0,.7);
}
.price-card--featured:hover{border-color:var(--tide);}
.price-card--glass{
  background:rgba(20,24,26,.62);backdrop-filter:blur(14px);
}
.price-card .tag{
  position:absolute;top:-.7rem;left:1.5rem;
  background:var(--sand);color:var(--ink);
  font:600 .64rem/1 var(--sans);letter-spacing:.1em;text-transform:uppercase;
  padding:.4rem .7rem;border-radius:6px;
}
.price-card header{
  padding-bottom:1.1rem;margin-bottom:1.1rem;border-bottom:1px solid var(--line);
}
.price-card h3{
  font:500 1.25rem/1.2 var(--serif);margin-bottom:.5rem;
}
.price{
  font:500 2.5rem/1 var(--serif);color:var(--bone);
  display:flex;align-items:baseline;gap:.05rem;
}
.price span{font-size:1.1rem;color:var(--mist);}
.price small{
  font:400 .82rem/1 var(--sans);color:var(--mist);margin-left:.35rem;
}
.price--from span{font-size:.92rem;}
.price--from{font-size:2.2rem;}
.price-card ul{display:flex;flex-direction:column;gap:.6rem;flex:1;}
.price-card li{
  font-size:.9rem;color:var(--mist);padding-left:1.4rem;position:relative;
}
.price-card li b{color:var(--bone);font-weight:600;}
.price-card li::before{
  content:"";position:absolute;left:0;top:.55em;
  width:8px;height:8px;border-radius:50%;
  border:1.5px solid var(--tide);
}
.price-card li b::after{}
.price-cta{
  margin-top:1.5rem;text-align:center;
  padding:.85rem 1rem;border-radius:100px;
  font-size:.82rem;font-weight:600;letter-spacing:.03em;
  border:1px solid var(--line-2);
  transition:.35s var(--ease);
}
.price-cta:hover{background:var(--bone);color:var(--ink);border-color:var(--bone);}
.price-card--featured .price-cta{background:var(--tide);color:var(--ink);border-color:var(--tide);}
.price-card--featured .price-cta:hover{background:var(--bone);border-color:var(--bone);}

/* ============================================================
   DRONE
   ============================================================ */
.drone{overflow:hidden;background:var(--ink-soft);}
.drone-bg{position:absolute;inset:0;z-index:0;}
.drone-video{
  width:100%;height:100%;object-fit:cover;
  filter:brightness(.4) saturate(.9);
}
.drone-veil{
  position:absolute;inset:0;
  background:linear-gradient(180deg,var(--ink-soft) 0%,rgba(15,18,19,.7) 35%,rgba(15,18,19,.7) 65%,var(--ink-soft) 100%);
}
.drone .wrap{position:relative;z-index:2;}
.drone-tags{
  display:flex;flex-wrap:wrap;justify-content:center;gap:.6rem;
  margin:0 auto 3rem;
}
.drone-tags span{
  padding:.55rem 1.1rem;border-radius:100px;
  border:1px solid var(--line-2);background:rgba(10,12,13,.5);
  font-size:.78rem;font-weight:500;color:var(--bone);
}

/* ============================================================
   REAL ESTATE
   ============================================================ */
.re-toggle{
  position:relative;display:flex;gap:.3rem;
  background:var(--ink-card);border:1px solid var(--line);
  border-radius:100px;padding:.35rem;
  width:max-content;margin:0 auto 3rem;
}
.re-tab{
  position:relative;z-index:2;
  display:flex;flex-direction:column;align-items:center;
  padding:.7rem 1.6rem;border-radius:100px;
  font-size:.88rem;font-weight:600;color:var(--mist);
  transition:color .35s var(--ease);
}
.re-tab small{
  font-weight:400;font-size:.68rem;color:var(--mist-dim);margin-top:.15rem;
  transition:color .35s var(--ease);
}
.re-tab.is-active{color:var(--ink);}
.re-tab.is-active small{color:rgba(10,12,13,.65);}
.re-glider{
  position:absolute;z-index:1;top:.35rem;bottom:.35rem;left:.35rem;
  width:calc(50% - .35rem);border-radius:100px;background:var(--bone);
  transition:transform .45s var(--ease);
}
.re-glider.right{transform:translateX(100%);}

.re-panel{display:none;}
.re-panel.is-active{display:block;animation:panelIn .5s var(--ease-out);}
@keyframes panelIn{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:translateY(0);}}

.re-note{
  max-width:62ch;margin:0 auto 2.4rem;text-align:center;
  font-size:1rem;color:var(--mist);
  padding:1.2rem 1.6rem;border-radius:12px;
  background:rgba(70,196,188,.06);border:1px solid rgba(70,196,188,.18);
}
.re-note strong{color:var(--tide);font-weight:600;}

.re-perks{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;
  margin-top:2.6rem;
}
.perk{
  display:flex;gap:1rem;align-items:flex-start;
  padding:1.4rem;border-radius:12px;
  border:1px solid var(--line);background:var(--ink-card);
}
.perk-i{
  flex-shrink:0;width:38px;height:38px;border-radius:9px;
  display:grid;place-items:center;font-size:1rem;
  background:rgba(70,196,188,.1);color:var(--tide);
  border:1px solid rgba(70,196,188,.2);
}
.perk b{font:500 1rem/1.3 var(--serif);font-style:normal;}
.perk p{font-size:.86rem;color:var(--mist);margin-top:.2rem;}

/* ============================================================
   SOCIAL MEDIA
   ============================================================ */
.social{background:var(--ink-soft);}
.social-top{
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4rem);
  margin-bottom:3.2rem;align-items:start;
}
.social-list{
  display:grid;grid-template-columns:1fr 1fr;gap:.7rem 1.4rem;margin-top:1.8rem;
}
.social-list li{
  font-size:.92rem;color:var(--mist);padding-left:1.5rem;position:relative;
}
.social-list li::before{
  content:"";position:absolute;left:0;top:.5em;width:9px;height:9px;
  border-radius:2px;background:var(--tide);transform:rotate(45deg);
}
.social-platforms{
  background:var(--ink-card);border:1px solid var(--line);
  border-radius:16px;padding:1.8rem;
}
.sp-label{
  font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--mist);margin-bottom:1rem;
}
.sp-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:.6rem;margin-bottom:1.6rem;
}
.sp-grid span{
  padding:.8rem 1rem;border-radius:9px;text-align:center;
  background:var(--ink-soft);border:1px solid var(--line);
  font-size:.86rem;font-weight:600;
  transition:.35s var(--ease);
}
.sp-grid span:hover{border-color:var(--tide);color:var(--tide);transform:translateY(-3px);}
.sp-figure{position:relative;border-radius:12px;overflow:hidden;}
.sp-figure img{width:100%;aspect-ratio:16/10;object-fit:cover;}
.sp-chip{
  position:absolute;left:.8rem;bottom:.8rem;
  background:rgba(10,12,13,.85);backdrop-filter:blur(8px);
  padding:.45rem .8rem;border-radius:100px;
  font-size:.72rem;font-weight:600;color:var(--bone);
}

/* ============================================================
   WHY
   ============================================================ */
.why-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;
}
.why-card{
  padding:2rem 1.6rem;border-radius:14px;
  border:1px solid var(--line);background:var(--ink-card);
  transition:transform .5s var(--ease),border-color .5s var(--ease);
}
.why-card:hover{transform:translateY(-6px);border-color:var(--line-2);}
.why-i{
  font:500 1.6rem/1 var(--serif);color:var(--tide);
  display:block;margin-bottom:1.1rem;
}
.why-card h3{font:500 1.15rem/1.25 var(--serif);margin-bottom:.5rem;}
.why-card p{font-size:.9rem;color:var(--mist);}

/* ============================================================
   PROCESS
   ============================================================ */
.steps{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;
}
.step{
  position:relative;padding:2rem 1.5rem;border-radius:14px;
  border:1px solid var(--line);background:var(--ink-card);
  transition:transform .5s var(--ease),background .5s var(--ease);
}
.step::after{
  content:"";position:absolute;top:2.5rem;right:-.5rem;
  width:12px;height:12px;border-top:1.5px solid var(--line-2);
  border-right:1.5px solid var(--line-2);transform:rotate(45deg);
}
.step:last-child::after{display:none;}
.step:hover{transform:translateY(-6px);background:var(--ink-card-2);}
.step-num{
  font:500 2.6rem/1 var(--serif);color:var(--tide);
  display:block;margin-bottom:.9rem;
  -webkit-text-stroke:1px var(--tide);color:transparent;
}
.step h3{font:500 1.2rem/1.2 var(--serif);margin-bottom:.5rem;}
.step p{font-size:.9rem;color:var(--mist);}

/* ============================================================
   CONTACT
   ============================================================ */
.contact-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);
  align-items:start;
}
.contact-direct{
  display:flex;flex-direction:column;gap:.2rem;margin-top:2.2rem;
}
.contact-direct a{
  display:flex;flex-direction:column;
  padding:1.1rem 0;border-bottom:1px solid var(--line);
  font:500 1.2rem/1.2 var(--serif);
  transition:color .35s var(--ease),padding-left .35s var(--ease);
}
.contact-direct a:hover{color:var(--tide);padding-left:.6rem;}
.cd-label{
  font:600 .68rem/1 var(--sans);letter-spacing:.14em;text-transform:uppercase;
  color:var(--mist);margin-bottom:.35rem;
}

/* form */
.quote-form{
  background:var(--ink-card);border:1px solid var(--line);
  border-radius:18px;padding:clamp(1.6rem,3vw,2.4rem);
}
.hp{position:absolute;left:-9999px;}
.field{position:relative;margin-bottom:1rem;}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.field input,.field textarea,.field select{
  width:100%;padding:1.15rem 1rem .55rem;
  background:var(--ink-soft);border:1px solid var(--line-2);
  border-radius:10px;color:var(--bone);font-family:var(--sans);font-size:.95rem;
  transition:border-color .3s var(--ease),background .3s var(--ease);
}
.field select{padding-top:.85rem;padding-bottom:.85rem;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%2398a0a0' stroke-width='2'%3E%3Cpath d='M2 4l5 5 5-5'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 1rem center;cursor:pointer;}
.field textarea{padding-top:1.3rem;resize:vertical;min-height:110px;}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;border-color:var(--tide);background:var(--ink-card-2);
}
.field label{
  position:absolute;left:1rem;top:.95rem;
  font-size:.95rem;color:var(--mist);pointer-events:none;
  transition:.25s var(--ease);
}
.field label.label-static{top:-.55rem;left:.7rem;font-size:.7rem;
  background:var(--ink-card);padding:0 .4rem;color:var(--tide);
  letter-spacing:.08em;text-transform:uppercase;}
.field input:focus+label,.field input:not(:placeholder-shown)+label,
.field textarea:focus+label,.field textarea:not(:placeholder-shown)+label{
  top:-.55rem;left:.7rem;font-size:.7rem;
  background:var(--ink-card);padding:0 .4rem;color:var(--tide);
  letter-spacing:.08em;text-transform:uppercase;
}
.form-fine{
  margin-top:.9rem;font-size:.74rem;color:var(--mist-dim);text-align:center;
}
.form-done{
  text-align:center;padding:2rem 1rem;
}
.form-done h3{font:500 1.4rem/1.2 var(--serif);color:var(--tide);margin-bottom:.5rem;}
.form-done p{color:var(--mist);font-size:.95rem;}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{
  border-top:1px solid var(--line);
  padding:clamp(3rem,6vw,5rem) 0 2rem;background:var(--ink-soft);
}
.foot-top{
  display:grid;grid-template-columns:1.3fr 2fr;gap:3rem;
  padding-bottom:3rem;border-bottom:1px solid var(--line);
}
.brand--foot{margin-bottom:1.1rem;}
.foot-brand p{color:var(--mist);font-size:.92rem;max-width:34ch;}
.foot-cols{
  display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;
}
.foot-col h4{
  font:600 .74rem/1 var(--sans);letter-spacing:.14em;text-transform:uppercase;
  color:var(--mist);margin-bottom:1.1rem;
}
.foot-col a,.foot-static{
  display:block;font-size:.9rem;color:var(--bone);margin-bottom:.6rem;
  transition:color .3s var(--ease);
}
.foot-col a:hover{color:var(--tide);}
.foot-static{color:var(--mist);}
.foot-bottom{
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem;
  padding-top:1.6rem;font-size:.78rem;color:var(--mist-dim);
}
.foot-credit{color:var(--mist);}

/* ----- Footer areas-served block ----- */
.foot-areas{
  padding:1.8rem 0;border-bottom:1px solid var(--line);
}
.foot-areas h4{
  font:600 .74rem/1.4 var(--sans);letter-spacing:.12em;text-transform:uppercase;
  color:var(--mist);margin-bottom:.7rem;
}
.foot-areas p{
  color:var(--mist-dim);font-size:.84rem;line-height:1.7;max-width:82ch;
}

/* ============================================================
   FAQ
   ============================================================ */
.faq-list{
  max-width:780px;margin:0 auto;
  border-top:1px solid var(--line);
}
.faq-item{border-bottom:1px solid var(--line);}
.faq-item summary{
  list-style:none;cursor:pointer;
  display:flex;align-items:flex-start;justify-content:space-between;gap:1.5rem;
  padding:1.5rem .25rem;
  font:500 clamp(1.05rem,2vw,1.3rem)/1.4 var(--serif);
  color:var(--bone);
  transition:color .3s var(--ease);
}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary:hover{color:var(--tide);}
.faq-item summary::after{
  content:"";flex:none;width:17px;height:17px;margin-top:.4rem;
  background:
    linear-gradient(var(--tide),var(--tide)) center/100% 2px no-repeat,
    linear-gradient(var(--tide),var(--tide)) center/2px 100% no-repeat;
  transition:transform .35s var(--ease);
}
.faq-item[open] summary{color:var(--tide);}
.faq-item[open] summary::after{transform:rotate(135deg);}
.faq-a{padding:0 .25rem 1.7rem;}
.faq-a p{
  color:var(--mist);font-size:.97rem;line-height:1.75;max-width:64ch;
}

/* ============================================================
   LIGHTBOX
   ============================================================ */
.lightbox{
  position:fixed;inset:0;z-index:9500;
  background:rgba(7,9,10,.96);backdrop-filter:blur(10px);
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;transition:opacity .4s var(--ease),visibility .4s;
}
.lightbox.open{opacity:1;visibility:visible;}
.lb-stage{
  max-width:88vw;max-height:82vh;position:relative;
  transform:scale(.94);transition:transform .45s var(--ease-out);
}
.lightbox.open .lb-stage{transform:scale(1);}
.lb-stage img{
  max-width:88vw;max-height:78vh;object-fit:contain;border-radius:8px;
}
.lb-stage figcaption{
  margin-top:.9rem;text-align:center;
  font:500 1.05rem/1.3 var(--serif);color:var(--bone);
}
.lb-close,.lb-nav{
  position:fixed;width:54px;height:54px;border-radius:50%;
  border:1px solid var(--line-2);background:rgba(20,24,26,.7);
  display:grid;place-items:center;font-size:1.4rem;color:var(--bone);
  transition:.35s var(--ease);
}
.lb-close:hover,.lb-nav:hover{background:var(--tide);color:var(--ink);border-color:var(--tide);}
.lb-close{top:1.5rem;right:1.5rem;}
.lb-nav{top:50%;transform:translateY(-50%);}
.lb-prev{left:1.5rem;}
.lb-next{right:1.5rem;}
.lb-count{
  position:fixed;bottom:1.6rem;left:50%;transform:translateX(-50%);
  font:600 .8rem/1 var(--sans);letter-spacing:.1em;color:var(--mist);
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .svc-grid,.why-grid,.steps{grid-template-columns:repeat(2,1fr);}
  .gallery{grid-template-columns:repeat(3,1fr);}
  .step::after{display:none;}
}
@media (max-width:880px){
  .nav{display:none;}
  .menu-toggle{display:block;}
  .price-row,.price-row--3,.re-perks{grid-template-columns:1fr;}
  .feature-grid,.social-top,.contact-grid{grid-template-columns:1fr;}
  .fm-stack{padding:1.5rem 3rem 0 0;max-width:440px;}
  .stats-grid{grid-template-columns:1fr 1fr;}
  .stat:nth-child(2){border-right:0;}
  .stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid var(--line);}
  .sec-head--row{align-items:flex-start;}
}
@media (max-width:620px){
  .svc-grid,.why-grid,.steps,.gallery,.social-list,.sp-grid,.field-row,.foot-cols{
    grid-template-columns:1fr;
  }
  .gallery{grid-auto-rows:260px;}
  .g-item.g-tall{grid-row:span 1;}
  .foot-top{grid-template-columns:1fr;gap:2rem;}
  .stats-grid{grid-template-columns:1fr;}
  .stat{border-right:0;border-bottom:1px solid var(--line);}
  .stat:last-child{border-bottom:0;}
  .re-tab{padding:.65rem 1.1rem;}
  .lb-nav{width:46px;height:46px;}
  .lb-prev{left:.6rem;}.lb-next{right:.6rem;}
}

/* ---------- REDUCED MOTION ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;animation-iteration-count:1 !important;
    transition-duration:.01ms !important;scroll-behavior:auto !important;
  }
  [data-reveal]{opacity:1;transform:none;}
  .hero-title .w{transform:none;}
  .marquee-track{animation:none;}
}
