/* FILMED BY ABBY — the site IS a camera. Viewfinder HUD, shutter boot,
   AF box, EXIF captions. Palette: true black body, signal-orange REC,
   viewfinder white, teal/amber grade accents. */
:root{
  --bg:#050505; --bg-card:#0C0C0C; --line:#1C1C1C;
  --vf:#EDEDED; --vf-dim:#8A8A8A;
  --rec:#FF3B30; --amber:#FFB454; --teal:#37C8C3;
  --mono:"Space Mono",ui-monospace,monospace;
  --disp:"Space Grotesk","Helvetica Neue",sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--vf);font-family:var(--disp);line-height:1.6;overflow-x:hidden}
.mono{font-family:var(--mono)}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.hidden{display:none}

/* ── SHUTTER BOOT ─────────────────────────────── */
#shutter{position:fixed;inset:0;z-index:100;background:#000;display:flex;align-items:center;justify-content:center;transition:opacity .5s .2s, visibility .5s .2s}
#shutter.open{opacity:0;visibility:hidden}
.shutter-iris{position:absolute;inset:0;background:
  conic-gradient(from 0deg,#000 0 60deg,#0A0A0A 60deg 120deg,#000 120deg 180deg,#0A0A0A 180deg 240deg,#000 240deg 300deg,#0A0A0A 300deg);
  clip-path:circle(75%);transition:clip-path .6s cubic-bezier(.7,0,.3,1)}
#shutter.open .shutter-iris{clip-path:circle(0%)}
.boot-text{position:relative;text-align:center;font-size:13px;letter-spacing:.4em;color:var(--vf)}
.boot-text span{color:var(--rec);font-size:11px;animation:blink 1s steps(2) infinite}

/* ── VIEWFINDER HUD ───────────────────────────── */
.vf{position:fixed;inset:0;pointer-events:none;z-index:60}
.vf-corner{position:absolute;width:26px;height:26px;border:2px solid rgba(237,237,237,.55)}
.vf-corner.tl{top:14px;left:14px;border-right:0;border-bottom:0}
.vf-corner.tr{top:14px;right:14px;border-left:0;border-bottom:0}
.vf-corner.bl{bottom:14px;left:14px;border-right:0;border-top:0}
.vf-corner.br{bottom:14px;right:14px;border-left:0;border-top:0}
.vf-top,.vf-bottom{position:absolute;left:54px;right:54px;display:flex;gap:22px;font-size:10.5px;letter-spacing:.14em;color:var(--vf-dim);text-shadow:0 1px 4px rgba(0,0,0,.9)}
.vf-top{top:20px}
.vf-bottom{bottom:20px}
.vf-right{margin-left:auto}
.rec{color:var(--rec);display:flex;align-items:center;gap:6px;font-weight:700}
.rec i{width:8px;height:8px;border-radius:50%;background:var(--rec);animation:blink 1.2s steps(2) infinite}
@keyframes blink{50%{opacity:0}}
#battery{color:var(--teal);letter-spacing:0}

/* ── NAV ──────────────────────────────────────── */
#nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;justify-content:space-between;align-items:center;
     padding:26px 64px;transition:background .3s,padding .3s}
#nav.scrolled{background:rgba(5,5,5,.88);backdrop-filter:blur(14px);padding:14px 64px;border-bottom:1px solid var(--line)}
.brand{font-size:13px;letter-spacing:.22em;font-weight:700}
.brand span{color:var(--rec)}
.links{display:flex;gap:30px;font-size:11px;letter-spacing:.18em}
.links a{color:var(--vf-dim);transition:color .2s}
.links a:hover{color:var(--vf)}
.links a.cta{color:#050505;background:var(--vf);padding:9px 16px;transition:background .2s}
.links a.cta:hover{background:var(--amber)}

/* ── HERO ─────────────────────────────────────── */
.hero{position:relative;height:100vh;min-height:640px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.72) saturate(1.08);transform:scale(1.05);animation:slowpush 24s ease-out forwards}
@keyframes slowpush{to{transform:scale(1.0)}}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,5,5,.45) 0%,rgba(5,5,5,.08) 35%,rgba(5,5,5,.78) 100%)}
.grid-overlay{position:absolute;inset:0;z-index:2;
  background:linear-gradient(90deg,transparent calc(33.33% - 1px),rgba(237,237,237,.09) 33.33%,transparent calc(33.33% + 1px)),
             linear-gradient(90deg,transparent calc(66.66% - 1px),rgba(237,237,237,.09) 66.66%,transparent calc(66.66% + 1px)),
             linear-gradient(0deg,transparent calc(33.33% - 1px),rgba(237,237,237,.09) 33.33%,transparent calc(33.33% + 1px)),
             linear-gradient(0deg,transparent calc(66.66% - 1px),rgba(237,237,237,.09) 66.66%,transparent calc(66.66% + 1px))}
