/* ===========================================================
   FINE & GLAD PHOTOGRAPHY — Layout & Mobile Menu
   - Desktop: 3-column masonry grid
   - Mobile: 1-column scroll
   - Mobile: bottom-sheet hamburger menu (Carty-style)
   =========================================================== */

:root{
  --bg:#f1f1f1;
  --ink:#555555;
  --mute:#6b6b6b;
  --line:#00000012;
  --accent:#6F4E37;       /* coffee brown accent */
  --maxw:1600px;
  --page-pad:8px;
  --gap:3px;
  --h:76px;
}

/* Base */
*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:"Lato",system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}

/* Optional signature font */
@font-face{
  font-family:"Amsterdam";
  src:url("/fonts/Amsterdam.woff2") format("woff2");
  font-weight:400;
  font-style:normal;
  font-display:swap;
}
.sig{ font-family:"Amsterdam","Lato",sans-serif; }

/* ===================== HEADER ===================== */

.hdr{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(241,241,241,.95);
  backdrop-filter:saturate(115%) blur(6px);
  border-bottom:1px solid var(--line);
}

.hdr-in{
  max-width:var(--maxw);
  margin:0 auto;
  height:var(--h);
  padding:0 var(--page-pad);
  display:grid;
  grid-template-columns:170px 1fr auto; /* logo | title | right cluster */
  align-items:center;
  column-gap:14px;
}

.logo-slot{
  display:flex;
  align-items:center;
  min-width:140px;
}
.logo{
  display:block;
  border:none;
  background:transparent;
}

.title{
  text-align:center;
  font-weight:900;
  letter-spacing:.06em;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.title a{
  color:var(--ink);
  text-decoration:none;
}

.hdr-right{
  display:flex;
  align-items:center;
  gap:6px;
  justify-content:flex-end;
}

/* ===================== NAV (desktop) ===================== */

nav{
  display:flex;
  align-items:center;
  justify-content:flex-end;
}

.menu{
  display:flex;
  align-items:center;
  gap:4px;
  padding:0;
  margin:0;
  font-size:0.95rem;
}
.menu>li{
  list-style:none;
  position:relative;
}

.menu>li>a,
.menu>li>button{
  background:transparent;
  border:1px solid transparent;
  color:var(--ink);
  padding:6px 8px;
  border-radius:10px;
  cursor:pointer;
  font:inherit;
  text-decoration:none;
  position:relative;
  transition:color .25s ease;
}
.caret{
  font-size:.82rem;
  opacity:.6;
  margin-left:4px;
}

.menu>li>a::after,
.menu>li>button::after{
  content:"";
  position:absolute;
  left:8px;
  right:8px;
  bottom:5px;
  height:2px;
  background:var(--accent);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .25s ease;
}
.menu>li>a:hover,
.menu>li>button:hover{
  color:#333;
}
.menu>li>a:hover::after,
.menu>li>button:hover::after{
  transform:scaleX(1);
}

/* Desktop dropdown menu */
.dd{
  position:absolute;
  top:calc(100% + 8px);
  left:0;
  min-width:200px;
  display:none;
  background:#fff;
  border:1px solid var(--line);
  border-radius:12px;
  padding:8px;
  box-shadow:0 12px 28px rgba(0,0,0,.15);
}
.dd a{
  display:block;
  padding:9px 11px;
  border-radius:8px;
  color:var(--ink);
  text-decoration:none;
  position:relative;
}
.dd a:hover{
  background:#00000008;
}
.dd a::after{
  content:"";
  position:absolute;
  left:11px;
  right:11px;
  bottom:7px;
  height:2px;
  background:var(--accent);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .25s ease;
}
.dd a:hover::after{
  transform:scaleX(1);
}
.menu>li.open .dd{ display:block; }

/* Desktop social icons */
.social{
  display:flex;
  gap:4px;
}
.icon{
  width:30px;
  height:30px;
  display:grid;
  place-items:center;
  border-radius:10px;
  border:1px solid var(--line);
  background:#fff;
  color:#333;
  text-decoration:none;
  transition:border-color .25s ease, box-shadow .25s ease;
}
.icon:hover{
  border-color:var(--accent);
  box-shadow:0 0 0 3px #6f4e371e;
}

.desktop-nav{}
.desktop-social{}

/* ===================== HAMBURGER (mobile trigger) ===================== */

.hamburger{
  display:none;               /* shown only on small screens */
  width:34px;
  height:30px;
  border-radius:10px;
  border:1px solid var(--line);
  background:#fff;
  padding:5px 6px;
  cursor:pointer;
  justify-content:center;
  align-items:center;
  flex-direction:column;
  gap:3px;
}
.hamburger span{
  display:block;
  width:100%;
  height:2px;
  border-radius:999px;
  background:#333;
}

/* ===================== MOBILE BOTTOM-SHEET MENU ===================== */

.mobile-menu{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.55);     /* dim background so photos show faintly */
  display:none;
  z-index:1200;
}
.mobile-menu.open{
  display:flex;
  align-items:flex-end;          /* bottom-sheet style */
  justify-content:center;
}

