/*
Theme Name:  Media Frame
Theme URI:   https://mediaframe.in
Author:      Media Frame Studio
Author URI:  https://mediaframe.in
Description: Custom WordPress theme for Media Frame, a commercial product photography studio in Kacha Tobha, Hoshiarpur, Punjab. Clean PHP template structure with Customizer-editable business details. Page bodies are designed to be built and edited visually with Elementor (or any page builder) — header, footer, and the slide-out side panel are theme-native PHP and are not Elementor-dependent.
Version:     1.0.0
Requires at least: 5.8
Tested up to: 6.6
Requires PHP: 7.4
License:     GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: mediaframe
Tags: business, photography, portfolio, custom-menu, translation-ready
*/


  :root{
    --ink:#101113;
    --ink-soft:#1c1d20;
    --paper:#F7F5F0;
    --paper-warm:#EFEAE0;
    --brass:#C9A227;
    --brass-soft:#a98a23;
    --steel:#5A5F66;
    --steel-light:#8b9097;
    --line: rgba(16,17,19,0.10);
    --line-on-dark: rgba(247,245,240,0.14);
    --max: 1320px;
  }
  *{box-sizing:border-box; margin:0; padding:0;}
  html{scroll-behavior:smooth;}
  body{
    background:var(--paper);
    color:var(--ink);
    font-family:'Inter', sans-serif;
    font-weight:400;
    line-height:1.5;
    -webkit-font-smoothing:antialiased;
  }
  img{max-width:100%; display:block;}
  a{color:inherit; text-decoration:none;}
  button{ font-family:inherit; cursor:pointer; }
  .wrap{max-width:var(--max); margin:0 auto; padding:0 40px;}

  .eyebrow{
    font-family:'JetBrains Mono', monospace;
    font-size:11px;
    letter-spacing:0.16em;
    text-transform:uppercase;
    color:var(--brass-soft);
    display:flex;
    align-items:center;
    gap:10px;
  }
  .eyebrow::before{
    content:"";
    width:18px; height:1px;
    background:var(--brass-soft);
    display:inline-block;
  }
  .eyebrow.on-dark{ color:var(--brass); }
  .eyebrow.on-dark::before{ background:var(--brass); }

  h1,h2,h3,h4{
    font-family:'Fraunces', serif;
    font-weight:500;
    letter-spacing:-0.015em;
  }
  ::selection{ background:var(--brass); color:var(--ink); }

  a:focus-visible, button:focus-visible{
    outline:2px solid var(--brass);
    outline-offset:2px;
  }

  /* ===== crop marks motif ===== */
  .crop{ position:absolute; width:16px; height:16px; pointer-events:none; }
  .crop::before, .crop::after{ content:""; position:absolute; background:currentColor; }
  .crop::before{ width:16px; height:1px; top:0; left:0; }
  .crop::after{ width:1px; height:16px; top:0; left:0; }
  .crop.tl{ top:20px; left:20px; }
  .crop.tr{ top:20px; right:20px; left:auto; transform:scaleX(-1); }

  /* ===== TOP UTILITY BAR ===== */
  .utility-bar{
    background:var(--ink);
    color:var(--steel-light);
    font-family:'JetBrains Mono', monospace;
    font-size:11.5px;
    letter-spacing:0.02em;
  }
  .utility-inner{
    max-width:var(--max); margin:0 auto; padding:10px 40px;
    display:flex; justify-content:space-between; align-items:center;
    flex-wrap:wrap; gap:10px;
  }
  .utility-inner a:hover{ color:var(--brass); }
  .utility-left{ display:flex; gap:24px; flex-wrap:wrap; }
  .utility-right{ display:flex; gap:18px; align-items:center; }

  /* ===== NAV ===== */
  header{
    position:sticky; top:0; z-index:100;
    background:var(--paper);
    border-bottom:1px solid var(--line);
  }
  .navbar{
    max-width:var(--max); margin:0 auto;
    padding:20px 40px;
    display:flex; align-items:center; justify-content:space-between;
  }
  .logo{
    font-family:'Fraunces', serif;
    font-size:19px;
    font-weight:500;
    color:var(--ink);
    display:flex; align-items:center; gap:10px;
  }
  .logo .mark{
    width:26px; height:26px;
    border:1px solid var(--brass-soft);
    position:relative; flex-shrink:0;
  }
  .logo .mark::before, .logo .mark::after{
    content:""; position:absolute; background:var(--brass-soft);
  }
  .logo .mark::before{ width:9px; height:1px; top:50%; left:50%; transform:translate(-50%,-50%); }
  .logo .mark::after{ width:1px; height:9px; top:50%; left:50%; transform:translate(-50%,-50%); }

  nav ul{ list-style:none; display:flex; gap:34px; }
  nav a{
    font-size:13px; letter-spacing:0.03em; text-transform:uppercase;
    color:var(--ink); position:relative; padding-bottom:4px;
  }
  nav a.active{ color:var(--brass-soft); }
  nav a.active::after{
    content:""; position:absolute; left:0; right:0; bottom:0; height:1px; background:var(--brass-soft);
  }
  nav a:hover{ color:var(--brass-soft); }
  .nav-links{ display:flex; }

  .nav-right{ display:flex; align-items:center; gap:22px; }
  .nav-icon{
    width:34px; height:34px;
    display:flex; align-items:center; justify-content:center;
    border:1px solid var(--line); border-radius:50%;
    color:var(--steel); font-size:13px;
    transition:border-color .2s ease, color .2s ease;
  }
  .nav-icon:hover{ border-color:var(--brass-soft); color:var(--brass-soft); }
  .nav-toggle{ display:flex; align-items:center; justify-content:center; width:34px; height:34px; background:none; border:1px solid var(--line); border-radius:50%; font-size:15px; color:var(--ink); cursor:pointer; transition:border-color .2s ease, color .2s ease; }
  .nav-toggle:hover{ border-color:var(--brass-soft); color:var(--brass-soft); }

  /* ===== HERO — split scene ===== */
  .hero{
    position:relative;
    height:88vh;
    min-height:560px;
    overflow:hidden;
    background:var(--ink);
  }
  .hero-scene{
    position:absolute; inset:0;
    display:grid;
    grid-template-columns: 1.05fr 1fr;
  }
  .hero-panel{ position:relative; overflow:hidden; }
  .hero-panel.left{
    background:
      radial-gradient(ellipse 60% 50% at 30% 25%, rgba(247,245,240,0.10), transparent 60%),
      linear-gradient(160deg, #1c1d20 0%, #101113 70%);
  }
  .hero-panel.right{
    background:
      radial-gradient(ellipse 65% 55% at 65% 60%, rgba(201,162,39,0.20), transparent 65%),
      linear-gradient(200deg, #15110a 0%, #0c0a07 70%);
  }
  /* studio softbox glows + product silhouette, css only */
  .softbox{
    position:absolute;
    border-radius:50%;
    filter:blur(1px);
  }
  .hero-panel.left .softbox{
    width:40%; aspect-ratio:1;
    top:10%; left:8%;
    background:radial-gradient(circle at 35% 30%, rgba(247,245,240,0.85), rgba(247,245,240,0.05) 65%);
    opacity:0.5;
  }
  .hero-panel.left .product{
    position:absolute; left:18%; top:14%;
    width:30%; aspect-ratio:0.62;
    background:linear-gradient(160deg, rgba(20,21,23,0.92), rgba(8,8,9,0.98));
    border-radius:6px 6px 2px 2px;
    box-shadow:0 30px 60px rgba(0,0,0,0.5);
  }
  .hero-panel.left .product::before{
    content:"";
    position:absolute; inset:14% 16%;
    border:1px solid rgba(247,245,240,0.18);
  }
  .hero-panel.right .softbox{
    width:50%; aspect-ratio:1;
    top:30%; right:14%;
    background:radial-gradient(circle at 40% 35%, rgba(201,162,39,0.9), rgba(201,162,39,0.04) 65%);
    opacity:0.5;
  }
  .hero-panel.right .product{
    position:absolute; left:42%; bottom:10%;
    width:30%; aspect-ratio:1;
    border-radius:50%;
    background:radial-gradient(circle at 35% 28%, #e8c25c, #C9A227 55%, #5c4715 100%);
    box-shadow:0 30px 60px rgba(0,0,0,0.5);
  }
  .hero-grid-overlay{
    position:absolute; inset:0;
    background-image:
      linear-gradient(var(--line-on-dark) 1px, transparent 1px),
      linear-gradient(90deg, var(--line-on-dark) 1px, transparent 1px);
    background-size:25% 25%;
    opacity:0.35;
  }
  .hero-content{
    position:relative; z-index:3;
    height:100%;
    max-width:var(--max); margin:0 auto; padding:0 40px;
    display:flex; flex-direction:column; justify-content:flex-end;
    padding-bottom:80px;
  }
  .hero-content::before{
    content:"";
    position:absolute;
    left:-40px; right:-40px; bottom:-1px; top:38%;
    background:linear-gradient(0deg, rgba(16,17,19,0.78) 30%, rgba(16,17,19,0.0) 100%);
    z-index:-1;
  }
  .hero-content .eyebrow{ margin-bottom:20px; }
  .hero h1{
    color:var(--paper);
    font-size:clamp(40px, 6vw, 78px);
    line-height:1.0;
    max-width:760px;
  }
  .hero h1 .accent{ color:var(--brass); font-weight:400; }
  .hero-sub{
    margin-top:22px;
    max-width:440px;
    color:var(--steel-light);
    font-size:15px;
    line-height:1.7;
  }
  .hero-cta-row{
    margin-top:34px;
    display:flex; align-items:center; gap:28px;
  }
  .btn-primary{
    font-family:'JetBrains Mono', monospace;
    font-size:12px; letter-spacing:0.06em;
    background:var(--brass); color:var(--ink);
    padding:15px 28px; display:inline-block;
    transition:background .2s ease;
  }
  .btn-primary:hover{ background:#ddb734; }
  .btn-text{
    font-size:13.5px; color:var(--paper);
    border-bottom:1px solid var(--steel); padding-bottom:3px;
    transition:border-color .2s ease;
  }
  .btn-text:hover{ border-color:var(--brass); }

  .hero-scroll-cue{
    position:absolute; left:40px; bottom:28px; z-index:3;
    display:flex; align-items:center; gap:10px;
    font-family:'JetBrains Mono', monospace; font-size:10.5px;
    letter-spacing:0.1em; text-transform:uppercase;
    color:var(--steel-light);
  }
  .hero-scroll-cue .ln{ width:28px; height:1px; background:var(--steel-light); }

  /* ===== ABOUT — aperture motif instead of circular portrait ===== */
  .about{
    background:var(--paper-warm);
    padding:130px 0;
    border-bottom:1px solid var(--line);
  }
  .about-inner{
    max-width:var(--max); margin:0 auto; padding:0 40px;
    display:grid; grid-template-columns:0.9fr 1.1fr; gap:90px; align-items:center;
  }
  .aperture{
    position:relative;
    width:100%; aspect-ratio:1;
    max-width:440px;
  }
  .aperture-ring{
    position:absolute; inset:0; border-radius:50%;
    border:1px solid var(--line);
  }
  .aperture-ring.r2{ inset:8%; border-color: rgba(16,17,19,0.16); }
  .aperture-ring.r3{ inset:16%; border-color: rgba(16,17,19,0.22); }
  .aperture-core{
    position:absolute; inset:24%;
    border-radius:50%;
    background: radial-gradient(circle at 38% 32%, #2a2b2e, #101113 70%);
    box-shadow:0 30px 60px rgba(16,17,19,0.25);
    display:flex; align-items:center; justify-content:center;
  }
  .aperture-core .blade{
    position:absolute; inset:0;
    border-radius:50%;
    background:
      conic-gradient(from 0deg,
        rgba(201,162,39,0.0) 0deg, rgba(201,162,39,0.0) 51deg,
        rgba(201,162,39,0.55) 60deg, rgba(201,162,39,0.0) 69deg,
        rgba(201,162,39,0.0) 120deg);
    opacity:0.9;
  }
  .aperture-core .iris{
    position:relative; z-index:2;
    width:30%; aspect-ratio:1; border-radius:50%;
    background:var(--paper);
  }
  .aperture-tag{
    position:absolute; bottom:6%; left:50%; transform:translateX(-50%);
    font-family:'JetBrains Mono', monospace; font-size:10.5px;
    letter-spacing:0.08em; color:var(--steel);
    background:var(--paper-warm);
    padding:4px 10px;
  }

  .about-copy h2{
    font-size:clamp(30px,3.6vw,44px);
    line-height:1.18;
    color:var(--ink);
    margin-bottom:22px;
  }
  .about-copy h2 .accent{ color:var(--brass-soft); }
  .about-copy .rule{ width:40px; height:2px; background:var(--brass-soft); margin-bottom:26px; }
  .about-copy p{
    font-size:15.5px; color:var(--steel); line-height:1.8; max-width:520px; margin-bottom:28px;
  }
  .about-stats{
    display:flex; gap:54px; margin:36px 0 32px;
    padding-top:30px; border-top:1px solid var(--line);
  }
  .about-stats .num{ font-family:'Fraunces', serif; font-size:34px; color:var(--ink); font-weight:500; }
  .about-stats .lbl{
    font-family:'JetBrains Mono', monospace; font-size:10.5px;
    letter-spacing:0.05em; text-transform:uppercase; color:var(--steel); margin-top:6px;
  }
  .link-arrow{
    font-size:13.5px; color:var(--ink);
    border-bottom:1px solid var(--brass-soft); padding-bottom:3px;
    display:inline-flex; align-items:center; gap:8px;
  }

  /* ===== LATEST WORK / GALLERY ===== */
  .gallery{ padding:130px 0 100px; background:var(--paper); }
  .gallery-head{ text-align:center; margin-bottom:16px; }
  .gallery-head h2{
    font-size:clamp(32px,4vw,48px); color:var(--ink);
  }
  .gallery-head h2 .accent{ color:var(--brass-soft); }
  .gallery-head .rule{
    width:40px; height:2px; background:var(--brass-soft); margin:18px auto 50px;
  }

  .filter-row{
    display:flex; justify-content:center; gap:34px; flex-wrap:wrap;
    margin-bottom:54px;
  }
  .filter-row button{
    background:none; border:none;
    font-family:'JetBrains Mono', monospace; font-size:11.5px;
    letter-spacing:0.08em; text-transform:uppercase;
    color:var(--steel); padding-bottom:6px; border-bottom:2px solid transparent;
    transition:color .2s ease, border-color .2s ease;
  }
  .filter-row button.active, .filter-row button:hover{
    color:var(--ink); border-color:var(--brass-soft);
  }

  .masonry{
    max-width:var(--max); margin:0 auto; padding:0 40px;
    columns:4 220px;
    column-gap:14px;
  }
  .m-item{
    break-inside:avoid;
    margin-bottom:14px;
    position:relative;
    overflow:hidden;
    background:var(--ink);
  }
  .m-item .swatch{
    width:100%; display:flex; align-items:center; justify-content:center;
    position:relative;
  }
  .m-item .swatch .obj{ position:relative; z-index:1; }
  .m-item .cap{
    position:absolute; left:0; right:0; bottom:0;
    padding:14px 16px;
    background:linear-gradient(0deg, rgba(16,17,19,0.88), transparent);
    opacity:0; transition:opacity .25s ease;
  }
  .m-item:hover .cap{ opacity:1; }
  .cap .cat{
    font-family:'JetBrains Mono', monospace; font-size:9.5px;
    letter-spacing:0.08em; text-transform:uppercase; color:var(--brass);
  }
  .cap .nm{ color:var(--paper); font-family:'Fraunces', serif; font-size:14.5px; margin-top:2px; }

  .gallery-more{ text-align:center; margin-top:50px; }
  .gallery-more button{
    background:none; border:none;
    font-family:'JetBrains Mono', monospace; font-size:12px;
    letter-spacing:0.06em; color:var(--steel);
    border-bottom:1px solid var(--steel); padding-bottom:4px;
    transition:color .2s ease, border-color .2s ease;
  }
  .gallery-more button:hover{ color:var(--brass-soft); border-color:var(--brass-soft); }

  /* ===== CAPABILITIES (replaces pricing) ===== */
  .capabilities{ background:var(--paper); padding:130px 0 110px; }
  .cap-head{ text-align:center; max-width:680px; margin:0 auto 64px; padding:0 40px; }
  .cap-head h2{ font-size:clamp(30px,3.6vw,46px); color:var(--ink); margin-top:16px; }
  .cap-head h2 .accent{ color:var(--brass-soft); }
  .cap-head .rule{ width:40px; height:2px; background:var(--brass-soft); margin:20px auto 0; }

  .cap-grid{
    max-width:var(--max); margin:0 auto; padding:0 40px;
    display:grid; grid-template-columns:repeat(3,1fr);
    border-top:1px solid var(--line); border-left:1px solid var(--line);
  }
  .cap-card{
    padding:42px 38px 46px;
    border-right:1px solid var(--line);
    border-bottom:1px solid var(--line);
    transition:background .25s ease;
  }
  .cap-card:hover{ background:var(--paper-warm); }
  .cap-icon{
    width:54px; height:54px;
    border:1px solid var(--brass-soft);
    border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    color:var(--brass-soft);
    margin-bottom:24px;
  }
  .cap-card h3{
    font-size:19px; color:var(--ink); margin-bottom:12px; font-weight:500;
  }
  .cap-card p{
    font-size:14px; color:var(--steel); line-height:1.7;
  }

  /* ===== ENQUIRY BANNER ===== */
  .enquiry-banner{ background:var(--ink-soft); padding:90px 40px; }
  .enquiry-inner{
    max-width:var(--max); margin:0 auto;
    display:grid; grid-template-columns:1.3fr 1fr; gap:60px; align-items:center;
  }
  .enquiry-copy h2{
    color:var(--paper); font-size:clamp(24px,2.8vw,34px); line-height:1.3; margin-top:16px; max-width:560px;
  }
  .enquiry-sub{ color:var(--steel-light); font-size:14.5px; line-height:1.75; margin-top:18px; max-width:480px; }
  .enquiry-action{ display:flex; flex-direction:column; align-items:flex-start; gap:18px; }

  /* ===== CONTACT STRIP ===== */
  .cta-strip{
    background:var(--paper-warm);
    padding:90px 40px;
    text-align:center;
  }
  .cta-strip h2{
    font-size:clamp(28px,3.4vw,42px); color:var(--ink); max-width:640px; margin:0 auto 16px;
  }
  .cta-strip p{ color:var(--steel); font-size:15px; margin-bottom:34px; }
  .cta-row{ display:flex; justify-content:center; gap:24px; flex-wrap:wrap; }
  .btn-dark{
    font-family:'JetBrains Mono', monospace; font-size:12px; letter-spacing:0.06em;
    background:var(--ink); color:var(--paper); padding:15px 28px;
    transition:background .2s ease;
  }
  .btn-dark:hover{ background:var(--ink-soft); }

  /* ===== STRIP GALLERY (footer lead-in) ===== */
  .strip-gallery{
    display:grid; grid-template-columns:repeat(6,1fr);
  }
  .strip-item{ aspect-ratio:1; position:relative; overflow:hidden; }
  .strip-item.follow{
    display:flex; align-items:center; justify-content:center;
    background:var(--ink);
  }
  .strip-item.follow span{
    font-family:'JetBrains Mono', monospace; font-size:11px;
    letter-spacing:0.06em; color:var(--brass); border:1px solid var(--brass);
    padding:10px 16px;
  }

  /* ===== FOOTER ===== */
  footer{ background:var(--ink); color:var(--steel-light); padding:80px 0 0; }
  .footer-inner{
    max-width:var(--max); margin:0 auto; padding:0 40px 60px;
    display:grid; grid-template-columns:1.3fr 1fr 1fr; gap:60px;
  }
  .footer-brand .logo{ color:var(--paper); margin-bottom:18px; }
  .footer-brand p{ font-size:14px; line-height:1.75; max-width:340px; color:var(--steel-light); }
  .footer-social{ display:flex; gap:16px; margin-top:24px; }
  .footer-social a{
    font-family:'JetBrains Mono', monospace; font-size:11px;
    color:var(--steel-light); border-bottom:1px solid transparent;
  }
  .footer-social a:hover{ color:var(--brass); border-color:var(--brass); }

  footer h4{
    font-family:'JetBrains Mono', monospace; font-size:11.5px;
    letter-spacing:0.08em; text-transform:uppercase;
    color:var(--paper); font-weight:500; margin-bottom:22px;
  }
  footer .flinks{ list-style:none; display:flex; flex-direction:column; gap:13px; }
  footer .flinks a{ font-size:14px; color:var(--steel-light); }
  footer .flinks a:hover{ color:var(--brass); }
  .footer-contact-row{ margin-bottom:14px; }
  .footer-contact-row .k{
    font-family:'JetBrains Mono', monospace; font-size:10.5px;
    letter-spacing:0.05em; text-transform:uppercase; color:var(--brass); margin-bottom:4px;
  }
  .footer-contact-row .v{ font-size:14px; color:var(--paper); }
  .footer-contact-row .v a:hover{ color:var(--brass); }

  .footer-bottom{
    border-top:1px solid var(--line-on-dark);
    padding:24px 40px;
  }
  .footer-bottom-inner{
    max-width:var(--max); margin:0 auto;
    display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px;
    font-family:'JetBrains Mono', monospace; font-size:11px; color:var(--steel-light);
  }

  /* ===== reveal ===== */
  .reveal{ opacity:0; transform:translateY(14px); transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); }
  .reveal.in{ opacity:1; transform:translateY(0); }
  @media (prefers-reduced-motion: reduce){ *{ animation:none !important; transition:none !important; } .reveal{ opacity:1; transform:none; } }

  /* ===== RESPONSIVE ===== */
  @media (max-width:1080px){
    .about-inner{ grid-template-columns:1fr; gap:50px; }
    .aperture{ margin:0 auto; }
    .masonry{ columns:3 200px; }
    .cap-grid{ grid-template-columns:1fr 1fr; }
    .enquiry-inner{ grid-template-columns:1fr; gap:34px; }
    .footer-inner{ grid-template-columns:1fr 1fr; }
    .footer-brand{ grid-column:span 2; }
    .strip-gallery{ grid-template-columns:repeat(3,1fr); }
  }
  @media (max-width:760px){
    .utility-left{ display:none; }
    .nav-links{ display:none; }
    .logo{ font-size:16px; white-space:nowrap; }
    .navbar{ padding:16px 20px; gap:12px; }
    .nav-right{ gap:14px; }
    .btn-primary{ padding:10px 16px !important; font-size:11px; }
    .hero-scene{ grid-template-columns:1fr; }
    .hero-panel.left{ display:none; }
    .hero{ height:78vh; }
    .masonry{ columns:2 160px; }
    .footer-inner{ grid-template-columns:1fr; }
    .footer-brand{ grid-column:span 1; }
    .strip-gallery{ grid-template-columns:repeat(3,1fr); }
    .about-stats{ gap:34px; flex-wrap:wrap; }
    .cap-grid{ grid-template-columns:1fr; }
  }

  /* ===== ABOUT PAGE: page header ===== */
  .page-header{
    position:relative;
    background:var(--ink);
    padding:64px 0 70px;
    overflow:hidden;
  }
  .page-header-bg{
    position:absolute; inset:0;
    background:
      radial-gradient(ellipse 50% 60% at 85% 20%, rgba(201,162,39,0.14), transparent 60%),
      radial-gradient(ellipse 40% 50% at 10% 90%, rgba(247,245,240,0.05), transparent 60%);
  }
  .page-header-grid{
    position:absolute; inset:0;
    background-image:
      linear-gradient(var(--line-on-dark) 1px, transparent 1px),
      linear-gradient(90deg, var(--line-on-dark) 1px, transparent 1px);
    background-size:16.6% 100%;
    opacity:0.4;
  }
  .page-header-inner{
    position:relative; z-index:2;
    max-width:var(--max); margin:0 auto; padding:0 40px;
  }
  .page-header h1{
    color:var(--paper);
    font-size:clamp(36px,4.6vw,58px);
    margin-top:18px;
  }
  .page-header h1 .accent{ color:var(--brass); font-weight:400; }
  .breadcrumb{
    margin-top:20px;
    font-family:'JetBrains Mono', monospace; font-size:11.5px;
    color:var(--steel-light); letter-spacing:0.03em;
  }
  .breadcrumb a:hover{ color:var(--brass); }
  .breadcrumb .sep{ margin:0 8px; color:var(--steel); }

  /* ===== BIO SPLIT ===== */
  .bio{ background:var(--paper); padding:120px 0; border-bottom:1px solid var(--line); }
  .bio-inner{
    max-width:var(--max); margin:0 auto; padding:0 40px;
    display:grid; grid-template-columns:0.95fr 1.05fr; gap:90px; align-items:center;
  }
  .bio-visual{
    position:relative;
    aspect-ratio:4/5;
    background:linear-gradient(160deg,#1c1d20 0%, #101113 75%);
    overflow:hidden;
  }
  .bio-visual .softbox{
    position:absolute; width:55%; aspect-ratio:1; top:8%; left:14%;
    border-radius:50%;
    background:radial-gradient(circle at 35% 30%, rgba(247,245,240,0.5), rgba(247,245,240,0.04) 65%);
    opacity:0.5;
  }
  .bio-visual .rig{
    position:absolute; left:50%; bottom:10%; transform:translateX(-50%);
    width:62%;
  }
  .bio-visual .rig .stand{
    width:3px; height:140px; background:rgba(247,245,240,0.25); margin:0 auto;
  }
  .bio-visual .rig .head{
    width:100%; aspect-ratio:1.6;
    background:linear-gradient(160deg, rgba(30,31,34,0.95), rgba(10,10,11,0.98));
    border-radius:6px;
    box-shadow:0 25px 50px rgba(0,0,0,0.45);
    position:relative;
  }
  .bio-visual .rig .head::before{
    content:"";
    position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
    width:34%; aspect-ratio:1; border-radius:50%;
    border:2px solid var(--brass);
  }
  .bio-visual .tag{
    position:absolute; left:24px; bottom:22px;
    font-family:'JetBrains Mono', monospace; font-size:10.5px;
    letter-spacing:0.07em; color:var(--steel-light);
  }
  .bio-copy h2{ font-size:clamp(28px,3.4vw,42px); color:var(--ink); line-height:1.2; margin:16px 0 22px; }
  .bio-copy h2 .accent{ color:var(--brass-soft); }
  .bio-copy .rule{ width:40px; height:2px; background:var(--brass-soft); margin-bottom:26px; }
  .bio-copy p{ font-size:15px; color:var(--steel); line-height:1.8; margin-bottom:18px; max-width:540px; }
  .bio-copy p.lead{ font-size:16.5px; color:var(--ink); font-weight:500; }

  /* ===== SKILLS / EQUIPMENT RINGS ===== */
  .skills{ background:var(--paper-warm); padding:120px 0; }
  .skills-inner{
    max-width:var(--max); margin:0 auto; padding:0 40px;
    display:grid; grid-template-columns:1fr 1fr; gap:90px; align-items:start;
  }
  .skills-copy h2{ font-size:clamp(28px,3.4vw,40px); color:var(--ink); margin:16px 0 26px; }
  .skills-copy .rule{ width:40px; height:2px; background:var(--brass-soft); margin-bottom:30px; }
  .ring-grid{ display:grid; grid-template-columns:1fr 1fr; gap:40px 30px; }
  .ring-item{ display:flex; flex-direction:column; align-items:flex-start; }
  .ring{ position:relative; width:84px; height:84px; margin-bottom:18px; }
  .ring svg{ transform:rotate(-90deg); }
  .ring circle{ fill:none; stroke-width:3; }
  .ring .bg{ stroke: rgba(16,17,19,0.10); }
  .ring .fg{ stroke: var(--brass-soft); stroke-linecap:round; transition:stroke-dashoffset 1.4s cubic-bezier(.2,.7,.2,1); }
  .ring .pct{
    position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
    font-family:'JetBrains Mono', monospace; font-size:14px; color:var(--ink); font-weight:500;
  }
  .ring-item h4{ font-size:15px; color:var(--ink); font-weight:500; margin-bottom:6px; }
  .ring-item p{ font-size:13px; color:var(--steel); line-height:1.6; }

  /* ===== JOURNAL / RECENT SHOOTS ===== */
  .journal{ background:var(--paper); padding:120px 0 130px; }
  .journal-head{ text-align:center; max-width:600px; margin:0 auto 60px; padding:0 40px; }
  .journal-head h2{ font-size:clamp(30px,3.6vw,46px); color:var(--ink); margin-top:16px; }
  .journal-head .rule{ width:40px; height:2px; background:var(--brass-soft); margin:20px auto 0; }
  .journal-grid{
    max-width:var(--max); margin:0 auto; padding:0 40px;
    display:grid; grid-template-columns:repeat(3,1fr); gap:30px;
  }
  .journal-card{ display:flex; flex-direction:column; }
  .journal-thumb{
    aspect-ratio:4/3; position:relative; overflow:hidden; margin-bottom:22px;
  }
  .journal-date{
    font-family:'JetBrains Mono', monospace; font-size:11px;
    color:var(--brass-soft); letter-spacing:0.04em; margin-bottom:10px;
  }
  .journal-card h3{ font-size:19px; color:var(--ink); margin-bottom:10px; font-weight:500; }
  .journal-card p{ font-size:13.5px; color:var(--steel); line-height:1.7; }
  .journal-link{
    margin-top:14px; font-size:12.5px; color:var(--ink);
    border-bottom:1px solid var(--brass-soft); padding-bottom:2px; display:inline-block; width:fit-content;
  }

  /* ===== About page responsive ===== */
  @media (max-width:1080px){
    .bio-inner{ grid-template-columns:1fr; gap:50px; }
    .bio-visual{ max-width:440px; margin:0 auto; }
    .skills-inner{ grid-template-columns:1fr; gap:50px; }
    .journal-grid{ grid-template-columns:1fr; max-width:480px; }
  }
  @media (max-width:760px){
    .ring-grid{ grid-template-columns:1fr 1fr; gap:30px 20px; }
    .page-header{ padding:50px 0 56px; }
  }

  /* ===== SERVICES PAGE ===== */
  .services-list{ background:var(--paper); padding:110px 0 60px; }
  .service-row{
    max-width:var(--max); margin:0 auto 90px; padding:0 40px;
    display:grid; grid-template-columns:0.85fr 1.15fr; gap:80px; align-items:center;
  }
  .service-row:nth-child(even) .service-visual{ order:2; }
  .service-row:nth-child(even) .service-copy{ order:1; }
  .service-visual{
    position:relative; aspect-ratio:4/3; overflow:hidden;
  }
  .service-index{
    font-family:'JetBrains Mono', monospace; font-size:12px; color:var(--brass-soft);
    letter-spacing:0.08em; margin-bottom:14px;
  }
  .service-copy h2{ font-size:clamp(26px,3vw,38px); color:var(--ink); margin-bottom:18px; }
  .service-copy p{ font-size:15px; color:var(--steel); line-height:1.8; max-width:480px; margin-bottom:24px; }
  .service-tags{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom:28px; }
  .service-tags span{
    font-family:'JetBrains Mono', monospace; font-size:11px;
    border:1px solid var(--line); padding:7px 14px; color:var(--steel);
  }

  /* ===== FULL GALLERY PAGE ===== */
  .gallery-page{ background:var(--paper); padding:100px 0 130px; }
  .gallery-page-head{ max-width:var(--max); margin:0 auto 50px; padding:0 40px; }
  .gallery-page-head h1{ font-size:clamp(34px,4.4vw,56px); color:var(--ink); margin-top:16px; max-width:700px; }
  .gallery-page-head p{ color:var(--steel); font-size:15px; margin-top:18px; max-width:520px; line-height:1.7; }

  /* ===== CONTACT PAGE ===== */
  .contact-page{ background:var(--paper); padding:100px 0 0; }
  .contact-grid{
    max-width:var(--max); margin:0 auto; padding:0 40px 120px;
    display:grid; grid-template-columns:0.9fr 1.1fr; gap:80px;
  }
  .contact-info h1{ font-size:clamp(32px,4vw,48px); color:var(--ink); margin:16px 0 24px; line-height:1.15; }
  .contact-info > p{ color:var(--steel); font-size:15px; line-height:1.8; max-width:440px; margin-bottom:40px; }
  .contact-block{ margin-bottom:30px; padding-bottom:26px; border-bottom:1px solid var(--line); }
  .contact-block:last-child{ border-bottom:none; }
  .contact-block .k{
    font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:0.06em;
    text-transform:uppercase; color:var(--brass-soft); margin-bottom:8px;
  }
  .contact-block .v{ font-size:15.5px; color:var(--ink); line-height:1.7; }
  .contact-block .v a:hover{ color:var(--brass-soft); }
  .contact-social{ display:flex; gap:20px; margin-top:8px; }
  .contact-social a{
    font-family:'JetBrains Mono', monospace; font-size:12px;
    color:var(--steel); border-bottom:1px solid var(--steel);
  }
  .contact-social a:hover{ color:var(--brass-soft); border-color:var(--brass-soft); }

  .contact-form-card{ background:var(--ink); padding:48px 42px; }
  .contact-form-card .eyebrow{ margin-bottom:10px; }
  .contact-form-card h3{ color:var(--paper); font-size:24px; margin-bottom:30px; }
  .form-row{ display:grid; grid-template-columns:1fr 1fr; gap:20px; }
  .field{ margin-bottom:22px; }
  .field label{
    display:block; font-family:'JetBrains Mono', monospace; font-size:10.5px;
    letter-spacing:0.06em; text-transform:uppercase; color:var(--steel-light); margin-bottom:9px;
  }
  .field input, .field select, .field textarea{
    width:100%; background:transparent; border:none; border-bottom:1px solid var(--line-on-dark);
    color:var(--paper); font-family:'Inter', sans-serif; font-size:14.5px; padding:10px 2px; outline:none;
    transition:border-color .2s ease;
  }
  .field select option{ background:var(--ink); }
  .field input:focus, .field select:focus, .field textarea:focus{ border-color:var(--brass); }
  .field textarea{ resize:none; height:90px; }
  .form-submit{
    margin-top:8px; width:100%; background:var(--brass); color:var(--ink); border:none;
    font-family:'JetBrains Mono', monospace; font-size:13px; letter-spacing:0.04em;
    padding:16px; cursor:pointer; transition:background .2s ease;
  }
  .form-submit:hover{ background:#ddb734; }
  .form-note{
    margin-top:16px; font-size:12px; color:var(--steel-light); line-height:1.6;
  }

  .map-strip{
    height:340px; position:relative; overflow:hidden;
    background:
      radial-gradient(ellipse 60% 70% at 30% 40%, rgba(201,162,39,0.10), transparent 60%),
      linear-gradient(160deg, #1c1d20, #101113);
  }
  .map-strip .pin{
    position:absolute; left:38%; top:42%;
    width:14px; height:14px; border-radius:50% 50% 50% 0; transform:rotate(-45deg);
    background:var(--brass); box-shadow:0 0 0 6px rgba(201,162,39,0.18);
  }
  .map-strip .pin-label{
    position:absolute; left:38%; top:30%; transform:translateX(-50%);
    font-family:'JetBrains Mono', monospace; font-size:11px; color:var(--paper);
    background:var(--ink); padding:6px 12px; white-space:nowrap;
    border:1px solid var(--line-on-dark);
  }

  /* ===== FAQ PAGE ===== */
  .faq-page{ background:var(--paper); padding:100px 0 130px; }
  .faq-head{ max-width:680px; margin:0 auto 60px; padding:0 40px; text-align:center; }
  .faq-head h1{ font-size:clamp(32px,4vw,48px); color:var(--ink); margin-top:16px; }
  .faq-list{ max-width:840px; margin:0 auto; padding:0 40px; }
  .faq-item{ border-bottom:1px solid var(--line); }
  .faq-q{
    width:100%; text-align:left; background:none; border:none;
    padding:26px 0; display:flex; justify-content:space-between; align-items:center; gap:20px;
    font-family:'Fraunces', serif; font-size:18px; color:var(--ink); font-weight:500;
  }
  .faq-q .plus{
    font-family:'JetBrains Mono', monospace; font-size:18px; color:var(--brass-soft);
    flex-shrink:0; transition:transform .25s ease;
  }
  .faq-item.open .faq-q .plus{ transform:rotate(45deg); }
  .faq-a{
    max-height:0; overflow:hidden; transition:max-height .35s ease;
  }
  .faq-a-inner{ padding:0 0 26px; font-size:14.5px; color:var(--steel); line-height:1.75; max-width:680px; }
  .faq-cat{
    font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:0.08em;
    text-transform:uppercase; color:var(--brass-soft); margin:50px 0 6px;
  }
  .faq-cat:first-child{ margin-top:0; }

  /* ===== LEGAL / POLICY PAGES ===== */
  .legal-page{ background:var(--paper); padding:100px 0 130px; }
  .legal-inner{
    max-width:840px; margin:0 auto; padding:0 40px;
  }
  .legal-inner h1{ font-size:clamp(30px,3.6vw,44px); color:var(--ink); margin-top:16px; }
  .legal-updated{
    font-family:'JetBrains Mono', monospace; font-size:11.5px; color:var(--steel);
    margin-top:16px; margin-bottom:50px;
  }
  .legal-body h2{
    font-size:21px; color:var(--ink); margin:44px 0 16px; font-weight:500;
  }
  .legal-body h2:first-child{ margin-top:0; }
  .legal-body p{ font-size:14.5px; color:var(--steel); line-height:1.8; margin-bottom:16px; }
  .legal-body ul{ margin:0 0 16px 22px; }
  .legal-body li{ font-size:14.5px; color:var(--steel); line-height:1.8; margin-bottom:8px; }
  .legal-body a{ color:var(--brass-soft); border-bottom:1px solid var(--brass-soft); }
  .legal-toc{
    background:var(--paper-warm); padding:28px 30px; margin-bottom:50px;
  }
  .legal-toc .ttl{
    font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:0.06em;
    text-transform:uppercase; color:var(--brass-soft); margin-bottom:14px;
  }
  .legal-toc ol{ margin-left:18px; }
  .legal-toc li{ font-size:13.5px; color:var(--steel); padding:5px 0; }
  .legal-toc a:hover{ color:var(--brass-soft); }

  /* ===== shared: simple page header (used by services/gallery/contact/faq/legal) ===== */
  .simple-header{
    position:relative; background:var(--ink); padding:56px 0 60px; overflow:hidden;
  }
  .simple-header-inner{ position:relative; z-index:2; max-width:var(--max); margin:0 auto; padding:0 40px; }
  .simple-header h1{ color:var(--paper); font-size:clamp(34px,4.4vw,54px); margin-top:16px; }
  .simple-header h1 .accent{ color:var(--brass); font-weight:400; }

  /* ===== shared responsive: new page types ===== */
  @media (max-width:1080px){
    .service-row{ grid-template-columns:1fr; gap:40px; }
    .service-row:nth-child(even) .service-visual,
    .service-row:nth-child(even) .service-copy{ order:initial; }
    .contact-grid{ grid-template-columns:1fr; gap:60px; }
  }
  @media (max-width:760px){
    .form-row{ grid-template-columns:1fr; gap:0; }
    .contact-form-card{ padding:36px 26px; }
    .faq-q{ font-size:16px; }
    .legal-toc{ padding:22px 20px; }
  }

  /* ===== SIDE PANEL (slide-out menu, matches reference theme pattern) ===== */
  .side-panel-overlay{
    position:fixed; inset:0; z-index:200;
    background:rgba(16,17,19,0.55);
    opacity:0; visibility:hidden;
    transition:opacity .35s ease, visibility 0s linear .35s;
  }
  .side-panel-overlay.open{
    opacity:1; visibility:visible;
    transition:opacity .35s ease, visibility 0s linear 0s;
  }
  .side-panel{
    position:fixed; top:0; left:0; bottom:0; z-index:201;
    width:380px; max-width:86vw;
    background:var(--paper-warm);
    transform:translateX(-100%);
    transition:transform .4s cubic-bezier(.2,.8,.2,1);
    overflow-y:auto;
    display:flex; flex-direction:column;
    padding:34px 36px 30px;
  }
  .side-panel.open{ transform:translateX(0); }
  .side-panel-close{
    background:none; border:none; cursor:pointer;
    width:34px; height:34px;
    display:flex; align-items:center; justify-content:center;
    color:var(--ink); font-size:18px;
    border:1px solid var(--line);
    border-radius:50%;
    transition:border-color .2s ease, color .2s ease, transform .2s ease;
    margin-bottom:40px;
  }
  .side-panel-close:hover{ border-color:var(--brass-soft); color:var(--brass-soft); transform:rotate(90deg); }

  .side-panel-nav{ list-style:none; margin-bottom:36px; }
  .side-panel-nav li{ border-bottom:1px solid var(--line); }
  .side-panel-nav li:first-child{ border-top:1px solid var(--line); }
  .side-panel-nav a{
    display:block; padding:14px 2px;
    font-family:'Fraunces', serif; font-size:19px; color:var(--ink);
    transition:color .2s ease, padding-left .2s ease;
  }
  .side-panel-nav a:hover{ color:var(--brass-soft); padding-left:8px; }
  .side-panel-nav a.active{ color:var(--brass-soft); }

  .side-panel h3{
    font-size:22px; color:var(--ink); margin-bottom:6px; line-height:1.3;
  }
  .side-panel h3 .accent{ color:var(--brass-soft); }
  .side-panel .rule{ width:32px; height:2px; background:var(--brass-soft); margin:16px 0 18px; }
  .side-panel p{ font-size:14px; color:var(--steel); line-height:1.75; margin-bottom:30px; }

  .side-panel-label{
    font-family:'JetBrains Mono', monospace; font-size:10.5px; letter-spacing:0.08em;
    text-transform:uppercase; color:var(--brass-soft); margin-bottom:14px;
  }
  .side-panel-grid{
    display:grid; grid-template-columns:repeat(3,1fr); gap:8px; margin-bottom:30px;
  }
  .side-panel-grid .sp-thumb{
    aspect-ratio:1; overflow:hidden; position:relative;
  }
  .side-panel-grid .sp-thumb > div{ width:100%; height:100%; display:flex; align-items:center; justify-content:center; }

  .side-panel-contact{
    margin-top:auto; padding-top:24px; border-top:1px solid var(--line);
    font-family:'JetBrains Mono', monospace; font-size:12px; color:var(--steel);
    line-height:1.9;
  }
  .side-panel-contact a:hover{ color:var(--brass-soft); }
  .side-panel-foot{
    margin-top:18px; font-size:11px; color:var(--steel-light);
    font-family:'JetBrains Mono', monospace;
  }

  @media (max-width:480px){
    .side-panel{ width:100%; max-width:100%; padding:26px 24px 24px; }
  }

/* ═══════════════════════════════════════════
   WORDPRESS SCAFFOLDING
═══════════════════════════════════════════ */
.site-wrapper{ display:flex; flex-direction:column; min-height:100vh; }
.site-main{ flex:1 0 auto; width:100%; }
#mediaframe-page-content{ width:100%; }
.aligncenter{ display:block; margin-left:auto; margin-right:auto; }
.alignleft{ float:left; margin:0 24px 16px 0; }
.alignright{ float:right; margin:0 0 16px 24px; }
.screen-reader-text{ position:absolute !important; clip:rect(1px,1px,1px,1px); width:1px; height:1px; overflow:hidden; }

/* Blog / single / 404 support */
.page-hero{ position:relative; background:var(--ink); padding:70px 0 64px; overflow:hidden; }
.page-hero-inner{ position:relative; z-index:2; max-width:var(--max); margin:0 auto; padding:0 40px; text-align:center; }
.page-hero h1{ color:var(--paper); font-size:clamp(32px,4.2vw,52px); margin-top:14px; }
.page-hero h1 .hs, .page-hero h1 .hgold{ color:var(--brass); font-weight:400; }
.page-hero p{ color:var(--steel-light); font-size:15px; max-width:560px; margin:18px auto 0; line-height:1.7; }
.page-hero .breadcrumb{ margin-top:20px; font-family:'JetBrains Mono', monospace; font-size:11.5px; color:var(--steel-light); }
.page-hero .breadcrumb .sep{ margin:0 8px; color:var(--steel); }
.page-hero .breadcrumb a:hover{ color:var(--brass); }
.page-eyebrow{ font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:0.14em; text-transform:uppercase; color:var(--brass); display:inline-flex; align-items:center; gap:10px; }

.blog-grid{ max-width:var(--max); margin:0 auto; padding:0 40px; display:grid; grid-template-columns:1.6fr 0.9fr; gap:60px; }
.post-card{ border-bottom:1px solid var(--line); padding-bottom:34px; margin-bottom:34px; }
.post-thumb{ width:100%; aspect-ratio:16/9; object-fit:cover; margin-bottom:18px; }
.post-date{ font-family:'JetBrains Mono', monospace; font-size:11px; color:var(--brass-soft); margin-bottom:8px; }
.post-title{ font-family:'Fraunces', serif; font-size:24px; color:var(--ink); margin-bottom:10px; }
.post-title a:hover{ color:var(--brass-soft); }
.post-excerpt{ color:var(--steel); font-size:14.5px; line-height:1.7; margin-bottom:14px; }
.entry-content{ color:var(--steel); font-size:15px; line-height:1.85; }
.entry-content h2{ font-family:'Fraunces', serif; color:var(--ink); font-size:24px; margin:32px 0 14px; }
.entry-content p{ margin-bottom:16px; }

.btn{ display:inline-flex; align-items:center; gap:8px; font-family:'JetBrains Mono', monospace; font-size:12px; letter-spacing:0.05em; padding:14px 26px; transition:background .2s ease, color .2s ease; }
.btn-gold{ background:var(--brass); color:var(--ink); border:1px solid var(--brass); }
.btn-gold:hover{ background:#ddb734; }
.btn-saffron{ background:var(--ink); color:var(--paper); border:1px solid var(--ink); }
.btn-saffron:hover{ background:var(--ink-soft); }
.btn-outline-white{ background:transparent; color:var(--paper); border:1px solid var(--steel-light); }
.btn-outline-white:hover{ border-color:var(--brass); color:var(--brass); }
.btn-lg{ padding:17px 34px; font-size:13px; }
.btn-sm{ padding:9px 18px; font-size:11px; }

.widget{ background:var(--paper-warm); border:1px solid var(--line); padding:26px; margin-bottom:24px; }
.widget-title{ font-family:'Fraunces', serif; font-size:17px; color:var(--ink); margin-bottom:14px; }

@media (max-width:1080px){
  .blog-grid{ grid-template-columns:1fr; gap:40px; }
}
