/* ==========================================================================
   MKC33 PHOTOGRAPHY — stylesheet
   Design tokens
   -------------------------------------------------------------------------
   --ink        #0B0C0A   near-black background
   --panel      #15140F   raised panel / card background
   --paper      #F3EEE3   off-white
   --paper-dim  #C9C3B4   off-white, dimmed for secondary text on dark
   --gold       #C9A24B   muted gold accent
   --green      #57654C   muted olive/sage green accent
   --line       #2A2820   hairline rule on dark
   ========================================================================== */

:root{
  --ink:#0B0C0A;
  --panel:#15140F;
  --panel-raised:#1B1912;
  --paper:#F3EEE3;
  --paper-dim:#C9C3B4;
  --gold:#C9A24B;
  --gold-bright:#E0BE72;
  --green:#57654C;
  --green-bright:#7C9270;
  --line:#2A2820;
  --line-light:#E4DECE;
  --font-display:'Fraunces', Georgia, serif;
  --font-body:'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-mono:'Space Mono', 'Courier New', monospace;
  --maxw:1180px;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--ink);
  color:var(--paper);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; }
h1,h2,h3,h4{ font-family:var(--font-display); font-weight:600; margin:0; line-height:1.08; }
p{ margin:0 0 1em; }
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 24px; }
@media(min-width:900px){ .wrap{ padding:0 48px; } }

::selection{ background:var(--gold); color:var(--ink); }
:focus-visible{ outline:2px solid var(--gold-bright); outline-offset:3px; }
@media (prefers-reduced-motion: reduce){
  *{ animation-duration:0.01ms !important; animation-iteration-count:1 !important; transition-duration:0.01ms !important; scroll-behavior:auto !important; }
}

/* ---------- Eyebrow / frame-tag (signature EXIF-style label) ---------- */
.frame-tag{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--gold);
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.frame-tag::before{
  content:"";
  width:6px; height:6px;
  border-radius:50%;
  background:var(--gold);
  display:inline-block;
}

/* ---------- Nav ---------- */
.nav{
  position:sticky; top:0; z-index:100;
  background:rgba(11,12,10,.86);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav .wrap{ display:flex; align-items:center; justify-content:space-between; height:64px; }
.nav-logo{ font-family:var(--font-display); font-size:20px; font-weight:700; letter-spacing:.02em; }
.nav-logo span{ color:var(--gold); }
.nav-links{ display:none; gap:28px; font-size:14px; letter-spacing:.02em; }
@media(min-width:860px){ .nav-links{ display:flex; } }
.nav-links a{ text-decoration:none; color:var(--paper-dim); transition:color .2s; }
.nav-links a:hover{ color:var(--gold-bright); }
.nav-cta{
  font-family:var(--font-mono);
  font-size:12px;
  letter-spacing:.06em;
  text-transform:uppercase;
  background:var(--gold);
  color:var(--ink);
  padding:10px 16px;
  border-radius:2px;
  text-decoration:none;
  white-space:nowrap;
}
.nav-cta:hover{ background:var(--gold-bright); }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  font-family:var(--font-mono);
  font-size:13px;
  letter-spacing:.06em;
  text-transform:uppercase;
  text-decoration:none;
  padding:14px 22px;
  border-radius:2px;
  border:1px solid transparent;
  cursor:pointer;
  transition:all .2s ease;
}
.btn-gold{ background:var(--gold); color:var(--ink); }
.btn-gold:hover{ background:var(--gold-bright); transform:translateY(-1px); }
.btn-outline{ border-color:var(--paper-dim); color:var(--paper); background:transparent; }
.btn-outline:hover{ border-color:var(--paper); background:rgba(243,238,227,.06); }
.btn-green{ background:var(--green); color:var(--paper); }
.btn-green:hover{ background:var(--green-bright); color:var(--ink); }
.btn-ghost{ color:var(--gold); background:transparent; padding:14px 4px; }
.btn-ghost:hover{ color:var(--gold-bright); }
.btn-block{ width:100%; }
.btn-row{ display:flex; flex-wrap:wrap; gap:12px; }