.mobile-menu-panel{
  position:relative;
  width:100%;
  max-width:520px;
  max-height:88vh;
  padding:20px 22px 18px;
  border-radius:18px 18px 0 0;
  background:rgba(58,58,58,.94);  /* translucent #3a3a3a */
  color:#f5f5f5;
  box-shadow:0 -18px 40px rgba(0,0,0,.5);
  display:flex;
  flex-direction:column;
  transform:translateY(100%);
  transition:transform .25s ease;
}
.mobile-menu.open .mobile-menu-panel{
  transform:translateY(0);
}

/* close button */
.mobile-close{
  position:absolute;
  top:10px;
  right:12px;
  width:32px;
  height:32px;
  border-radius:999px;
  border:none;
  background:#ffffff18;
  color:#f5f5f5;
  font-size:18px;
  cursor:pointer;
}

/* force nav in the sheet to be vertical, text right-aligned */
.mobile-nav{
  display:block;
  margin-top:8px;
}

.mobile-menu-list{
  list-style:none;
  padding:0;
  margin:4px 0 16px;
  text-align:right;           /* align text to right like Carty */
  color:#f5f5f5;
}
.mobile-menu-list>li{
  margin:8px 0;
}

/* top-level links */
.mm-link{
  display:block;
  font-size:1.1rem;
  letter-spacing:.03em;
  padding:8px 2px;
  text-decoration:none;
  color:#dcdcdc;
  transition:color .18s ease, text-shadow .18s ease;
}
.mm-link.active{
  color:var(--accent);
  font-weight:700;
  text-shadow:0 0 6px rgba(0,0,0,.5);
}
.mm-link:hover{
  color:var(--accent);
}

/* sections with submenus */
.mm-section{
  margin:6px 0;
}

/* toggle with caret on right */
.mm-toggle{
  width:100%;
  border:none;
  background:transparent;
  padding:8px 2px;
  display:flex;
  align-items:center;
  justify-content:flex-end;   /* text + caret to the right */
  gap:8px;
  font:inherit;
  color:#e0e0e0;
  cursor:pointer;
  text-align:right;
  transition:color .18s ease;
}
.mm-toggle:hover{
  color:var(--accent);
}
.mm-heading{
  font-size:1.05rem;
  letter-spacing:.03em;
}
.mm-caret{
  font-size:0.9rem;
  transition:transform .2s ease;
}

/* submenu */
.mm-sub{
  list-style:none;
  margin:0;
  padding:0;
  padding-right:18px;           /* indent from right */
  font-size:0.96rem;
  display:none;
  text-align:right;
}
.mm-sub li{
  margin:3px 0;
}
.mm-sublink{
  color:#f0f0f0;
  text-decoration:none;
  padding:4px 0;
  display:block;
  transition:color .18s ease;
}
.mm-sublink:hover{
  color:var(--accent);
}

/* open state */
.mm-section.open .mm-sub{
  display:block;
}
.mm-section.open .mm-caret{
  transform:rotate(180deg);
}

/* mobile social icons at bottom */
.mobile-social{
  display:flex;
  gap:10px;
  margin-top:auto;
  padding-top:10px;
  border-top:1px solid #ffffff25;
}


body.mm-open{
  overflow:hidden;
}

/* ===================== MAIN ===================== */

main{
  max-width:var(--maxw);
  margin:0 auto;
  padding:8px var(--page-pad) 36px;
}

