:root{
    --ink:#15130F;
    --ink-2:#211D16;
    --paper:#ECE7DD;
    --paper-2:#E1D9C8;
    --ink-soft:#4A453C;
    --safelight:#B8392B;
    --safelight-dim:#8E2C21;
    --gold:#AD8A3C;
    --line: rgba(21,19,15,0.14);
    --line-on-dark: rgba(236,231,221,0.18);
    --maxw: 1180px;
  }
  *{box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  body{
    margin:0;
    background:var(--paper);
    color:var(--ink);
    font-family:'IBM Plex Sans', sans-serif;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  img{max-width:100%;display:block;}
  a{color:inherit;}
  .wrap{max-width:var(--maxw); margin:0 auto; padding:0 28px;}
  .mono{
    font-family:'IBM Plex Mono', monospace;
    letter-spacing:.08em;
    text-transform:uppercase;
  }
  .eyebrow{
    display:flex; align-items:center; gap:10px;
    font-size:12px; font-weight:500;
    color:var(--safelight);
    margin-bottom:18px;
  }
  .eyebrow .ap-icon{flex:none;}
  h1,h2,h3{
    font-family:'Fraunces', serif;
    font-weight:500;
    line-height:1.05;
    margin:0;
  }
  h2{font-size:clamp(2rem, 4.4vw, 3.1rem); letter-spacing:-.01em;}
  p{line-height:1.65; margin:0;}
  .btn{
    display:inline-flex; align-items:center; gap:10px;
    padding:14px 24px;
    border-radius:2px;
    font-family:'IBM Plex Mono', monospace;
    font-size:13px;
    letter-spacing:.05em;
    text-transform:uppercase;
    text-decoration:none;
    border:1px solid currentColor;
    transition:transform .25s ease, background .25s ease, color .25s ease;
    white-space:nowrap;
  }
  .btn:hover{ transform:translateY(-2px); }
  .btn-solid{
    background:var(--safelight);
    border-color:var(--safelight);
    color:var(--paper);
  }
  .btn-solid:hover{ background:var(--ink); border-color:var(--ink); }
  .btn-ghost{
    background:transparent;
    color:var(--paper);
    border-color:var(--line-on-dark);
  }
  .btn-ghost:hover{ background:rgba(236,231,221,.08); color:var(--paper); }

  /* ===== NAV ===== */
  .nav{
    position:fixed; top:0; left:0; right:0; z-index:50;
    padding:18px 28px;
    display:flex; align-items:center; justify-content:space-between;
    transition:background .35s ease, padding .35s ease, box-shadow .35s ease;
  }
  .nav.solid{
    background:rgba(21,19,15,.92);
    backdrop-filter:blur(8px);
    padding:12px 28px;
    box-shadow:0 1px 0 var(--line-on-dark);
  }
  .nav-brand{ display:flex; align-items:center; gap:10px; text-decoration:none; }
  .nav-brand img{ width:30px; height:30px; filter:invert(1) brightness(2); }
  .nav-brand span{
    font-family:'IBM Plex Mono', monospace;
    font-size:13px; letter-spacing:.12em; color:var(--paper); text-transform:uppercase;
  }
  .nav-links{ display:flex; align-items:center; gap:30px; }
  .nav-links a{
    font-family:'IBM Plex Mono', monospace;
    font-size:12px; letter-spacing:.08em; text-transform:uppercase;
    color:var(--paper); text-decoration:none; opacity:.78;
    transition:opacity .2s;
  }
  .nav-links a:hover{ opacity:1; }
  .nav-call{
    font-family:'IBM Plex Mono', monospace;
    font-size:12px; color:var(--paper); text-decoration:none;
    border-bottom:1px solid var(--safelight); padding-bottom:2px;
  }
  .nav-toggle{ display:none; background:none; border:none; color:var(--paper); cursor:pointer; padding:4px; }
  .nav-toggle svg{ width:24px; height:24px; }
  .nav-mobile{
    position:fixed; inset:0; background:var(--ink); z-index:60;
    display:flex; flex-direction:column; justify-content:center; gap:28px;
    padding:40px; transform:translateY(-100%); transition:transform .4s ease;
  }
  .nav-mobile.open{ transform:translateY(0); }
  .nav-mobile a{
    font-family:'Fraunces', serif; font-size:2rem; color:var(--paper); text-decoration:none;
  }
  .nav-mobile-close{ position:absolute; top:24px; right:28px; background:none; border:none; color:var(--paper); cursor:pointer; }

  /* ===== HERO ===== */
  .hero{
    position:relative;
    min-height:100vh;
    display:flex; flex-direction:column; justify-content:center;
    background:var(--ink);
    color:var(--paper);
    overflow:hidden;
    padding:140px 0 80px;
  }
  .hero-bg{
    position:absolute; inset:0;
    background-image:url('../images/hero.jpg');
    background-size:cover; background-position:center 30%;
    opacity:.34;
    filter:saturate(.85) contrast(1.05);
  }
  .hero-bg::after{ content:""; }
  .hero-scrim{
    position:absolute; inset:0;
    background:
      radial-gradient(ellipse 60% 50% at 50% 35%, rgba(21,19,15,.2), rgba(21,19,15,.86) 70%),
      linear-gradient(180deg, rgba(21,19,15,.55) 0%, rgba(21,19,15,.93) 78%, var(--ink) 100%);
  }
  .hero-inner{ position:relative; z-index:2; }
  .hero .wrap{ width:100%; }
  .hero-eyebrow{
    font-family:'IBM Plex Mono', monospace;
    font-size:12px; letter-spacing:.18em; text-transform:uppercase;
    color:var(--paper); opacity:.7;
    margin:0 0 28px; text-align:center;
  }
  .hero-quote{
    font-family:'Fraunces', serif;
    font-style:italic;
    font-weight:400;
    font-size:clamp(1.7rem, 5vw, 3.4rem);
    line-height:1.18;
    text-align:center;
    max-width:920px;
    margin:0 auto 30px;
  }
  .hero-quote span{ color:var(--safelight); font-style:normal; }
  .hero-sub{
    text-align:center; max-width:560px; margin:0 auto 40px;
    font-size:16px; color:var(--paper); opacity:.82;
  }
  .hero-sub b{ color:var(--paper); font-weight:600; }
  .hero-ctas{ display:flex; justify-content:center; gap:16px; flex-wrap:wrap; margin-bottom:34px; }
  .hero-meta{
    text-align:center; font-size:11px; color:var(--paper); opacity:.55;
  }
  .hero-meta span{ margin:0 10px; }

  /* aperture */
  .aperture-stage{
    position:absolute; inset:0; z-index:1;
    display:flex; align-items:center; justify-content:center;
    pointer-events:none;
  }
  .aperture{ position:relative; width:min(64vw, 460px); height:min(64vw, 460px); }
  .blade{
    position:absolute; top:50%; left:50%; width:50%; height:50%;
    transform-origin:0% 0%;
    background:var(--ink);
    clip-path:polygon(0 0, 100% 0, 46% 100%);
    transform:rotate(calc(var(--i) * 36deg));
    animation:bladeOpen 1.5s cubic-bezier(.2,1,.3,1) forwards;
    animation-delay:calc(var(--i) * 0.035s + .2s);
  }
  @keyframes bladeOpen{
    0%{ transform:rotate(calc(var(--i) * 36deg)) scale(1); opacity:1; }
    100%{ transform:rotate(calc(var(--i) * 36deg + 30deg)) scale(.02); opacity:0; }
  }
  .aperture-ring{
    position:absolute; inset:0; border-radius:50%;
    border:1px solid rgba(236,231,221,.22);
    opacity:0; animation:ringIn 1s ease forwards; animation-delay:1.1s;
  }
  @keyframes ringIn{ to{ opacity:1; } }
  .fstop{
    position:absolute; font-family:'IBM Plex Mono',monospace; font-size:10px; color:rgba(236,231,221,.4);
    opacity:0; animation:ringIn .8s ease forwards; animation-delay:1.3s;
  }

  /* ===== SECTION SHELL ===== */
  section{ padding:120px 0; position:relative; }
  .reveal{ opacity:0; transform:translateY(24px); transition:opacity .8s ease, transform .8s ease; }
  .reveal.in{ opacity:1; transform:translateY(0); }

  .divider{ height:1px; background:var(--line); }

  /* ===== ABOUT ===== */
  .about{ background:var(--paper); }
  .about-grid{
    display:grid; grid-template-columns:1.1fr .9fr; gap:80px; align-items:start;
  }
  .about h2{ margin-bottom:26px; }
  .about p + p{ margin-top:18px; }
  .about-text p{ color:var(--ink-soft); font-size:16.5px; max-width:520px; }
  .pull{
    border-left:2px solid var(--safelight);
    padding-left:22px;
    margin-top:40px;
  }
  .pull p{
    font-family:'Fraunces', serif; font-style:italic; font-size:1.3rem; color:var(--ink);
  }
  .pull cite{
    display:block; margin-top:10px; font-family:'IBM Plex Mono', monospace;
    font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-soft); font-style:normal;
  }
  .about-stats{ display:flex; flex-direction:column; gap:0; border:1px solid var(--line); }
  .stat-row{
    display:flex; justify-content:space-between; align-items:baseline;
    padding:22px 24px; border-bottom:1px solid var(--line);
  }
  .stat-row:last-child{ border-bottom:none; }
  .stat-num{ font-family:'Fraunces', serif; font-size:2.1rem; }
  .stat-label{ font-family:'IBM Plex Mono', monospace; font-size:11px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-soft); text-align:right; max-width:180px; }

  /* ===== SERVICES ===== */
  .services{ background:var(--ink); color:var(--paper); }
  .services .eyebrow{ color:var(--safelight); }
  .services h2{ color:var(--paper); margin-bottom:16px; }
  .services-intro{ max-width:560px; color:rgba(236,231,221,.7); font-size:16.5px; margin-bottom:64px; }
  .svc-grid{ display:grid; grid-template-columns:repeat(3, 1fr); gap:1px; background:var(--line-on-dark); border:1px solid var(--line-on-dark); }
  .svc-card{ background:var(--ink); padding:36px 28px; }
  .svc-setting{ font-family:'IBM Plex Mono', monospace; font-size:13px; color:var(--safelight); margin-bottom:22px; }
  .svc-card h3{ font-family:'Fraunces', serif; font-weight:500; font-size:1.25rem; margin-bottom:10px; }
  .svc-card p{ color:rgba(236,231,221,.65); font-size:14.5px; }

  /* ===== GALLERY ===== */
  .gallery{ background:var(--paper-2); overflow:hidden; }
  .gallery .eyebrow{ color:var(--safelight); }
  .gallery h2{ margin-bottom:16px; }
  .gallery-intro{ max-width:520px; color:var(--ink-soft); font-size:16.5px; margin-bottom:0; }
  .album-row{
    display:grid; grid-template-columns:1.05fr .95fr; gap:60px; align-items:center; margin-top:8px;
  }
  /* the stacked album */
  .album-stage{ position:relative; height:440px; display:flex; align-items:center; justify-content:center; }
  .album{ position:relative; width:300px; height:380px; cursor:pointer; }
  .album-card{
    position:absolute; inset:0; border-radius:3px; overflow:hidden;
    background:var(--ink); box-shadow:0 18px 50px -18px rgba(21,19,15,.55);
    transition:transform .55s cubic-bezier(.2,.9,.25,1), box-shadow .4s;
    transform-origin:bottom center;
  }
  .album-card img{ width:100%; height:100%; object-fit:cover; display:block; }
  /* fanned resting state */
  .album-card:nth-child(1){ transform:rotate(-7deg) translate(-14px,8px) scale(.97); }
  .album-card:nth-child(2){ transform:rotate(5deg) translate(12px,4px) scale(.985); }
  .album-card:nth-child(3){ transform:rotate(-2deg); }
  .album-card:nth-child(4){ transform:rotate(0deg); }
  .album:hover .album-card:nth-child(1){ transform:rotate(-13deg) translate(-46px,2px) scale(.97); }
  .album:hover .album-card:nth-child(2){ transform:rotate(11deg) translate(44px,-2px) scale(.985); }
  .album:hover .album-card:nth-child(3){ transform:rotate(-4deg) translateY(-8px); }
  .album:hover .album-card:nth-child(4){ transform:rotate(1deg) translateY(-14px); box-shadow:0 26px 60px -16px rgba(21,19,15,.6); }
  .album-top-cap{
    position:absolute; left:0; right:0; bottom:0; z-index:5; padding:46px 18px 16px;
    background:linear-gradient(transparent, rgba(21,19,15,.9));
    color:var(--paper); pointer-events:none;
  }
  .album-top-cap .atc-eyebrow{ font-family:'IBM Plex Mono', monospace; font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--safelight); display:block; margin-bottom:5px; }
  .album-top-cap .atc-title{ font-family:'Fraunces', serif; font-size:1.15rem; }
  .album-count{
    position:absolute; top:-14px; right:-14px; z-index:6;
    width:62px; height:62px; border-radius:50%;
    background:var(--safelight); color:var(--paper);
    display:flex; flex-direction:column; align-items:center; justify-content:center;
    font-family:'IBM Plex Mono', monospace; box-shadow:0 8px 20px -6px rgba(184,57,43,.6);
    transform:rotate(-6deg);
  }
  .album-count b{ font-size:1.15rem; line-height:1; }
  .album-count span{ font-size:8px; letter-spacing:.08em; text-transform:uppercase; margin-top:2px; }
  /* right-side copy */
  .album-copy h3{ font-family:'Fraunces', serif; font-weight:500; font-size:1.5rem; margin-bottom:14px; }
  .album-copy p{ color:var(--ink-soft); font-size:16px; max-width:420px; margin-bottom:24px; }
  .album-tags{ display:flex; flex-wrap:wrap; gap:8px; margin-bottom:30px; }
  .album-tag{ font-family:'IBM Plex Mono', monospace; font-size:10px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-soft); border:1px solid var(--line); padding:6px 11px; border-radius:2px; }
  .album-open{
    display:inline-flex; align-items:center; gap:10px; cursor:pointer;
    background:var(--ink); color:var(--paper); border:1px solid var(--ink);
    padding:14px 24px; border-radius:2px;
    font-family:'IBM Plex Mono', monospace; font-size:13px; letter-spacing:.05em; text-transform:uppercase;
    transition:transform .25s, background .25s;
  }
  .album-open:hover{ transform:translateY(-2px); background:var(--safelight); border-color:var(--safelight); }

  /* lightbox */
  .lightbox{
    position:fixed; inset:0; z-index:80; background:rgba(15,13,10,.96);
    display:flex; align-items:center; justify-content:center; padding:40px;
    opacity:0; pointer-events:none; transition:opacity .3s;
  }
  .lightbox.open{ opacity:1; pointer-events:auto; }
  .lightbox img{ max-width:90vw; max-height:82vh; object-fit:contain; border-radius:2px; }
  .lb-cap{ position:absolute; bottom:26px; left:0; right:0; text-align:center; color:var(--paper); font-family:'IBM Plex Mono', monospace; font-size:12px; letter-spacing:.05em; }
  .lb-cap span{ color:var(--safelight); }
  .lb-close, .lb-prev, .lb-next{
    position:absolute; background:rgba(236,231,221,.1); border:1px solid var(--line-on-dark); color:var(--paper);
    width:46px; height:46px; border-radius:50%; cursor:pointer; display:flex; align-items:center; justify-content:center;
    transition:background .2s;
  }
  .lb-close:hover,.lb-prev:hover,.lb-next:hover{ background:rgba(236,231,221,.22); }
  .lb-close{ top:24px; right:24px; }
  .lb-prev{ left:24px; top:50%; transform:translateY(-50%); }
  .lb-next{ right:24px; top:50%; transform:translateY(-50%); }

  /* ===== REVIEWS ===== */
  .reviews{ background:var(--paper); }
  .reviews-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:40px; margin-bottom:60px; flex-wrap:wrap; }
  .reviews-stat{ font-family:'IBM Plex Mono', monospace; font-size:12px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-soft); }
  .reviews-stat b{ color:var(--ink); font-weight:600; }
  .rev-grid{ display:grid; grid-template-columns:repeat(3, 1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
  .rev-card{ background:var(--paper); padding:32px 28px; display:flex; flex-direction:column; gap:16px; }
  .rev-stars{ color:var(--gold); font-size:13px; letter-spacing:2px; }
  .rev-card p{ font-size:15px; color:var(--ink); flex:1; }
  .rev-name{ font-family:'IBM Plex Mono', monospace; font-size:11px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-soft); display:flex; justify-content:space-between; gap:14px; padding-top:14px; border-top:1px solid var(--line); }
  .rev-name span:first-child{ color:var(--ink); font-weight:500; }
  .rev-name span:last-child{ color:var(--safelight); white-space:nowrap; text-align:right; }

  /* ===== CONTACT ===== */
  .contact{ background:var(--ink-2); color:var(--paper); text-align:center; }
  .contact .eyebrow{ justify-content:center; color:var(--safelight); }
  .contact h2{ color:var(--paper); margin-bottom:22px; }
  .contact-sub{ max-width:480px; margin:0 auto 48px; color:rgba(236,231,221,.7); font-size:16px; }
  .contact-links{ display:flex; justify-content:center; gap:18px; flex-wrap:wrap; margin-bottom:36px; }
  .contact-big{
    font-family:'Fraunces', serif; font-size:clamp(1.3rem,3vw,1.9rem);
    text-decoration:none; color:var(--paper); border-bottom:1px solid var(--line-on-dark);
    padding-bottom:6px; transition:border-color .25s, color .25s;
  }
  .contact-big:hover{ border-color:var(--safelight); color:var(--safelight); }
  .contact-foot{ font-family:'IBM Plex Mono', monospace; font-size:11px; letter-spacing:.06em; text-transform:uppercase; color:rgba(236,231,221,.45); }

  /* ===== FOOTER ===== */
  footer{ background:var(--ink-2); color:rgba(236,231,221,.5); padding:30px 0 40px; }
  .foot-row{ display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px; font-family:'IBM Plex Mono', monospace; font-size:11px; letter-spacing:.04em; }
  .foot-row img{ width:20px; height:20px; filter:invert(1) brightness(2); opacity:.6; }
  .foot-brand{ display:flex; align-items:center; gap:10px; }

  @media (max-width:880px){
    .about-grid{ grid-template-columns:1fr; gap:50px; }
    .svc-grid{ grid-template-columns:1fr 1fr; }
    .rev-grid{ grid-template-columns:1fr 1fr; }
    .nav-links{ display:none; }
    .nav-toggle{ display:block; }
    .album-row{ grid-template-columns:1fr; gap:30px; }
    .album-stage{ height:400px; }
    .album-copy{ text-align:center; }
    .album-copy p{ margin-left:auto; margin-right:auto; }
    .album-tags{ justify-content:center; }
  }
  @media (max-width:600px){
    section{ padding:80px 0; }
    .svc-grid{ grid-template-columns:1fr; }
    .rev-grid{ grid-template-columns:1fr; }
    .reviews-head{ align-items:flex-start; }
    .hero{ padding-top:120px; }
    .album{ width:240px; height:310px; }
    .album-stage{ height:360px; }
  }

  @media (prefers-reduced-motion: reduce){
    .blade, .aperture-ring, .fstop{ animation:none !important; opacity:0 !important; }
    .reveal{ opacity:1 !important; transform:none !important; transition:none !important; }
  }