/* ---------- Hero ---------- */
.hero{
  position:relative;
  min-height:92vh;
  display:flex;
  align-items:flex-end;
  padding-top:64px;
  overflow:hidden;
  background:
    linear-gradient(180deg, rgba(11,12,10,.35) 0%, rgba(11,12,10,.55) 55%, var(--ink) 96%),
    #0B0C0A;
}
.hero-bg{
  position:absolute; inset:0;
  background-image:var(--hero-img);
  background-size:cover;
  background-position:center 20%;
  filter:grayscale(35%) contrast(1.05);
  opacity:.6;
}
.hero-sprocket{
  position:absolute; top:0; bottom:0; width:22px;
  background-image:repeating-linear-gradient(180deg, var(--ink) 0 10px, transparent 10px 22px);
  z-index:2;
}
.hero-sprocket.left{ left:0; } .hero-sprocket.right{ right:0; }
.hero-content{ position:relative; z-index:3; padding:80px 0 64px; }
.hero .frame-tag{ margin-bottom:22px; }
.hero h1{
  font-size:clamp(34px, 6vw, 68px);
  max-width:16ch;
  color:var(--paper);
}
.hero h1 em{ font-style:italic; color:var(--gold-bright); }
.hero-sub{
  margin-top:22px;
  max-width:56ch;
  font-size:clamp(15px,2vw,18px);
  color:var(--paper-dim);
}
.hero .btn-row{ margin-top:34px; }

/* ---------- Section shells ---------- */
section{ padding:88px 0; }
.section-dark{ background:var(--ink); }
.section-panel{ background:var(--panel); }
.section-paper{ background:var(--paper); color:var(--ink); }
.section-head{ max-width:640px; margin-bottom:56px; }
.section-head .frame-tag{ margin-bottom:16px; }
.section-head h2{ font-size:clamp(28px,4vw,44px); }
.section-paper .section-head h2{ color:var(--ink); }
.section-head p{ margin-top:16px; color:var(--paper-dim); font-size:17px; }
.section-paper .section-head p{ color:#5b5648; }

/* ---------- Services grid ---------- */
.services-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:28px;
}
@media(min-width:720px){ .services-grid{ grid-template-columns:1fr 1fr; } }
@media(min-width:1100px){ .services-grid{ grid-template-columns:1fr 1fr 1fr; } }

.service-card{
  background:var(--panel-raised);
  border:1px solid var(--line);
  border-radius:3px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transition:border-color .2s, transform .2s;
}
.service-card:hover{ border-color:var(--gold); transform:translateY(-3px); }
.service-thumb{
  position:relative;
  aspect-ratio:4/3;
  overflow:hidden;
  background:#000;
}
.service-thumb img{
  width:100%; height:100%; object-fit:cover;
  object-position:center top;
  filter:grayscale(20%) contrast(1.05);
  transition:transform .5s ease;
}
.service-card:hover .service-thumb img{ transform:scale(1.05); }
.service-thumb .frame-tag{
  position:absolute; top:12px; left:12px;
  background:rgba(11,12,10,.72);
  padding:5px 9px;
  border-radius:2px;
}
.service-body{ padding:22px 22px 24px; display:flex; flex-direction:column; flex:1; }
.service-body h3{ font-size:21px; margin-bottom:10px; }
.service-body p{ color:var(--paper-dim); font-size:14.5px; flex:1; margin-bottom:18px; }
.service-actions{ display:flex; flex-direction:column; gap:8px; }
.service-actions .btn{ font-size:12px; padding:11px 16px; }
.service-fallback{
  font-family:var(--font-mono);
  font-size:11px;
  color:var(--paper-dim);
  text-align:center;
  text-decoration:underline;
  margin-top:4px;
}
.service-fallback:hover{ color:var(--gold-bright); }

/* Expandable inline viewer */
.viewer-toggle{
  background:none; border:1px solid var(--line); color:var(--paper-dim);
  font-family:var(--font-mono); font-size:11px; letter-spacing:.04em; text-transform:uppercase;
  padding:10px 14px; border-radius:2px; cursor:pointer; width:100%;
  display:flex; align-items:center; justify-content:space-between;
}
.viewer-toggle:hover{ border-color:var(--gold); color:var(--paper); }
.viewer-toggle .chev{ transition:transform .25s; }
.viewer-toggle[aria-expanded="true"] .chev{ transform:rotate(180deg); }
.pdf-embed-wrap{
  overflow:hidden; height:0; transition:height .3s ease;
}
.pdf-embed-wrap iframe{
  width:100%; height:520px; border:0; margin-top:10px; background:#1c1a14;
}