/* ===================== MASONRY GALLERY ===================== */

.grid{
  column-count:3;
  column-gap:var(--gap);
}
.card{
  display:block;
  background:transparent;
  border:none;
  border-radius:0;
  margin:0 0 var(--gap);
  break-inside:avoid;
  -webkit-column-break-inside:avoid;
  cursor:pointer;
  position:relative;
}
.card img{
  display:block;
  width:100%;
  height:auto;
  border:none;
  border-radius:0;
  transition:transform .35s ease;
}
.card:hover img{
  transform:scale(1.01);
}

/* subtle coffee overlay on hover */
.card::after{
  content:"";
  position:absolute;
  inset:0;
  background:var(--accent);
  mix-blend-mode:multiply;
  opacity:0;
  transition:opacity .25s ease;
}
.card:hover::after{
  opacity:.10;
}

/* ===================== LIGHTBOX ===================== */

.lb{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.85);
  display:none;
  align-items:center;
  justify-content:center;
  z-index:2000;
}
.lb.open{ display:flex; }

.lb .panel{
  position:relative;
  background:transparent;
  padding:0;
  border-radius:0;
  max-width:94vw;
  max-height:94vh;
  display:flex;
  align-items:center;
  justify-content:center;
}
.lb img{
  max-width:94vw;
  max-height:94vh;
  border-radius:0;
  border:none;
}
.lb .ctl.close{
  position:absolute;
  top:8px;
  right:8px;
  width:36px;
  height:36px;
  background:#00000070;
  color:#fff;
  border:1px solid #ffffff30;
  border-radius:10px;
  cursor:pointer;
  display:grid;
  place-items:center;
}

/* ===================== RIGHT-CLICK TOOLTIP ===================== */

.rc-tip{
  position:fixed;
  z-index:3000;
  background:rgba(0,0,0,.9);
  color:#fff;
  padding:6px 8px;
  border-radius:6px;
  font-size:12px;
  pointer-events:none;
  white-space:nowrap;
  transform:translate(6px,10px);
  opacity:0;
  transition:opacity .12s ease;
}
.rc-tip.show{ opacity:1; }

/* ===================== FOOTER ===================== */

footer{
  border-top:1px solid var(--line);
  color:var(--mute);
  padding:16px var(--page-pad) 32px;
  margin-top:32px;
}
.f-in{
  max-width:var(--maxw);
  margin:0 auto;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  align-items:center;
  justify-content:space-between;
}

/* ===================== RESPONSIVE ===================== */

/* Phones: 1-column photos and hamburger + bottom-sheet menu */
@media (max-width:599px){

  :root{
    --page-pad:0px;
    --gap:2px;
  }

  html,body{
    width:100%;
    overflow-x:hidden;
  }

  .hdr-in,
  main,
  .f-in{
    max-width:none;
    width:100%;
    margin:0;
    padding-left:0 !important;
    padding-right:0 !important;
  }

  .hdr-in{
    grid-template-columns:140px 1fr auto;
    column-gap:6px;
  }

  .title{
    font-size:0.95rem;
    letter-spacing:.05em;
  }

  /* hide desktop nav/social, show hamburger */
  .desktop-nav,
  .desktop-social{
    display:none;
  }
  .hamburger{
    display:inline-flex;
  }

  /* single-column scroll */
  .grid{
    column-count:1 !important;
    column-gap:0 !important;
  }
  .card{
    margin:0 0 2px !important;
  }
}

/* Tablets */
@media (min-width:600px) and (max-width:899px){
  :root{
    --page-pad:8px;
    --gap:3px;
  }
  .title{
    font-size:1.05rem;
  }
}

/* Desktops */
@media (min-width:900px){
  :root{
    --page-pad:10px;
    --gap:4px;
  }
  .title{
    font-size:1.12rem;
  }
}

/* Very wide */
@media (min-width:1440px){
  :root{
    --page-pad:12px;
    --gap:5px;
  }
  .title{
    font-size:1.18rem;
  }
}

/* ===================== UTILITIES ===================== */

a{
  text-decoration:none;
  color:inherit;
}
a:hover,
a:focus{
  text-decoration:none;
}
img{
  max-width:100%;
  height:auto;
}
p,li{
  word-wrap:break-word;
  overflow-wrap:break-word;
}
