/* ===== Studio 3 Images — Mesa, AZ ===== */
:root{
  --ink:#0e0e10;
  --ink-2:#17161a;
  --ink-3:#201e24;
  --blush:#e7c4c0;
  --blush-lt:#f3dedb;
  --gold:#c8a45c;
  --gold-lt:#d8bd7e;
  --ivory:#f7f1ea;
  --ivory-2:#efe6da;
  --text:#2a2528;
  --muted:#6f6560;
  --white:#ffffff;
  --serif:"Playfair Display", serif;
  --serif-2:"Cormorant Garamond", serif;
  --sans:"Jost", system-ui, -apple-system, Segoe UI, sans-serif;
  --wrap:1180px;
  --r:14px;
  --shadow:0 22px 60px -30px rgba(14,14,16,.5);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--text);
  background:var(--ivory);
  line-height:1.65;
  font-weight:300;
  -webkit-font-smoothing:antialiased;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.12;color:var(--ink)}
.wrap{width:100%;max-width:var(--wrap);margin:0 auto;padding:0 22px}

.eyebrow{
  font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold);font-weight:500;margin-bottom:14px;
}
.section-head{max-width:640px;margin:0 auto 48px;text-align:center}
.section-head h2{font-size:clamp(1.9rem,4.2vw,3rem)}
.section-sub{color:var(--muted);font-size:1.05rem;margin-top:14px}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--sans);font-weight:500;font-size:.95rem;letter-spacing:.04em;
  padding:.9rem 1.8rem;border-radius:40px;cursor:pointer;border:1.5px solid transparent;
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease, color .25s ease;
}
.btn-gold{background:linear-gradient(120deg,var(--gold),var(--gold-lt));color:var(--ink);box-shadow:0 14px 30px -14px rgba(200,164,92,.8)}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 20px 38px -14px rgba(200,164,92,.9)}
.btn-ghost{border-color:rgba(255,255,255,.55);color:var(--white)}
.btn-ghost:hover{background:rgba(255,255,255,.12);transform:translateY(-2px)}
.btn-outline-lt{border-color:var(--gold);color:var(--ivory)}
.btn-outline-lt:hover{background:var(--gold);color:var(--ink);transform:translateY(-2px)}
.btn-full{width:100%}