/* ---------- Portfolio strip ---------- */
.portfolio-strip{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:4px;
}
@media(min-width:640px){ .portfolio-strip{ grid-template-columns:repeat(4,1fr); } }
.portfolio-strip figure{ margin:0; position:relative; aspect-ratio:3/4; overflow:hidden; background:#000; }
.portfolio-strip img{ width:100%; height:100%; object-fit:cover; filter:grayscale(30%); transition:transform .5s; }
.portfolio-strip figure:hover img{ transform:scale(1.06); filter:grayscale(0%); }
.portfolio-strip figcaption{
  position:absolute; left:10px; bottom:10px;
  font-family:var(--font-mono); font-size:10px; letter-spacing:.06em; text-transform:uppercase;
  color:var(--paper); background:rgba(11,12,10,.65); padding:4px 8px;
}

/* ---------- About ---------- */
.about-grid{ display:grid; gap:40px; align-items:center; }
@media(min-width:860px){ .about-grid{ grid-template-columns:0.9fr 1.1fr; } }
.about-photo{ aspect-ratio:4/5; overflow:hidden; border:1px solid var(--line); }
.about-photo img{ width:100%; height:100%; object-fit:cover; filter:grayscale(15%); }
.about-copy p{ color:var(--paper-dim); font-size:16.5px; }
.about-tags{ display:flex; flex-wrap:wrap; gap:10px; margin-top:24px; }
.about-tag{
  font-family:var(--font-mono); font-size:11px; letter-spacing:.05em; text-transform:uppercase;
  border:1px solid var(--line); color:var(--paper-dim); padding:7px 12px; border-radius:2px;
}

/* ---------- Booking ---------- */
.booking-panel{
  background:var(--panel);
  border:1px solid var(--line);
  padding:40px 28px;
  border-radius:3px;
}
@media(min-width:720px){ .booking-panel{ padding:56px; } }
.booking-grid{ display:grid; gap:12px; margin-top:32px; }
@media(min-width:640px){ .booking-grid{ grid-template-columns:1fr 1fr; } }
@media(min-width:980px){ .booking-grid{ grid-template-columns:repeat(3,1fr); } }
.booking-deposit{
  margin-top:20px;
  padding-top:28px;
  border-top:1px solid var(--line);
}

/* ---------- FAQ ---------- */
.faq-item{
  border-bottom:1px solid #E4DECE;
  padding:22px 0;
}
.faq-item summary{
  cursor:pointer;
  list-style:none;
  display:flex; justify-content:space-between; align-items:center;
  font-family:var(--font-display); font-weight:600; font-size:18px;
}
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary .plus{ font-family:var(--font-mono); color:var(--green); font-size:20px; transition:transform .2s; }
.faq-item[open] summary .plus{ transform:rotate(45deg); }
.faq-item p{ margin-top:14px; color:#5b5648; max-width:64ch; }

/* ---------- Contact form ---------- */
.contact-grid{ display:grid; gap:48px; }
@media(min-width:900px){ .contact-grid{ grid-template-columns:1fr 1fr; } }
.field{ margin-bottom:18px; }
.field label{
  display:block; font-family:var(--font-mono); font-size:11px; letter-spacing:.06em;
  text-transform:uppercase; color:var(--paper-dim); margin-bottom:8px;
}
.field input, .field select, .field textarea{
  width:100%; background:var(--panel-raised); border:1px solid var(--line); color:var(--paper);
  padding:13px 14px; font-family:var(--font-body); font-size:15px; border-radius:2px;
}
.field input:focus, .field select:focus, .field textarea:focus{ border-color:var(--gold); outline:none; }
.field textarea{ min-height:120px; resize:vertical; }
.field-error{
  display:block; margin-top:6px; font-size:12.5px; color:#D98B6B;
}
.form-notice{
  margin-top:20px; padding:14px 16px; border-radius:2px; font-size:14px;
}
.form-notice[hidden]{ display:none; }
.form-notice-success{ background:rgba(87,101,76,.25); border:1px solid var(--green-bright); color:var(--paper); }
.form-notice-error{ background:rgba(217,139,107,.12); border:1px solid #D98B6B; color:var(--paper); }
.contact-info{ display:flex; flex-direction:column; gap:20px; }
.contact-info a{ text-decoration:none; }
.contact-info .row{ display:flex; align-items:baseline; gap:14px; }
.contact-info .label{ font-family:var(--font-mono); font-size:11px; letter-spacing:.06em; color:var(--gold); text-transform:uppercase; width:90px; flex-shrink:0; }
.contact-info .val{ font-size:17px; }
.contact-info .val:hover{ color:var(--gold-bright); }

/* ---------- Footer ---------- */
footer{ background:var(--panel); border-top:1px solid var(--line); padding:48px 0 28px; }
.footer-top{ display:flex; flex-wrap:wrap; gap:24px; justify-content:space-between; align-items:center; margin-bottom:28px; }
.footer-links{ display:flex; gap:22px; flex-wrap:wrap; font-size:14px; }
.footer-links a{ text-decoration:none; color:var(--paper-dim); }
.footer-links a:hover{ color:var(--gold-bright); }
.footer-bottom{ font-family:var(--font-mono); font-size:11.5px; color:var(--paper-dim); display:flex; flex-wrap:wrap; gap:8px 18px; justify-content:space-between; border-top:1px solid var(--line); padding-top:22px; }

/* ---------- Sticky mobile booking bar ---------- */
.sticky-bar{
  position:fixed; left:0; right:0; bottom:0; z-index:200;
  background:var(--ink); border-top:1px solid var(--line);
  display:flex; gap:1px;
  box-shadow:0 -8px 24px rgba(0,0,0,.35);
}
@media(min-width:860px){ .sticky-bar{ display:none; } }
.sticky-bar a{
  flex:1; text-align:center; padding:14px 8px;
  font-family:var(--font-mono); font-size:11.5px; letter-spacing:.04em; text-transform:uppercase;
  text-decoration:none;
}
.sticky-bar .a1{ background:var(--panel); color:var(--paper); }
.sticky-bar .a2{ background:var(--gold); color:var(--ink); }
body{ padding-bottom:52px; }
@media(min-width:860px){ body{ padding-bottom:0; } }

/* ---------- Film grain / vignette texture (site-wide, subtle) ---------- */
.grain-overlay{
  position:fixed; inset:0; z-index:9999; pointer-events:none;
  opacity:.045;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}

/* ---------- Hero v2 (real photography, vignette, bigger type) ---------- */
.hero{
  min-height:100vh;
}
.hero-bg{
  filter:grayscale(15%) contrast(1.12) brightness(.85);
  opacity:1;
}
.hero::after{
  content:"";
  position:absolute; inset:0; z-index:1;
  background:
    radial-gradient(ellipse at 50% 100%, rgba(11,12,10,.15) 0%, rgba(11,12,10,.85) 78%),
    linear-gradient(180deg, rgba(11,12,10,.55) 0%, rgba(11,12,10,.25) 30%, rgba(11,12,10,.65) 72%, var(--ink) 100%);
}
.hero-content{ padding:120px 0 72px; }
.hero h1{
  font-size:clamp(38px, 7.4vw, 84px);
  letter-spacing:-0.01em;
}
.hero-sub{ font-size:clamp(16px,2.1vw,19px); }

/* ---------- Masonry portfolio (replaces uniform grid) ---------- */
.masonry{
  columns:1;
  column-gap:14px;
}
@media(min-width:640px){ .masonry{ columns:2; } }
@media(min-width:1000px){ .masonry{ columns:3; } }
.masonry figure{
  margin:0 0 14px;
  break-inside:avoid;
  position:relative;
  overflow:hidden;
  border-radius:2px;
}
.masonry img{
  width:100%; display:block;
  filter:grayscale(25%) contrast(1.04);
  transition:transform .6s cubic-bezier(.2,.7,.2,1), filter .4s;
}
.masonry figure:hover img{ transform:scale(1.045); filter:grayscale(0%) contrast(1.08); }
.masonry figcaption{
  position:absolute; left:0; right:0; bottom:0;
  padding:28px 16px 14px;
  background:linear-gradient(180deg, transparent, rgba(11,12,10,.92));
  font-family:var(--font-mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase;
  color:var(--paper);
}
.masonry figcaption span{ display:block; color:var(--gold-bright); font-size:10px; margin-bottom:3px; }

/* ---------- Reveal-on-scroll ---------- */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .7s ease, transform .7s ease; }
.reveal.is-visible{ opacity:1; transform:translateY(0); }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
}

/* ---------- About v2: bigger, bleeding photo ---------- */
.about-photo{
  aspect-ratio:3/4;
  position:relative;
}
.about-photo::after{
  content:"";
  position:absolute; inset:0;
  box-shadow:inset 0 0 0 1px rgba(243,238,227,.08);
}
.about-photo img{ filter:grayscale(10%) contrast(1.08); }

/* ---------- Section divider mark (signature: frame counter) ---------- */
.section-mark{
  font-family:var(--font-mono);
  font-size:12px; letter-spacing:.1em;
  color:var(--paper-dim);
  display:flex; align-items:center; gap:14px;
  margin-bottom:18px;
}
.section-mark::after{ content:""; flex:1; height:1px; background:var(--line); }
.section-paper .section-mark{ color:#8a8574; }
.section-paper .section-mark::after{ background:#E4DECE; }

.skip-link{
  position:absolute; left:-9999px; top:0; background:var(--gold); color:var(--ink);
  padding:12px 18px; z-index:1000; font-family:var(--font-mono); font-size:13px;
}
.skip-link:focus{ left:12px; top:12px; }