.af-box{position:absolute;z-index:3;width:90px;height:64px;border:2px solid var(--amber);color:var(--amber);
        font-size:10px;letter-spacing:.2em;padding:2px 5px;opacity:0;transition:opacity .3s;will-change:transform}
.af-box.lock{border-color:var(--teal);color:var(--teal)}
.hero-content{position:relative;z-index:4;text-align:center;padding:0 24px;max-width:1000px}
.kicker{font-size:11px;letter-spacing:.34em;color:var(--amber);margin-bottom:18px}
.hero h1{font-size:clamp(44px,8.5vw,108px);font-weight:700;line-height:.98;letter-spacing:-.01em;
         text-shadow:0 4px 40px rgba(0,0,0,.5)}
.hero .sub{margin:26px auto 0;max-width:560px;color:rgba(237,237,237,.85);font-size:17px}
.hero-ctas{margin-top:38px;display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.btn-solid{display:inline-block;background:var(--vf);color:#050505;padding:16px 30px;font-size:12px;
           letter-spacing:.18em;font-weight:700;transition:background .2s,transform .15s}
.btn-solid:hover{background:var(--amber);transform:translateY(-2px)}
.btn-ghost{display:inline-block;border:1px solid rgba(237,237,237,.5);color:var(--vf);padding:16px 30px;
           font-size:12px;letter-spacing:.18em;transition:border-color .2s,background .2s}
.btn-ghost:hover{border-color:var(--vf);background:rgba(237,237,237,.08)}
.hero-exif{position:absolute;bottom:54px;left:0;right:0;text-align:center;z-index:4;
           font-size:10px;letter-spacing:.22em;color:rgba(237,237,237,.5)}

/* ── TICKER ───────────────────────────────────── */
.ticker{border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;padding:14px 0;background:var(--bg-card)}
.ticker-track{display:flex;gap:34px;white-space:nowrap;font-size:11px;letter-spacing:.22em;color:var(--vf-dim);
              animation:tick 36s linear infinite;width:max-content}
.ticker-track span:nth-child(even){color:var(--rec)}
@keyframes tick{to{transform:translateX(-50%)}}

/* ── SECTIONS ─────────────────────────────────── */
.section{padding:110px 64px;max-width:1340px;margin:0 auto}
.sec-head{margin-bottom:54px}
.sec-head h2{font-size:clamp(32px,4.6vw,58px);font-weight:700;letter-spacing:-.01em}
.sec-sub{color:var(--vf-dim);margin-top:12px;max-width:520px}

/* ── WORK GRID ────────────────────────────────── */
.work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.shot{position:relative;overflow:hidden;background:var(--bg-card);border:1px solid var(--line)}
.shot.wide{grid-column:span 2}
.shot img{width:100%;height:100%;min-height:320px;max-height:560px;object-fit:cover;
          transition:transform .7s cubic-bezier(.2,.6,.2,1),filter .4s;filter:saturate(1.02)}
.shot:hover img{transform:scale(1.04)}
.shot::before{content:"";position:absolute;inset:14px;border:1px solid rgba(237,237,237,0);z-index:2;
              transition:border-color .3s;pointer-events:none}
.shot:hover::before{border-color:rgba(237,237,237,.35)}
.shot figcaption{position:absolute;left:0;right:0;bottom:0;z-index:2;display:flex;align-items:center;gap:9px;
                 padding:14px 18px;font-size:10px;letter-spacing:.2em;color:var(--vf);
                 background:linear-gradient(0deg,rgba(5,5,5,.85),transparent)}
.shot .dot{width:7px;height:7px;border-radius:50%;background:var(--rec);flex:none;animation:blink 1.4s steps(2) infinite}

/* ── PANORAMA ─────────────────────────────────── */
.pano{position:relative;margin:40px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.pano img{width:100%;height:46vh;min-height:300px;object-fit:cover}
.pano-label{position:absolute;bottom:18px;left:64px;font-size:10px;letter-spacing:.24em;color:var(--vf);
            background:rgba(5,5,5,.6);padding:8px 14px;backdrop-filter:blur(8px)}

/* ── SERVICES ─────────────────────────────────── */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.svc{background:var(--bg-card);border:1px solid var(--line);padding:34px 28px;position:relative;
     transition:border-color .25s,transform .25s}
.svc:hover{border-color:rgba(237,237,237,.4);transform:translateY(-4px)}
.svc-num{font-size:10px;color:var(--rec);letter-spacing:.2em}
.svc h3{font-size:21px;margin:14px 0 12px;font-weight:700}
.svc p{font-size:14.5px;color:var(--vf-dim)}
.svc-tag{display:inline-block;margin-top:18px;font-size:9.5px;letter-spacing:.2em;color:var(--teal);
         border:1px solid rgba(55,200,195,.3);padding:6px 10px}
.svc-no{opacity:.62;border-style:dashed}
.svc-no h3{text-decoration:line-through;text-decoration-color:var(--rec);text-decoration-thickness:3px}

/* ── ABOUT ────────────────────────────────────── */
.about{display:grid;grid-template-columns:1fr 1.1fr;gap:64px;align-items:center}
.about-img{position:relative}
.about-img img{border:1px solid var(--line)}
.about-frame{position:absolute;top:16px;left:16px;font-size:9.5px;letter-spacing:.2em;color:var(--amber);
             background:rgba(5,5,5,.65);padding:7px 11px;backdrop-filter:blur(6px)}
.about h2{font-size:clamp(36px,5vw,64px);margin:10px 0 20px}
.about p{color:var(--vf-dim);margin-bottom:16px;font-size:16px}
.about-list{list-style:none;margin-top:24px;font-size:12px;letter-spacing:.12em;color:var(--vf)}
.about-list li{padding:9px 0;border-bottom:1px solid var(--line)}

/* ── PACKAGES ─────────────────────────────────── */
.pkg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:start}
.pkg{background:var(--bg-card);border:1px solid var(--line);padding:38px 30px;position:relative;
     transition:border-color .25s,transform .25s}
.pkg:hover{border-color:rgba(237,237,237,.4);transform:translateY(-4px)}
.pkg-featured{border-color:var(--amber);box-shadow:0 0 60px rgba(255,180,84,.07)}
.pkg-flag{position:absolute;top:-11px;left:30px;background:var(--amber);color:#050505;font-size:9.5px;
          font-weight:700;letter-spacing:.18em;padding:5px 12px}
.pkg h3{font-size:13px;letter-spacing:.22em;color:var(--vf-dim)}
.price{font-size:46px;font-weight:700;margin:16px 0 22px}
.price span{font-size:16px;color:var(--vf-dim);font-weight:400}
.pkg ul{list-style:none;margin-bottom:28px}
.pkg li{font-size:14px;color:var(--vf-dim);padding:8px 0 8px 20px;position:relative;border-bottom:1px solid var(--line)}
.pkg li::before{content:"◆";position:absolute;left:0;color:var(--rec);font-size:9px;top:12px}
.pkg .btn-solid{width:100%;text-align:center}
.stripe-note{text-align:center;margin-top:34px;font-size:10px;letter-spacing:.22em;color:var(--vf-dim)}

/* ── CONTACT FORM ─────────────────────────────── */
.contact{max-width:860px}
.form{display:flex;flex-direction:column;gap:20px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.form label{display:flex;flex-direction:column;gap:9px;font-size:10px;letter-spacing:.2em;color:var(--vf-dim)}
.form input,.form select,.form textarea{background:var(--bg-card);border:1px solid var(--line);color:var(--vf);
       padding:15px 16px;font-size:15px;font-family:var(--disp);transition:border-color .2s;border-radius:0;-webkit-appearance:none}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--amber)}
.form button{border:none;cursor:pointer;margin-top:6px;align-self:flex-start}

/* ── FOOTER ───────────────────────────────────── */
footer{border-top:1px solid var(--line);padding:64px;text-align:center}
.foot-brand{font-size:18px;font-weight:700;letter-spacing:.3em;margin-bottom:14px}
footer p{font-size:10.5px;letter-spacing:.2em;margin:6px 0;color:var(--vf)}
footer .dim{color:var(--vf-dim)}

/* ── MOBILE ───────────────────────────────────── */
@media (max-width:920px){
  #nav{padding:18px 22px}
  #nav.scrolled{padding:12px 22px}
  .links{gap:16px;font-size:10px}
  .links a:not(.cta){display:none}
  .vf-top,.vf-bottom{left:30px;right:30px;gap:12px;font-size:9px}
  #coords{display:none}
  .section{padding:72px 22px}
  .work-grid,.svc-grid,.pkg-grid,.form-row{grid-template-columns:1fr}
  .shot.wide{grid-column:span 1}
  .about{grid-template-columns:1fr;gap:34px}
  .pano-label{left:22px}
  .hero h1{font-size:clamp(40px,12vw,64px)}
  .af-box{display:none}
}