/* ===== Intro animation ===== */
.intro{
  position:fixed;inset:0;z-index:1000;background:var(--ink);
  display:flex;align-items:center;justify-content:center;flex-direction:column;
  overflow:hidden;
}
.intro.done{animation:introOut .6s ease forwards}
@keyframes introOut{to{opacity:0;visibility:hidden}}
.intro-gallery{
  position:absolute;inset:0;display:grid;
  grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);
  gap:10px;padding:8vmin;opacity:0;transform:scale(1.06);
  animation:galFade .9s ease 1s forwards;
}
.ig{border-radius:8px}
.ig1{background:linear-gradient(135deg,#3a2d33,var(--blush))}
.ig2{background:linear-gradient(135deg,var(--gold),#6b5327)}
.ig3{background:linear-gradient(135deg,#25313a,#7d95a8)}
.ig4{background:linear-gradient(135deg,var(--blush),#caa)}
.ig5{background:linear-gradient(135deg,var(--gold-lt),var(--blush-lt))}
.ig6{background:linear-gradient(135deg,#2a2130,#8a6d7e)}
.ig7{background:linear-gradient(135deg,#4a3b2a,var(--gold-lt))}
.ig8{background:linear-gradient(135deg,#c9b3a6,var(--ivory))}
.ig9{background:linear-gradient(135deg,#332a36,var(--blush))}
@keyframes galFade{to{opacity:1;transform:scale(1)}}
.shutter{
  position:relative;z-index:2;width:min(78vmin,560px);height:min(78vmin,560px);
}
.blades{transform-origin:100px 100px;animation:bladeSpin 2.2s ease forwards}
.blade{fill:var(--ink-2);stroke:var(--gold);stroke-width:.7;transform-origin:100px 100px;
  animation:bladeOpen 1.5s cubic-bezier(.7,0,.2,1) .35s forwards}
@keyframes bladeOpen{to{transform:scale(2.4);opacity:0}}
@keyframes bladeSpin{to{transform:rotate(24deg)}}
.intro-brand{
  position:absolute;z-index:3;text-align:center;color:var(--ivory);
  opacity:0;animation:brandIn .8s ease .55s forwards;
}
.intro-name{display:block;font-family:var(--serif);font-size:clamp(1.8rem,6vw,3.2rem);letter-spacing:.02em}
.intro-tag{display:block;margin-top:8px;font-size:.75rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-lt)}
@keyframes brandIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.intro-skip{
  position:absolute;bottom:26px;right:26px;z-index:4;background:transparent;
  border:1px solid rgba(247,241,234,.4);color:var(--ivory);padding:.5rem 1.1rem;
  border-radius:30px;font-family:var(--sans);font-size:.8rem;letter-spacing:.1em;cursor:pointer;
  transition:background .2s,border-color .2s;
}
.intro-skip:hover{background:rgba(247,241,234,.14);border-color:var(--gold)}

/* ===== Header ===== */
.site-header{
  position:sticky;top:0;z-index:200;background:rgba(14,14,16,.94);
  backdrop-filter:blur(10px);border-bottom:1px solid rgba(200,164,92,.2);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:12px}
.brand-mark{width:36px;height:36px}
.brand-text{font-family:var(--serif);font-size:1.25rem;color:var(--ivory);letter-spacing:.01em}
.brand-3{color:var(--gold)}
.nav{display:flex;align-items:center;gap:28px}
.nav a{color:var(--ivory);font-size:.9rem;letter-spacing:.05em;transition:color .2s}
.nav a:hover{color:var(--gold-lt)}
.nav .nav-cta{
  border:1.5px solid var(--gold);color:var(--gold-lt);padding:.5rem 1.2rem;border-radius:30px;
}
.nav .nav-cta:hover{background:var(--gold);color:var(--ink)}
.menu-btn{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.menu-btn span{width:24px;height:2px;background:var(--ivory);transition:.3s}
.mobile-nav{display:none;flex-direction:column;background:var(--ink-2);border-bottom:1px solid rgba(200,164,92,.25)}
.mobile-nav a{padding:14px 22px;color:var(--ivory);border-top:1px solid rgba(255,255,255,.06)}
.mobile-nav a:hover{background:var(--ink-3);color:var(--gold-lt)}

/* ===== Hero ===== */
.hero{
  position:relative;overflow:hidden;color:var(--ivory);
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(200,164,92,.18), transparent 60%),
    radial-gradient(900px 500px at 10% 110%, rgba(231,196,192,.16), transparent 55%),
    linear-gradient(160deg,var(--ink),var(--ink-3));
  padding:clamp(80px,13vh,150px) 0 clamp(70px,10vh,120px);
}
.hero-frames{position:absolute;inset:0;pointer-events:none}
.hf{position:absolute;border:1px solid rgba(200,164,92,.35);border-radius:10px;opacity:.5}
.hf1{width:220px;height:280px;top:8%;right:6%;background:linear-gradient(135deg,rgba(231,196,192,.14),transparent);animation:float 9s ease-in-out infinite}
.hf2{width:150px;height:190px;bottom:12%;right:22%;background:linear-gradient(135deg,rgba(200,164,92,.14),transparent);animation:float 11s ease-in-out infinite reverse}
.hf3{width:120px;height:150px;top:22%;left:4%;background:linear-gradient(135deg,rgba(247,241,234,.1),transparent);animation:float 10s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-18px) rotate(2deg)}}
.hero-inner{position:relative;z-index:2;max-width:760px}
.hero h1{font-size:clamp(2.4rem,6vw,4.2rem);letter-spacing:-.01em;color:var(--ivory)}
.hero-sub{font-size:clamp(1.05rem,2.2vw,1.3rem);color:#d8cdc6;margin:22px 0 32px;max-width:620px;font-weight:300}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap}
.trust-line{margin-top:28px;font-size:.85rem;letter-spacing:.06em;color:var(--gold-lt)}

/* ===== Trust bar ===== */
.trustbar{background:var(--ink);color:var(--ivory);border-top:1px solid rgba(200,164,92,.2)}
.trustbar-inner{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:34px 22px;text-align:center}
.tb-num{display:block;font-family:var(--serif);font-size:clamp(1.6rem,3.6vw,2.4rem);color:var(--gold-lt)}
.tb-lbl{display:block;font-size:.78rem;letter-spacing:.08em;color:#c7bcb5;margin-top:4px}

/* ===== Services ===== */
.services{padding:clamp(70px,10vh,110px) 0;background:var(--ivory)}
.grid{display:grid;gap:22px}
.services-grid{grid-template-columns:repeat(3,1fr)}
.card{
  background:var(--white);border:1px solid var(--ivory-2);border-radius:var(--r);
  padding:34px 30px;transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--gold)}
.svc-icon{display:inline-grid;place-items:center;width:58px;height:58px;border-radius:50%;
  background:var(--ivory-2);margin-bottom:18px}
.svc-icon svg{width:30px;height:30px}
.card h3{font-family:var(--serif-2);font-weight:600;font-size:1.5rem;margin-bottom:8px}
.card p{color:var(--muted);font-size:.96rem}

/* ===== Why ===== */
.why{padding:clamp(70px,10vh,110px) 0;background:var(--white)}
.why-inner{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center}
.why-copy h2{font-size:clamp(1.9rem,4.2vw,2.9rem)}
.why-list{list-style:none;margin:28px 0 32px;display:grid;gap:18px}
.why-list li{display:flex;gap:14px;align-items:flex-start}
.why-ic{flex:0 0 auto;width:30px;height:30px;border-radius:50%;background:var(--ivory);display:grid;place-items:center}
.why-ic svg{width:18px;height:18px}
.why-list strong{color:var(--ink);font-weight:500}
.why-list div{color:var(--muted);font-size:.98rem}
.why-art{position:relative;height:440px}
.polaroid{position:absolute;background:var(--white);padding:12px 12px 34px;border-radius:6px;
  box-shadow:var(--shadow);width:220px}
.polaroid-img{display:block;height:200px;border-radius:3px}
.polaroid-cap{position:absolute;bottom:9px;left:0;right:0;text-align:center;
  font-family:var(--serif-2);font-style:italic;color:var(--muted);font-size:1.05rem}
.p1{top:0;left:6%;transform:rotate(-7deg);z-index:2}
.p2{top:70px;right:2%;transform:rotate(6deg);z-index:3}
.p3{bottom:0;left:24%;transform:rotate(-3deg);z-index:1}
.grad-a{background:linear-gradient(135deg,#2a313a,var(--blush))}
.grad-b{background:linear-gradient(135deg,var(--gold),var(--blush-lt))}
.grad-c{background:linear-gradient(135deg,#c9b3a6,var(--ivory))}

/* ===== Showcase ===== */
.showcase{padding:clamp(70px,10vh,110px) 0;background:var(--ink);color:var(--ivory)}
.showcase .section-head h2,.showcase .eyebrow{color:var(--ivory)}
.showcase .eyebrow{color:var(--gold-lt)}
.showcase .section-sub{color:#c7bcb5}
.gallery{
  display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:150px;gap:14px;
  max-width:1240px;margin:0 auto;padding:0 22px;
}
.frame{position:relative;overflow:hidden;border-radius:10px;border:1px solid rgba(200,164,92,.25)}
.frame .scene{position:absolute;inset:0;transition:transform .6s ease}
.frame:hover .scene{transform:scale(1.08)}
.scene-cap{position:absolute;left:12px;bottom:10px;z-index:2;font-family:var(--serif-2);
  font-style:italic;font-size:1.05rem;color:var(--ivory);text-shadow:0 2px 10px rgba(0,0,0,.6)}
.frame::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.45),transparent 55%)}
.f1{grid-column:span 2;grid-row:span 2}
.f6{grid-column:span 2}
.f4{grid-row:span 2}
.sky{background:linear-gradient(160deg,#243447,#8aa2b5 60%,var(--blush-lt))}
.blush{background:linear-gradient(150deg,#3a2b31,var(--blush))}
.dusk{background:linear-gradient(160deg,#4a2f3a,var(--gold-lt))}
.ivory{background:linear-gradient(150deg,#cdbcae,var(--ivory))}
.gold{background:linear-gradient(150deg,#6b5327,var(--gold-lt))}
.night{background:linear-gradient(160deg,#171522,#4a3b57)}
.rose{background:linear-gradient(150deg,#5a3a42,var(--blush))}
.mint{background:linear-gradient(150deg,#2f3f3a,#a9c3b5)}

/* ===== Reviews ===== */
.reviews{padding:clamp(70px,10vh,110px) 0;background:var(--ivory)}
.reviews-grid{grid-template-columns:repeat(3,1fr)}
.review{background:var(--white);border:1px solid var(--ivory-2);border-radius:var(--r);
  padding:32px 30px;box-shadow:0 10px 30px -22px rgba(14,14,16,.5)}
.review p{font-family:var(--serif-2);font-size:1.2rem;font-style:italic;color:var(--ink);line-height:1.55}
.review footer{display:flex;align-items:center;gap:12px;margin-top:20px}
.rev-avatar{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--gold),var(--blush));color:var(--ink);
  font-family:var(--serif);font-weight:600}
.review cite{font-style:normal;font-size:.9rem;color:var(--muted);letter-spacing:.04em}

/* ===== FAQ ===== */
.faq{padding:clamp(70px,10vh,110px) 0;background:var(--white)}
.faq-inner{max-width:820px;margin:0 auto}
.faq-list details{border:1px solid var(--ivory-2);border-radius:12px;margin-bottom:14px;
  background:var(--ivory);overflow:hidden;transition:border-color .2s}
.faq-list details[open]{border-color:var(--gold)}
.faq-list summary{cursor:pointer;list-style:none;padding:20px 24px;font-family:var(--serif-2);
  font-size:1.25rem;color:var(--ink);position:relative;padding-right:52px}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::after{content:"+";position:absolute;right:24px;top:50%;transform:translateY(-50%);
  font-size:1.5rem;color:var(--gold);transition:transform .25s}
.faq-list details[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.faq-list p{padding:0 24px 22px;color:var(--muted);font-size:1rem}

/* ===== CTA band ===== */
.cta-band{padding:clamp(64px,9vh,100px) 0;color:var(--ivory);text-align:center;
  background:
    radial-gradient(700px 400px at 50% -30%, rgba(200,164,92,.25), transparent 60%),
    linear-gradient(150deg,var(--ink-2),var(--ink))}
.cta-inner{max-width:680px;margin:0 auto}
.cta-band h2{font-size:clamp(1.9rem,4.6vw,3rem);color:var(--ivory)}
.cta-band p{color:#d0c5bd;margin:16px 0 30px;font-size:1.08rem}
.cta-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ===== Contact ===== */
.contact{padding:clamp(70px,10vh,110px) 0;background:var(--ivory)}
.contact-inner{display:grid;grid-template-columns:1fr 1.1fr;gap:56px;align-items:start}
.contact-copy h2{font-size:clamp(1.9rem,4.2vw,2.9rem)}
.contact-list{list-style:none;margin:26px 0;display:grid;gap:16px}
.contact-list li{display:flex;align-items:center;gap:14px;font-size:1.02rem}
.c-ic{width:38px;height:38px;border-radius:50%;background:var(--white);border:1px solid var(--ivory-2);
  display:grid;place-items:center}
.c-ic svg{width:20px;height:20px}
.contact-list a:hover{color:var(--gold)}
.portal-note{font-size:.95rem;color:var(--muted);margin-top:6px}
.portal-note a{color:var(--gold);text-decoration:underline;text-underline-offset:3px}
.contact-form{background:var(--white);border:1px solid var(--ivory-2);border-radius:var(--r);
  padding:34px 32px;box-shadow:var(--shadow)}
.field{display:flex;flex-direction:column;margin-bottom:16px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field label{font-size:.82rem;letter-spacing:.06em;color:var(--muted);margin-bottom:6px;text-transform:uppercase}
.field input,.field select,.field textarea{
  font-family:var(--sans);font-size:1rem;padding:.75rem .9rem;border:1px solid var(--ivory-2);
  border-radius:10px;background:var(--ivory);color:var(--text);transition:border-color .2s,box-shadow .2s;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(200,164,92,.18);background:var(--white)}
.field textarea{resize:vertical}
.form-note{margin-top:12px;font-size:.9rem;color:var(--gold);min-height:1.2em;text-align:center}

/* ===== Footer ===== */
.site-footer{background:var(--ink);color:var(--ivory);padding:56px 0 26px}
.footer-inner{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px;padding-bottom:34px;
  border-bottom:1px solid rgba(255,255,255,.1)}
.footer-brand .brand-text{font-size:1.4rem}
.footer-brand p{color:#b8ada6;margin-top:12px;font-size:.95rem;max-width:320px}
.footer-nav{display:flex;flex-direction:column;gap:10px}
.footer-nav a,.footer-contact a{color:#c7bcb5;font-size:.95rem;transition:color .2s}
.footer-nav a:hover,.footer-contact a:hover{color:var(--gold-lt)}
.footer-contact{display:flex;flex-direction:column;gap:10px}
.footer-contact span{color:#8f8681;font-size:.95rem}
.footer-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;
  padding-top:22px;font-size:.85rem;color:#8f8681}
.credit a{color:var(--gold-lt);text-decoration:underline;text-underline-offset:3px}
.credit a:hover{color:var(--gold)}

/* ===== Mobile bar ===== */
.mobile-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:180;
  grid-template-columns:1fr 1.3fr;background:var(--ink);border-top:1px solid rgba(200,164,92,.3);
  box-shadow:0 -8px 24px -12px rgba(0,0,0,.6)}
.mobile-bar a{padding:15px;text-align:center;font-weight:500;letter-spacing:.04em}
.mb-call{color:var(--ivory);display:flex;align-items:center;justify-content:center;gap:8px}
.mb-call svg{width:20px;height:20px}
.mb-quote{background:linear-gradient(120deg,var(--gold),var(--gold-lt));color:var(--ink)}

/* ===== Reveal ===== */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ===== Responsive ===== */
@media(max-width:960px){
  .why-inner,.contact-inner{grid-template-columns:1fr;gap:40px}
  .why-art{height:400px;max-width:460px;margin:0 auto}
  .services-grid,.reviews-grid{grid-template-columns:repeat(2,1fr)}
  .footer-inner{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  .nav{display:none}
  .menu-btn{display:flex}
  .mobile-nav{display:none}
  .mobile-nav.open{display:flex}
  .mobile-bar{display:grid}
  main{padding-bottom:60px}
  .trustbar-inner{grid-template-columns:repeat(2,1fr);gap:26px}
  .gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:130px}
  .f1{grid-column:span 2;grid-row:span 2}
  .f6{grid-column:span 2}
  .f4{grid-row:span 1}
}
@media(max-width:520px){
  .services-grid,.reviews-grid{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr;gap:28px}
  .field-row{grid-template-columns:1fr}
  .hero-cta .btn,.cta-actions .btn{width:100%}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}
